Initial source code
[oam/tr069-adapter.git] / ves-agent / src / main / java / org / commscope / tr069adapter / vesagent / fault / Parser.java
diff --git a/ves-agent/src/main/java/org/commscope/tr069adapter/vesagent/fault/Parser.java b/ves-agent/src/main/java/org/commscope/tr069adapter/vesagent/fault/Parser.java
new file mode 100644 (file)
index 0000000..371d6c9
--- /dev/null
@@ -0,0 +1,100 @@
+/*\r
+ * ============LICENSE_START========================================================================\r
+ * ONAP : tr-069-adapter\r
+ * =================================================================================================\r
+ * Copyright (C) 2020 CommScope Inc Intellectual Property.\r
+ * =================================================================================================\r
+ * This tr-069-adapter software file is distributed by CommScope Inc under the Apache License,\r
+ * Version 2.0 (the "License"); you may not use this file except in compliance with the License. You\r
+ * may obtain a copy of the License at\r
+ *\r
+ * http://www.apache.org/licenses/LICENSE-2.0\r
+ *\r
+ * This file is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND,\r
+ * either express or implied. See the License for the specific language governing permissions and\r
+ * limitations under the License.\r
+ * ===============LICENSE_END=======================================================================\r
+ */\r
+\r
+package org.commscope.tr069adapter.vesagent.fault;\r
+\r
+import java.util.HashMap;\r
+import java.util.List;\r
+import java.util.Map;\r
+\r
+import org.apache.commons.logging.Log;\r
+import org.apache.commons.logging.LogFactory;\r
+import org.commscope.tr069adapter.acs.common.ParameterDTO;\r
+import org.commscope.tr069adapter.vesagent.InformEventData;\r
+import org.commscope.tr069adapter.vesagent.exception.InvalidFaultOperationException;\r
+import org.commscope.tr069adapter.vesagent.model.PnfRegEventFields;\r
+\r
+public class Parser {\r
+\r
+  private Log logger = LogFactory.getLog(Parser.class);\r
+\r
+  public Map<String, ExpeditedEvent> parseFaultParams(List<ParameterDTO> parameters)\r
+      throws InvalidFaultOperationException {\r
+    Map<String, ExpeditedEvent> dmAlarmParameters = new HashMap<>();\r
+\r
+    try {\r
+      for (ParameterDTO parameter : parameters) {\r
+        logger.debug("PARAM NAME " + parameter.getParamName());\r
+        if (parameter.getParamName() == null || !isAlarmEvent(parameter.getParamName())) {\r
+          continue;\r
+        }\r
+\r
+        String alarmParamMO = parameter.getParamName();\r
+        String alarmParam = null;\r
+        String alarmParamParentMoWithIndex = null;\r
+\r
+        if (null != alarmParamMO) {\r
+          alarmParam = alarmParamMO.substring(alarmParamMO.lastIndexOf('.') + 1);\r
+          alarmParamParentMoWithIndex = alarmParamMO.substring(0, alarmParamMO.lastIndexOf('.'));\r
+        }\r
+\r
+        ExpeditedEvent expeditedEvent = null;\r
+        if (dmAlarmParameters.containsKey(alarmParamParentMoWithIndex)) {\r
+          expeditedEvent = dmAlarmParameters.get(alarmParamParentMoWithIndex);\r
+        } else {\r
+          expeditedEvent = new ExpeditedEvent();\r
+          logger.debug("ADDING " + alarmParamParentMoWithIndex);\r
+          dmAlarmParameters.put(alarmParamParentMoWithIndex, expeditedEvent);\r
+        }\r
+\r
+        expeditedEvent.parse(parameter, alarmParam);\r
+      }\r
+    } catch (NumberFormatException ex) {\r
+      logger.error("Error while parsing alarm event parameter {}", ex);\r
+      throw new InvalidFaultOperationException(ex.getMessage());\r
+    } catch (Exception e) {\r
+      logger.error("Error occurred while parsing alarm event notification");\r
+      throw new InvalidFaultOperationException(e.getMessage());\r
+    }\r
+\r
+    return dmAlarmParameters;\r
+  }\r
+\r
+  public PnfRegEventFields parseNotificationParams(List<ParameterDTO> parameters) {\r
+    InformEventData feild = new InformEventData();\r
+    try {\r
+      for (ParameterDTO parameter : parameters) {\r
+\r
+        if (isAlarmEvent(parameter.getParamName())) {\r
+          continue;\r
+        }\r
+\r
+        feild.parse(parameter, parameter.getParamName());\r
+      }\r
+    } catch (Exception e) {\r
+      logger.error("Error occurred while parsing alarm event notification");\r
+    }\r
+\r
+    return feild.getFeilds();\r
+  }\r
+\r
+  public static boolean isAlarmEvent(String str) {\r
+    return (str.contains(".FaultMgmt.ExpeditedEvent.")\r
+        || str.startsWith("InternetGatewayDevice.X_0005B9_FaultStatus"));\r
+  }\r
+}\r