2 * ============LICENSE_START====================================================
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
11 * http://www.apache.org/licenses/LICENSE-2.0
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====================================================
21 package org.onap.aaf.auth.batch.helpers;
23 import java.io.IOException;
24 import java.util.ArrayList;
25 import java.util.List;
27 import org.onap.aaf.auth.batch.approvalsets.DataView;
28 import org.onap.aaf.auth.dao.cass.ApprovalDAO;
29 import org.onap.aaf.auth.dao.cass.FutureDAO;
30 import org.onap.aaf.auth.dao.cass.NsDAO;
31 import org.onap.aaf.auth.dao.cass.RoleDAO;
32 import org.onap.aaf.auth.dao.cass.UserRoleDAO;
33 import org.onap.aaf.auth.dao.cass.UserRoleDAO.Data;
34 import org.onap.aaf.auth.env.AuthzTrans;
35 import org.onap.aaf.auth.layer.Result;
36 import org.onap.aaf.cadi.Hash;
37 import org.onap.aaf.misc.env.APIException;
38 import org.onap.aaf.misc.env.TimeTaken;
39 import org.onap.aaf.misc.env.Trans;
40 import org.onap.aaf.misc.env.util.Chrono;
42 import com.datastax.driver.core.Session;
44 public class BatchDataView implements DataView {
45 private static final String QUOTE_PAREN_SEMI = "');\n";
46 private static final String QUOTE_COMMA = "',";
47 private static final String QUOTE_COMMA_QUOTE = "','";
48 private static final String COMMA_QUOTE = ",'";
49 private final CQLBatchLoop cqlBatch;
50 private final Session session;
52 public BatchDataView(final AuthzTrans trans, final Session session, final boolean dryRun ) throws APIException, IOException {
53 this.session = session;
54 cqlBatch = new CQLBatchLoop(new CQLBatch(trans.info(),session),50,dryRun);
57 public Session getSession(AuthzTrans trans) throws APIException, IOException {
61 public Result<NsDAO.Data> ns(AuthzTrans trans, String id) {
63 TimeTaken tt = trans.start("Get NS by ID %s", Trans.SUB, id);
70 if(n==null || n.ndd==null) {
71 return Result.err(Result.ERR_Backend,"Namespace '%s' does not exist", id);
73 return Result.ok(n.ndd);
78 public Result<RoleDAO.Data> roleByName(AuthzTrans trans, String name) {
79 Role r = Role.byName.get(name);
80 if(r==null || r.rdd==null) {
81 return Result.err(Result.ERR_Backend,"Role '%s' does not exist", name);
83 return Result.ok(r.rdd);
87 public Result<List<UserRoleDAO.Data>> ursByRole(AuthzTrans trans, String role) {
88 List<UserRole> urs = UserRole.getByRole().get(role);
90 return Result.err(Result.ERR_Backend, "UserRoles for Role '%s' does not exist", role);
95 private Result<List<Data>> toLURDD(List<UserRole> urs) {
96 List<UserRoleDAO.Data> rv = new ArrayList<>();
98 for(UserRole ur : urs) {
102 return Result.ok(rv);
106 public Result<List<UserRoleDAO.Data>> ursByUser(AuthzTrans trans, String user) {
107 List<UserRole> urs = UserRole.getByUser().get(user);
109 return Result.err(Result.ERR_Backend, "UserRoles for User '%s' does not exist", user);
115 public Result<FutureDAO.Data> delete(AuthzTrans trans, FutureDAO.Data fdd) {
117 StringBuilder sb = cqlBatch.inc();
118 sb.append("DELETE from authz.future WHERE id = ");
119 sb.append(fdd.id.toString());
120 return Result.ok(fdd);
124 public Result<ApprovalDAO.Data> delete(AuthzTrans trans, ApprovalDAO.Data add) {
126 StringBuilder sb = cqlBatch.inc();
127 sb.append("DELETE from authz.approval WHERE id = ");
128 sb.append(add.id.toString());
129 return Result.ok(add);
134 public Result<ApprovalDAO.Data> insert(AuthzTrans trans, ApprovalDAO.Data add) {
136 StringBuilder sb = cqlBatch.inc();
137 sb.append("INSERT INTO authz.approval (id,approver,memo,operation,status,ticket,type,user) VALUES (");
138 sb.append(add.id.toString());
139 sb.append(COMMA_QUOTE);
140 sb.append(add.approver);
141 // sb.append(QUOTE_COMMA_QUOTE);
142 // sb.append(Chrono.utcStamp(add.last_notified));
143 sb.append(QUOTE_COMMA_QUOTE);
144 sb.append(add.memo.replace("'", "''"));
145 sb.append(QUOTE_COMMA_QUOTE);
146 sb.append(add.operation);
147 sb.append(QUOTE_COMMA_QUOTE);
148 sb.append(add.status);
149 sb.append(QUOTE_COMMA);
150 sb.append(add.ticket.toString());
151 sb.append(COMMA_QUOTE);
153 sb.append(QUOTE_COMMA_QUOTE);
155 sb.append(QUOTE_PAREN_SEMI);
156 return Result.ok(add);
160 public Result<FutureDAO.Data> insert(AuthzTrans trans, FutureDAO.Data fdd) {
162 StringBuilder sb = cqlBatch.inc();
163 sb.append("INSERT INTO authz.future (id,construct,expires,memo,start,target,target_key,target_date) VALUES (");
164 sb.append(fdd.id.toString());
166 fdd.construct.hasArray();
167 sb.append(Hash.toHex(fdd.construct.array()));
168 sb.append(COMMA_QUOTE);
169 sb.append(Chrono.utcStamp(fdd.expires));
170 sb.append(QUOTE_COMMA_QUOTE);
171 sb.append(fdd.memo.replace("'", "''"));
172 sb.append(QUOTE_COMMA_QUOTE);
173 sb.append(Chrono.utcStamp(fdd.expires));
174 sb.append(QUOTE_COMMA_QUOTE);
175 sb.append(fdd.target);
176 if(fdd.target_key==null) {
179 sb.append(QUOTE_COMMA_QUOTE);
180 sb.append(fdd.target_key==null?"":fdd.target_key);
181 sb.append(QUOTE_COMMA_QUOTE);
183 sb.append(Chrono.utcStamp(fdd.target_date));
184 sb.append(QUOTE_PAREN_SEMI);
185 return Result.ok(fdd);
189 public void flush() {