2 * ============LICENSE_START=======================================================
4 * ================================================================================
5 * Copyright © 2017-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=========================================================
20 package org.onap.aai.util;
22 import java.io.StringWriter;
23 import java.util.Iterator;
24 import java.util.UUID;
26 import javax.xml.bind.Marshaller;
28 import com.att.eelf.configuration.EELFLogger;
29 import com.att.eelf.configuration.EELFManager;
30 import org.eclipse.persistence.dynamic.DynamicEntity;
31 import org.eclipse.persistence.jaxb.dynamic.DynamicJAXBContext;
32 import org.json.JSONException;
33 import org.json.JSONObject;
34 import org.onap.aai.dmaap.AAIDmaapEventJMSProducer;
35 import org.onap.aai.dmaap.MessageProducer;
36 import org.onap.aai.domain.notificationEvent.NotificationEvent;
37 import org.onap.aai.exceptions.AAIException;
38 import org.onap.aai.introspection.Introspector;
39 import org.onap.aai.introspection.Loader;
40 import org.onap.aai.introspection.exceptions.AAIUnknownObjectException;
41 import org.springframework.context.ApplicationContext;
42 import org.springframework.core.env.Environment;
44 public class StoreNotificationEvent {
46 private static final EELFLogger logger = EELFManager.getInstance().getLogger(StoreNotificationEvent.class);
48 private MessageProducer messageProducer;
49 private String fromAppId = "";
50 private String transId = "";
51 private final String transactionId;
52 private final String sourceOfTruth;
54 private ApplicationContext context;
55 private Environment env;
58 * Instantiates a new store notification event.
60 public StoreNotificationEvent(String transactionId, String sourceOfTruth) {
61 this.messageProducer = new AAIDmaapEventJMSProducer();
62 this.transactionId = transactionId;
63 this.sourceOfTruth = sourceOfTruth;
66 public StoreNotificationEvent(AAIDmaapEventJMSProducer producer, String transactionId, String sourceOfTruth) {
67 this.messageProducer = producer;
68 this.transactionId = transactionId;
69 this.sourceOfTruth = sourceOfTruth;
79 * @throws AAIException
82 public String storeEvent(NotificationEvent.EventHeader eh, Object obj) throws AAIException {
85 throw new AAIException("AAI_7350");
88 org.onap.aai.domain.notificationEvent.ObjectFactory factory = new org.onap.aai.domain.notificationEvent.ObjectFactory();
90 org.onap.aai.domain.notificationEvent.NotificationEvent ne = factory.createNotificationEvent();
92 if (eh.getId() == null) {
93 eh.setId(genDate2() + "-" + UUID.randomUUID().toString());
95 if (eh.getTimestamp() == null) {
96 eh.setTimestamp(genDate());
99 // there's no default, but i think we want to put this in hbase?
101 if (eh.getEntityLink() == null) {
102 eh.setEntityLink("UNK");
105 if (eh.getAction() == null) {
109 if (eh.getEventType() == null) {
110 eh.setEventType(AAIConfig.get("aai.notificationEvent.default.eventType", "UNK"));
113 if (eh.getDomain() == null) {
114 eh.setDomain(AAIConfig.get("aai.notificationEvent.default.domain", "UNK"));
117 if (eh.getSourceName() == null) {
118 eh.setSourceName(AAIConfig.get("aai.notificationEvent.default.sourceName", "UNK"));
121 if (eh.getSequenceNumber() == null) {
122 eh.setSequenceNumber(AAIConfig.get("aai.notificationEvent.default.sequenceNumber", "UNK"));
125 if (eh.getSeverity() == null) {
126 eh.setSeverity(AAIConfig.get("aai.notificationEvent.default.severity", "UNK"));
129 if (eh.getVersion() == null) {
130 eh.setVersion(AAIConfig.get("aai.notificationEvent.default.version", "UNK"));
133 ne.setCambriaPartition(AAIConstants.UEB_PUB_PARTITION_AAI);
134 ne.setEventHeader(eh);
138 PojoUtils pu = new PojoUtils();
139 String entityJson = pu.getJsonFromObject(ne);
140 sendToDmaapJmsQueue(entityJson);
142 } catch (Exception e) {
143 throw new AAIException("AAI_7350", e);
148 * Store dynamic event.
150 * @param notificationJaxbContext
151 * the notification jaxb context
152 * @param notificationVersion
153 * the notification version
158 * @throws AAIException
161 public void storeDynamicEvent(DynamicJAXBContext notificationJaxbContext, String notificationVersion, DynamicEntity eventHeader, DynamicEntity obj) throws AAIException {
164 throw new AAIException("AAI_7350");
167 DynamicEntity notificationEvent = notificationJaxbContext.getDynamicType("inventory.aai.onap.org." + notificationVersion + ".NotificationEvent").newDynamicEntity();
169 if (eventHeader.get("id") == null) {
170 eventHeader.set("id", genDate2() + "-" + UUID.randomUUID().toString());
173 if (eventHeader.get("timestamp") == null) {
174 eventHeader.set("timestamp", genDate());
177 if (eventHeader.get("entityLink") == null) {
178 eventHeader.set("entityLink", "UNK");
181 if (eventHeader.get("action") == null) {
182 eventHeader.set("action", "UNK");
185 if (eventHeader.get("eventType") == null) {
186 eventHeader.set("eventType", AAIConfig.get("aai.notificationEvent.default.eventType", "UNK"));
189 if (eventHeader.get("domain") == null) {
190 eventHeader.set("domain", AAIConfig.get("aai.notificationEvent.default.domain", "UNK"));
193 if (eventHeader.get("sourceName") == null) {
194 eventHeader.set("sourceName", AAIConfig.get("aai.notificationEvent.default.sourceName", "UNK"));
197 if (eventHeader.get("sequenceNumber") == null) {
198 eventHeader.set("sequenceNumber", AAIConfig.get("aai.notificationEvent.default.sequenceNumber", "UNK"));
201 if (eventHeader.get("severity") == null) {
202 eventHeader.set("severity", AAIConfig.get("aai.notificationEvent.default.severity", "UNK"));
205 if (eventHeader.get("version") == null) {
206 eventHeader.set("version", AAIConfig.get("aai.notificationEvent.default.version", "UNK"));
209 if (notificationEvent.get("cambriaPartition") == null) {
210 notificationEvent.set("cambriaPartition", AAIConstants.UEB_PUB_PARTITION_AAI);
213 notificationEvent.set("eventHeader", eventHeader);
214 notificationEvent.set("entity", obj);
217 StringWriter result = new StringWriter();
219 Marshaller marshaller = notificationJaxbContext.createMarshaller();
220 marshaller.setProperty(org.eclipse.persistence.jaxb.MarshallerProperties.MEDIA_TYPE, "application/json");
221 marshaller.setProperty(org.eclipse.persistence.jaxb.MarshallerProperties.JSON_INCLUDE_ROOT, false);
222 marshaller.setProperty(org.eclipse.persistence.jaxb.MarshallerProperties.JSON_WRAPPER_AS_ARRAY_NAME, false);
223 marshaller.setProperty(Marshaller.JAXB_FORMATTED_OUTPUT, false);
224 marshaller.marshal(notificationEvent, result);
225 this.sendToDmaapJmsQueue(result.toString());
227 } catch (Exception e) {
228 throw new AAIException("AAI_7350", e);
232 public String storeEvent(Loader loader, Introspector eventHeader, Introspector obj) throws AAIException {
234 throw new AAIException("AAI_7350");
238 final Introspector notificationEvent = loader.introspectorFromName("notification-event");
240 if (eventHeader.getValue("id") == null) {
241 eventHeader.setValue("id", genDate2() + "-" + UUID.randomUUID().toString());
244 if (eventHeader.getValue("timestamp") == null) {
245 eventHeader.setValue("timestamp", genDate());
248 if (eventHeader.getValue("entity-link") == null) {
249 eventHeader.setValue("entity-link", "UNK");
252 if (eventHeader.getValue("action") == null) {
253 eventHeader.setValue("action", "UNK");
256 if (eventHeader.getValue("event-type") == null) {
257 eventHeader.setValue("event-type", AAIConfig.get("aai.notificationEvent.default.eventType", "UNK"));
260 if (eventHeader.getValue("domain") == null) {
261 eventHeader.setValue("domain", AAIConfig.get("aai.notificationEvent.default.domain", "UNK"));
264 if (eventHeader.getValue("source-name") == null) {
265 eventHeader.setValue("source-name", AAIConfig.get("aai.notificationEvent.default.sourceName", "UNK"));
268 if (eventHeader.getValue("sequence-number") == null) {
269 eventHeader.setValue("sequence-number", AAIConfig.get("aai.notificationEvent.default.sequenceNumber", "UNK"));
272 if (eventHeader.getValue("severity") == null) {
273 eventHeader.setValue("severity", AAIConfig.get("aai.notificationEvent.default.severity", "UNK"));
276 if (eventHeader.getValue("version") == null) {
277 eventHeader.setValue("version", AAIConfig.get("aai.notificationEvent.default.version", "UNK"));
280 if (notificationEvent.getValue("cambria-partition") == null) {
281 notificationEvent.setValue("cambria-partition", AAIConfig.get("aai.notificationEvent.default.partition", AAIConstants.UEB_PUB_PARTITION_AAI));
284 notificationEvent.setValue("event-header", eventHeader.getUnderlyingObject());
285 notificationEvent.setValue("entity", obj.getUnderlyingObject());
287 String entityJson = notificationEvent.marshal(false);
288 sendToDmaapJmsQueue(entityJson);
290 } catch (JSONException e) {
291 throw new AAIException("AAI_7350", e);
292 } catch (AAIUnknownObjectException e) {
293 throw new AAIException("AAI_7350", e);
297 private void sendToDmaapJmsQueue(String entityString) throws JSONException {
300 JSONObject entityJsonObject = new JSONObject(entityString);
302 JSONObject entityJsonObjectUpdated = new JSONObject();
303 JSONObject finalJson = new JSONObject();
305 JSONObject entityHeader = entityJsonObject.getJSONObject("event-header");
306 String cambriaPartition = entityJsonObject.getString("cambria.partition");
308 entityJsonObject.remove("event-header");
309 entityJsonObject.remove("cambria.partition");
311 entityJsonObjectUpdated.put("event-header", entityHeader);
312 entityJsonObjectUpdated.put("cambria.partition", cambriaPartition);
314 String transId = entityHeader.getString("id");
315 String fromAppId = entityHeader.getString("source-name");
317 Iterator<String> iter = entityJsonObject.keys();
318 JSONObject entity = new JSONObject();
319 if (iter.hasNext()) {
320 entity = entityJsonObject.getJSONObject(iter.next());
323 entityJsonObjectUpdated.put("entity", entity);
325 finalJson.put("event-topic", "AAI-EVENT");
326 finalJson.put("transId", transId);
327 finalJson.put("fromAppId", fromAppId);
328 finalJson.put("fullId", "");
329 finalJson.put("aaiEventPayload", entityJsonObjectUpdated);
331 messageProducer.sendMessageToDefaultDestination(finalJson);
339 public static String genDate() {
340 FormatDate fd = new FormatDate("YYYYMMdd-HH:mm:ss:SSS");
341 return fd.getDateTime();
349 public static String genDate2() {
350 FormatDate fd = new FormatDate("YYYYMMddHHmmss");
351 return fd.getDateTime();