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.update;
23 import java.io.BufferedReader;
25 import java.io.FileReader;
26 import java.io.IOException;
27 import java.util.ArrayList;
28 import java.util.List;
30 import org.onap.aaf.auth.Batch;
31 import org.onap.aaf.auth.env.AuthzTrans;
32 import org.onap.aaf.auth.org.OrganizationException;
33 import org.onap.aaf.misc.env.APIException;
34 import org.onap.aaf.misc.env.Env;
35 import org.onap.aaf.misc.env.TimeTaken;
37 import com.datastax.driver.core.ResultSet;
39 public class Upload extends Batch {
40 public Upload(AuthzTrans trans) throws APIException, IOException, OrganizationException {
42 trans.info().log("Starting Connection Process");
44 TimeTaken tt0 = trans.start("Cassandra Initialization", Env.SUB);
46 TimeTaken tt = trans.start("Connect to Cluster", Env.REMOTE);
48 session = cluster.connect();
58 private static final int BATCH_LENGTH = 100;
63 protected void run(AuthzTrans trans) {
65 StringBuilder sb = new StringBuilder();
66 StringBuilder query = new StringBuilder();
67 List<String> array = new ArrayList<String>();
68 for(String feed : args()) {
69 File file = new File(feed + ".dat");
70 TimeTaken tt = trans.start(file.getAbsolutePath(), Env.SUB);
71 System.out.println("#### Running " + feed + ".dat Feed ####");
77 BufferedReader br = new BufferedReader(new FileReader(file));
79 while((line=br.readLine())!=null) {
80 if(query.length()==0) {
81 query.append("BEGIN BATCH\n");
83 // Split into fields, first turning Escaped values into something we can convert back from
85 boolean inQuote = false;
88 for(int i=0;i<line.length();++i) {
89 switch(c=line.charAt(i)) {
97 addField(feed,fldcnt++,array,sb);
104 addField(feed,fldcnt,array,sb);
105 query.append(build(feed, array));
107 if((++count % BATCH_LENGTH)==0) {
111 if((count % BATCH_LENGTH)!=0) {
121 } catch (IOException e) {
122 trans.error().log(e);
127 trans.error().log("No file found: ", file.getAbsolutePath());
132 System.out.printf("\n%d applied in %d batches\n",count,batchCnt);
140 private static final String APPR_INS_FMT=" INSERT INTO authz.approval "
141 + "(id,approver,last_notified,memo,operation,status,ticket,type,user) "
142 + "VALUES (%s,%s,%s,%s,%s,%s,%s,%s,%s);\n";
143 private static final Boolean[] APPR_QUOTES = new Boolean[]{false,true,true,true,true,true,false,true,true};
146 private static final String ARTI_INS_FMT=" INSERT INTO authz.artifact "
147 + "(mechid,machine,ca,dir,expires,notify,ns,os_user,renewdays,sans,sponsor,type) "
148 + "VALUES (%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s);\n";
149 private static final Boolean[] ARTI_QUOTES = new Boolean[]
150 {true,true,true,true,true,true,true,true,false,false,true,false};
153 private static final String CRED_INS_FMT=" INSERT INTO authz.cred "
154 + "(id,type,expires,cred,notes,ns,other,prev) "
155 + "VALUES (%s,%s,%s,%s,%s,%s,%s,%s);\n";
156 private static final Boolean[] CRED_QUOTES = new Boolean[]
157 {true,false,true,false,true,true,false,false};
160 private static final String NS_INS_FMT=" INSERT INTO authz.ns "
161 + "(name,description,parent,scope,type) "
162 + "VALUES (%s,%s,%s,%s,%s);\n";
163 private static final Boolean[] NS_QUOTES = new Boolean[]
164 {true,true,true,false,false};
167 private static final String X509_INS_FMT=" INSERT INTO authz.x509 "
168 + "(ca,serial,id,x500,x509) "
169 + "VALUES (%s,%s,%s,%s,%s);\n";
170 private static final Boolean[] X509_QUOTES = new Boolean[]
171 {true,false,true,true,true};
174 private static final String ROLE_INS_FMT=" INSERT INTO authz.role "
175 + "(ns,name,description,perms) "
176 + "VALUES (%s,%s,%s,%s);\n";
177 private static final Boolean[] ROLE_QUOTES = new Boolean[]
178 {true,true,true,false};
180 private static final String PERM_INS_FMT=" INSERT INTO authz.perm "
181 + "(ns,type,instance,action,description,roles) "
182 + "VALUES (%s,%s,%s,%s,%s,%s);\n";
183 private static final Boolean[] PERM_QUOTES = new Boolean[]
184 {true,true,true,true,true,false};
187 private String build(String feed, List<String> array) {
191 rv = String.format(APPR_INS_FMT,array.toArray());
194 rv = String.format(ARTI_INS_FMT,array.toArray());
197 rv = String.format(CRED_INS_FMT,array.toArray());
200 rv = String.format(NS_INS_FMT,array.toArray());
203 rv = String.format(ROLE_INS_FMT,array.toArray());
206 rv = String.format(PERM_INS_FMT,array.toArray());
209 rv = String.format(X509_INS_FMT,array.toArray());
218 private void addField(String feed, int fldcnt, List<String> array, StringBuilder sb) {
246 if(sb.toString().length()==0) {
251 if(sb.indexOf("'")>=0) {
252 s = sb.toString().replace("'","''");
254 if(sb.indexOf("\\n")>=0) {
256 s = sb.toString().replace("\\n","\n");
258 s = s.replace("\\n","\n");
261 if(sb.indexOf("\\t")>=0) {
263 s = sb.toString().replace("\\t","\t");
265 s = s.replace("\\t","\t");
269 array.add("'" + sb + '\'');
271 array.add("'" + s + '\'');
274 array.add(sb.toString());
281 private void applyBatch(StringBuilder query) {
282 query.append("APPLY BATCH;");
283 ResultSet rv = session.execute(query.toString());
284 if(rv.wasApplied()) {
285 System.out.print('.');
286 if((++batchCnt % 60)==0) {
287 System.out.println();
290 System.out.print("Data NOT APPLIED");
297 protected void _close(AuthzTrans trans) {