Sync Integ to Master
[sdc.git] / catalog-dao / src / main / java / org / openecomp / sdc / be / resources / data / auditing / DistributionEngineEvent.java
1 /*-
2  * ============LICENSE_START=======================================================
3  * SDC
4  * ================================================================================
5  * Copyright (C) 2017 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.openecomp.sdc.be.resources.data.auditing;
22
23 import java.text.SimpleDateFormat;
24 import java.util.*;
25
26 import org.openecomp.sdc.be.resources.data.auditing.model.CommonAuditData;
27 import org.openecomp.sdc.common.datastructure.AuditingFieldsKeysEnum;
28
29 import com.datastax.driver.core.utils.UUIDs;
30 import com.datastax.driver.mapping.annotations.ClusteringColumn;
31 import com.datastax.driver.mapping.annotations.Column;
32 import com.datastax.driver.mapping.annotations.PartitionKey;
33 import com.datastax.driver.mapping.annotations.Table;
34
35 @Table(keyspace = AuditingTypesConstants.AUDIT_KEYSPACE, name = AuditingTypesConstants.DISTRIBUTION_ENGINE_EVENT_TYPE)
36 public class DistributionEngineEvent extends AuditingGenericEvent {
37
38     private static String DISTRIBUTION_ENGINE_EVENT_TEMPLATE = "action=\"%s\" timestamp=\"%s\" "
39             + "environmentName=\"%s\" topicName=\"%s\" role=\"%s\" apiKey=\"%s\" " + "status=\"%s\" ";
40
41     @PartitionKey
42     protected UUID timebaseduuid;
43
44     @ClusteringColumn
45     protected Date timestamp1;
46
47     @Column(name = "request_id")
48     protected String requestId;
49
50     @Column(name = "service_instance_id")
51     protected String serviceInstanceId;
52
53     @Column
54     protected String action;
55     @Column
56     protected String status;
57
58     @Column(name = "description")
59     protected String desc;
60
61     @Column(name = "consumer_id")
62     private String consumerId;
63
64     @Column(name = "DSTATUS_TOPIC")
65     private String dstatusTopic;
66
67     @Column(name = "DNOTIF_TOPIC")
68     private String dnotifTopic;
69
70     @Column(name = "d_env")
71     private String environmentName;
72
73     @Column
74     private String role;
75
76     @Column(name = "api_key")
77     private String apiKey;
78
79     public DistributionEngineEvent() {
80         super();
81         timestamp1 = new Date();
82         timebaseduuid = UUIDs.timeBased();
83     }
84
85     public DistributionEngineEvent(Map<AuditingFieldsKeysEnum, Object> auditingFields) {
86         this();
87         Object value;
88         value = auditingFields.get(AuditingFieldsKeysEnum.AUDIT_REQUEST_ID);
89         if (value != null) {
90             setRequestId((String) value);
91         }
92         value = auditingFields.get(AuditingFieldsKeysEnum.AUDIT_SERVICE_INSTANCE_ID);
93         if (value != null) {
94             setServiceInstanceId((String) value);
95         }
96         value = auditingFields.get(AuditingFieldsKeysEnum.AUDIT_ACTION);
97         if (value != null) {
98             setAction((String) value);
99         }
100         value = auditingFields.get(AuditingFieldsKeysEnum.AUDIT_STATUS);
101         if (value != null) {
102             setStatus((String) value);
103         }
104         value = auditingFields.get(AuditingFieldsKeysEnum.AUDIT_DESC);
105         if (value != null) {
106             setDesc((String) value);
107         } else {
108             value = auditingFields.get(AuditingFieldsKeysEnum.AUDIT_DISTRIBUTION_STATUS_DESC);
109             if (value != null) {
110                 setDesc((String) value);
111             }
112         }
113         value = auditingFields.get(AuditingFieldsKeysEnum.AUDIT_DISTRIBUTION_CONSUMER_ID);
114         if (value != null) {
115             setConsumerId((String) value);
116         }
117         value = auditingFields.get(AuditingFieldsKeysEnum.AUDIT_DISTRIBUTION_STATUS_TOPIC_NAME);
118         if (value != null) {
119             setDstatusTopic((String) value);
120         }
121         value = auditingFields.get(AuditingFieldsKeysEnum.AUDIT_DISTRIBUTION_NOTIFICATION_TOPIC_NAME);
122         if (value != null) {
123             setDnotifTopic((String) value);
124         }
125         value = auditingFields.get(AuditingFieldsKeysEnum.AUDIT_DISTRIBUTION_API_KEY);
126         if (value != null) {
127             setApiKey((String) value);
128         }
129         value = auditingFields.get(AuditingFieldsKeysEnum.AUDIT_DISTRIBUTION_ENVRIONMENT_NAME);
130         if (value != null) {
131             setEnvironmentName((String) value);
132         }
133         value = auditingFields.get(AuditingFieldsKeysEnum.AUDIT_DISTRIBUTION_ROLE);
134         if (value != null) {
135             setRole((String) value);
136         }
137     }
138
139     public DistributionEngineEvent(String action, CommonAuditData commonAuditData, String consumerId, String distStatusTopic, String distNotifTopic,
140                                    String apiKey, String envName, String role) {
141         this();
142         this.action = action;
143         this.requestId = commonAuditData.getRequestId();
144         this.serviceInstanceId = commonAuditData.getServiceInstanceId();
145         this.status = commonAuditData.getStatus();
146         //if no desc, keep distr desc
147         this.desc = commonAuditData.getDescription();
148         this.consumerId = consumerId;
149         this.dstatusTopic = distStatusTopic;
150         this.dnotifTopic = distNotifTopic;
151         this.apiKey = apiKey;
152         this.environmentName = envName;
153         this.role = role;
154     }
155
156     @Override
157     public void fillFields() {
158         fields.put(AuditingFieldsKeysEnum.AUDIT_REQUEST_ID.getDisplayName(), getRequestId());
159
160                 fields.put(AuditingFieldsKeysEnum.AUDIT_SERVICE_INSTANCE_ID.getDisplayName(), getServiceInstanceId());
161                 fields.put(AuditingFieldsKeysEnum.AUDIT_ACTION.getDisplayName(), getAction());
162                 fields.put(AuditingFieldsKeysEnum.AUDIT_STATUS.getDisplayName(), getStatus());
163                 fields.put(AuditingFieldsKeysEnum.AUDIT_DESC.getDisplayName(), getDesc());
164
165                 fields.put(AuditingFieldsKeysEnum.AUDIT_DISTRIBUTION_CONSUMER_ID.getDisplayName(), getConsumerId());
166                 fields.put(AuditingFieldsKeysEnum.AUDIT_DISTRIBUTION_API_KEY.getDisplayName(), getApiKey());
167                 fields.put(AuditingFieldsKeysEnum.AUDIT_DISTRIBUTION_ENVRIONMENT_NAME.getDisplayName(), getEnvironmentName());
168                 fields.put(AuditingFieldsKeysEnum.AUDIT_DISTRIBUTION_ROLE.getDisplayName(), getRole());
169                 fields.put(AuditingFieldsKeysEnum.AUDIT_DISTRIBUTION_STATUS_TOPIC_NAME.getDisplayName(), getDstatusTopic());
170                 fields.put(AuditingFieldsKeysEnum.AUDIT_DISTRIBUTION_NOTIFICATION_TOPIC_NAME.getDisplayName(),
171                                 getDnotifTopic());
172                 SimpleDateFormat simpleDateFormat = new SimpleDateFormat(dateFormatPattern);
173                 simpleDateFormat.setTimeZone(TimeZone.getTimeZone("UTC"));
174                 fields.put(AuditingFieldsKeysEnum.AUDIT_TIMESTAMP.getDisplayName(), simpleDateFormat.format(timestamp1));
175         }
176
177     public String getDstatusTopic() {
178         return dstatusTopic;
179     }
180
181     public void setDstatusTopic(String dstatusTopic) {
182         this.dstatusTopic = dstatusTopic;
183     }
184
185     public String getDnotifTopic() {
186         return dnotifTopic;
187     }
188
189     public void setDnotifTopic(String dnotifTopic) {
190         this.dnotifTopic = dnotifTopic;
191     }
192
193     public String getEnvironmentName() {
194         return environmentName;
195     }
196
197     public void setEnvironmentName(String environmentName) {
198         this.environmentName = environmentName;
199     }
200
201     public String getRole() {
202         return role;
203     }
204
205     public void setRole(String role) {
206         this.role = role;
207     }
208
209     public String getApiKey() {
210         return apiKey;
211     }
212
213     public void setApiKey(String apiKey) {
214         this.apiKey = apiKey;
215     }
216
217     public UUID getTimebaseduuid() {
218         return timebaseduuid;
219     }
220
221     public void setTimebaseduuid(UUID timebaseduuid) {
222         this.timebaseduuid = timebaseduuid;
223     }
224
225     public Date getTimestamp1() {
226         return timestamp1;
227     }
228
229     public void setTimestamp1(Date timestamp1) {
230         this.timestamp1 = timestamp1;
231     }
232
233     public String getRequestId() {
234         return requestId;
235     }
236
237     public void setRequestId(String requestId) {
238         this.requestId = requestId;
239     }
240
241     public String getServiceInstanceId() {
242         return serviceInstanceId;
243     }
244
245     public void setServiceInstanceId(String serviceInstanceId) {
246         this.serviceInstanceId = serviceInstanceId;
247     }
248
249     public String getAction() {
250         return action;
251     }
252
253     public void setAction(String action) {
254         this.action = action;
255     }
256
257     public String getStatus() {
258         return status;
259     }
260
261     public void setStatus(String status) {
262         this.status = status;
263     }
264
265     public String getDesc() {
266         return desc;
267     }
268
269     public void setDesc(String desc) {
270         this.desc = desc;
271     }
272
273     public String getConsumerId() {
274         return consumerId;
275     }
276
277     public void setConsumerId(String consumerId) {
278         this.consumerId = consumerId;
279     }
280
281     @Override
282     public String toString() {
283         return "DistributionEngineEvent [timebaseduuid=" + timebaseduuid + ", timestamp1=" + timestamp1 + ", requestId="
284                 + requestId + ", serviceInstanceId=" + serviceInstanceId + ", action=" + action + ", status=" + status
285                 + ", desc=" + desc + ", consumerId=" + consumerId + ", dstatusTopic=" + dstatusTopic + ", dnotifTopic="
286                 + dnotifTopic + ", environmentName=" + environmentName + ", role=" + role + ", apiKey=" + apiKey + "]";
287     }
288
289 }