AT&T 2.0.19 Code drop, stage 3
[aaf/authz.git] / auth / auth-cmd / src / main / java / org / onap / aaf / auth / cmd / role / ListByPerm.java
1 /**
2  * ============LICENSE_START====================================================
3  * org.onap.aaf
4  * ===========================================================================
5  * Copyright (c) 2018 AT&T Intellectual Property. All rights reserved.
6  * ===========================================================================
7  * Licensed under the Apache License, Version 2.0 (the "License");
8  * you may not use this file except in compliance with the License.
9  * You may obtain a copy of the License at
10  * 
11  *      http://www.apache.org/licenses/LICENSE-2.0
12  * 
13  * Unless required by applicable law or agreed to in writing, software
14  * distributed under the License is distributed on an "AS IS" BASIS,
15  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
16  * See the License for the specific language governing permissions and
17  * limitations under the License.
18  * ============LICENSE_END====================================================
19  *
20  */
21
22 package org.onap.aaf.auth.cmd.role;
23
24 import org.onap.aaf.auth.cmd.Cmd;
25 import org.onap.aaf.auth.cmd.Param;
26 import org.onap.aaf.auth.rserv.HttpMethods;
27 import org.onap.aaf.cadi.CadiException;
28 import org.onap.aaf.cadi.LocatorException;
29 import org.onap.aaf.cadi.client.Future;
30 import org.onap.aaf.cadi.client.Rcli;
31 import org.onap.aaf.misc.env.APIException;
32
33 import aaf.v2_0.Roles;
34
35 /**
36  * Return Roles by NS
37  * 
38  * @author Jonathan
39  *
40  */
41 public class ListByPerm extends Cmd {
42         private static final String HEADER = "List Roles by Perm ";
43         
44         public ListByPerm(List parent) {
45                 super(parent,"perm", 
46                                 new Param("type",true),
47                                 new Param("instance", true),
48                                 new Param("action", true)); 
49         }
50
51         @Override
52         public int _exec(int _idx, final String ... args) throws CadiException, APIException, LocatorException {
53                 int idx = _idx;
54                 final String type=args[idx];
55                 final String instance=args[++idx];
56                 final String action=args[++idx];
57
58                 return same(((List)parent).new ListRoles() {
59                         @Override
60                         public Integer code(Rcli<?> client) throws CadiException, APIException {
61
62                                 Future<Roles> fp = client.read(
63                                                 "/authz/roles/perm/"+type+'/'+instance+'/'+action, 
64                                                 getDF(Roles.class)
65                                                 );
66                                 return list(fp,client, HEADER+type+'|'+instance+'|'+action);
67                         }
68                 });
69         }
70         
71         @Override
72         public void detailedHelp(int indent, StringBuilder sb) {
73                 detailLine(sb,indent,HEADER);
74                 api(sb,indent,HttpMethods.GET,"authz/roles/user/<user>",Roles.class,true);
75         }
76
77
78 }