add alarm synchronization related operation
[holmes/engine-management.git] / engine-d / src / main / java / org / onap / holmes / engine / manager / DroolsEngine.java
index d790ee7..3740f18 100644 (file)
@@ -21,11 +21,11 @@ import java.util.List;
 import java.util.Locale;\r
 import java.util.Set;\r
 import javax.annotation.PostConstruct;\r
-import javax.annotation.PreDestroy;\r
 import javax.inject.Inject;\r
 import lombok.extern.slf4j.Slf4j;\r
 import org.drools.compiler.kie.builder.impl.InternalKieModule;\r
 import org.jvnet.hk2.annotations.Service;\r
+\r
 import org.kie.api.KieBase;\r
 import org.kie.api.KieServices;\r
 import org.kie.api.builder.KieBuilder;\r
@@ -45,8 +45,14 @@ import org.kie.api.runtime.KieContainer;
 import org.kie.api.runtime.KieSession;\r
 import org.kie.api.runtime.conf.ClockTypeOption;\r
 import org.kie.api.runtime.rule.FactHandle;\r
+\r
+import org.onap.holmes.common.api.entity.AlarmInfo;\r
+\r
 import org.onap.holmes.common.api.stat.VesAlarm;\r
 import org.onap.holmes.common.dmaap.DmaapService;\r
+import org.onap.holmes.common.exception.AlarmInfoException;\r
+import org.onap.holmes.common.utils.DbDaoUtil;\r
+import org.onap.holmes.engine.db.AlarmInfoDao;\r
 import org.onap.holmes.engine.request.DeployRuleRequest;\r
 import org.onap.holmes.common.api.entity.CorrelationRule;\r
 import org.onap.holmes.common.exception.CorrelationException;\r
@@ -62,6 +68,7 @@ public class DroolsEngine {
     @Inject\r
     private RuleMgtWrapper ruleMgtWrapper;\r
 \r
+\r
     private KieBase kieBase;\r
     private KieSession kieSession;\r
     private KieContainer kieContainer;\r
@@ -71,8 +78,14 @@ public class DroolsEngine {
     private KieResources resources;\r
     private KieRepository kieRepository;\r
 \r
+    private AlarmInfoDao alarmInfoDao;\r
+    @Inject\r
+    private DbDaoUtil daoUtil;\r
+\r
+\r
     @PostConstruct\r
     private void init() {\r
+        alarmInfoDao = daoUtil.getJdbiDaoByOnDemand(AlarmInfoDao.class);\r
         try {\r
             // start engine\r
             start();\r
@@ -82,13 +95,14 @@ public class DroolsEngine {
         }\r
     }\r
 \r
-    private void start() throws CorrelationException {\r
+    private void start() throws AlarmInfoException {\r
         log.info("Drools Engine Initialize Beginning...");\r
 \r
         initEngineParameter();\r
-        initDeployRule();\r
+        alarmSynchronization();\r
+//        initDeployRule();\r
 \r
-        log.info("Business Rule Engine Initialize Successfully.");\r
+        log.info("Alarm synchronization Successfully.");\r
     }\r
 \r
     public void stop() {\r
@@ -220,6 +234,7 @@ public class DroolsEngine {
         }\r
         this.kieSession.insert(raiseAlarm);\r
         this.kieSession.fireAllRules();\r
+\r
     }\r
 \r
     public List<String> queryAllPackage() {\r
@@ -261,4 +276,22 @@ public class DroolsEngine {
         kieBase.removeKiePackage(kiePackage.getName());\r
     }\r
 \r
+    public void alarmSynchronization() throws AlarmInfoException {\r
+        alarmInfoDao.queryAllAlarm().forEach(alarmInfo -> alarmInfoDao.deleteClearedAlarm(alarmInfo));\r
+        alarmInfoDao.queryAllAlarm().forEach(alarmInfo -> putRaisedIntoStream(convertAlarmInfo2VesAlarm(alarmInfo)));\r
+    }\r
+\r
+    private VesAlarm convertAlarmInfo2VesAlarm(AlarmInfo alarmInfo) {\r
+        VesAlarm vesAlarm = new VesAlarm();\r
+        vesAlarm.setEventId(alarmInfo.getEventId());\r
+        vesAlarm.setEventName(alarmInfo.getEventName());\r
+        vesAlarm.setStartEpochMicrosec(alarmInfo.getStartEpochMicroSec());\r
+        vesAlarm.setSourceId(alarmInfo.getSourceId());\r
+        vesAlarm.setSourceName(alarmInfo.getSourceName());\r
+        vesAlarm.setRootFlag(alarmInfo.getRootFlag());\r
+        vesAlarm.setAlarmIsCleared(alarmInfo.getAlarmIsCleared());\r
+        vesAlarm.setLastEpochMicrosec(alarmInfo.getLastEpochMicroSec());\r
+        return vesAlarm;\r
+    }\r
+\r
 }\r