2 * ============LICENSE_START====================================================
4 * ===========================================================================
5 * Copyright (c) 2018 AT&T Intellectual Property. All rights reserved.
7 * Modifications Copyright (C) 2018 IBM.
8 * ===========================================================================
9 * Licensed under the Apache License, Version 2.0 (the "License");
10 * you may not use this file except in compliance with the License.
11 * You may obtain a copy of the License at
13 * http://www.apache.org/licenses/LICENSE-2.0
15 * Unless required by applicable law or agreed to in writing, software
16 * distributed under the License is distributed on an "AS IS" BASIS,
17 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
18 * See the License for the specific language governing permissions and
19 * limitations under the License.
20 * ============LICENSE_END====================================================
23 package org.onap.aaf.auth.batch.update;
25 import java.io.BufferedReader;
27 import java.io.FileReader;
28 import java.io.IOException;
29 import java.util.ArrayList;
30 import java.util.List;
32 import org.onap.aaf.auth.batch.Batch;
33 import org.onap.aaf.auth.env.AuthzTrans;
34 import org.onap.aaf.auth.org.OrganizationException;
35 import org.onap.aaf.misc.env.APIException;
36 import org.onap.aaf.misc.env.Env;
37 import org.onap.aaf.misc.env.TimeTaken;
39 import com.datastax.driver.core.ResultSet;
41 public class Upload extends Batch {
43 private static final int BATCH_LENGTH = 100;
49 private static final String APPR_INS_FMT=" INSERT INTO authz.approval "
50 + "(id,approver,last_notified,memo,operation,status,ticket,type,user) "
51 + "VALUES (%s,%s,%s,%s,%s,%s,%s,%s,%s);\n";
52 private static final Boolean[] APPR_QUOTES = new Boolean[]{false,true,true,true,true,true,false,true,true};
55 private static final String ARTI_INS_FMT=" INSERT INTO authz.artifact "
56 + "(mechid,machine,ca,dir,expires,notify,ns,os_user,renewdays,sans,sponsor,type) "
57 + "VALUES (%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s);\n";
58 private static final Boolean[] ARTI_QUOTES = new Boolean[]
59 {true,true,true,true,true,true,true,true,false,false,true,false};
62 private static final String CRED_INS_FMT=" INSERT INTO authz.cred "
63 + "(id,type,expires,cred,notes,ns,other,prev) "
64 + "VALUES (%s,%s,%s,%s,%s,%s,%s,%s);\n";
65 private static final Boolean[] CRED_QUOTES = new Boolean[]
66 {true,false,true,false,true,true,false,false};
69 private static final String NS_INS_FMT=" INSERT INTO authz.ns "
70 + "(name,description,parent,scope,type) "
71 + "VALUES (%s,%s,%s,%s,%s);\n";
72 private static final Boolean[] NS_QUOTES = new Boolean[]
73 {true,true,true,false,false};
76 private static final String X509_INS_FMT=" INSERT INTO authz.x509 "
77 + "(ca,serial,id,x500,x509) "
78 + "VALUES (%s,%s,%s,%s,%s);\n";
79 private static final Boolean[] X509_QUOTES = new Boolean[]
80 {true,false,true,true,true};
83 private static final String ROLE_INS_FMT=" INSERT INTO authz.role "
84 + "(ns,name,description,perms) "
85 + "VALUES (%s,%s,%s,%s);\n";
86 private static final Boolean[] ROLE_QUOTES = new Boolean[]
87 {true,true,true,false};
89 private static final String PERM_INS_FMT=" INSERT INTO authz.perm "
90 + "(ns,type,instance,action,description,roles) "
91 + "VALUES (%s,%s,%s,%s,%s,%s);\n";
92 private static final Boolean[] PERM_QUOTES = new Boolean[]
93 {true,true,true,true,true,false};
95 public Upload(AuthzTrans trans) throws APIException, IOException, OrganizationException {
97 trans.info().log("Starting Connection Process");
99 TimeTaken tt0 = trans.start("Cassandra Initialization", Env.SUB);
101 TimeTaken tt = trans.start("Connect to Cluster", Env.REMOTE);
103 session = cluster.connect();
114 protected void run(AuthzTrans trans) {
116 StringBuilder sb = new StringBuilder();
117 StringBuilder query = new StringBuilder();
118 List<String> array = new ArrayList<String>();
119 for(String feed : args()) {
120 File file = new File(feed + ".dat");
121 TimeTaken tt = trans.start(file.getAbsolutePath(), Env.SUB);
122 System.out.println("#### Running " + feed + ".dat Feed ####");
127 boolean justOne = false;
129 BufferedReader br = new BufferedReader(new FileReader(file));
131 while((line=br.readLine())!=null) {
132 if(line.length()>5000) {
133 if(query.length()>0) {
138 if(query.length()==0) {
139 query.append("BEGIN BATCH\n");
141 // Split into fields, first turning Escaped values into something we can convert back from
143 boolean inQuote = false;
146 for(int i=0;i<line.length();++i) {
147 switch(c=line.charAt(i)) {
155 addField(feed,fldcnt++,array,sb);
162 addField(feed,fldcnt,array,sb);
163 query.append(build(feed, array));
165 if((++count % BATCH_LENGTH)==0 || justOne) {
170 if(query.length()>0) {
180 } catch (IOException e) {
181 trans.error().log(e);
186 trans.error().log("No file found: ", file.getAbsolutePath());
191 System.out.printf("\n%d applied in %d batches\n",count,batchCnt);
199 private String build(String feed, List<String> array) {
203 rv = String.format(APPR_INS_FMT,array.toArray());
206 rv = String.format(ARTI_INS_FMT,array.toArray());
209 rv = String.format(CRED_INS_FMT,array.toArray());
212 rv = String.format(NS_INS_FMT,array.toArray());
215 rv = String.format(ROLE_INS_FMT,array.toArray());
218 rv = String.format(PERM_INS_FMT,array.toArray());
221 rv = String.format(X509_INS_FMT,array.toArray());
230 private void addField(String feed, int fldcnt, List<String> array, StringBuilder sb) {
258 if(sb.toString().length()==0) {
263 if(sb.indexOf("'")>=0) {
264 s = sb.toString().replace("'","''");
266 if(sb.indexOf("\\n")>=0) {
268 s = sb.toString().replace("\\n","\n");
270 s = s.replace("\\n","\n");
273 if(sb.indexOf("\\t")>=0) {
275 s = sb.toString().replace("\\t","\t");
277 s = s.replace("\\t","\t");
281 array.add("'" + sb + '\'');
283 array.add("'" + s + '\'');
286 array.add(sb.toString());
293 private void applyBatch(StringBuilder query) {
295 query.append("APPLY BATCH;");
296 ResultSet rv = session.execute(query.toString());
297 if(rv.wasApplied()) {
298 System.out.print('.');
299 if((++batchCnt % 60)==0) {
300 System.out.println();
303 System.out.print("Data NOT APPLIED");
312 protected void _close(AuthzTrans trans) {