--- /dev/null
+/*\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