summaryrefslogtreecommitdiffstats
path: root/authz-cmd/src/main/java/org/onap/aaf/cmd/mgmt/Deny.java
blob: 44b3f8f9d7d55619e6aaa87e5e335e6cb6ae7dfa (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
/*******************************************************************************
 * ============LICENSE_START====================================================
 * * org.onap.aaf
 * * ===========================================================================
 * * Copyright © 2017 AT&T Intellectual Property. All rights reserved.
 * * ===========================================================================
 * * Licensed under the Apache License, Version 2.0 (the "License");
 * * you may not use this file except in compliance with the License.
 * * You may obtain a copy of the License at
 * * 
 *  *      http://www.apache.org/licenses/LICENSE-2.0
 * * 
 *  * Unless required by applicable law or agreed to in writing, software
 * * distributed under the License is distributed on an "AS IS" BASIS,
 * * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * * See the License for the specific language governing permissions and
 * * limitations under the License.
 * * ============LICENSE_END====================================================
 * *
 * * ECOMP is a trademark and service mark of AT&T Intellectual Property.
 * *
 ******************************************************************************/
package org.onap.aaf.cmd.mgmt;

import org.onap.aaf.cmd.AAFcli;
import org.onap.aaf.cmd.BaseCmd;
import org.onap.aaf.cmd.Cmd;
import org.onap.aaf.cmd.Param;

import org.onap.aaf.cadi.CadiException;
import org.onap.aaf.cadi.LocatorException;
import org.onap.aaf.cadi.client.Future;
import org.onap.aaf.cadi.client.Rcli;
import org.onap.aaf.cadi.client.Retryable;
import org.onap.aaf.inno.env.APIException;

public class Deny extends BaseCmd<Mgmt> {
	private final static String[] options = {"add","del"};

	public Deny(Mgmt mgmt) throws APIException {
		super(mgmt, "deny");
		cmds.add(new DenySomething(this,"ip","ipv4or6[,ipv4or6]*"));
		cmds.add(new DenySomething(this,"id","identity[,identity]*"));
	}
	
	public class DenySomething extends Cmd {

		private boolean isID;

		public DenySomething(Deny deny, String type, String repeatable) {
			super(deny, type,
				new Param(optionsToString(options),true),
				new Param(repeatable,true));
			isID = "id".equals(type);
		}

		@Override
		protected int _exec(int _idx, String... args) throws CadiException, APIException, LocatorException {
		        int idx = _idx;
			String action = args[idx++];
			final int option = whichOption(options, action);
			int rv=409;
			for(final String name : args[idx++].split(COMMA)) {
				final String append;
				if(isID && name.indexOf("@")<0) {
					append='@'+ env.getProperty(AAFcli.AAF_DEFAULT_REALM);
				} else {
					append = "";
				}
				final String path = "/mgmt/deny/"+getName() + '/'+ name + append;
				rv = all(new Retryable<Integer>() {
					@Override
					public Integer code(Rcli<?> client) throws APIException, CadiException  {
						int rv = 409;
						Future<Void> fp;
						String resp;
						switch(option) {
							case 0: 
								fp = client.create(path, Void.class);
								resp = " added";
								break;
							default: 
								fp = client.delete(path, Void.class);
								resp = " deleted";
						}
						if(fp.get(AAFcli.timeout())) {
							pw().println(name + append + resp + " on " + client);
							rv=fp.code();
						} else {
							if(rv==409)rv = fp.code();
							error(fp);
						}
						return rv;
					}
				});
			}
			return rv;
		}

	}

}