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====================================================
22 package org.onap.aaf.auth.batch.update;
25 import java.io.IOException;
26 import java.util.ArrayList;
27 import java.util.GregorianCalendar;
28 import java.util.List;
30 import java.util.Map.Entry;
32 import java.util.TreeMap;
34 import org.onap.aaf.auth.batch.Batch;
35 import org.onap.aaf.auth.batch.BatchPrincipal;
36 import org.onap.aaf.auth.batch.approvalsets.ApprovalSet;
37 import org.onap.aaf.auth.batch.approvalsets.Pending;
38 import org.onap.aaf.auth.batch.approvalsets.URApprovalSet;
39 import org.onap.aaf.auth.batch.helpers.BatchDataView;
40 import org.onap.aaf.auth.batch.helpers.NS;
41 import org.onap.aaf.auth.batch.helpers.Role;
42 import org.onap.aaf.auth.batch.helpers.UserRole;
43 import org.onap.aaf.auth.batch.reports.Analyze;
44 import org.onap.aaf.auth.dao.cass.UserRoleDAO;
45 import org.onap.aaf.auth.env.AuthzTrans;
46 import org.onap.aaf.auth.layer.Result;
47 import org.onap.aaf.auth.org.OrganizationException;
48 import org.onap.aaf.cadi.CadiException;
49 import org.onap.aaf.cadi.client.Holder;
50 import org.onap.aaf.cadi.util.CSV;
51 import org.onap.aaf.cadi.util.CSV.Writer;
52 import org.onap.aaf.misc.env.APIException;
53 import org.onap.aaf.misc.env.TimeTaken;
54 import org.onap.aaf.misc.env.Trans;
55 import org.onap.aaf.misc.env.util.Chrono;
57 public class Approvals extends Batch {
58 private final AuthzTrans noAvg;
59 private BatchDataView dataview;
60 private List<CSV> csvList;
61 private Writer napproveCW;
62 private final GregorianCalendar now;
63 private final String sdate;
64 private static final String CSV = ".csv";
65 private static final String APPROVALS_NEW = "ApprovalsNew";
67 public Approvals(AuthzTrans trans) throws APIException, IOException, OrganizationException {
69 now = new GregorianCalendar();
70 sdate = Chrono.dateOnlyStamp(now);
71 noAvg = env.newTransNoAvg();
72 noAvg.setUser(new BatchPrincipal("batch:Approvals"));
73 session = cluster.connect();
74 dataview = new BatchDataView(noAvg,session,dryRun);
75 NS.load(trans, session, NS.v2_0_11);
76 Role.load(trans, session);
77 UserRole.load(trans, session, UserRole.v2_0_11);
79 csvList = new ArrayList<>();
82 for(int i=0;i<args().length;++i) {
83 f = new File(logDir(), args()[i]);
85 csvList.add(new CSV(env.access(),f).processAll());
87 trans.error().printf("CSV File %s does not exist",f.getAbsolutePath());
91 f = new File(logDir(), Analyze.NEED_APPROVALS+Chrono.dateOnlyStamp()+".csv");
93 csvList.add(new CSV(env.access(),f).processAll());
95 trans.error().printf("CSV File %s does not exist",f.getAbsolutePath());
100 File file = new File(logDir(),APPROVALS_NEW + sdate +CSV);
101 CSV approveCSV = new CSV(env.access(),file);
102 napproveCW = approveCSV.writer();
103 napproveCW.row("info",APPROVALS_NEW,sdate,1);
108 protected void run(AuthzTrans trans) {
109 Map<String,Pending> mpending = new TreeMap<>();
110 Pending p = Pending.create();
112 Holder<Integer> count = new Holder<>(0);
113 for(CSV neeedApproveCSV : csvList) {
114 TimeTaken tt = trans.start("Processing %s's UserRoles",Trans.SUB,neeedApproveCSV.name());
116 neeedApproveCSV.visit(row -> {
118 case UserRole.APPROVE_UR:
119 UserRoleDAO.Data urdd = UserRole.row(row);
120 // Create an Approval
121 ApprovalSet uras = new URApprovalSet(noAvg, now, dataview, () -> {
124 Result<Void> rw = uras.write(noAvg);
126 Set<String> approvers = uras.approvers();
127 if(approvers.isEmpty()) {
128 trans.error().printf("No Approvers found for %s-%s (probably no owner)",urdd.user,urdd.role);
130 for(String approver : approvers) {
131 Pending mp = mpending.get(approver);
133 mpending.put(approver, Pending.create());
135 mp.inc(p); // FYI, unlikely
138 count.set(count.get()+1);
141 trans.error().log(rw.errorString());
147 } catch (IOException | CadiException e) {
149 // .... but continue with next row
153 trans.info().printf("Processed %d UserRoles", count.get());
155 tt = trans.start("Writing Approvals to %s",Trans.SUB,neeedApproveCSV.name());
158 for(Entry<String, Pending> es : mpending.entrySet()) {
159 p.row(napproveCW,es.getKey());
164 trans.info().printf("Processed %d Reminders", cnt);
170 protected void _close(AuthzTrans trans) {
171 if(napproveCW!=null) {