2  * ============LICENSE_START=======================================================
 
   3  * ONAP : ccsdk features
 
   4  * ================================================================================
 
   5  * Copyright (C) 2019 highstreet technologies GmbH Intellectual Property.
 
   7  * ================================================================================
 
   8  * Licensed under the Apache License, Version 2.0 (the "License");
 
   9  * you may not use this file except in compliance with the License.
 
  10  * You may obtain a copy of the License at
 
  12  *     http://www.apache.org/licenses/LICENSE-2.0
 
  14  * Unless required by applicable law or agreed to in writing, software
 
  15  * distributed under the License is distributed on an "AS IS" BASIS,
 
  16  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 
  17  * See the License for the specific language governing permissions and
 
  18  * limitations under the License.
 
  19  * ============LICENSE_END=========================================================
 
  22 package org.onap.ccsdk.features.sdnr.wt.dataprovider.database.elasticsearch.data.entity;
 
  24 import java.util.regex.Matcher;
 
  25 import java.util.regex.Pattern;
 
  26 import javax.annotation.Nonnull;
 
  27 import org.onap.ccsdk.features.sdnr.wt.dataprovider.database.sqldb.data.entity.DatabaseIdGenerator;
 
  28 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.data.provider.rev201110.Fault;
 
  29 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.data.provider.rev201110.FaultcurrentEntity;
 
  30 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.data.provider.rev201110.SeverityType;
 
  32 public class FaultEntityManager {
 
  35      * The leading indication for notification or events that are not in the currentProblem data of the ONF Coremodel
 
  37     private static final String NOCURRENTPROBLEMINDICATION = "#";
 
  40      * Specific problems are not moving into current problem list
 
  42      * @param problemName to be verified
 
  43      * @return true if problem is current
 
  45     public static boolean isManagedAsCurrentProblem(String problemName) {
 
  46         return !problemName.startsWith(NOCURRENTPROBLEMINDICATION);
 
  49     public static boolean isManagedAsCurrentProblem(Fault problem) {
 
  50         return isManagedAsCurrentProblem(problem.getProblem());
 
  54      * Specific problems are not moving into current problem list
 
  56      * @param fault to be verified
 
  57      * @return true if cleared indication
 
  59     public static boolean isNoAlarmIndication(@Nonnull Fault fault) {
 
  60         return SeverityType.NonAlarmed.equals(fault.getSeverity());
 
  64      * Create a specific ES id for the current log.
 
  66      * @return a string with the generated ES Id
 
  68     public static String genSpecificEsId(String nodeName, String objectId, String problemName) {
 
  70         String uuId = DatabaseIdGenerator.extractUuid(objectId);
 
  72         StringBuffer strBuf = new StringBuffer();
 
  73         strBuf.append(nodeName);
 
  77         strBuf.append(problemName);
 
  78         return strBuf.toString();
 
  84      * @param fault used to create uuid for faultcurrent
 
  85      * @return String with Id
 
  87     public static String genSpecificEsId(FaultcurrentEntity fault) {
 
  88         return genSpecificEsId(fault.getNodeId(), fault.getObjectId(), fault.getProblem());