Improved multi Proxy DNSLocator based
[aaf/authz.git] / auth / auth-batch / src / main / java / org / onap / aaf / auth / batch / helpers / BatchDataView.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 package org.onap.aaf.auth.batch.helpers;
22
23 import java.util.ArrayList;
24 import java.util.List;
25
26 import org.onap.aaf.auth.batch.approvalsets.DataView;
27 import org.onap.aaf.auth.dao.cass.ApprovalDAO;
28 import org.onap.aaf.auth.dao.cass.FutureDAO;
29 import org.onap.aaf.auth.dao.cass.NsDAO;
30 import org.onap.aaf.auth.dao.cass.RoleDAO;
31 import org.onap.aaf.auth.dao.cass.UserRoleDAO;
32 import org.onap.aaf.auth.dao.cass.UserRoleDAO.Data;
33 import org.onap.aaf.auth.env.AuthzTrans;
34 import org.onap.aaf.auth.layer.Result;
35 import org.onap.aaf.cadi.Hash;
36 import org.onap.aaf.misc.env.TimeTaken;
37 import org.onap.aaf.misc.env.Trans;
38 import org.onap.aaf.misc.env.util.Chrono;
39
40 import com.datastax.driver.core.Session;
41
42 public class BatchDataView implements DataView {
43     private static final String QUOTE_PAREN_SEMI = "');\n";
44     private static final String QUOTE_COMMA = "',";
45     private static final String QUOTE_COMMA_QUOTE = "','";
46     private static final String COMMA_QUOTE = ",'";
47     private final CQLBatchLoop cqlBatch;
48     private final Session session;
49
50     public BatchDataView(final AuthzTrans trans, final Session session, final boolean dryRun ){
51         this.session = session;
52         cqlBatch = new CQLBatchLoop(new CQLBatch(trans.info(),session),50,dryRun);
53     }
54
55     public Session getSession(AuthzTrans trans){
56         return session;
57     }
58     
59     public Result<NsDAO.Data> ns(AuthzTrans trans, String id) {
60         NS n;
61         TimeTaken tt = trans.start("Get NS by ID %s", Trans.SUB, id);
62         try {
63             n=NS.data.get(id);
64         } finally {
65             tt.done();
66         }
67         
68         if(n==null || n.ndd==null) {
69             return Result.err(Result.ERR_Backend,"Namespace '%s' does not exist", id);
70         }
71         return Result.ok(n.ndd);
72     }
73
74     
75     @Override
76     public Result<RoleDAO.Data> roleByName(AuthzTrans trans, String name) {
77         Role r = Role.byName.get(name);
78         if(r==null || r.rdd==null) {
79             return Result.err(Result.ERR_Backend,"Role '%s' does not exist", name);
80         }
81         return Result.ok(r.rdd);
82     }
83
84     @Override
85     public Result<List<UserRoleDAO.Data>> ursByRole(AuthzTrans trans, String role) {
86         List<UserRole> urs = UserRole.getByRole().get(role);
87         if(urs==null) {
88             return Result.err(Result.ERR_Backend, "UserRoles for Role '%s' does not exist", role);
89         }
90         return toLURDD(urs);
91     }
92
93     private Result<List<Data>> toLURDD(List<UserRole> urs) {
94         List<UserRoleDAO.Data> rv = new ArrayList<>();
95         if(urs!=null) {
96             for(UserRole ur : urs) {
97                 rv.add(ur.urdd());
98             }
99         }
100         return Result.ok(rv);
101     }
102
103     @Override
104     public Result<List<UserRoleDAO.Data>> ursByUser(AuthzTrans trans, String user) {
105         List<UserRole> urs = UserRole.getByUser().get(user);
106         if(urs==null) {
107             return Result.err(Result.ERR_Backend, "UserRoles for User '%s' does not exist", user);
108         }
109         return toLURDD(urs);
110     }
111
112     @Override
113     public Result<FutureDAO.Data> delete(AuthzTrans trans, FutureDAO.Data fdd) {
114         StringBuilder sb = cqlBatch.inc();
115         sb.append("DELETE from authz.future WHERE id = ");
116         sb.append(fdd.id.toString());
117         return Result.ok(fdd);        
118     }
119     
120     @Override
121     public Result<ApprovalDAO.Data> delete(AuthzTrans trans, ApprovalDAO.Data add) {
122         StringBuilder sb = cqlBatch.inc();
123         sb.append("DELETE from authz.approval WHERE id = ");
124         sb.append(add.id.toString());
125         return Result.ok(add);        
126     }
127
128
129     @Override
130     public Result<ApprovalDAO.Data> insert(AuthzTrans trans, ApprovalDAO.Data add) {
131         StringBuilder sb = cqlBatch.inc();
132         sb.append("INSERT INTO authz.approval (id,approver,memo,operation,status,ticket,type,user) VALUES ("); 
133         sb.append(add.id.toString());
134         sb.append(COMMA_QUOTE);
135         sb.append(add.approver);
136 //        sb.append(QUOTE_COMMA_QUOTE);
137 //        sb.append(Chrono.utcStamp(add.last_notified));
138         sb.append(QUOTE_COMMA_QUOTE);
139         sb.append(add.memo.replace("'", "''"));
140         sb.append(QUOTE_COMMA_QUOTE);
141         sb.append(add.operation);
142         sb.append(QUOTE_COMMA_QUOTE);
143         sb.append(add.status);
144         sb.append(QUOTE_COMMA);
145         sb.append(add.ticket.toString());
146         sb.append(COMMA_QUOTE);
147         sb.append(add.type);
148         sb.append(QUOTE_COMMA_QUOTE);
149         sb.append(add.user);
150         sb.append(QUOTE_PAREN_SEMI);
151         return Result.ok(add);
152     }
153
154     @Override
155     public Result<FutureDAO.Data> insert(AuthzTrans trans, FutureDAO.Data fdd) {
156         StringBuilder sb = cqlBatch.inc();
157         sb.append("INSERT INTO authz.future (id,construct,expires,memo,start,target,target_key,target_date) VALUES ("); 
158         sb.append(fdd.id.toString());
159         sb.append(',');
160         fdd.construct.hasArray();
161         sb.append(Hash.toHex(fdd.construct.array()));
162         sb.append(COMMA_QUOTE);
163         sb.append(Chrono.utcStamp(fdd.expires));
164         sb.append(QUOTE_COMMA_QUOTE);
165         sb.append(fdd.memo.replace("'", "''"));
166         sb.append(QUOTE_COMMA_QUOTE);
167         sb.append(Chrono.utcStamp(fdd.expires));
168         sb.append(QUOTE_COMMA_QUOTE);
169         sb.append(fdd.target);
170         if(fdd.target_key==null) {
171             sb.append("',,'");
172         } else {
173             sb.append(QUOTE_COMMA_QUOTE);
174             sb.append(fdd.target_key==null?"":fdd.target_key);
175             sb.append(QUOTE_COMMA_QUOTE);
176         }
177         sb.append(Chrono.utcStamp(fdd.target_date));
178         sb.append(QUOTE_PAREN_SEMI);
179         return Result.ok(fdd);
180     }
181     
182     @Override
183     public void flush() {
184         cqlBatch.flush();
185     }
186 }