*/
package org.onap.holmes.common.dmaap;
+import com.fasterxml.jackson.core.JsonProcessingException;
import java.util.List;
import java.util.Optional;
-import lombok.AllArgsConstructor;
+import java.util.UUID;
+import java.util.concurrent.ConcurrentHashMap;
+import javax.inject.Inject;
import lombok.extern.slf4j.Slf4j;
+import org.jvnet.hk2.annotations.Service;
import org.onap.holmes.common.aai.AaiQuery;
+import org.onap.holmes.common.aai.entity.RelationshipList.Relationship;
import org.onap.holmes.common.aai.entity.RelationshipList.RelationshipData;
import org.onap.holmes.common.aai.entity.VmEntity;
import org.onap.holmes.common.aai.entity.VnfEntity;
import org.onap.holmes.common.api.stat.VesAlarm;
+import org.onap.holmes.common.dcae.DcaeConfigurationsCache;
import org.onap.holmes.common.dmaap.entity.PolicyMsg;
import org.onap.holmes.common.dmaap.entity.PolicyMsg.EVENT_STATUS;
import org.onap.holmes.common.exception.CorrelationException;
+import org.onap.holmes.common.utils.JacksonUtil;
@Slf4j
-@AllArgsConstructor
+@Service
public class DmaapService {
+ public static final int POLICY_MESSAGE_ABATED = 1;
+ public static final String SERVICE_INSTANCE = "service-instance";
+ public static final String SERVICE_INSTANCE_ID = "service-instance.service-instance-id";
+ @Inject
+ private AaiQuery aaiQuery;
+ public static ConcurrentHashMap<String, String> loopControlNames = new ConcurrentHashMap<>();
+ public static ConcurrentHashMap<String, String> alarmUniqueRequestID = new ConcurrentHashMap<>();
- private static AaiQuery aaiQuery;
- private static Publisher publisher;
-
- public static void publishPolicyMsg(PolicyMsg policyMsg) {
+ public void publishPolicyMsg(PolicyMsg policyMsg, String dmaapConfigKey) {
try {
+ Publisher publisher = new Publisher();
+ publisher.setUrl(DcaeConfigurationsCache.getPubSecInfo(dmaapConfigKey).getDmaapInfo().getTopicUrl());
publisher.publish(policyMsg);
+ log.info("send policyMsg: " + JacksonUtil.beanToJson(policyMsg));
} catch (CorrelationException e) {
log.error("Failed to publish policyMsg to dmaap", e.getMessage());
+ } catch (JsonProcessingException e) {
+ log.info("Failed to convert policyMsg to json");
+ } catch (NullPointerException e) {
+ log.error("DMaaP configurations does not exist!");
}
}
- public static PolicyMsg getPolicyMsg(VesAlarm vesAlarm) {
- return Optional.ofNullable(getVmEntity(vesAlarm.getSourceId(), vesAlarm.getSourceName()))
- .map(vmEntity -> getEnrichedPolicyMsg(vmEntity, vesAlarm))
- .orElse(getDefaultPolicyMsg(vesAlarm.getSourceName()));
+ public PolicyMsg getPolicyMsg(VesAlarm rootAlarm, VesAlarm childAlarm, String packgeName) {
+ return Optional.ofNullable(getVmEntity(rootAlarm.getSourceId(), rootAlarm.getSourceName()))
+ .map(vmEntity -> getEnrichedPolicyMsg(vmEntity, rootAlarm, childAlarm, packgeName))
+ .orElse(getDefaultPolicyMsg(rootAlarm.getSourceName()));
}
- private static String getVserverInstanceId(VnfEntity vnfEntity) {
+ private String getVserverInstanceId(VnfEntity vnfEntity) {
String vserverInstanceId = "";
if (vnfEntity != null) {
- List<RelationshipData> relationshipDataList = vnfEntity.getRelationshipList()
- .getRelationships().stream()
- .filter(relationship -> relationship.getRelatedTo().equals("service-instance"))
- .limit(1).findFirst().get().getRelationshipDataList();
-
- vserverInstanceId = relationshipDataList.stream()
- .filter(relationshipData -> relationshipData.getRelationshipKey().equals("service-instance.service-instance-id"))
- .findFirst()
- .map(relationshipData -> relationshipData.getRelationshipValue()).get();
+ List<Relationship> relationshipList = vnfEntity.getRelationshipList().getRelationships();
+ Relationship relationship = null;
+ for(int i = 0; i < relationshipList.size(); i++) {
+ if (SERVICE_INSTANCE.equals(relationshipList.get(i).getRelatedTo())) {
+ relationship = relationshipList.get(i);
+ break;
+ }
+ }
+ if (relationship != null) {
+ List<RelationshipData> relationshipDataList = relationship.getRelationshipDataList();
+ for(int i = 0; i < relationshipDataList.size(); i++) {
+ if (SERVICE_INSTANCE_ID
+ .equals(relationshipDataList.get(i).getRelationshipKey())) {
+ vserverInstanceId = relationshipDataList.get(i).getRelationshipValue();
+ break;
+ }
+ }
+ }
}
return vserverInstanceId;
}
- private static VnfEntity getVnfEntity(String vnfId, String vnfName) {
- VnfEntity vnfEntity = null;
- try {
- vnfEntity = aaiQuery.getAaiVnfData(vnfId, vnfName);
- } catch (CorrelationException e) {
- log.error("Failed to get vnf data", e.getMessage());
+ private PolicyMsg getEnrichedPolicyMsg(VmEntity vmEntity, VesAlarm rootAlarm, VesAlarm childAlarm,
+ String packageName) {
+ PolicyMsg policyMsg = new PolicyMsg();
+ String alarmUniqueKey = "";
+ if (rootAlarm.getAlarmIsCleared() == POLICY_MESSAGE_ABATED) {
+ policyMsg.setClosedLoopEventStatus(EVENT_STATUS.ABATED);
+ alarmUniqueKey =
+ rootAlarm.getSourceId() + ":" + rootAlarm.getEventName().replace("Cleared", "");
+ } else {
+ policyMsg.setClosedLoopEventStatus(EVENT_STATUS.ONSET);
+ enrichVnfInfo(childAlarm, policyMsg);
+ alarmUniqueKey = rootAlarm.getSourceId() + ":" + rootAlarm.getEventName();
}
- return vnfEntity;
- }
-
- private static VmEntity getVmEntity(String sourceId, String sourceName) {
- VmEntity vmEntity = null;
- try {
- vmEntity = aaiQuery.getAaiVmData(sourceId, sourceName);
- } catch (CorrelationException e) {
- log.error("Failed to get vm data", e.getMessage());
+ if (alarmUniqueRequestID.containsKey(alarmUniqueKey)) {
+ policyMsg.setRequestID(alarmUniqueRequestID.get(alarmUniqueKey));
+ } else {
+ String requestID = UUID.randomUUID().toString();
+ policyMsg.setRequestID(requestID);
+ alarmUniqueRequestID.put(alarmUniqueKey, requestID);
}
- return vmEntity;
- }
-
- private static PolicyMsg getEnrichedPolicyMsg(VmEntity vmEntity, VesAlarm vesAlarm) {
- VnfEntity vnfEntity = getVnfEntity(vesAlarm.getEventId(), vesAlarm.getEventName());
- String vserverInstatnceId = getVserverInstanceId(vnfEntity);
- PolicyMsg policyMsg = new PolicyMsg();
- policyMsg.setClosedLoopEventClient("DCAE_INSTANCE_ID.dcae-tca");
- policyMsg.setPolicyVersion("1.0.0.5");
- policyMsg.setPolicyName("vLoadBalancer");
- policyMsg.setPolicyScope(
- "resource=SampleResource,service=SampleService,type=SampleType,closedLoopControlName=SampleClosedLoop");
- policyMsg.setTargetType("VM");
- policyMsg.setClosedLoopAlarmStart(1484855);
- policyMsg.setClosedLoopEventStatus(EVENT_STATUS.ONSET);
- policyMsg.setClosedLoopControlName(
- "CL-LB-LOW-TRAFFIC-SIG-d925ed73-8231-4d02-9545-db4e101f88f8");
- policyMsg.setVersion("1.0.2");
- policyMsg.setTarget("generic-vnf.vnf-id");
- policyMsg.setRequestID("8c1b8bd8-06f7-493f-8ed7-daaa4cc481bc");
- policyMsg.setFrom("DCAE");
+ policyMsg.setClosedLoopControlName(loopControlNames.get(packageName));
+ policyMsg.setTarget(vmEntity.getVserverName());
policyMsg.getAai().put("vserver.in-maint", String.valueOf(vmEntity.getInMaint()));
policyMsg.getAai().put("vserver.is-closed-loop-disabled",
String.valueOf(vmEntity.getClosedLoopDisable()));
policyMsg.getAai().put("vserver.vserver-name", vmEntity.getVserverName());
policyMsg.getAai().put("vserver.vserver-name2", vmEntity.getVserverName2());
policyMsg.getAai().put("vserver.vserver-selflink", vmEntity.getVserverSelflink());
- policyMsg.getAai().put("generic-vnf.vnf-id", vesAlarm.getEventId());
- policyMsg.getAai().put("generic-vnf.vnf-name", vesAlarm.getEventName());
- policyMsg.getAai().put("generic-vnf.service-instance-id", vserverInstatnceId);
return policyMsg;
}
- private static PolicyMsg getDefaultPolicyMsg(String sourceName) {
+ private PolicyMsg getDefaultPolicyMsg(String sourceName) {
PolicyMsg policyMsg = new PolicyMsg();
policyMsg.setTarget("vserver.vserver-name");
policyMsg.setTargetType("VM");
policyMsg.getAai().put("vserver.vserver-name", sourceName);
return policyMsg;
}
+
+ private void enrichVnfInfo(VesAlarm childAlarm, PolicyMsg policyMsg) {
+ VnfEntity vnfEntity = getVnfEntity(childAlarm.getSourceId(), childAlarm.getSourceName());
+ String vserverInstatnceId = getVserverInstanceId(vnfEntity);
+ policyMsg.getAai().put("generic-vnf.vnf-id", childAlarm.getSourceId());
+ policyMsg.getAai().put("generic-vnf.vnf-name", childAlarm.getSourceName());
+ policyMsg.getAai().put("generic-vnf.service-instance-id", vserverInstatnceId);
+ }
+
+ private VnfEntity getVnfEntity(String vnfId, String vnfName) {
+ VnfEntity vnfEntity = null;
+ try {
+ vnfEntity = aaiQuery.getAaiVnfData(vnfId, vnfName);
+ } catch (CorrelationException e) {
+ log.error("Failed to get vnf data", e.getMessage());
+ }
+ return vnfEntity;
+ }
+
+ private VmEntity getVmEntity(String sourceId, String sourceName) {
+ VmEntity vmEntity = null;
+ try {
+ vmEntity = aaiQuery.getAaiVmData(sourceId, sourceName);
+ } catch (CorrelationException e) {
+ log.error("Failed to get vm data", e.getMessage());
+ }
+ return vmEntity;
+ }
}