aboutsummaryrefslogtreecommitdiffstats
path: root/sdnr/wt/devicemanager-onap/onf14/provider/src/main
diff options
context:
space:
mode:
authorRavi Pendurty <ravi.pendurty@highstreet-technologies.com>2023-10-20 15:03:52 +0530
committerRavi Pendurty <ravi.pendurty@highstreet-technologies.com>2023-11-02 04:21:25 +0000
commit2286feed554a5588ed0a29e658e4dbb47d1a0cd9 (patch)
tree052a1303f83f0cbbc77829af82c960cb729da184 /sdnr/wt/devicemanager-onap/onf14/provider/src/main
parent85dafe60643bc766f60b5a3b5e832b48456d00b0 (diff)
Multiple YANG revision support
Refactoring Issue-ID: CCSDK-3949 Change-Id: I6f2b9a93d64219bf2c2c9141898aef6193e50f8a Signed-off-by: Ravi Pendurty <ravi.pendurty@highstreet-technologies.com>
Diffstat (limited to 'sdnr/wt/devicemanager-onap/onf14/provider/src/main')
-rw-r--r--sdnr/wt/devicemanager-onap/onf14/provider/src/main/java/org/onap/ccsdk/features/sdnr/wt/devicemanager/onf14/dom/impl/Onf14DomNetworkElement.java24
-rw-r--r--sdnr/wt/devicemanager-onap/onf14/provider/src/main/java/org/onap/ccsdk/features/sdnr/wt/devicemanager/onf14/dom/impl/Onf14DomNetworkElementFactory.java24
-rw-r--r--sdnr/wt/devicemanager-onap/onf14/provider/src/main/java/org/onap/ccsdk/features/sdnr/wt/devicemanager/onf14/dom/impl/dataprovider/Onf14DomToInternalDataModel.java78
-rw-r--r--sdnr/wt/devicemanager-onap/onf14/provider/src/main/java/org/onap/ccsdk/features/sdnr/wt/devicemanager/onf14/dom/impl/equipment/Onf14DomEquipmentManager.java33
-rw-r--r--sdnr/wt/devicemanager-onap/onf14/provider/src/main/java/org/onap/ccsdk/features/sdnr/wt/devicemanager/onf14/dom/impl/interfaces/Onf14DomInterfacePacManager.java421
-rw-r--r--sdnr/wt/devicemanager-onap/onf14/provider/src/main/java/org/onap/ccsdk/features/sdnr/wt/devicemanager/onf14/dom/impl/interfaces/Onf14Interfaces.java49
-rw-r--r--sdnr/wt/devicemanager-onap/onf14/provider/src/main/java/org/onap/ccsdk/features/sdnr/wt/devicemanager/onf14/dom/impl/interfaces/TechnologySpecific.java27
-rw-r--r--sdnr/wt/devicemanager-onap/onf14/provider/src/main/java/org/onap/ccsdk/features/sdnr/wt/devicemanager/onf14/dom/impl/notifications/Onf14DomAirInterfaceNotificationListener.java (renamed from sdnr/wt/devicemanager-onap/onf14/provider/src/main/java/org/onap/ccsdk/features/sdnr/wt/devicemanager/onf14/dom/notifications/Onf14DomAirInterfaceNotificationListener.java)4
-rw-r--r--sdnr/wt/devicemanager-onap/onf14/provider/src/main/java/org/onap/ccsdk/features/sdnr/wt/devicemanager/onf14/dom/impl/notifications/Onf14DomAlarmsNotificationListener.java69
-rw-r--r--sdnr/wt/devicemanager-onap/onf14/provider/src/main/java/org/onap/ccsdk/features/sdnr/wt/devicemanager/onf14/dom/impl/notifications/Onf14DomEthernetContainerNotificationListener.java (renamed from sdnr/wt/devicemanager-onap/onf14/provider/src/main/java/org/onap/ccsdk/features/sdnr/wt/devicemanager/onf14/dom/notifications/Onf14DomEthernetContainerNotificationListener.java)4
-rw-r--r--sdnr/wt/devicemanager-onap/onf14/provider/src/main/java/org/onap/ccsdk/features/sdnr/wt/devicemanager/onf14/dom/impl/notifications/Onf14DomWireInterfaceNotificationListener.java (renamed from sdnr/wt/devicemanager-onap/onf14/provider/src/main/java/org/onap/ccsdk/features/sdnr/wt/devicemanager/onf14/dom/notifications/Onf14DomWireInterfaceNotificationListener.java)4
-rw-r--r--sdnr/wt/devicemanager-onap/onf14/provider/src/main/java/org/onap/ccsdk/features/sdnr/wt/devicemanager/onf14/dom/impl/pm/PerformanceDataAirInterface.java2
-rw-r--r--sdnr/wt/devicemanager-onap/onf14/provider/src/main/java/org/onap/ccsdk/features/sdnr/wt/devicemanager/onf14/dom/impl/qnames/DevicemanagerQNames.java66
-rw-r--r--sdnr/wt/devicemanager-onap/onf14/provider/src/main/java/org/onap/ccsdk/features/sdnr/wt/devicemanager/onf14/dom/impl/qnames/Onf14DevicemanagerQNames.java (renamed from sdnr/wt/devicemanager-onap/onf14/provider/src/main/java/org/onap/ccsdk/features/sdnr/wt/devicemanager/onf14/dom/impl/util/Onf14DevicemanagerQNames.java)59
-rw-r--r--sdnr/wt/devicemanager-onap/onf14/provider/src/main/java/org/onap/ccsdk/features/sdnr/wt/devicemanager/onf14/dom/impl/util/Onf14DMDOMUtility.java112
-rw-r--r--sdnr/wt/devicemanager-onap/onf14/provider/src/main/java/org/onap/ccsdk/features/sdnr/wt/devicemanager/onf14/dom/impl/yangspecs/AirInterface20.java193
-rw-r--r--sdnr/wt/devicemanager-onap/onf14/provider/src/main/java/org/onap/ccsdk/features/sdnr/wt/devicemanager/onf14/dom/impl/yangspecs/Alarms10.java195
-rw-r--r--sdnr/wt/devicemanager-onap/onf14/provider/src/main/java/org/onap/ccsdk/features/sdnr/wt/devicemanager/onf14/dom/impl/yangspecs/CoreModel14.java190
-rw-r--r--sdnr/wt/devicemanager-onap/onf14/provider/src/main/java/org/onap/ccsdk/features/sdnr/wt/devicemanager/onf14/dom/impl/yangspecs/EthernetContainer20.java145
-rw-r--r--sdnr/wt/devicemanager-onap/onf14/provider/src/main/java/org/onap/ccsdk/features/sdnr/wt/devicemanager/onf14/dom/impl/yangspecs/WireInterface20.java142
-rw-r--r--sdnr/wt/devicemanager-onap/onf14/provider/src/main/java/org/onap/ccsdk/features/sdnr/wt/devicemanager/onf14/dom/impl/yangspecs/YangModule.java51
21 files changed, 1421 insertions, 471 deletions
diff --git a/sdnr/wt/devicemanager-onap/onf14/provider/src/main/java/org/onap/ccsdk/features/sdnr/wt/devicemanager/onf14/dom/impl/Onf14DomNetworkElement.java b/sdnr/wt/devicemanager-onap/onf14/provider/src/main/java/org/onap/ccsdk/features/sdnr/wt/devicemanager/onf14/dom/impl/Onf14DomNetworkElement.java
index 6ff43bd69..4431865e2 100644
--- a/sdnr/wt/devicemanager-onap/onf14/provider/src/main/java/org/onap/ccsdk/features/sdnr/wt/devicemanager/onf14/dom/impl/Onf14DomNetworkElement.java
+++ b/sdnr/wt/devicemanager-onap/onf14/provider/src/main/java/org/onap/ccsdk/features/sdnr/wt/devicemanager/onf14/dom/impl/Onf14DomNetworkElement.java
@@ -30,7 +30,8 @@ import org.onap.ccsdk.features.sdnr.wt.devicemanager.onf14.dom.impl.dataprovider
import org.onap.ccsdk.features.sdnr.wt.devicemanager.onf14.dom.impl.equipment.Onf14DomEquipmentManager;
import org.onap.ccsdk.features.sdnr.wt.devicemanager.onf14.dom.impl.interfaces.Onf14DomInterfacePacManager;
import org.onap.ccsdk.features.sdnr.wt.devicemanager.onf14.dom.impl.interfaces.TechnologySpecificPacKeys;
-import org.onap.ccsdk.features.sdnr.wt.devicemanager.onf14.dom.impl.util.Onf14DevicemanagerQNames;
+import org.onap.ccsdk.features.sdnr.wt.devicemanager.onf14.dom.impl.qnames.Onf14DevicemanagerQNames;
+import org.onap.ccsdk.features.sdnr.wt.devicemanager.onf14.dom.impl.yangspecs.CoreModel14;
import org.onap.ccsdk.features.sdnr.wt.devicemanager.service.DeviceManagerServiceProvider;
import org.onap.ccsdk.features.sdnr.wt.devicemanager.service.FaultService;
import org.onap.ccsdk.features.sdnr.wt.devicemanager.service.NotificationService;
@@ -45,7 +46,6 @@ import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.netmod.notification.r
import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.data.provider.rev201110.NetworkElementConnectionBuilder;
import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.data.provider.rev201110.NetworkElementDeviceType;
import org.opendaylight.yang.gen.v1.urn.tbd.params.xml.ns.yang.network.topology.rev131021.NodeId;
-import org.opendaylight.yangtools.yang.data.api.YangInstanceIdentifier;
import org.opendaylight.yangtools.yang.data.api.schema.NormalizedNode;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
@@ -58,10 +58,6 @@ public class Onf14DomNetworkElement implements NetworkElement, PerformanceDataPr
private static final Logger log = LoggerFactory.getLogger(Onf14DomNetworkElement.class);
- protected static final YangInstanceIdentifier TOPLEVELEQUIPMENT_IID =
- YangInstanceIdentifier.builder().node(Onf14DevicemanagerQNames.CORE_MODEL_CONTROL_CONSTRUCT_CONTAINER)
- .node(Onf14DevicemanagerQNames.CORE_MODEL_CC_TOP_LEVEL_EQPT).build();
-
private final @NonNull Object pmLock = new Object();
protected @Nullable TechnologySpecificPacKeys pmLp = null;
protected @Nullable Iterator<TechnologySpecificPacKeys> interfaceListIterator = null;
@@ -75,21 +71,20 @@ public class Onf14DomNetworkElement implements NetworkElement, PerformanceDataPr
private final @NonNull Onf14DomEquipmentManager equipmentManager;
private final @NonNull Onf14DomInterfacePacManager interfacePacManager;
- private final @NonNull String namespaceRevision;
+ private final @NonNull CoreModel14 onf14CoreModelQNames;
public Onf14DomNetworkElement(NetconfDomAccessor netconfDomAccessor, DeviceManagerServiceProvider serviceProvider,
- String namespaceRevision) {
+ CoreModel14 onf14CoreModelQNames) {
log.info("Create {}", Onf14DomNetworkElement.class.getSimpleName());
this.netconfDomAccessor = netconfDomAccessor;
+ this.onf14CoreModelQNames = onf14CoreModelQNames;
this.databaseService = serviceProvider.getDataProvider();
this.notificationService = serviceProvider.getNotificationService();
this.faultService = serviceProvider.getFaultService();
this.performanceManager = serviceProvider.getPerformanceManagerService();
- this.namespaceRevision = namespaceRevision;
this.onf14Mapper = new Onf14DomToInternalDataModel();
- this.equipmentManager = new Onf14DomEquipmentManager(netconfDomAccessor, databaseService, onf14Mapper);
- this.interfacePacManager = new Onf14DomInterfacePacManager(netconfDomAccessor, serviceProvider);
-
+ this.equipmentManager = new Onf14DomEquipmentManager(netconfDomAccessor, databaseService, onf14Mapper, onf14CoreModelQNames);
+ this.interfacePacManager = new Onf14DomInterfacePacManager(netconfDomAccessor, serviceProvider, onf14CoreModelQNames);
}
/**
@@ -113,7 +108,7 @@ public class Onf14DomNetworkElement implements NetworkElement, PerformanceDataPr
*/
public void setCoreModel() {
NetworkElementConnectionBuilder eb = new NetworkElementConnectionBuilder();
- eb.setCoreModelCapability(namespaceRevision);
+ eb.setCoreModelCapability(onf14CoreModelQNames.getRevision());
databaseService.updateNetworkConnection22(eb.build(), netconfDomAccessor.getNodeId().getValue());
}
@@ -173,7 +168,8 @@ public class Onf14DomNetworkElement implements NetworkElement, PerformanceDataPr
}
private Optional<NormalizedNode> readTopLevelEquipment(NetconfDomAccessor netconfDomAccessor) {
- return netconfDomAccessor.readDataNode(LogicalDatastoreType.CONFIGURATION, TOPLEVELEQUIPMENT_IID);
+ log.debug("Reading Top level equipment data");
+ return netconfDomAccessor.readDataNode(LogicalDatastoreType.CONFIGURATION, onf14CoreModelQNames.getTopLevelEquipment_IId());
}
public Object getPmLock() {
diff --git a/sdnr/wt/devicemanager-onap/onf14/provider/src/main/java/org/onap/ccsdk/features/sdnr/wt/devicemanager/onf14/dom/impl/Onf14DomNetworkElementFactory.java b/sdnr/wt/devicemanager-onap/onf14/provider/src/main/java/org/onap/ccsdk/features/sdnr/wt/devicemanager/onf14/dom/impl/Onf14DomNetworkElementFactory.java
index 0c84cdf1b..eaef478d6 100644
--- a/sdnr/wt/devicemanager-onap/onf14/provider/src/main/java/org/onap/ccsdk/features/sdnr/wt/devicemanager/onf14/dom/impl/Onf14DomNetworkElementFactory.java
+++ b/sdnr/wt/devicemanager-onap/onf14/provider/src/main/java/org/onap/ccsdk/features/sdnr/wt/devicemanager/onf14/dom/impl/Onf14DomNetworkElementFactory.java
@@ -21,9 +21,8 @@ package org.onap.ccsdk.features.sdnr.wt.devicemanager.onf14.dom.impl;
import java.util.Optional;
import org.onap.ccsdk.features.sdnr.wt.devicemanager.ne.factory.NetworkElementFactory;
import org.onap.ccsdk.features.sdnr.wt.devicemanager.ne.service.NetworkElement;
-import org.onap.ccsdk.features.sdnr.wt.devicemanager.onf14.dom.impl.util.Onf14DevicemanagerQNames;
+import org.onap.ccsdk.features.sdnr.wt.devicemanager.onf14.dom.impl.yangspecs.CoreModel14;
import org.onap.ccsdk.features.sdnr.wt.devicemanager.service.DeviceManagerServiceProvider;
-import org.onap.ccsdk.features.sdnr.wt.netconfnodestateservice.Capabilities;
import org.onap.ccsdk.features.sdnr.wt.netconfnodestateservice.NetconfAccessor;
import org.onap.ccsdk.features.sdnr.wt.netconfnodestateservice.NetconfDomAccessor;
import org.slf4j.Logger;
@@ -31,24 +30,21 @@ import org.slf4j.LoggerFactory;
public class Onf14DomNetworkElementFactory implements NetworkElementFactory {
- private static final Logger log = LoggerFactory.getLogger(Onf14DomNetworkElementFactory.class);
+ private static final Logger LOG = LoggerFactory.getLogger(Onf14DomNetworkElementFactory.class);
@Override
public Optional<NetworkElement> create(NetconfAccessor accessor, DeviceManagerServiceProvider serviceProvider) {
Optional<NetworkElement> ne = Optional.empty();
- Capabilities capabilities = accessor.getCapabilites();
- if (capabilities.isSupportingNamespace(Onf14DevicemanagerQNames.CORE_MODEL_CONTROL_CONSTRUCT_CONTAINER)) {
- String namespaceRevision = capabilities
- .getRevisionForNamespace(Onf14DevicemanagerQNames.CORE_MODEL_CONTROL_CONSTRUCT_CONTAINER);
-
- Optional<NetconfDomAccessor> domAccessor = accessor.getNetconfDomAccessor();
- if (domAccessor.isPresent()) {
- ne = Optional.of(new Onf14DomNetworkElement(domAccessor.get(), serviceProvider, namespaceRevision));
+ Optional<NetconfDomAccessor> domAccessor = accessor.getNetconfDomAccessor();
+ if (domAccessor.isPresent()) {
+ Optional<CoreModel14> onf14CoreModelQnames = CoreModel14.getModule(domAccessor.get());
+ if (onf14CoreModelQnames.isPresent()) {
+ ne = Optional
+ .of(new Onf14DomNetworkElement(domAccessor.get(), serviceProvider, onf14CoreModelQnames.get()));
}
-
- log.info("Create device:{}", ne.isPresent() ? ne.get().getClass().getSimpleName() : "not");
- }
+ }
+ LOG.info("Create device:{}", ne.isPresent() ? ne.get().getClass().getSimpleName() : "not");
return ne;
}
diff --git a/sdnr/wt/devicemanager-onap/onf14/provider/src/main/java/org/onap/ccsdk/features/sdnr/wt/devicemanager/onf14/dom/impl/dataprovider/Onf14DomToInternalDataModel.java b/sdnr/wt/devicemanager-onap/onf14/provider/src/main/java/org/onap/ccsdk/features/sdnr/wt/devicemanager/onf14/dom/impl/dataprovider/Onf14DomToInternalDataModel.java
index af817fe18..ed7f7276e 100644
--- a/sdnr/wt/devicemanager-onap/onf14/provider/src/main/java/org/onap/ccsdk/features/sdnr/wt/devicemanager/onf14/dom/impl/dataprovider/Onf14DomToInternalDataModel.java
+++ b/sdnr/wt/devicemanager-onap/onf14/provider/src/main/java/org/onap/ccsdk/features/sdnr/wt/devicemanager/onf14/dom/impl/dataprovider/Onf14DomToInternalDataModel.java
@@ -5,7 +5,7 @@ import java.util.HashSet;
import java.util.Objects;
import java.util.Set;
import org.onap.ccsdk.features.sdnr.wt.devicemanager.onf14.dom.impl.util.Onf14DMDOMUtility;
-import org.onap.ccsdk.features.sdnr.wt.devicemanager.onf14.dom.impl.util.Onf14DevicemanagerQNames;
+import org.onap.ccsdk.features.sdnr.wt.devicemanager.onf14.dom.impl.yangspecs.CoreModel14;
import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.data.provider.rev201110.Inventory;
import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.data.provider.rev201110.InventoryBuilder;
import org.opendaylight.yang.gen.v1.urn.tbd.params.xml.ns.yang.network.topology.rev131021.NodeId;
@@ -20,29 +20,29 @@ import org.slf4j.LoggerFactory;
public class Onf14DomToInternalDataModel {
private static final Logger LOG = LoggerFactory.getLogger(Onf14DomToInternalDataModel.class);
- public Inventory getInternalEquipment(NodeId nodeId, MapEntryNode currentEq, MapEntryNode parentEq,
- long treeLevel) {
+ public Inventory getInternalEquipment(NodeId nodeId, MapEntryNode currentEq, MapEntryNode parentEq, long treeLevel,
+ CoreModel14 qNames) {
Objects.requireNonNull(nodeId);
Objects.requireNonNull(currentEq);
InventoryBuilder inventoryBuilder = new InventoryBuilder();
- String parentUuid = parentEq != null ? Onf14DMDOMUtility.getUuidFromEquipment(parentEq) : "None";
+ String parentUuid =
+ parentEq != null ? Onf14DMDOMUtility.getUuidFromEquipment(parentEq, qNames.getQName("uuid")) : "None";
// General
inventoryBuilder.setNodeId(nodeId.getValue());
inventoryBuilder.setTreeLevel(Uint32.valueOf(treeLevel));
- inventoryBuilder.setUuid(Onf14DMDOMUtility.getUuidFromEquipment(currentEq));
+ inventoryBuilder.setUuid(Onf14DMDOMUtility.getUuidFromEquipment(currentEq, qNames.getQName("uuid")));
inventoryBuilder.setParentUuid(parentUuid);
Set<String> containedHolderKeyList = new HashSet<>();
- MapNode containedHolderMap = (MapNode) currentEq
- .childByArg(new NodeIdentifier(Onf14DevicemanagerQNames.CORE_MODEL_CC_EQPT_CONTAINED_HOLDER));
+ MapNode containedHolderMap =
+ (MapNode) currentEq.childByArg(new NodeIdentifier(qNames.getQName("contained-holder")));
if (containedHolderMap != null) {
Collection<MapEntryNode> containedHolderCollection = containedHolderMap.body();
for (MapEntryNode holder : containedHolderCollection) {
- String occupyingFru = Onf14DMDOMUtility.getLeafValue(holder,
- Onf14DevicemanagerQNames.CORE_MODEL_CC_EQPT_OCCUPYING_FRU);
+ String occupyingFru = Onf14DMDOMUtility.getLeafValue(holder, qNames.getQName("occupying-fru"));
if (occupyingFru != null) {
containedHolderKeyList.add(occupyingFru);
@@ -52,73 +52,73 @@ public class Onf14DomToInternalDataModel {
inventoryBuilder.setContainedHolder(containedHolderKeyList);
// actual-equipment
- ContainerNode actualEquipment = (ContainerNode) currentEq
- .childByArg(new NodeIdentifier(Onf14DevicemanagerQNames.CORE_MODEL_CC_EQPT_ACTUAL_EQUIPMENT));
+ ContainerNode actualEquipment =
+ (ContainerNode) currentEq.childByArg(new NodeIdentifier(qNames.getQName("actual-equipment")));
if (actualEquipment != null) {
ContainerNode manThing = (ContainerNode) actualEquipment
- .childByArg(new NodeIdentifier(Onf14DevicemanagerQNames.CORE_MODEL_CC_EQPT_MANUFACTURED_THING));
+ .childByArg(new NodeIdentifier(qNames.getQName("manufactured-thing")));
if (manThing != null) {
// Manufacturer properties
ContainerNode props = (ContainerNode) manThing
- .childByArg(new NodeIdentifier(Onf14DevicemanagerQNames.CORE_MODEL_CC_EQPT_MANUFACTURER_PROPS));
+ .childByArg(new NodeIdentifier(qNames.getQName("manufacturer-properties")));
if (props != null) {
- inventoryBuilder.setManufacturerName(Onf14DMDOMUtility.getLeafValue(props,
- Onf14DevicemanagerQNames.CORE_MODEL_CC_EQPT_MANUFACTURER_NAME));
+ inventoryBuilder.setManufacturerName(
+ Onf14DMDOMUtility.getLeafValue(props, qNames.getQName("manufacturer-name")));
- inventoryBuilder.setManufacturerIdentifier(Onf14DMDOMUtility.getLeafValue(props,
- Onf14DevicemanagerQNames.CORE_MODEL_CC_EQPT_MANUFACTURER_ID));
+ inventoryBuilder.setManufacturerIdentifier(
+ Onf14DMDOMUtility.getLeafValue(props, qNames.getQName("manufacturer-identifier")));
} else {
LOG.debug("manufacturer-properties is not present in Equipment with uuid={}",
- Onf14DMDOMUtility.getUuidFromEquipment(currentEq));
+ Onf14DMDOMUtility.getUuidFromEquipment(currentEq, qNames.getQName("uuid")));
}
// Equipment instance
- ContainerNode equipmentInstance = (ContainerNode) manThing.childByArg(
- new NodeIdentifier(Onf14DevicemanagerQNames.CORE_MODEL_CC_EQPT_ACTUAL_EQPT_EQPT_INSTANCE));
+ ContainerNode equipmentInstance =
+ (ContainerNode) manThing.childByArg(new NodeIdentifier(qNames.getQName("equipment-instance")));
if (equipmentInstance != null) {
- inventoryBuilder.setSerial(Onf14DMDOMUtility.getLeafValue(equipmentInstance,
- Onf14DevicemanagerQNames.CORE_MODEL_CC_EQPT_ACTUAL_EQPT_EQPT_INSTANCE_SERIAL_NUM));
+ inventoryBuilder.setSerial(
+ Onf14DMDOMUtility.getLeafValue(equipmentInstance, qNames.getQName("serial-number")));
- inventoryBuilder.setDate(Onf14DMDOMUtility.getLeafValue(equipmentInstance,
- Onf14DevicemanagerQNames.CORE_MODEL_CC_EQPT_ACTUAL_EQPT_EQPT_INSTANCE_MANUFACTURED_DATE));
+ inventoryBuilder.setDate(
+ Onf14DMDOMUtility.getLeafValue(equipmentInstance, qNames.getQName("manufactured-date")));
} else {
LOG.debug("equipment-instance is not present in Equipment with uuid={}",
- Onf14DMDOMUtility.getUuidFromEquipment(currentEq));
+ Onf14DMDOMUtility.getUuidFromEquipment(currentEq, qNames.getQName("uuid")));
}
// Equipment type
- ContainerNode equipmentType = (ContainerNode) manThing.childByArg(
- new NodeIdentifier(Onf14DevicemanagerQNames.CORE_MODEL_CC_EQPT_ACTUAL_EQPT_EQPT_TYPE));
+ ContainerNode equipmentType =
+ (ContainerNode) manThing.childByArg(new NodeIdentifier(qNames.getQName("equipment-type")));
if (equipmentType != null) {
- inventoryBuilder.setVersion(Onf14DMDOMUtility.getLeafValue(equipmentType,
- Onf14DevicemanagerQNames.CORE_MODEL_CC_EQPT_ACTUAL_EQPT_EQPT_TYPE_VERSION));
+ inventoryBuilder
+ .setVersion(Onf14DMDOMUtility.getLeafValue(equipmentType, qNames.getQName("version")));
- inventoryBuilder.setDescription(Onf14DMDOMUtility.getLeafValue(equipmentType,
- Onf14DevicemanagerQNames.CORE_MODEL_CC_EQPT_ACTUAL_EQPT_EQPT_TYPE_DESCRIPTION));
+ inventoryBuilder.setDescription(
+ Onf14DMDOMUtility.getLeafValue(equipmentType, qNames.getQName("description")));
- inventoryBuilder.setPartTypeId(Onf14DMDOMUtility.getLeafValue(equipmentType,
- Onf14DevicemanagerQNames.CORE_MODEL_CC_EQPT_ACTUAL_EQPT_EQPT_TYPE_PART_TYPE_ID));
+ inventoryBuilder.setPartTypeId(
+ Onf14DMDOMUtility.getLeafValue(equipmentType, qNames.getQName("part-type-identifier")));
inventoryBuilder.setModelIdentifier(Onf14DMDOMUtility.getLeafValue(equipmentType,
- Onf14DevicemanagerQNames.CORE_MODEL_CC_EQPT_ACTUAL_EQPT_EQPT_TYPE_MODEL_ID));
+ qNames.getQName("model-identifier")));
- inventoryBuilder.setTypeName(Onf14DMDOMUtility.getLeafValue(equipmentType,
- Onf14DevicemanagerQNames.CORE_MODEL_CC_EQPT_ACTUAL_EQPT_EQPT_TYPE_TYPE_NAME));
+ inventoryBuilder
+ .setTypeName(Onf14DMDOMUtility.getLeafValue(equipmentType, qNames.getQName("type-name")));
} else {
LOG.debug("equipment-type is not present in Equipment with uuid={}",
- Onf14DMDOMUtility.getUuidFromEquipment(currentEq));
+ Onf14DMDOMUtility.getUuidFromEquipment(currentEq, qNames.getQName("uuid")));
}
} else {
LOG.debug("manufactured-thing is not present in Equipment with uuid={}",
- Onf14DMDOMUtility.getUuidFromEquipment(currentEq));
+ Onf14DMDOMUtility.getUuidFromEquipment(currentEq, qNames.getQName("uuid")));
}
} else {
LOG.debug("actual-equipment is not present in Equipment with uuid={}",
- Onf14DMDOMUtility.getUuidFromEquipment(currentEq));
+ Onf14DMDOMUtility.getUuidFromEquipment(currentEq, qNames.getQName("uuid")));
}
return inventoryBuilder.build();
diff --git a/sdnr/wt/devicemanager-onap/onf14/provider/src/main/java/org/onap/ccsdk/features/sdnr/wt/devicemanager/onf14/dom/impl/equipment/Onf14DomEquipmentManager.java b/sdnr/wt/devicemanager-onap/onf14/provider/src/main/java/org/onap/ccsdk/features/sdnr/wt/devicemanager/onf14/dom/impl/equipment/Onf14DomEquipmentManager.java
index 5c7101199..6f7b24a19 100644
--- a/sdnr/wt/devicemanager-onap/onf14/provider/src/main/java/org/onap/ccsdk/features/sdnr/wt/devicemanager/onf14/dom/impl/equipment/Onf14DomEquipmentManager.java
+++ b/sdnr/wt/devicemanager-onap/onf14/provider/src/main/java/org/onap/ccsdk/features/sdnr/wt/devicemanager/onf14/dom/impl/equipment/Onf14DomEquipmentManager.java
@@ -30,7 +30,7 @@ import java.util.Optional;
import org.onap.ccsdk.features.sdnr.wt.dataprovider.model.DataProvider;
import org.onap.ccsdk.features.sdnr.wt.devicemanager.onf14.dom.impl.dataprovider.Onf14DomToInternalDataModel;
import org.onap.ccsdk.features.sdnr.wt.devicemanager.onf14.dom.impl.util.Onf14DMDOMUtility;
-import org.onap.ccsdk.features.sdnr.wt.devicemanager.onf14.dom.impl.util.Onf14DevicemanagerQNames;
+import org.onap.ccsdk.features.sdnr.wt.devicemanager.onf14.dom.impl.yangspecs.CoreModel14;
import org.onap.ccsdk.features.sdnr.wt.netconfnodestateservice.NetconfDomAccessor;
import org.opendaylight.mdsal.common.api.LogicalDatastoreType;
import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.data.provider.rev201110.Inventory;
@@ -54,14 +54,15 @@ public class Onf14DomEquipmentManager {
private final DataProvider databaseService;
private final Onf14DomToInternalDataModel onf14Mapper;
private final List<String> equipmentUuidList;
+ private final CoreModel14 qNames;
public Onf14DomEquipmentManager(NetconfDomAccessor netconfDomAccessor, DataProvider databaseService,
- Onf14DomToInternalDataModel onf14Mapper) {
+ Onf14DomToInternalDataModel onf14Mapper, CoreModel14 qNames) {
super();
this.netconfDomAccessor = Objects.requireNonNull(netconfDomAccessor);
this.databaseService = Objects.requireNonNull(databaseService);
this.onf14Mapper = Objects.requireNonNull(onf14Mapper);
-
+ this.qNames = qNames;
this.equipmentUuidList = new ArrayList<>();
}
@@ -114,11 +115,10 @@ public class Onf14DomEquipmentManager {
log.debug("DBRead Get equipment from mountpoint {} for uuid {}", accessData.getNodeId().getValue(),
equipmentUuid);
- InstanceIdentifierBuilder equipmentIIDBuilder = YangInstanceIdentifier.builder()
- .node(Onf14DevicemanagerQNames.CORE_MODEL_CONTROL_CONSTRUCT_CONTAINER)
- .node(Onf14DevicemanagerQNames.CORE_MODEL_CC_EQPT)
- .nodeWithKey(Onf14DevicemanagerQNames.CORE_MODEL_CC_EQPT,
- QName.create(Onf14DevicemanagerQNames.CORE_MODEL_CC_EQPT, "uuid").intern(), equipmentUuid);
+ InstanceIdentifierBuilder equipmentIIDBuilder =
+ YangInstanceIdentifier.builder().node(qNames.getQName("control-construct"))
+ .node(qNames.getQName("equipment")).nodeWithKey(qNames.getQName("equipment"),
+ QName.create(qNames.getQName("equipment"), "uuid").intern(), equipmentUuid);
return accessData.readDataNode(LogicalDatastoreType.CONFIGURATION, equipmentIIDBuilder.build());
}
@@ -128,32 +128,33 @@ public class Onf14DomEquipmentManager {
// if the Equipment UUID is already in the list, it was already processed
// needed for solving possible circular dependencies
- if (equipmentUuidList.contains(Onf14DMDOMUtility.getUuidFromEquipment(currentEq))) {
+ if (equipmentUuidList.contains(Onf14DMDOMUtility.getUuidFromEquipment(currentEq, qNames.getQName("uuid")))) {
log.debug("Not adding equipment with uuid {} because it was aleady added...",
- Onf14DMDOMUtility.getUuidFromEquipment(currentEq));
+ Onf14DMDOMUtility.getUuidFromEquipment(currentEq, qNames.getQName("uuid")));
return list;
}
// we add this to our internal list, such that we avoid circular dependencies
- equipmentUuidList.add(Onf14DMDOMUtility.getUuidFromEquipment(currentEq));
+ equipmentUuidList.add(Onf14DMDOMUtility.getUuidFromEquipment(currentEq, qNames.getQName("uuid")));
log.debug("Adding equipment with uuid {} to the database...",
- Onf14DMDOMUtility.getUuidFromEquipment(currentEq));
+ Onf14DMDOMUtility.getUuidFromEquipment(currentEq, qNames.getQName("uuid")));
// we add our current equipment to the database
- list.add(onf14Mapper.getInternalEquipment(netconfDomAccessor.getNodeId(), currentEq, parentEq, treeLevel));
+ list.add(onf14Mapper.getInternalEquipment(netconfDomAccessor.getNodeId(), currentEq, parentEq, treeLevel,
+ qNames));
// we iterate the kids of our current equipment and add them to the database
// recursively
// the actual reference is here:
// /core-model:control-construct/equipment/contained-holder/occupying-fru
- MapNode containedHolderMap = (MapNode) currentEq
- .childByArg(new NodeIdentifier(Onf14DevicemanagerQNames.CORE_MODEL_CC_EQPT_CONTAINED_HOLDER));
+ MapNode containedHolderMap =
+ (MapNode) currentEq.childByArg(new NodeIdentifier(qNames.getQName("contained-holder")));
if (containedHolderMap != null) {
Collection<MapEntryNode> containedHolderCollection = containedHolderMap.body();
for (MapEntryNode holder : containedHolderCollection) {
String occupyingFru = Onf14DMDOMUtility.getLeafValue(holder,
- Onf14DevicemanagerQNames.CORE_MODEL_CC_EQPT_OCCUPYING_FRU);
+ qNames.getQName("occupying-fru")/*Onf14DevicemanagerQNames.CORE_MODEL_CC_EQPT_OCCUPYING_FRU*/);
if (occupyingFru != null) {
Optional<NormalizedNode> childEq = readEquipmentInstance(netconfDomAccessor, occupyingFru);
diff --git a/sdnr/wt/devicemanager-onap/onf14/provider/src/main/java/org/onap/ccsdk/features/sdnr/wt/devicemanager/onf14/dom/impl/interfaces/Onf14DomInterfacePacManager.java b/sdnr/wt/devicemanager-onap/onf14/provider/src/main/java/org/onap/ccsdk/features/sdnr/wt/devicemanager/onf14/dom/impl/interfaces/Onf14DomInterfacePacManager.java
index 71f94dc26..d1914342f 100644
--- a/sdnr/wt/devicemanager-onap/onf14/provider/src/main/java/org/onap/ccsdk/features/sdnr/wt/devicemanager/onf14/dom/impl/interfaces/Onf14DomInterfacePacManager.java
+++ b/sdnr/wt/devicemanager-onap/onf14/provider/src/main/java/org/onap/ccsdk/features/sdnr/wt/devicemanager/onf14/dom/impl/interfaces/Onf14DomInterfacePacManager.java
@@ -21,35 +21,32 @@
*/
package org.onap.ccsdk.features.sdnr.wt.devicemanager.onf14.dom.impl.interfaces;
-import com.google.common.collect.Sets;
import java.util.ArrayList;
import java.util.Collection;
import java.util.List;
import java.util.Objects;
import java.util.Optional;
import org.eclipse.jdt.annotation.NonNull;
-import org.onap.ccsdk.features.sdnr.wt.devicemanager.onf14.dom.impl.dataprovider.InternalDataModelSeverity;
-import org.onap.ccsdk.features.sdnr.wt.devicemanager.onf14.dom.impl.pm.PerformanceDataAirInterface;
-import org.onap.ccsdk.features.sdnr.wt.devicemanager.onf14.dom.impl.util.Debug;
+import org.onap.ccsdk.features.sdnr.wt.devicemanager.onf14.dom.impl.notifications.Onf14DomAirInterfaceNotificationListener;
+import org.onap.ccsdk.features.sdnr.wt.devicemanager.onf14.dom.impl.notifications.Onf14DomAlarmsNotificationListener;
+import org.onap.ccsdk.features.sdnr.wt.devicemanager.onf14.dom.impl.notifications.Onf14DomEthernetContainerNotificationListener;
+import org.onap.ccsdk.features.sdnr.wt.devicemanager.onf14.dom.impl.notifications.Onf14DomWireInterfaceNotificationListener;
+import org.onap.ccsdk.features.sdnr.wt.devicemanager.onf14.dom.impl.qnames.Onf14DevicemanagerQNames;
import org.onap.ccsdk.features.sdnr.wt.devicemanager.onf14.dom.impl.util.Onf14DMDOMUtility;
-import org.onap.ccsdk.features.sdnr.wt.devicemanager.onf14.dom.impl.util.Onf14DevicemanagerQNames;
-import org.onap.ccsdk.features.sdnr.wt.devicemanager.onf14.dom.notifications.Onf14DomAirInterfaceNotificationListener;
-import org.onap.ccsdk.features.sdnr.wt.devicemanager.onf14.dom.notifications.Onf14DomEthernetContainerNotificationListener;
-import org.onap.ccsdk.features.sdnr.wt.devicemanager.onf14.dom.notifications.Onf14DomWireInterfaceNotificationListener;
+import org.onap.ccsdk.features.sdnr.wt.devicemanager.onf14.dom.impl.yangspecs.AirInterface20;
+import org.onap.ccsdk.features.sdnr.wt.devicemanager.onf14.dom.impl.yangspecs.Alarms10;
+import org.onap.ccsdk.features.sdnr.wt.devicemanager.onf14.dom.impl.yangspecs.CoreModel14;
+import org.onap.ccsdk.features.sdnr.wt.devicemanager.onf14.dom.impl.yangspecs.EthernetContainer20;
+import org.onap.ccsdk.features.sdnr.wt.devicemanager.onf14.dom.impl.yangspecs.WireInterface20;
import org.onap.ccsdk.features.sdnr.wt.devicemanager.service.DeviceManagerServiceProvider;
import org.onap.ccsdk.features.sdnr.wt.devicemanager.service.FaultService;
import org.onap.ccsdk.features.sdnr.wt.devicemanager.types.FaultData;
import org.onap.ccsdk.features.sdnr.wt.devicemanager.types.PerformanceDataLtp;
import org.onap.ccsdk.features.sdnr.wt.netconfnodestateservice.NetconfDomAccessor;
import org.opendaylight.mdsal.common.api.LogicalDatastoreType;
-import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.yang.types.rev130715.DateAndTime;
import org.opendaylight.yangtools.yang.common.QName;
import org.opendaylight.yangtools.yang.data.api.YangInstanceIdentifier;
-import org.opendaylight.yangtools.yang.data.api.YangInstanceIdentifier.AugmentationIdentifier;
-import org.opendaylight.yangtools.yang.data.api.YangInstanceIdentifier.InstanceIdentifierBuilder;
import org.opendaylight.yangtools.yang.data.api.YangInstanceIdentifier.NodeIdentifier;
-import org.opendaylight.yangtools.yang.data.api.schema.AugmentationNode;
-import org.opendaylight.yangtools.yang.data.api.schema.ContainerNode;
import org.opendaylight.yangtools.yang.data.api.schema.MapEntryNode;
import org.opendaylight.yangtools.yang.data.api.schema.MapNode;
import org.opendaylight.yangtools.yang.data.api.schema.NormalizedNode;
@@ -84,11 +81,11 @@ import org.slf4j.LoggerFactory;
public class Onf14DomInterfacePacManager {
- private static final Logger log = LoggerFactory.getLogger(Onf14DomInterfacePacManager.class);
+ private static final Logger LOG = LoggerFactory.getLogger(Onf14DomInterfacePacManager.class);
- private static final YangInstanceIdentifier LTP_IID =
- YangInstanceIdentifier.builder().node(Onf14DevicemanagerQNames.CORE_MODEL_CONTROL_CONSTRUCT_CONTAINER)
- .node(Onf14DevicemanagerQNames.CORE_MODEL_CC_LTP).build();
+ // private static final YangInstanceIdentifier LTP_IID =
+ // YangInstanceIdentifier.builder().node(Onf14DevicemanagerQNames.CORE_MODEL_CONTROL_CONSTRUCT_CONTAINER)
+ // .node(Onf14DevicemanagerQNames.CORE_MODEL_CC_LTP).build();
private final NetconfDomAccessor netconfDomAccessor;
private final @NonNull DeviceManagerServiceProvider serviceProvider;
@@ -108,15 +105,40 @@ public class Onf14DomInterfacePacManager {
@NonNull
private final Onf14DomWireInterfaceNotificationListener wireInterfaceNotificationListener;
+ // alarm-1-0 related alarms
+ private final Onf14DomAlarmsNotificationListener alarmNotifListener;
+
+ // Services and models
private final @NonNull FaultService faultService;
+ private final @NonNull CoreModel14 coreModel14;
+
+ private final Optional<Alarms10> alarms10;
+ private final Optional<AirInterface20> airInterface20;
+ private final Optional<EthernetContainer20> ethernetInterface20;
+ private final Optional<WireInterface20> wireInterface20;
+
+ private final Onf14Interfaces interfaces;
public Onf14DomInterfacePacManager(@NonNull NetconfDomAccessor netconfDomAccessor,
- @NonNull DeviceManagerServiceProvider serviceProvider) {
+ @NonNull DeviceManagerServiceProvider serviceProvider, CoreModel14 coreModel14) {
this.netconfDomAccessor = Objects.requireNonNull(netconfDomAccessor);
this.serviceProvider = Objects.requireNonNull(serviceProvider);
this.faultService = Objects.requireNonNull(serviceProvider.getFaultService());
-
+ this.interfaces = new Onf14Interfaces();
+
+ this.coreModel14 = coreModel14;
+ this.alarms10 = Alarms10.getModule(netconfDomAccessor, coreModel14);
+ this.airInterface20 = AirInterface20.getModule(netconfDomAccessor, coreModel14);
+ this.ethernetInterface20 = EthernetContainer20.getModule(netconfDomAccessor, coreModel14);
+ this.wireInterface20 = WireInterface20.getModule(netconfDomAccessor, coreModel14);
+
+ if (alarms10.isPresent()) {
+ this.alarmNotifListener =
+ new Onf14DomAlarmsNotificationListener(netconfDomAccessor, serviceProvider, alarms10.get());
+ } else {
+ this.alarmNotifListener = null;
+ }
this.airInterfaceNotificationListener =
new Onf14DomAirInterfaceNotificationListener(netconfDomAccessor, serviceProvider);
this.ethernetContainerNotificationListener =
@@ -128,8 +150,9 @@ public class Onf14DomInterfacePacManager {
public void register() {
// storing all the LTP UUIDs internally, for later usage, for air-interface and
// ethernet-container and wire-interface
- readKeys();
+ coreModel14.readKeys(interfaces);
readAndWriteInterfaceCurrentProblems();
+ readCurrentAlarms();
registerForNotifications();
}
@@ -137,106 +160,64 @@ public class Onf14DomInterfacePacManager {
return airInterfaceList;
}
- public PerformanceDataLtp readAirInterfaceHistoricalPerformanceData(String ltpUuid, String localId,
- PerformanceDataLtp res) {
- log.debug("Get historical performance data for class {} from mountpoint {} for LTP uuid {} and local-id {}",
- Onf14DevicemanagerQNames.AIR_INTERFACE_2_0_MODULE, netconfDomAccessor.getNodeId().getValue(), ltpUuid,
- localId);
-
- // constructing the IID needs the augmentation exposed by the air-interface-2-0
- // model
-
- InstanceIdentifierBuilder layerProtocolIID =
- YangInstanceIdentifier.builder().node(Onf14DevicemanagerQNames.CORE_MODEL_CONTROL_CONSTRUCT_CONTAINER)
- .node(Onf14DevicemanagerQNames.CORE_MODEL_CC_LTP)
- .nodeWithKey(Onf14DevicemanagerQNames.CORE_MODEL_CC_LTP,
- QName.create(Onf14DevicemanagerQNames.CORE_MODEL_CC_LTP, "uuid").intern(), ltpUuid)
- .node(Onf14DevicemanagerQNames.CORE_MODEL_CC_LTP_LAYER_PROTOCOL)
- .nodeWithKey(Onf14DevicemanagerQNames.CORE_MODEL_CC_LTP_LAYER_PROTOCOL, QName
- .create(Onf14DevicemanagerQNames.CORE_MODEL_CC_LTP_LAYER_PROTOCOL, "local-id").intern(),
- localId);
-
- @NonNull
- AugmentationIdentifier airInterfacePacIID = YangInstanceIdentifier.AugmentationIdentifier
- .create(Sets.newHashSet(Onf14DevicemanagerQNames.AIR_INTERFACE_PAC));
-
- InstanceIdentifierBuilder augmentedAirInterfacePacIID =
- YangInstanceIdentifier.builder(layerProtocolIID.build()).node(airInterfacePacIID);
-
- // reading historical performance list for this specific LTP and LP
- Optional<NormalizedNode> airInterfacePacDataOpt =
- netconfDomAccessor.readDataNode(LogicalDatastoreType.OPERATIONAL, augmentedAirInterfacePacIID.build());
- log.debug("Performance Data = {}", airInterfacePacDataOpt.get().body());
- if (airInterfacePacDataOpt.isPresent()) {
- AugmentationNode airInterfacePacData = (AugmentationNode) airInterfacePacDataOpt.get();
- ContainerNode cn = (ContainerNode) airInterfacePacData
- .childByArg(new NodeIdentifier(Onf14DevicemanagerQNames.AIR_INTERFACE_PAC));
- if (cn != null) {
- ContainerNode airIntfHistPerf = (ContainerNode) cn
- .childByArg(new NodeIdentifier(Onf14DevicemanagerQNames.AIR_INTERFACE_HISTORICAL_PERFORMANCES));
- if (airIntfHistPerf != null) {
- MapNode airInterfaceHistoricalPerformanceList = (MapNode) airIntfHistPerf.childByArg(
- new NodeIdentifier(Onf14DevicemanagerQNames.AIR_INTERFACE_HISTORICAL_PERFORMANCES_LIST));
- if (airInterfaceHistoricalPerformanceList != null) {
- Collection<MapEntryNode> airInterfaceHistoricalPerfCollection =
- airInterfaceHistoricalPerformanceList.body();
- for (MapEntryNode airInterfaceHistPerf : airInterfaceHistoricalPerfCollection) {
- res.add(new PerformanceDataAirInterface(netconfDomAccessor.getNodeId(), ltpUuid, localId,
- airInterfaceHistPerf));
- }
- return res;
- } else {
- log.debug("DBRead Id {} empty CurrentProblemList", ltpUuid);
- }
- }
- }
+ private void readCurrentAlarms() {
+ if (alarms10.isPresent()) {
+ FaultData resultList = alarms10.get().getCurrentAlarms();
+ LOG.debug("ResultList = {}", resultList.toString());
+ faultService.initCurrentProblemStatus(netconfDomAccessor.getNodeId(), resultList);
}
- return null;
}
private void readAndWriteInterfaceCurrentProblems() {
// Read all fault data
FaultData resultList = new FaultData();
int problems = 0;
- readAllAirInterfaceCurrentProblems(resultList);
- problems = resultList.size();
- log.debug("NETCONF read air interface current problems completed. Got back {} problems.", problems);
+ if (airInterface20.isPresent()) {
+ resultList = airInterface20.get().readAllCurrentProblems(resultList, airInterfaceList);
- readAllEthernetContainerCurrentProblems(resultList);
- problems = resultList.size() - problems;
- log.debug("NETCONF read current problems completed. Got back {} problems.", problems);
+ problems = resultList.size();
+ LOG.debug("NETCONF read airinterface current problems completed. Got back {} problems.", problems);
+ }
+ if (ethernetInterface20.isPresent()) {
+ resultList = ethernetInterface20.get().readAllCurrentProblems(resultList, ethernetContainerList);
- readAllWireInterfaceCurrentProblems(resultList);
- problems = resultList.size();
- log.debug("NETCONF read wire interface current problems completed. Got back {} problems.", problems);
+ problems = resultList.size() - problems;
+ LOG.debug("NETCONF read ethernet interface current problems completed. Got back {} problems.", problems);
+ }
+ if (wireInterface20.isPresent()) {
+ resultList = wireInterface20.get().readAllCurrentProblems(resultList, wireInterfaceList);
+ problems = resultList.size() - problems;
+ LOG.debug("NETCONF read wire interface current problems completed. Got back {} problems.", problems);
+ }
if (resultList.size() > 0) {
faultService.initCurrentProblemStatus(netconfDomAccessor.getNodeId(), resultList);
- log.debug("DB write current problems completed");
+ LOG.debug("DB write current problems completed");
}
}
private void readKeys() {
Optional<NormalizedNode> ltpData = readLtpData(netconfDomAccessor);
- log.debug("LTP Data is - {}", ltpData);
+ LOG.debug("LTP Data is - {}", ltpData);
if (ltpData.isPresent()) {
+ LOG.debug("In readKeys - ltpData = {}", ltpData.get());
MapNode ccLtp = (MapNode) ltpData.get();
if (ccLtp != null) {
- log.debug("Iterating the LTP list for node {}", netconfDomAccessor.getNodeId().getValue());
+ LOG.debug("Iterating the LTP list for node {}", netconfDomAccessor.getNodeId().getValue());
Collection<MapEntryNode> ltpList = ccLtp.body();
// iterating all the Logical Termination Point list
for (MapEntryNode ltp : ltpList) {
- MapNode lpList = (MapNode) ltp
- .childByArg(new NodeIdentifier(Onf14DevicemanagerQNames.CORE_MODEL_CC_LTP_LAYER_PROTOCOL));
+ MapNode lpList =
+ (MapNode) ltp.childByArg(new NodeIdentifier(coreModel14.getQName("layer-protocol")));
// the Layer Protocol list should contain only one item, since we have an 1:1
// relationship between the LTP and the LP
if (lpList != null && lpList.size() != 1) {
- log.debug("Layer protocol has no 1:1 relationship with the LTP.");
+ LOG.debug("Layer protocol has no 1:1 relationship with the LTP.");
return;
}
// accessing the LP, which should be only 1
@@ -244,49 +225,37 @@ public class Onf14DomInterfacePacManager {
for (MapEntryNode lpEntry : lp) {
String layerProtocolName = Onf14DMDOMUtility.getLeafValue(lpEntry,
- Onf14DevicemanagerQNames.CORE_MODEL_CC_LTP_LAYER_PROTOCOL_NAME);
+ coreModel14.getQName("layer-protocol-name"));
if (layerProtocolName != null) {
// if the LTP has an airInterface technology extension, the layer protocol name
// is air-layer
if (layerProtocolName.contains("LAYER_PROTOCOL_NAME_TYPE_AIR_LAYER")) {
TechnologySpecificPacKeys airInterfaceKey = new TechnologySpecificPacKeys(
- Onf14DMDOMUtility.getLeafValue(ltp,
- Onf14DevicemanagerQNames.CORE_MODEL_CC_LTP_UUID),
- Onf14DMDOMUtility.getLeafValue(lpEntry,
- Onf14DevicemanagerQNames.CORE_MODEL_CC_LTP_LAYER_PROTOCOL_LOCAL_ID));
+ Onf14DMDOMUtility.getLeafValue(ltp, coreModel14.getQName("uuid")),
+ Onf14DMDOMUtility.getLeafValue(lpEntry, coreModel14.getQName("local-id")));
airInterfaceList.add(airInterfaceKey);
- log.debug("Adding Ltp with uuid {} and local-id {} to the air-interface list",
- Onf14DMDOMUtility.getLeafValue(ltp,
- Onf14DevicemanagerQNames.CORE_MODEL_CC_LTP_UUID),
- Onf14DMDOMUtility.getLeafValue(lpEntry,
- Onf14DevicemanagerQNames.CORE_MODEL_CC_LTP_LAYER_PROTOCOL_LOCAL_ID));
+ LOG.debug("Adding Ltp with uuid {} and local-id {} to the air-interface list",
+ Onf14DMDOMUtility.getLeafValue(ltp, coreModel14.getQName("uuid")),
+ Onf14DMDOMUtility.getLeafValue(lpEntry, coreModel14.getQName("local-id")));
}
- // if the LTP has an ethernetContainer technology extension, the layer protocol
+ // if the LTP has an ethernetContainier technology extension, the layer protocol
// name is ethernet-container-layer
else if (layerProtocolName.contains("LAYER_PROTOCOL_NAME_TYPE_ETHERNET_CONTAINER_LAYER")) {
TechnologySpecificPacKeys ethernetContainerKey = new TechnologySpecificPacKeys(
- Onf14DMDOMUtility.getLeafValue(ltp,
- Onf14DevicemanagerQNames.CORE_MODEL_CC_LTP_UUID),
- Onf14DMDOMUtility.getLeafValue(lpEntry,
- Onf14DevicemanagerQNames.CORE_MODEL_CC_LTP_LAYER_PROTOCOL_LOCAL_ID));
+ Onf14DMDOMUtility.getLeafValue(ltp, coreModel14.getQName("uuid")),
+ Onf14DMDOMUtility.getLeafValue(lpEntry, coreModel14.getQName("local-id")));
ethernetContainerList.add(ethernetContainerKey);
- log.debug("Adding Ltp with uuid {} and local-id {} to the ethernet-container list",
- Onf14DMDOMUtility.getLeafValue(ltp,
- Onf14DevicemanagerQNames.CORE_MODEL_CC_LTP_UUID),
- Onf14DMDOMUtility.getLeafValue(lpEntry,
- Onf14DevicemanagerQNames.CORE_MODEL_CC_LTP_LAYER_PROTOCOL_LOCAL_ID));
+ LOG.debug("Adding Ltp with uuid {} and local-id {} to the ethernet-container list",
+ Onf14DMDOMUtility.getLeafValue(ltp, coreModel14.getQName("uuid")),
+ Onf14DMDOMUtility.getLeafValue(lpEntry, coreModel14.getQName("local-id")));
} else if (layerProtocolName.contains("LAYER_PROTOCOL_NAME_TYPE_WIRE_LAYER")) {
TechnologySpecificPacKeys wireInterfaceKey = new TechnologySpecificPacKeys(
- Onf14DMDOMUtility.getLeafValue(ltp,
- Onf14DevicemanagerQNames.CORE_MODEL_CC_LTP_UUID),
- Onf14DMDOMUtility.getLeafValue(lpEntry,
- Onf14DevicemanagerQNames.CORE_MODEL_CC_LTP_LAYER_PROTOCOL_LOCAL_ID));
+ Onf14DMDOMUtility.getLeafValue(ltp, coreModel14.getQName("uuid")),
+ Onf14DMDOMUtility.getLeafValue(lpEntry, coreModel14.getQName("local-id")));
wireInterfaceList.add(wireInterfaceKey);
- log.debug("Adding Ltp with uuid {} and local-id {} to the wire-interface list",
- Onf14DMDOMUtility.getLeafValue(ltp,
- Onf14DevicemanagerQNames.CORE_MODEL_CC_LTP_UUID),
- Onf14DMDOMUtility.getLeafValue(lpEntry,
- Onf14DevicemanagerQNames.CORE_MODEL_CC_LTP_LAYER_PROTOCOL_LOCAL_ID));
+ LOG.debug("Adding Ltp with uuid {} and local-id {} to the wire-interface list",
+ Onf14DMDOMUtility.getLeafValue(ltp, coreModel14.getQName("uuid")),
+ Onf14DMDOMUtility.getLeafValue(lpEntry, coreModel14.getQName("local-id")));
}
}
}
@@ -295,207 +264,12 @@ public class Onf14DomInterfacePacManager {
}
}
- private void readAllAirInterfaceCurrentProblems(FaultData resultList) {
-
- int idxStart; // Start index for debug messages
-
- for (TechnologySpecificPacKeys key : airInterfaceList) {
- idxStart = resultList.size();
-
- readAirInterfaceCurrentProblemForLtp(key.getLtpUuid(), key.getLocalId(), resultList);
- Debug.debugResultList(key.getLtpUuid(), resultList, idxStart);
- }
- }
-
- private void readAllEthernetContainerCurrentProblems(FaultData resultList) {
-
- int idxStart; // Start index for debug messages
-
- for (TechnologySpecificPacKeys key : ethernetContainerList) {
- idxStart = resultList.size();
-
- readEthernetContainerCurrentProblemForLtp(key.getLtpUuid(), key.getLocalId(), resultList);
- Debug.debugResultList(key.getLtpUuid(), resultList, idxStart);
- }
- }
-
- private void readAllWireInterfaceCurrentProblems(FaultData resultList) {
-
- int idxStart; // Start index for debug messages
-
- for (TechnologySpecificPacKeys key : wireInterfaceList) {
- idxStart = resultList.size();
-
- readWireInterfaceCurrentProblemForLtp(key.getLtpUuid(), key.getLocalId(), resultList);
- Debug.debugResultList(key.getLtpUuid(), resultList, idxStart);
- }
- }
-
- private void readAirInterfaceCurrentProblemForLtp(String ltpUuid, String localId, FaultData resultList) {
-
- log.debug("DBRead Get current problems for class {} from mountpoint {} for LTP uuid {} and local-id {}",
- Onf14DevicemanagerQNames.AIR_INTERFACE_2_0_MODULE, netconfDomAccessor.getNodeId().getValue(), ltpUuid,
- localId);
-
- // constructing the IID needs the augmentation exposed by the air-interface-2-0
- // model
-
- InstanceIdentifierBuilder layerProtocolIID =
- YangInstanceIdentifier.builder().node(Onf14DevicemanagerQNames.CORE_MODEL_CONTROL_CONSTRUCT_CONTAINER)
- .node(Onf14DevicemanagerQNames.CORE_MODEL_CC_LTP)
- .nodeWithKey(Onf14DevicemanagerQNames.CORE_MODEL_CC_LTP,
- QName.create(Onf14DevicemanagerQNames.CORE_MODEL_CC_LTP, "uuid").intern(), ltpUuid)
- .node(Onf14DevicemanagerQNames.CORE_MODEL_CC_LTP_LAYER_PROTOCOL)
- .nodeWithKey(Onf14DevicemanagerQNames.CORE_MODEL_CC_LTP_LAYER_PROTOCOL, QName
- .create(Onf14DevicemanagerQNames.CORE_MODEL_CC_LTP_LAYER_PROTOCOL, "local-id").intern(),
- localId);
-
- @NonNull
- AugmentationIdentifier airInterfacePacIID = YangInstanceIdentifier.AugmentationIdentifier
- .create(Sets.newHashSet(Onf14DevicemanagerQNames.AIR_INTERFACE_PAC));
-
- InstanceIdentifierBuilder augmentedAirInterfacePacIID =
- YangInstanceIdentifier.builder(layerProtocolIID.build()).node(airInterfacePacIID);
-
- // reading all the current-problems list for this specific LTP and LP
- Optional<NormalizedNode> airInterfacePacDataOpt =
- netconfDomAccessor.readDataNode(LogicalDatastoreType.OPERATIONAL, augmentedAirInterfacePacIID.build());
-
- if (airInterfacePacDataOpt.isPresent()) {
- AugmentationNode airInterfacePacData = (AugmentationNode) airInterfacePacDataOpt.get();
- MapNode airInterfaceCurrentProblemsList = (MapNode) airInterfacePacData
- .childByArg(new NodeIdentifier(Onf14DevicemanagerQNames.AIR_INTERFACE_CURRENT_PROBLEMS_LIST));
- if (airInterfaceCurrentProblemsList != null) {
- Collection<MapEntryNode> airInterfaceProblemsCollection = airInterfaceCurrentProblemsList.body();
- for (MapEntryNode airInterfaceProblem : airInterfaceProblemsCollection) {
- resultList.add(netconfDomAccessor.getNodeId(),
- Integer.parseInt(Onf14DMDOMUtility.getLeafValue(airInterfaceProblem,
- Onf14DevicemanagerQNames.AIR_INTERFACE_CURRENT_PROBLEMS_SEQ_NO)),
- new DateAndTime(Onf14DMDOMUtility.getLeafValue(airInterfaceProblem,
- Onf14DevicemanagerQNames.AIR_INTERFACE_CURRENT_PROBLEMS_TIMESTAMP)),
- ltpUuid,
- Onf14DMDOMUtility.getLeafValue(airInterfaceProblem,
- Onf14DevicemanagerQNames.AIR_INTERFACE_CURRENT_PROBLEMS_PROBLEM_NAME),
- InternalDataModelSeverity.mapSeverity(Onf14DMDOMUtility.getLeafValue(airInterfaceProblem,
- Onf14DevicemanagerQNames.AIR_INTERFACE_CURRENT_PROBLEMS_PROBLEM_SEVERITY)));
- }
- } else {
- log.debug("DBRead Id {} empty CurrentProblemList", ltpUuid);
- }
- }
- }
-
- private void readEthernetContainerCurrentProblemForLtp(String ltpUuid, String localId, FaultData resultList) {
-
- log.debug(
- "DBRead Get current problems for Ethernet Container from mountpoint {} for LTP uuid {} and local-id {}",
- netconfDomAccessor.getNodeId().getValue(), ltpUuid, localId);
-
- // constructing the IID needs the augmentation exposed by the
- // ethernet-container-2-0 model
- InstanceIdentifierBuilder layerProtocolIID =
- YangInstanceIdentifier.builder().node(Onf14DevicemanagerQNames.CORE_MODEL_CONTROL_CONSTRUCT_CONTAINER)
- .node(Onf14DevicemanagerQNames.CORE_MODEL_CC_LTP)
- .nodeWithKey(Onf14DevicemanagerQNames.CORE_MODEL_CC_LTP,
- QName.create(Onf14DevicemanagerQNames.CORE_MODEL_CC_LTP, "uuid").intern(), ltpUuid)
- .node(Onf14DevicemanagerQNames.CORE_MODEL_CC_LTP_LAYER_PROTOCOL)
- .nodeWithKey(Onf14DevicemanagerQNames.CORE_MODEL_CC_LTP_LAYER_PROTOCOL, QName
- .create(Onf14DevicemanagerQNames.CORE_MODEL_CC_LTP_LAYER_PROTOCOL, "local-id").intern(),
- localId);
-
- @NonNull
- AugmentationIdentifier ethernetContainerIID = YangInstanceIdentifier.AugmentationIdentifier
- .create(Sets.newHashSet(Onf14DevicemanagerQNames.ETHERNET_CONTAINER_PAC));
-
- InstanceIdentifierBuilder augmentedEthernetContainerConfigurationIID =
- YangInstanceIdentifier.builder(layerProtocolIID.build()).node(ethernetContainerIID);
-
- // reading all the current-problems list for this specific LTP and LP
- Optional<NormalizedNode> etherntContainerConfigurationOpt = netconfDomAccessor
- .readDataNode(LogicalDatastoreType.OPERATIONAL, augmentedEthernetContainerConfigurationIID.build());
-
- if (etherntContainerConfigurationOpt.isPresent()) {
- AugmentationNode etherntContainerConfiguration = (AugmentationNode) etherntContainerConfigurationOpt.get();
- MapNode ethernetContainerCurrentProblemsList = (MapNode) etherntContainerConfiguration
- .childByArg(new NodeIdentifier(Onf14DevicemanagerQNames.ETHERNET_CONTAINER_CURRENT_PROBLEMS_LIST));
- if (ethernetContainerCurrentProblemsList != null) {
- Collection<MapEntryNode> ethernetContainerProblemsCollection =
- ethernetContainerCurrentProblemsList.body();
- for (MapEntryNode ethernetContainerProblem : ethernetContainerProblemsCollection) {
- resultList.add(netconfDomAccessor.getNodeId(),
- Integer.parseInt(Onf14DMDOMUtility.getLeafValue(ethernetContainerProblem,
- Onf14DevicemanagerQNames.ETHERNET_CONTAINER_CURRENT_PROBLEMS_SEQ_NO)),
- new DateAndTime(Onf14DMDOMUtility.getLeafValue(ethernetContainerProblem,
- Onf14DevicemanagerQNames.ETHERNET_CONTAINER_CURRENT_PROBLEMS_TIMESTAMP)),
- ltpUuid,
- Onf14DMDOMUtility.getLeafValue(ethernetContainerProblem,
- Onf14DevicemanagerQNames.ETHERNET_CONTAINER_CURRENT_PROBLEMS_PROBLEM_NAME),
- InternalDataModelSeverity.mapSeverity(Onf14DMDOMUtility.getLeafValue(
- ethernetContainerProblem,
- Onf14DevicemanagerQNames.ETHERNET_CONTAINER_CURRENT_PROBLEMS_PROBLEM_SEVERITY)));
- }
- } else {
- log.debug("DBRead Id {} empty CurrentProblemList", ltpUuid);
- }
- }
-
- }
+ private void registerForNotifications() {
- private void readWireInterfaceCurrentProblemForLtp(String ltpUuid, String localId, FaultData resultList) {
-
- log.debug("DBRead Get current problems for Wire Interface from mountpoint {} for LTP uuid {} and local-id {}",
- netconfDomAccessor.getNodeId().getValue(), ltpUuid, localId);
-
- // constructing the IID needs the augmentation exposed by the wire-interface-2-0
- // model
- InstanceIdentifierBuilder layerProtocolIID =
- YangInstanceIdentifier.builder().node(Onf14DevicemanagerQNames.CORE_MODEL_CONTROL_CONSTRUCT_CONTAINER)
- .node(Onf14DevicemanagerQNames.CORE_MODEL_CC_LTP)
- .nodeWithKey(Onf14DevicemanagerQNames.CORE_MODEL_CC_LTP,
- QName.create(Onf14DevicemanagerQNames.CORE_MODEL_CC_LTP, "uuid").intern(), ltpUuid)
- .node(Onf14DevicemanagerQNames.CORE_MODEL_CC_LTP_LAYER_PROTOCOL)
- .nodeWithKey(Onf14DevicemanagerQNames.CORE_MODEL_CC_LTP_LAYER_PROTOCOL, QName
- .create(Onf14DevicemanagerQNames.CORE_MODEL_CC_LTP_LAYER_PROTOCOL, "local-id").intern(),
- localId);
-
- @NonNull
- AugmentationIdentifier wireInterfacePacIID = YangInstanceIdentifier.AugmentationIdentifier
- .create(Sets.newHashSet(Onf14DevicemanagerQNames.WIRE_INTERFACE_PAC));
-
- InstanceIdentifierBuilder augmentedWireInterfaceConfigurationIID =
- YangInstanceIdentifier.builder(layerProtocolIID.build()).node(wireInterfacePacIID);
-
- // reading all the current-problems list for this specific LTP and LP
- Optional<NormalizedNode> wireInterfaceConfigurationOpt = netconfDomAccessor
- .readDataNode(LogicalDatastoreType.OPERATIONAL, augmentedWireInterfaceConfigurationIID.build());
-
- if (wireInterfaceConfigurationOpt.isPresent()) {
- AugmentationNode wireInterfaceConfiguration = (AugmentationNode) wireInterfaceConfigurationOpt.get();
- MapNode wireInterfaceCurrentProblemsList = (MapNode) wireInterfaceConfiguration
- .childByArg(new NodeIdentifier(Onf14DevicemanagerQNames.WIRE_INTERFACE_CURRENT_PROBLEMS_LIST));
- if (wireInterfaceCurrentProblemsList != null) {
- Collection<MapEntryNode> wireInterfaceProblemsCollection = wireInterfaceCurrentProblemsList.body();
- for (MapEntryNode wireInterfaceProblem : wireInterfaceProblemsCollection) {
- resultList.add(netconfDomAccessor.getNodeId(),
- Integer.parseInt(Onf14DMDOMUtility.getLeafValue(wireInterfaceProblem,
- Onf14DevicemanagerQNames.WIRE_INTERFACE_CURRENT_PROBLEMS_SEQ_NO)),
- new DateAndTime(Onf14DMDOMUtility.getLeafValue(wireInterfaceProblem,
- Onf14DevicemanagerQNames.WIRE_INTERFACE_CURRENT_PROBLEMS_TIMESTAMP)),
- ltpUuid,
- Onf14DMDOMUtility.getLeafValue(wireInterfaceProblem,
- Onf14DevicemanagerQNames.WIRE_INTERFACE_CURRENT_PROBLEMS_PROBLEM_NAME),
- InternalDataModelSeverity.mapSeverity(Onf14DMDOMUtility.getLeafValue(wireInterfaceProblem,
- Onf14DevicemanagerQNames.WIRE_INTERFACE_CURRENT_PROBLEMS_PROBLEM_SEVERITY)));
- }
- } else {
- log.debug("DBRead Id {} empty CurrentProblemList", ltpUuid);
- }
+ if (alarms10.isPresent()) {
+ alarms10.get().doRegisterNotificationListener(alarmNotifListener);
}
- }
-
- private void registerForNotifications() {
-
QName[] airInterfaceNotifications = {Onf14DevicemanagerQNames.AIR_INTERFACE_OBJECT_CREATE_NOTIFICATION,
Onf14DevicemanagerQNames.AIR_INTERFACE_OBJECT_AVC_NOTIFICATION,
Onf14DevicemanagerQNames.AIR_INTERFACE_OBJECT_DELETE_NOTIFICATION,
@@ -519,13 +293,22 @@ public class Onf14DomInterfacePacManager {
}
public Optional<NormalizedNode> readLtpData(NetconfDomAccessor netconfDomAccessor) {
- log.info("Reading Logical Termination Point data");
- return netconfDomAccessor.readDataNode(LogicalDatastoreType.CONFIGURATION, LTP_IID);
+ LOG.info("Reading Logical Termination Point data");
+ return netconfDomAccessor.readDataNode(LogicalDatastoreType.CONFIGURATION, getLtp_IID());
}
public PerformanceDataLtp getLtpHistoricalPerformanceData(@NonNull TechnologySpecificPacKeys lp) {
PerformanceDataLtp res = new PerformanceDataLtp();
- readAirInterfaceHistoricalPerformanceData(lp.getLtpUuid(), lp.getLocalId(), res);
+ if (airInterface20.isPresent()) {
+ airInterface20.get().readAirInterfaceHistoricalPerformanceData(lp.getLtpUuid(), lp.getLocalId(), res);
+ } else {
+ LOG.warn("Air Interface Module Unsupported. PM data not read");
+ }
return res;
}
+
+ private YangInstanceIdentifier getLtp_IID() {
+ return YangInstanceIdentifier.builder().node(coreModel14.getQName("control-construct"))
+ .node(coreModel14.getQName("logical-termination-point")).build();
+ }
}
diff --git a/sdnr/wt/devicemanager-onap/onf14/provider/src/main/java/org/onap/ccsdk/features/sdnr/wt/devicemanager/onf14/dom/impl/interfaces/Onf14Interfaces.java b/sdnr/wt/devicemanager-onap/onf14/provider/src/main/java/org/onap/ccsdk/features/sdnr/wt/devicemanager/onf14/dom/impl/interfaces/Onf14Interfaces.java
new file mode 100644
index 000000000..47e164677
--- /dev/null
+++ b/sdnr/wt/devicemanager-onap/onf14/provider/src/main/java/org/onap/ccsdk/features/sdnr/wt/devicemanager/onf14/dom/impl/interfaces/Onf14Interfaces.java
@@ -0,0 +1,49 @@
+/*
+ * ============LICENSE_START=======================================================
+ * ONAP : ccsdk features
+ * ================================================================================
+ * Copyright (C) 2023 highstreet technologies GmbH Intellectual Property.
+ * All rights reserved.
+ * ================================================================================
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ * ============LICENSE_END=========================================================
+ *
+ */
+package org.onap.ccsdk.features.sdnr.wt.devicemanager.onf14.dom.impl.interfaces;
+
+import java.util.ArrayList;
+import java.util.EnumMap;
+import java.util.List;
+import java.util.Map;
+
+public class Onf14Interfaces {
+
+ public enum Key {
+ AIRINTERFACE,
+ ETHERNETCONTAINER,
+ WIREINTERFACE
+ }
+
+ private final Map<Key, List<TechnologySpecificPacKeys>> interfaces;
+
+ public Onf14Interfaces() {
+ interfaces = new EnumMap<>(Key.class);
+ for (Key key : Key.values()) {
+ interfaces.put(key, new ArrayList<TechnologySpecificPacKeys>());
+ }
+ }
+
+ public void add(Key key, List<TechnologySpecificPacKeys> specificInterfaceKeyList) {
+ interfaces.get(key).addAll(specificInterfaceKeyList);
+ }
+}
diff --git a/sdnr/wt/devicemanager-onap/onf14/provider/src/main/java/org/onap/ccsdk/features/sdnr/wt/devicemanager/onf14/dom/impl/interfaces/TechnologySpecific.java b/sdnr/wt/devicemanager-onap/onf14/provider/src/main/java/org/onap/ccsdk/features/sdnr/wt/devicemanager/onf14/dom/impl/interfaces/TechnologySpecific.java
new file mode 100644
index 000000000..2ad33aed8
--- /dev/null
+++ b/sdnr/wt/devicemanager-onap/onf14/provider/src/main/java/org/onap/ccsdk/features/sdnr/wt/devicemanager/onf14/dom/impl/interfaces/TechnologySpecific.java
@@ -0,0 +1,27 @@
+/*
+ * ============LICENSE_START=======================================================
+ * ONAP : ccsdk features
+ * ================================================================================
+ * Copyright (C) 2023 highstreet technologies GmbH Intellectual Property.
+ * All rights reserved.
+ * ================================================================================
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ * ============LICENSE_END=========================================================
+ *
+ */
+package org.onap.ccsdk.features.sdnr.wt.devicemanager.onf14.dom.impl.interfaces;
+
+public interface TechnologySpecific {
+
+
+}
diff --git a/sdnr/wt/devicemanager-onap/onf14/provider/src/main/java/org/onap/ccsdk/features/sdnr/wt/devicemanager/onf14/dom/notifications/Onf14DomAirInterfaceNotificationListener.java b/sdnr/wt/devicemanager-onap/onf14/provider/src/main/java/org/onap/ccsdk/features/sdnr/wt/devicemanager/onf14/dom/impl/notifications/Onf14DomAirInterfaceNotificationListener.java
index e32ca0134..fbc2d77df 100644
--- a/sdnr/wt/devicemanager-onap/onf14/provider/src/main/java/org/onap/ccsdk/features/sdnr/wt/devicemanager/onf14/dom/notifications/Onf14DomAirInterfaceNotificationListener.java
+++ b/sdnr/wt/devicemanager-onap/onf14/provider/src/main/java/org/onap/ccsdk/features/sdnr/wt/devicemanager/onf14/dom/impl/notifications/Onf14DomAirInterfaceNotificationListener.java
@@ -19,12 +19,12 @@
* ============LICENSE_END=========================================================
*
*/
-package org.onap.ccsdk.features.sdnr.wt.devicemanager.onf14.dom.notifications;
+package org.onap.ccsdk.features.sdnr.wt.devicemanager.onf14.dom.impl.notifications;
import org.eclipse.jdt.annotation.NonNull;
import org.onap.ccsdk.features.sdnr.wt.devicemanager.onf14.dom.impl.dataprovider.InternalDataModelSeverity;
+import org.onap.ccsdk.features.sdnr.wt.devicemanager.onf14.dom.impl.qnames.Onf14DevicemanagerQNames;
import org.onap.ccsdk.features.sdnr.wt.devicemanager.onf14.dom.impl.util.Onf14DMDOMUtility;
-import org.onap.ccsdk.features.sdnr.wt.devicemanager.onf14.dom.impl.util.Onf14DevicemanagerQNames;
import org.onap.ccsdk.features.sdnr.wt.devicemanager.service.DeviceManagerServiceProvider;
import org.onap.ccsdk.features.sdnr.wt.netconfnodestateservice.NetconfDomAccessor;
import org.opendaylight.mdsal.dom.api.DOMNotification;
diff --git a/sdnr/wt/devicemanager-onap/onf14/provider/src/main/java/org/onap/ccsdk/features/sdnr/wt/devicemanager/onf14/dom/impl/notifications/Onf14DomAlarmsNotificationListener.java b/sdnr/wt/devicemanager-onap/onf14/provider/src/main/java/org/onap/ccsdk/features/sdnr/wt/devicemanager/onf14/dom/impl/notifications/Onf14DomAlarmsNotificationListener.java
new file mode 100644
index 000000000..3243a0931
--- /dev/null
+++ b/sdnr/wt/devicemanager-onap/onf14/provider/src/main/java/org/onap/ccsdk/features/sdnr/wt/devicemanager/onf14/dom/impl/notifications/Onf14DomAlarmsNotificationListener.java
@@ -0,0 +1,69 @@
+/*
+ * ============LICENSE_START=======================================================
+ * ONAP : ccsdk features
+ * ================================================================================
+ * Copyright (C) 2023 highstreet technologies GmbH Intellectual Property.
+ * All rights reserved.
+ * ================================================================================
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ * ============LICENSE_END=========================================================
+ *
+ */
+package org.onap.ccsdk.features.sdnr.wt.devicemanager.onf14.dom.impl.notifications;
+
+import org.eclipse.jdt.annotation.NonNull;
+import org.onap.ccsdk.features.sdnr.wt.devicemanager.onf14.dom.impl.yangspecs.Alarms10;
+import org.onap.ccsdk.features.sdnr.wt.devicemanager.service.DeviceManagerServiceProvider;
+import org.onap.ccsdk.features.sdnr.wt.netconfnodestateservice.NetconfDomAccessor;
+import org.opendaylight.mdsal.dom.api.DOMNotification;
+import org.opendaylight.mdsal.dom.api.DOMNotificationListener;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.data.provider.rev201110.FaultlogEntity;
+import org.opendaylight.yangtools.yang.data.api.schema.ContainerNode;
+import org.slf4j.Logger;
+import org.slf4j.LoggerFactory;
+
+public class Onf14DomAlarmsNotificationListener implements DOMNotificationListener {
+
+ private static final Logger log = LoggerFactory.getLogger(Onf14DomAlarmsNotificationListener.class);
+
+ private final DeviceManagerServiceProvider serviceProvider;
+ private final Alarms10 alarms10;
+
+ public Onf14DomAlarmsNotificationListener(NetconfDomAccessor netconfDomAccessor,
+ DeviceManagerServiceProvider serviceProvider, Alarms10 alarms10) {
+ this.serviceProvider = serviceProvider;
+ this.alarms10 = alarms10;
+ }
+
+ @Override
+ public void onNotification(@NonNull DOMNotification domNotification) {
+ log.debug("In AlarmsNotificationListener - Got event of type :: {} {}", domNotification.getType(),
+ domNotification.getBody());
+ if (alarms10.isAlarmEventNotification(domNotification)) {
+ onAlarmEventNotification(domNotification);
+ } else {
+ log.error("Unknown notification received - {}", domNotification.getType());
+ }
+ }
+
+ private void onAlarmEventNotification(@NonNull DOMNotification domNotification) {
+ ContainerNode cn = domNotification.getBody();
+
+ FaultlogEntity faultAlarm = alarms10.getFaultlogEntity(cn);
+ serviceProvider.getFaultService().faultNotification(faultAlarm);
+ alarms10.sendNotification(serviceProvider.getWebsocketService(), domNotification, cn);
+ log.debug("onAlarmEventNotification log entry written");
+
+ }
+
+}
diff --git a/sdnr/wt/devicemanager-onap/onf14/provider/src/main/java/org/onap/ccsdk/features/sdnr/wt/devicemanager/onf14/dom/notifications/Onf14DomEthernetContainerNotificationListener.java b/sdnr/wt/devicemanager-onap/onf14/provider/src/main/java/org/onap/ccsdk/features/sdnr/wt/devicemanager/onf14/dom/impl/notifications/Onf14DomEthernetContainerNotificationListener.java
index 3f2b95e93..ec006f9b4 100644
--- a/sdnr/wt/devicemanager-onap/onf14/provider/src/main/java/org/onap/ccsdk/features/sdnr/wt/devicemanager/onf14/dom/notifications/Onf14DomEthernetContainerNotificationListener.java
+++ b/sdnr/wt/devicemanager-onap/onf14/provider/src/main/java/org/onap/ccsdk/features/sdnr/wt/devicemanager/onf14/dom/impl/notifications/Onf14DomEthernetContainerNotificationListener.java
@@ -1,9 +1,9 @@
-package org.onap.ccsdk.features.sdnr.wt.devicemanager.onf14.dom.notifications;
+package org.onap.ccsdk.features.sdnr.wt.devicemanager.onf14.dom.impl.notifications;
import org.eclipse.jdt.annotation.NonNull;
import org.onap.ccsdk.features.sdnr.wt.devicemanager.onf14.dom.impl.dataprovider.InternalDataModelSeverity;
+import org.onap.ccsdk.features.sdnr.wt.devicemanager.onf14.dom.impl.qnames.Onf14DevicemanagerQNames;
import org.onap.ccsdk.features.sdnr.wt.devicemanager.onf14.dom.impl.util.Onf14DMDOMUtility;
-import org.onap.ccsdk.features.sdnr.wt.devicemanager.onf14.dom.impl.util.Onf14DevicemanagerQNames;
import org.onap.ccsdk.features.sdnr.wt.devicemanager.service.DeviceManagerServiceProvider;
import org.onap.ccsdk.features.sdnr.wt.netconfnodestateservice.NetconfDomAccessor;
import org.opendaylight.mdsal.dom.api.DOMNotification;
diff --git a/sdnr/wt/devicemanager-onap/onf14/provider/src/main/java/org/onap/ccsdk/features/sdnr/wt/devicemanager/onf14/dom/notifications/Onf14DomWireInterfaceNotificationListener.java b/sdnr/wt/devicemanager-onap/onf14/provider/src/main/java/org/onap/ccsdk/features/sdnr/wt/devicemanager/onf14/dom/impl/notifications/Onf14DomWireInterfaceNotificationListener.java
index 9e7b35bc2..bae9c30f2 100644
--- a/sdnr/wt/devicemanager-onap/onf14/provider/src/main/java/org/onap/ccsdk/features/sdnr/wt/devicemanager/onf14/dom/notifications/Onf14DomWireInterfaceNotificationListener.java
+++ b/sdnr/wt/devicemanager-onap/onf14/provider/src/main/java/org/onap/ccsdk/features/sdnr/wt/devicemanager/onf14/dom/impl/notifications/Onf14DomWireInterfaceNotificationListener.java
@@ -1,9 +1,9 @@
-package org.onap.ccsdk.features.sdnr.wt.devicemanager.onf14.dom.notifications;
+package org.onap.ccsdk.features.sdnr.wt.devicemanager.onf14.dom.impl.notifications;
import org.eclipse.jdt.annotation.NonNull;
import org.onap.ccsdk.features.sdnr.wt.devicemanager.onf14.dom.impl.dataprovider.InternalDataModelSeverity;
+import org.onap.ccsdk.features.sdnr.wt.devicemanager.onf14.dom.impl.qnames.Onf14DevicemanagerQNames;
import org.onap.ccsdk.features.sdnr.wt.devicemanager.onf14.dom.impl.util.Onf14DMDOMUtility;
-import org.onap.ccsdk.features.sdnr.wt.devicemanager.onf14.dom.impl.util.Onf14DevicemanagerQNames;
import org.onap.ccsdk.features.sdnr.wt.devicemanager.service.DeviceManagerServiceProvider;
import org.onap.ccsdk.features.sdnr.wt.netconfnodestateservice.NetconfDomAccessor;
import org.opendaylight.mdsal.dom.api.DOMNotification;
diff --git a/sdnr/wt/devicemanager-onap/onf14/provider/src/main/java/org/onap/ccsdk/features/sdnr/wt/devicemanager/onf14/dom/impl/pm/PerformanceDataAirInterface.java b/sdnr/wt/devicemanager-onap/onf14/provider/src/main/java/org/onap/ccsdk/features/sdnr/wt/devicemanager/onf14/dom/impl/pm/PerformanceDataAirInterface.java
index 8abdb1e8f..d66f58fb9 100644
--- a/sdnr/wt/devicemanager-onap/onf14/provider/src/main/java/org/onap/ccsdk/features/sdnr/wt/devicemanager/onf14/dom/impl/pm/PerformanceDataAirInterface.java
+++ b/sdnr/wt/devicemanager-onap/onf14/provider/src/main/java/org/onap/ccsdk/features/sdnr/wt/devicemanager/onf14/dom/impl/pm/PerformanceDataAirInterface.java
@@ -19,7 +19,7 @@
package org.onap.ccsdk.features.sdnr.wt.devicemanager.onf14.dom.impl.pm;
import org.onap.ccsdk.features.sdnr.wt.devicemanager.onf14.dom.impl.util.Onf14DMDOMUtility;
-import org.onap.ccsdk.features.sdnr.wt.devicemanager.onf14.dom.impl.util.Onf14DevicemanagerQNames;
+import org.onap.ccsdk.features.sdnr.wt.devicemanager.onf14.dom.impl.qnames.Onf14DevicemanagerQNames;
import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.yang.types.rev130715.DateAndTime;
import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.data.provider.rev201110.PmdataEntityBuilder;
import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.data.provider.rev201110.pmdata.entity.PerformanceDataBuilder;
diff --git a/sdnr/wt/devicemanager-onap/onf14/provider/src/main/java/org/onap/ccsdk/features/sdnr/wt/devicemanager/onf14/dom/impl/qnames/DevicemanagerQNames.java b/sdnr/wt/devicemanager-onap/onf14/provider/src/main/java/org/onap/ccsdk/features/sdnr/wt/devicemanager/onf14/dom/impl/qnames/DevicemanagerQNames.java
new file mode 100644
index 000000000..4c90b24ad
--- /dev/null
+++ b/sdnr/wt/devicemanager-onap/onf14/provider/src/main/java/org/onap/ccsdk/features/sdnr/wt/devicemanager/onf14/dom/impl/qnames/DevicemanagerQNames.java
@@ -0,0 +1,66 @@
+/*
+ * ============LICENSE_START=======================================================
+ * ONAP : ccsdk features
+ * ================================================================================
+ * Copyright (C) 2023 highstreet technologies GmbH Intellectual Property.
+ * All rights reserved.
+ * ================================================================================
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ * ============LICENSE_END=========================================================
+ *
+ */
+package org.onap.ccsdk.features.sdnr.wt.devicemanager.onf14.dom.impl.qnames;
+
+import java.util.List;
+import java.util.Optional;
+import org.onap.ccsdk.features.sdnr.wt.netconfnodestateservice.Capabilities;
+import org.opendaylight.yangtools.yang.common.QName;
+import org.opendaylight.yangtools.yang.common.QNameModule;
+
+public class DevicemanagerQNames {
+
+ protected QNameModule qNameModule;
+ protected String revision;
+
+ public DevicemanagerQNames(QNameModule qnm, String revision) {
+ this.qNameModule = qnm;
+ this.revision = revision;
+ }
+
+ public QName getQName(String localName) {
+ return QName.create(qNameModule, localName);
+ }
+
+ public String getNamespaceRevision() {
+ return revision;
+ }
+
+ public QNameModule getQNameModule() {
+ return qNameModule;
+ }
+
+ public static Optional<DevicemanagerQNames> getDevicemanagerQNames(Capabilities capabilities,
+ List<QNameModule> modules) {
+
+ for (QNameModule module : modules) {
+
+ if (capabilities.isSupportingNamespaceAndRevision(module.getNamespace().toString(),
+ module.getRevision().toString())) {
+ String namespaceRevision = module.getRevision().toString();
+ return Optional.of(new DevicemanagerQNames(module, namespaceRevision));
+ }
+ }
+
+ return Optional.empty();
+ }
+}
diff --git a/sdnr/wt/devicemanager-onap/onf14/provider/src/main/java/org/onap/ccsdk/features/sdnr/wt/devicemanager/onf14/dom/impl/util/Onf14DevicemanagerQNames.java b/sdnr/wt/devicemanager-onap/onf14/provider/src/main/java/org/onap/ccsdk/features/sdnr/wt/devicemanager/onf14/dom/impl/qnames/Onf14DevicemanagerQNames.java
index f4fd2118f..a5d663bb5 100644
--- a/sdnr/wt/devicemanager-onap/onf14/provider/src/main/java/org/onap/ccsdk/features/sdnr/wt/devicemanager/onf14/dom/impl/util/Onf14DevicemanagerQNames.java
+++ b/sdnr/wt/devicemanager-onap/onf14/provider/src/main/java/org/onap/ccsdk/features/sdnr/wt/devicemanager/onf14/dom/impl/qnames/Onf14DevicemanagerQNames.java
@@ -19,7 +19,7 @@
* ============LICENSE_END=========================================================
*
*/
-package org.onap.ccsdk.features.sdnr.wt.devicemanager.onf14.dom.impl.util;
+package org.onap.ccsdk.features.sdnr.wt.devicemanager.onf14.dom.impl.qnames;
import org.opendaylight.yangtools.yang.common.QName;
import org.opendaylight.yangtools.yang.common.QNameModule;
@@ -27,53 +27,6 @@ import org.opendaylight.yangtools.yang.common.Revision;
import org.opendaylight.yangtools.yang.common.XMLNamespace;
public class Onf14DevicemanagerQNames {
- public static final QNameModule CORE_MODEL_1_4_MODULE =
- QNameModule.create(XMLNamespace.of("urn:onf:yang:core-model-1-4"), Revision.of("2019-11-27"));
- public static final QName CORE_MODEL_CONTROL_CONSTRUCT_CONTAINER =
- QName.create(CORE_MODEL_1_4_MODULE, "control-construct");
- public static final QName CORE_MODEL_CC_TOP_LEVEL_EQPT = QName.create(CORE_MODEL_1_4_MODULE, "top-level-equipment");
- public static final QName CORE_MODEL_CC_EQPT = QName.create(CORE_MODEL_1_4_MODULE, "equipment");
- public static final QName CORE_MODEL_CC_EQPT_GLOBAL_CLASS_UUID = QName.create(CORE_MODEL_1_4_MODULE, "uuid");
- public static final QName CORE_MODEL_CC_EQPT_ACTUAL_EQUIPMENT =
- QName.create(CORE_MODEL_1_4_MODULE, "actual-equipment");
- public static final QName CORE_MODEL_CC_EQPT_CONTAINED_HOLDER =
- QName.create(CORE_MODEL_1_4_MODULE, "contained-holder");
- public static final QName CORE_MODEL_CC_EQPT_OCCUPYING_FRU = QName.create(CORE_MODEL_1_4_MODULE, "occupying-fru");
- public static final QName CORE_MODEL_CC_EQPT_MANUFACTURED_THING =
- QName.create(CORE_MODEL_1_4_MODULE, "manufactured-thing");
- public static final QName CORE_MODEL_CC_EQPT_MANUFACTURER_PROPS =
- QName.create(CORE_MODEL_1_4_MODULE, "manufacturer-properties");
- public static final QName CORE_MODEL_CC_EQPT_MANUFACTURER_NAME =
- QName.create(CORE_MODEL_1_4_MODULE, "manufacturer-name");
- public static final QName CORE_MODEL_CC_EQPT_MANUFACTURER_ID =
- QName.create(CORE_MODEL_1_4_MODULE, "manufacturer-identifier");
- public static final QName CORE_MODEL_CC_EQPT_ACTUAL_EQPT_EQPT_INSTANCE =
- QName.create(CORE_MODEL_1_4_MODULE, "equipment-instance");
- public static final QName CORE_MODEL_CC_EQPT_ACTUAL_EQPT_EQPT_INSTANCE_SERIAL_NUM =
- QName.create(CORE_MODEL_1_4_MODULE, "serial-number");
- public static final QName CORE_MODEL_CC_EQPT_ACTUAL_EQPT_EQPT_INSTANCE_MANUFACTURED_DATE =
- QName.create(CORE_MODEL_1_4_MODULE, "manufactured-date");
- public static final QName CORE_MODEL_CC_EQPT_ACTUAL_EQPT_EQPT_TYPE =
- QName.create(CORE_MODEL_1_4_MODULE, "equipment-type");
- public static final QName CORE_MODEL_CC_EQPT_ACTUAL_EQPT_EQPT_TYPE_VERSION =
- QName.create(CORE_MODEL_1_4_MODULE, "version");
- public static final QName CORE_MODEL_CC_EQPT_ACTUAL_EQPT_EQPT_TYPE_DESCRIPTION =
- QName.create(CORE_MODEL_1_4_MODULE, "description");
- public static final QName CORE_MODEL_CC_EQPT_ACTUAL_EQPT_EQPT_TYPE_MODEL_ID =
- QName.create(CORE_MODEL_1_4_MODULE, "model-identifier");
- public static final QName CORE_MODEL_CC_EQPT_ACTUAL_EQPT_EQPT_TYPE_PART_TYPE_ID =
- QName.create(CORE_MODEL_1_4_MODULE, "part-type-identifier");
- public static final QName CORE_MODEL_CC_EQPT_ACTUAL_EQPT_EQPT_TYPE_TYPE_NAME =
- QName.create(CORE_MODEL_1_4_MODULE, "type-name");
-
-
- public static final QName CORE_MODEL_CC_LTP = QName.create(CORE_MODEL_1_4_MODULE, "logical-termination-point");
- public static final QName CORE_MODEL_CC_LTP_LAYER_PROTOCOL = QName.create(CORE_MODEL_1_4_MODULE, "layer-protocol");
- public static final QName CORE_MODEL_CC_LTP_LAYER_PROTOCOL_NAME =
- QName.create(CORE_MODEL_1_4_MODULE, "layer-protocol-name");
- public static final QName CORE_MODEL_CC_LTP_LAYER_PROTOCOL_LOCAL_ID =
- QName.create(CORE_MODEL_1_4_MODULE, "local-id");
- public static final QName CORE_MODEL_CC_LTP_UUID = QName.create(CORE_MODEL_1_4_MODULE, "uuid");
//Interface Notifications - common fields
private static String COUNTER = "counter";
@@ -350,4 +303,14 @@ public class Onf14DevicemanagerQNames {
public static final QName WIRE_INTERFACE_OBJECT_DELETE_NOTIFICATION_TIMESTAMP =
QName.create(WIRE_INTERFACE_2_0_MODULE, TIMESTAMP);
+
+ private final QNameModule coreModel14Module;
+ private final String namespaceRevision; //TODO generate out of coreModel14Module
+
+ private Onf14DevicemanagerQNames(QNameModule coreModel14Module, String namespaceRevision) {
+ this.coreModel14Module = coreModel14Module;
+ this.namespaceRevision = namespaceRevision;
+
+ }
+
}
diff --git a/sdnr/wt/devicemanager-onap/onf14/provider/src/main/java/org/onap/ccsdk/features/sdnr/wt/devicemanager/onf14/dom/impl/util/Onf14DMDOMUtility.java b/sdnr/wt/devicemanager-onap/onf14/provider/src/main/java/org/onap/ccsdk/features/sdnr/wt/devicemanager/onf14/dom/impl/util/Onf14DMDOMUtility.java
index ae1884dcb..dd20b5e6a 100644
--- a/sdnr/wt/devicemanager-onap/onf14/provider/src/main/java/org/onap/ccsdk/features/sdnr/wt/devicemanager/onf14/dom/impl/util/Onf14DMDOMUtility.java
+++ b/sdnr/wt/devicemanager-onap/onf14/provider/src/main/java/org/onap/ccsdk/features/sdnr/wt/devicemanager/onf14/dom/impl/util/Onf14DMDOMUtility.java
@@ -27,8 +27,14 @@ import java.util.ArrayList;
import java.util.Collection;
import java.util.Iterator;
import java.util.List;
+import java.util.regex.Matcher;
+import java.util.regex.Pattern;
+import org.eclipse.jdt.annotation.Nullable;
+import org.onap.ccsdk.features.sdnr.wt.devicemanager.onf14.dom.impl.dataprovider.InternalDataModelSeverity;
import org.opendaylight.mdsal.dom.api.DOMEvent;
import org.opendaylight.mdsal.dom.api.DOMNotification;
+import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.yang.types.rev130715.DateAndTime;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.data.provider.rev201110.SeverityType;
import org.opendaylight.yangtools.yang.common.QName;
import org.opendaylight.yangtools.yang.data.api.YangInstanceIdentifier.NodeIdentifier;
import org.opendaylight.yangtools.yang.data.api.YangInstanceIdentifier.NodeIdentifierWithPredicates;
@@ -44,26 +50,93 @@ public class Onf14DMDOMUtility {
public static final Logger LOG = LoggerFactory.getLogger(Onf14DMDOMUtility.class);
+ /*
+ * /(urn:onf:yang:core-model-1-4?revision=2019-11-27)control-construct/logical-
+ * termination-point/logical-termination-point[{(urn:onf:yang:core-model-1-4?
+ * revision=2019-11-27)uuid=10004041-0000-0001-0001-3c4cd0db3b20}]
+ */
+ private static final Pattern ALARM_RESOURCE_PATTERN =
+ Pattern.compile(".*uuid=([0-9a-z]*-[0-9a-z]*-[0-9a-z]*-[0-9a-z]*-[0-9a-z]*).*", Pattern.MULTILINE);
+
private Onf14DMDOMUtility() {}
- public static String getLeafValue(DataContainerNode componentEntry, QName leafQName) {
+ private static String getLeafValueX(DataContainerNode componentEntry, QName leafQName) {
NodeIdentifier leafNodeIdentifier = new NodeIdentifier(leafQName);
+ LeafNode<?> optLeafNode = (LeafNode<?>) componentEntry.getChildByArg(leafNodeIdentifier);
+ if (optLeafNode.body() instanceof QName) {
+ LOG.debug("Leaf is of type QName"); // Ex:
+ // ImmutableLeafNode{identifier=(urn:onf:yang:air-interface-2-0?revision=2020-01-21)severity,
+ // body=(urn:onf:yang:air-interface-2-0?revision=2020-01-21)SEVERITY_TYPE_MAJOR}
+ String severity_ = optLeafNode.body().toString();
+ return severity_.substring(severity_.indexOf(')') + 1); // Any other solution??
+ }
+ return optLeafNode.body().toString();
+ }
+
+ /**
+ * Return value as String
+ * @param componentEntry Container node with data
+ * @param leafQName Leaf to be converted
+ * @return String or null
+ */
+ public static String getLeafValue(DataContainerNode componentEntry, QName leafQName) {
try {
- LeafNode<?> optLeafNode = (LeafNode<?>) componentEntry.getChildByArg(leafNodeIdentifier);
- if (optLeafNode.body() instanceof QName) {
- LOG.debug("Leaf is of type QName"); // Ex:
- // ImmutableLeafNode{identifier=(urn:onf:yang:air-interface-2-0?revision=2020-01-21)severity,
- // body=(urn:onf:yang:air-interface-2-0?revision=2020-01-21)SEVERITY_TYPE_MAJOR}
- String severity_ = optLeafNode.body().toString();
- return severity_.substring(severity_.indexOf(')') + 1); // Any other solution??
- }
- return optLeafNode.body().toString();
+ return getLeafValueX(componentEntry, leafQName);
} catch (VerifyException ve) {
LOG.debug("Leaf with QName {} not found", leafQName);
return null;
}
}
+ /**
+ * Return value as Integer
+ *
+ * @param componentEntry Container node with data
+ * @param leafQName Leaf to be converted
+ * @return Integer with value
+ * @throws IllegalArgumentException, VerifyException
+ */
+ public static Integer getLeafValueInt(DataContainerNode componentEntry, QName leafQName) {
+ String val = getLeafValueX(componentEntry, leafQName);
+ if (val == null || val.isEmpty())
+ throw new IllegalArgumentException("Value should not be null or empty");
+ return Integer.parseInt(val);
+ }
+
+ /**
+ * Return value as DateAndTime
+ *
+ * @param componentEntry Container node with data
+ * @param leafQName Leaf to be converted
+ * @return DateAndTime value
+ * @throws IllegalArgumentException, VerifyException
+ */
+ public static DateAndTime getLeafValueDateAndTime(DataContainerNode componentEntry, QName leafQName) {
+ return new DateAndTime(getLeafValueX(componentEntry, leafQName));
+ }
+
+ /**
+ * return string with Uuid
+ * @param componentEntry Container node with data
+ * @param resource Leaf to be converted
+ * @return Uuid
+ */
+ public static @Nullable String getLeafValueUuid(DataContainerNode componentEntry, QName resource) {
+ return extractUuid(getLeafValue(componentEntry, resource));
+ }
+
+ /**
+ * return internal severity
+ * @param componentEntry Container node with data
+ * @param resource Leaf to be converted
+ * @return Internal SeverityType
+ */
+ public static @Nullable SeverityType getLeafValueInternalSeverity(DataContainerNode componentEntry, QName resource) {
+ return InternalDataModelSeverity
+ .mapSeverity(Onf14DMDOMUtility.getLeafValue(componentEntry, resource));
+ }
+
+
public static List<String> getLeafListValue(DataContainerNode componentEntry, QName leafListQName) {
List<String> containsChildList = new ArrayList<>();
try {
@@ -80,14 +153,13 @@ public class Onf14DMDOMUtility {
return containsChildList;
}
- public static String getUuidFromEquipment(MapEntryNode equipment) {
+ public static String getUuidFromEquipment(MapEntryNode equipment, QName qName) {
LOG.debug("Equipment Identifier is {}", equipment.getIdentifier());
NodeIdentifierWithPredicates componentKey = equipment.getIdentifier(); // list key
LOG.debug("Key Name is - {}", componentKey.keySet());
- LOG.debug("Key Value is - {}",
- componentKey.getValue(Onf14DevicemanagerQNames.CORE_MODEL_CC_EQPT_GLOBAL_CLASS_UUID));
+ LOG.debug("Key Value is - {}", componentKey.getValue(qName));
- return componentKey.getValue(Onf14DevicemanagerQNames.CORE_MODEL_CC_EQPT_GLOBAL_CLASS_UUID).toString();
+ return componentKey.getValue(qName).toString();
}
public static Instant getNotificationInstant(DOMNotification notification) {
@@ -98,4 +170,16 @@ public class Onf14DMDOMUtility {
}
}
+ private static String extractUuid(String leafValue) {
+ String uuid;
+
+ Matcher matcher = ALARM_RESOURCE_PATTERN.matcher(leafValue);
+ if (matcher.matches() && matcher.groupCount() == 1) {
+ uuid = matcher.group(1);
+ } else {
+ uuid = leafValue;
+ }
+ return uuid;
+ }
+
}
diff --git a/sdnr/wt/devicemanager-onap/onf14/provider/src/main/java/org/onap/ccsdk/features/sdnr/wt/devicemanager/onf14/dom/impl/yangspecs/AirInterface20.java b/sdnr/wt/devicemanager-onap/onf14/provider/src/main/java/org/onap/ccsdk/features/sdnr/wt/devicemanager/onf14/dom/impl/yangspecs/AirInterface20.java
new file mode 100644
index 000000000..19dab4be9
--- /dev/null
+++ b/sdnr/wt/devicemanager-onap/onf14/provider/src/main/java/org/onap/ccsdk/features/sdnr/wt/devicemanager/onf14/dom/impl/yangspecs/AirInterface20.java
@@ -0,0 +1,193 @@
+/*
+ * ============LICENSE_START=======================================================
+ * ONAP : ccsdk features
+ * ================================================================================
+ * Copyright (C) 2020 highstreet technologies GmbH Intellectual Property.
+ * All rights reserved.
+ * ================================================================================
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ * ============LICENSE_END=========================================================
+ *
+ */
+package org.onap.ccsdk.features.sdnr.wt.devicemanager.onf14.dom.impl.yangspecs;
+
+import com.google.common.collect.Sets;
+import java.util.Arrays;
+import java.util.Collection;
+import java.util.List;
+import java.util.Optional;
+import org.eclipse.jdt.annotation.NonNull;
+import org.onap.ccsdk.features.sdnr.wt.devicemanager.onf14.dom.impl.dataprovider.InternalDataModelSeverity;
+import org.onap.ccsdk.features.sdnr.wt.devicemanager.onf14.dom.impl.interfaces.TechnologySpecificPacKeys;
+import org.onap.ccsdk.features.sdnr.wt.devicemanager.onf14.dom.impl.pm.PerformanceDataAirInterface;
+import org.onap.ccsdk.features.sdnr.wt.devicemanager.onf14.dom.impl.qnames.Onf14DevicemanagerQNames;
+import org.onap.ccsdk.features.sdnr.wt.devicemanager.onf14.dom.impl.util.Debug;
+import org.onap.ccsdk.features.sdnr.wt.devicemanager.onf14.dom.impl.util.Onf14DMDOMUtility;
+import org.onap.ccsdk.features.sdnr.wt.devicemanager.types.FaultData;
+import org.onap.ccsdk.features.sdnr.wt.devicemanager.types.PerformanceDataLtp;
+import org.onap.ccsdk.features.sdnr.wt.netconfnodestateservice.Capabilities;
+import org.onap.ccsdk.features.sdnr.wt.netconfnodestateservice.NetconfDomAccessor;
+import org.opendaylight.mdsal.common.api.LogicalDatastoreType;
+import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.yang.types.rev130715.DateAndTime;
+import org.opendaylight.yangtools.yang.common.QNameModule;
+import org.opendaylight.yangtools.yang.common.Revision;
+import org.opendaylight.yangtools.yang.common.XMLNamespace;
+import org.opendaylight.yangtools.yang.data.api.YangInstanceIdentifier;
+import org.opendaylight.yangtools.yang.data.api.YangInstanceIdentifier.AugmentationIdentifier;
+import org.opendaylight.yangtools.yang.data.api.YangInstanceIdentifier.InstanceIdentifierBuilder;
+import org.opendaylight.yangtools.yang.data.api.YangInstanceIdentifier.NodeIdentifier;
+import org.opendaylight.yangtools.yang.data.api.schema.AugmentationNode;
+import org.opendaylight.yangtools.yang.data.api.schema.ContainerNode;
+import org.opendaylight.yangtools.yang.data.api.schema.MapEntryNode;
+import org.opendaylight.yangtools.yang.data.api.schema.MapNode;
+import org.opendaylight.yangtools.yang.data.api.schema.NormalizedNode;
+import org.slf4j.Logger;
+import org.slf4j.LoggerFactory;
+
+public class AirInterface20 extends YangModule {
+
+ private static final Logger LOG = LoggerFactory.getLogger(AirInterface20.class);
+
+ private static String NAMESPACE = "urn:onf:yang:air-interface-2-0";
+ private static final List<QNameModule> MODULES =
+ Arrays.asList(QNameModule.create(XMLNamespace.of(NAMESPACE), Revision.of("2020-01-21")),
+ QNameModule.create(XMLNamespace.of(NAMESPACE), Revision.of("2022-07-29")));
+
+ private final CoreModel14 coreModel14;
+
+ private AirInterface20(NetconfDomAccessor netconfDomAccessor, QNameModule module, CoreModel14 coreModel14) {
+ super(netconfDomAccessor, module);
+ this.coreModel14 = coreModel14;
+ }
+
+ public FaultData readAllCurrentProblems(FaultData resultList,
+ List<TechnologySpecificPacKeys> airInterfaceList) {
+
+ int idxStart; // Start index for debug messages
+
+ for (TechnologySpecificPacKeys key : airInterfaceList) {
+ idxStart = resultList.size();
+ readAirInterfaceCurrentProblemForLtp(key.getLtpUuid(), key.getLocalId(), resultList);
+ Debug.debugResultList(key.getLtpUuid(), resultList, idxStart);
+ }
+ return resultList;
+ }
+
+ /**
+ * Get specific module for device, depending on capabilities
+ */
+ public static Optional<AirInterface20> getModule(NetconfDomAccessor netconfDomAccessor, CoreModel14 coreModel14) {
+
+ Capabilities capabilities = netconfDomAccessor.getCapabilites();
+ for (QNameModule module : MODULES) {
+
+ if (capabilities.isSupportingNamespaceAndRevision(module)) {
+ return Optional.of(new AirInterface20(netconfDomAccessor, module, coreModel14));
+ }
+ }
+ return Optional.empty();
+ }
+
+ private FaultData readAirInterfaceCurrentProblemForLtp(String ltpUuid, String localId, FaultData resultList) {
+
+ LOG.debug("DBRead Get current problems for class {} from mountpoint {} for LTP uuid {} and local-id {}",
+ getQNameModule(), netconfDomAccessor.getNodeId().getValue(), ltpUuid, localId);
+
+ // constructing the IID needs the augmentation exposed by the air-interface-2-0
+ // model
+
+ YangInstanceIdentifier layerProtocolIID = coreModel14.getLayerProtocolIId(ltpUuid, localId);
+
+ @NonNull
+ AugmentationIdentifier airInterfacePacIID =
+ YangInstanceIdentifier.AugmentationIdentifier.create(Sets.newHashSet(getQName("air-interface-pac")));
+
+ InstanceIdentifierBuilder augmentedAirInterfacePacIID =
+ YangInstanceIdentifier.builder(layerProtocolIID).node(airInterfacePacIID);
+
+ // reading all the current-problems list for this specific LTP and LP
+ Optional<NormalizedNode> airInterfacePacDataOpt =
+ netconfDomAccessor.readDataNode(LogicalDatastoreType.OPERATIONAL, augmentedAirInterfacePacIID.build());
+
+ if (airInterfacePacDataOpt.isPresent()) {
+ AugmentationNode airInterfacePacData = (AugmentationNode) airInterfacePacDataOpt.get();
+ MapNode airInterfaceCurrentProblemsList =
+ (MapNode) airInterfacePacData.childByArg(new NodeIdentifier(getQName("current-problem-list")));
+ if (airInterfaceCurrentProblemsList != null) {
+ Collection<MapEntryNode> airInterfaceProblemsCollection = airInterfaceCurrentProblemsList.body();
+ for (MapEntryNode airInterfaceProblem : airInterfaceProblemsCollection) {
+ resultList.add(netconfDomAccessor.getNodeId(),
+ Integer.parseInt(
+ Onf14DMDOMUtility.getLeafValue(airInterfaceProblem, getQName("sequence-number"))),
+ new DateAndTime(Onf14DMDOMUtility.getLeafValue(airInterfaceProblem, getQName("timestamp"))),
+ ltpUuid, Onf14DMDOMUtility.getLeafValue(airInterfaceProblem, getQName("problem-name")),
+ InternalDataModelSeverity.mapSeverity(
+ Onf14DMDOMUtility.getLeafValue(airInterfaceProblem, getQName("problem-severity"))));
+ }
+ } else {
+ LOG.debug("DBRead Id {} empty CurrentProblemList", ltpUuid);
+ }
+ }
+ return resultList;
+ }
+
+ public PerformanceDataLtp readAirInterfaceHistoricalPerformanceData(String ltpUuid, String localId,
+ PerformanceDataLtp res) {
+ LOG.debug("Get historical performance data for class {} from mountpoint {} for LTP uuid {} and local-id {}",
+ Onf14DevicemanagerQNames.AIR_INTERFACE_2_0_MODULE, netconfDomAccessor.getNodeId().getValue(), ltpUuid,
+ localId);
+
+ // constructing the IID needs the augmentation exposed by the air-interface-2-0
+ // model
+
+ YangInstanceIdentifier layerProtocolIID = coreModel14.getLayerProtocolIId(ltpUuid, localId);
+
+ @NonNull
+ AugmentationIdentifier airInterfacePacIID = YangInstanceIdentifier.AugmentationIdentifier
+ .create(Sets.newHashSet(Onf14DevicemanagerQNames.AIR_INTERFACE_PAC));
+
+ InstanceIdentifierBuilder augmentedAirInterfacePacIID =
+ YangInstanceIdentifier.builder(layerProtocolIID).node(airInterfacePacIID);
+
+ // reading historical performance list for this specific LTP and LP
+ Optional<NormalizedNode> airInterfacePacDataOpt =
+ netconfDomAccessor.readDataNode(LogicalDatastoreType.OPERATIONAL, augmentedAirInterfacePacIID.build());
+ LOG.debug("Performance Data = {}", airInterfacePacDataOpt.get().body());
+ if (airInterfacePacDataOpt.isPresent()) {
+ AugmentationNode airInterfacePacData = (AugmentationNode) airInterfacePacDataOpt.get();
+ ContainerNode cn = (ContainerNode) airInterfacePacData
+ .childByArg(new NodeIdentifier(Onf14DevicemanagerQNames.AIR_INTERFACE_PAC));
+ if (cn != null) {
+ ContainerNode airIntfHistPerf = (ContainerNode) cn
+ .childByArg(new NodeIdentifier(Onf14DevicemanagerQNames.AIR_INTERFACE_HISTORICAL_PERFORMANCES));
+ if (airIntfHistPerf != null) {
+ MapNode airInterfaceHistoricalPerformanceList = (MapNode) airIntfHistPerf.childByArg(
+ new NodeIdentifier(Onf14DevicemanagerQNames.AIR_INTERFACE_HISTORICAL_PERFORMANCES_LIST));
+ if (airInterfaceHistoricalPerformanceList != null) {
+ Collection<MapEntryNode> airInterfaceHistoricalPerfCollection =
+ airInterfaceHistoricalPerformanceList.body();
+ for (MapEntryNode airInterfaceHistPerf : airInterfaceHistoricalPerfCollection) {
+ res.add(new PerformanceDataAirInterface(netconfDomAccessor.getNodeId(), ltpUuid, localId,
+ airInterfaceHistPerf));
+ }
+ return res;
+ } else {
+ LOG.debug("DBRead Id {} empty CurrentProblemList", ltpUuid);
+ }
+ }
+ }
+ }
+ return null;
+
+ }
+}
diff --git a/sdnr/wt/devicemanager-onap/onf14/provider/src/main/java/org/onap/ccsdk/features/sdnr/wt/devicemanager/onf14/dom/impl/yangspecs/Alarms10.java b/sdnr/wt/devicemanager-onap/onf14/provider/src/main/java/org/onap/ccsdk/features/sdnr/wt/devicemanager/onf14/dom/impl/yangspecs/Alarms10.java
new file mode 100644
index 000000000..3f92eb0ca
--- /dev/null
+++ b/sdnr/wt/devicemanager-onap/onf14/provider/src/main/java/org/onap/ccsdk/features/sdnr/wt/devicemanager/onf14/dom/impl/yangspecs/Alarms10.java
@@ -0,0 +1,195 @@
+/*
+ * ============LICENSE_START=======================================================
+ * ONAP : ccsdk features
+ * ================================================================================
+ * Copyright (C) 2020 highstreet technologies GmbH Intellectual Property.
+ * All rights reserved.
+ * ================================================================================
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ * ============LICENSE_END=========================================================
+ *
+ */
+package org.onap.ccsdk.features.sdnr.wt.devicemanager.onf14.dom.impl.yangspecs;
+
+import com.google.common.collect.Sets;
+import java.util.Arrays;
+import java.util.Collection;
+import java.util.List;
+import java.util.Optional;
+import org.eclipse.jdt.annotation.NonNull;
+import org.onap.ccsdk.features.sdnr.wt.devicemanager.onf14.dom.impl.util.Onf14DMDOMUtility;
+import org.onap.ccsdk.features.sdnr.wt.devicemanager.types.FaultData;
+import org.onap.ccsdk.features.sdnr.wt.netconfnodestateservice.Capabilities;
+import org.onap.ccsdk.features.sdnr.wt.netconfnodestateservice.NetconfDomAccessor;
+import org.onap.ccsdk.features.sdnr.wt.websocketmanager.model.WebsocketManagerService;
+import org.opendaylight.mdsal.common.api.LogicalDatastoreType;
+import org.opendaylight.mdsal.dom.api.DOMNotification;
+import org.opendaylight.mdsal.dom.api.DOMNotificationListener;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.data.provider.rev201110.FaultlogBuilder;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.data.provider.rev201110.FaultlogEntity;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.data.provider.rev201110.SourceType;
+import org.opendaylight.yang.gen.v1.urn.tbd.params.xml.ns.yang.network.topology.rev131021.NodeId;
+import org.opendaylight.yangtools.yang.common.QName;
+import org.opendaylight.yangtools.yang.common.QNameModule;
+import org.opendaylight.yangtools.yang.common.Revision;
+import org.opendaylight.yangtools.yang.common.XMLNamespace;
+import org.opendaylight.yangtools.yang.data.api.YangInstanceIdentifier;
+import org.opendaylight.yangtools.yang.data.api.YangInstanceIdentifier.AugmentationIdentifier;
+import org.opendaylight.yangtools.yang.data.api.YangInstanceIdentifier.InstanceIdentifierBuilder;
+import org.opendaylight.yangtools.yang.data.api.YangInstanceIdentifier.NodeIdentifier;
+import org.opendaylight.yangtools.yang.data.api.schema.AugmentationNode;
+import org.opendaylight.yangtools.yang.data.api.schema.ContainerNode;
+import org.opendaylight.yangtools.yang.data.api.schema.MapEntryNode;
+import org.opendaylight.yangtools.yang.data.api.schema.MapNode;
+import org.opendaylight.yangtools.yang.data.api.schema.NormalizedNode;
+import org.opendaylight.yangtools.yang.model.api.stmt.SchemaNodeIdentifier.Absolute;
+import org.slf4j.Logger;
+import org.slf4j.LoggerFactory;
+
+public class Alarms10 extends YangModule {
+
+ private static final Logger LOG = LoggerFactory.getLogger(Alarms10.class);
+
+ private static final String NAMESPACE = "urn:onf:yang:alarms-1-0";
+ private static final List<QNameModule> MODULES =
+ Arrays.asList(QNameModule.create(XMLNamespace.of(NAMESPACE), Revision.of("2022-03-02")),
+ QNameModule.create(XMLNamespace.of(NAMESPACE), Revision.of("2022-07-29")));
+
+ private final QName ALARM_PAC;
+ private final QName CURRENT_ALARMS;
+ private final QName CURRENT_ALARM_LIST;
+ private final QName CURRENT_ALARM_IDENTIFIER;
+ private final QName ALARM_TYPE_ID;
+ private final QName ALARM_TYPE_QUALIFIER;
+ private final QName RESOURCE;
+ private final QName ALARM_SEVERITY;
+ private final QName ALARM_TIMESTAMP;
+ private final QName ALARM_EVENT_SEQUENCE_NUMBER;
+ private final QName PROBLEM_SEVERITY;
+ private final QName ALARM_AVC_NOTIFICATION;
+ private final QName ALARM_EVENT_NOTIFICATION;
+
+ private final CoreModel14 coreModel14;
+
+ private Alarms10(NetconfDomAccessor netconfDomAccessor, QNameModule module, CoreModel14 coreModel14) {
+ super(netconfDomAccessor, module);
+ this.coreModel14 = coreModel14;
+
+ ALARM_PAC = QName.create(module, "alarm-pac");
+ CURRENT_ALARMS = QName.create(module, "current-alarms");
+ CURRENT_ALARM_LIST = QName.create(module, "current-alarm-list");
+ CURRENT_ALARM_IDENTIFIER = QName.create(module, "current-alarm-identifier");
+ ALARM_TYPE_ID = QName.create(module, "alarm-type-id");
+ ALARM_TYPE_QUALIFIER = QName.create(module, "alarm-type-qualifier");
+ RESOURCE = QName.create(module, "resource");
+ ALARM_SEVERITY = QName.create(module, "alarm-severity");
+ ALARM_TIMESTAMP = QName.create(module, "timestamp");
+ ALARM_EVENT_SEQUENCE_NUMBER = QName.create(module, "alarm-event-sequence-number");
+ PROBLEM_SEVERITY = QName.create(module, "problem-severity");
+ ALARM_AVC_NOTIFICATION = QName.create(module, "attribute-value-changed-notification");
+ ALARM_EVENT_NOTIFICATION = QName.create(module, "alarm-event-notification");
+ }
+
+ public QNameModule getModule() {
+ return module;
+ }
+
+ public FaultlogEntity getFaultlogEntity(ContainerNode cn) {
+ return new FaultlogBuilder().setNodeId(getNodeId().getValue()).setSourceType(SourceType.Netconf)
+ .setObjectId(Onf14DMDOMUtility.getLeafValueUuid(cn, RESOURCE))
+ .setProblem(Onf14DMDOMUtility.getLeafValue(cn, ALARM_TYPE_QUALIFIER))
+ .setTimestamp(Onf14DMDOMUtility.getLeafValueDateAndTime(cn, ALARM_TIMESTAMP))
+ .setSeverity(Onf14DMDOMUtility.getLeafValueInternalSeverity(cn, PROBLEM_SEVERITY))
+ .setCounter(Onf14DMDOMUtility.getLeafValueInt(cn, ALARM_EVENT_SEQUENCE_NUMBER)).build();
+ }
+
+ public boolean isAlarmEventNotification(DOMNotification domNotification) {
+ return domNotification.getType().equals(Absolute.of(ALARM_EVENT_NOTIFICATION));
+ }
+
+ public void doRegisterNotificationListener(DOMNotificationListener alarmNotifListener) {
+ QName[] alarmNotifications = {ALARM_AVC_NOTIFICATION, ALARM_EVENT_NOTIFICATION};
+ netconfDomAccessor.doRegisterNotificationListener(alarmNotifListener, alarmNotifications);
+ }
+
+ public void sendNotification(@NonNull WebsocketManagerService websocketService, DOMNotification domNotification,
+ ContainerNode cn) {
+ websocketService.sendNotification(domNotification, getNodeId(), ALARM_TYPE_QUALIFIER,
+ Onf14DMDOMUtility.getLeafValueDateAndTime(cn, ALARM_TIMESTAMP));
+ }
+
+ public FaultData getCurrentAlarms() {
+
+ YangInstanceIdentifier alarmsPacIID =
+ YangInstanceIdentifier.builder().node(coreModel14.getControlConstructQName()).build();
+
+ @NonNull
+ AugmentationIdentifier alarmsContainerIID =
+ YangInstanceIdentifier.AugmentationIdentifier.create(Sets.newHashSet(ALARM_PAC));
+
+ InstanceIdentifierBuilder augmentedAlarmsIID =
+ YangInstanceIdentifier.builder(alarmsPacIID).node(alarmsContainerIID);
+
+ // reading all the alarms
+ Optional<NormalizedNode> alarms =
+ this.getNetconfDomAccessor().readDataNode(LogicalDatastoreType.OPERATIONAL, augmentedAlarmsIID.build());
+
+ FaultData resultList = new FaultData();
+ if (alarms.isPresent()) {
+ AugmentationNode alarmsDataNode = (AugmentationNode) alarms.get();
+ ContainerNode alarmsContainer = (ContainerNode) alarmsDataNode.childByArg(new NodeIdentifier(ALARM_PAC));
+ ContainerNode currentAlarmsContainer =
+ (ContainerNode) alarmsContainer.childByArg(new NodeIdentifier(CURRENT_ALARMS));
+ MapNode currentAlarmsList =
+ (MapNode) currentAlarmsContainer.childByArg(new NodeIdentifier(CURRENT_ALARM_LIST));
+ if (currentAlarmsList != null) {
+ Collection<MapEntryNode> currentAlarmsCollection = currentAlarmsList.body();
+ for (MapEntryNode currentAlarm : currentAlarmsCollection) {
+ resultList.add(getNodeId(),
+ Onf14DMDOMUtility.getLeafValueInt(currentAlarm, CURRENT_ALARM_IDENTIFIER),
+ Onf14DMDOMUtility.getLeafValueDateAndTime(currentAlarm, ALARM_TIMESTAMP),
+ Onf14DMDOMUtility.getLeafValueUuid(currentAlarm, RESOURCE),
+ Onf14DMDOMUtility.getLeafValue(currentAlarm, ALARM_TYPE_QUALIFIER),
+ Onf14DMDOMUtility.getLeafValueInternalSeverity(currentAlarm, ALARM_SEVERITY));
+ }
+ } else {
+ LOG.debug("DBRead empty CurrentProblemList");
+ }
+ }
+ return resultList;
+ }
+
+ public boolean isSupported(Capabilities capabilites) {
+ return netconfDomAccessor.getCapabilites().isSupportingNamespace(NAMESPACE);
+ }
+
+ private NodeId getNodeId() {
+ return netconfDomAccessor.getNodeId();
+ }
+
+ /**
+ * Get specific instance, depending on capabilities
+ *
+ * @param capabilities
+ * @return
+ */
+ public static Optional<Alarms10> getModule(NetconfDomAccessor netconfDomAccessor, CoreModel14 coreModel14) {
+ Capabilities capabilities = netconfDomAccessor.getCapabilites();
+ for (QNameModule module : MODULES) {
+ if (capabilities.isSupportingNamespaceAndRevision(module)) {
+ return Optional.of(new Alarms10(netconfDomAccessor, module, coreModel14));
+ }
+ }
+ return Optional.empty();
+ }
+}
diff --git a/sdnr/wt/devicemanager-onap/onf14/provider/src/main/java/org/onap/ccsdk/features/sdnr/wt/devicemanager/onf14/dom/impl/yangspecs/CoreModel14.java b/sdnr/wt/devicemanager-onap/onf14/provider/src/main/java/org/onap/ccsdk/features/sdnr/wt/devicemanager/onf14/dom/impl/yangspecs/CoreModel14.java
new file mode 100644
index 000000000..5a2b5772b
--- /dev/null
+++ b/sdnr/wt/devicemanager-onap/onf14/provider/src/main/java/org/onap/ccsdk/features/sdnr/wt/devicemanager/onf14/dom/impl/yangspecs/CoreModel14.java
@@ -0,0 +1,190 @@
+/*
+ * ============LICENSE_START=======================================================
+ * ONAP : ccsdk features
+ * ================================================================================
+ * Copyright (C) 2022 highstreet technologies GmbH Intellectual Property.
+ * All rights reserved.
+ * ================================================================================
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ * ============LICENSE_END=========================================================
+ *
+ */
+package org.onap.ccsdk.features.sdnr.wt.devicemanager.onf14.dom.impl.yangspecs;
+
+import java.util.ArrayList;
+import java.util.Arrays;
+import java.util.Collection;
+import java.util.Collections;
+import java.util.List;
+import java.util.Optional;
+import org.onap.ccsdk.features.sdnr.wt.devicemanager.onf14.dom.impl.interfaces.Onf14Interfaces;
+import org.onap.ccsdk.features.sdnr.wt.devicemanager.onf14.dom.impl.interfaces.TechnologySpecificPacKeys;
+import org.onap.ccsdk.features.sdnr.wt.devicemanager.onf14.dom.impl.util.Onf14DMDOMUtility;
+import org.onap.ccsdk.features.sdnr.wt.netconfnodestateservice.Capabilities;
+import org.onap.ccsdk.features.sdnr.wt.netconfnodestateservice.NetconfDomAccessor;
+import org.opendaylight.mdsal.common.api.LogicalDatastoreType;
+import org.opendaylight.yangtools.yang.common.QName;
+import org.opendaylight.yangtools.yang.common.QNameModule;
+import org.opendaylight.yangtools.yang.common.Revision;
+import org.opendaylight.yangtools.yang.common.XMLNamespace;
+import org.opendaylight.yangtools.yang.data.api.YangInstanceIdentifier;
+import org.opendaylight.yangtools.yang.data.api.YangInstanceIdentifier.NodeIdentifier;
+import org.opendaylight.yangtools.yang.data.api.schema.DataContainerNode;
+import org.opendaylight.yangtools.yang.data.api.schema.MapEntryNode;
+import org.opendaylight.yangtools.yang.data.api.schema.MapNode;
+import org.opendaylight.yangtools.yang.data.api.schema.NormalizedNode;
+import org.slf4j.Logger;
+import org.slf4j.LoggerFactory;
+
+public class CoreModel14 extends YangModule {
+
+ private static final Logger LOG = LoggerFactory.getLogger(CoreModel14.class);
+
+ private static final String NAMESPACE = "urn:onf:yang:core-model-1-4";
+ private static final List<QNameModule> MODULES =
+ Arrays.asList(QNameModule.create(XMLNamespace.of(NAMESPACE), Revision.of("2019-11-27")));
+
+ private final QName CONTROL_CONSTRUCT;
+ private final QName TOP_LEVEL_EQUIPMENT;
+
+ private CoreModel14(NetconfDomAccessor netconfDomAccessor, QNameModule module) {
+ super(netconfDomAccessor, module);
+
+ CONTROL_CONSTRUCT = QName.create(module, "control-construct");
+ TOP_LEVEL_EQUIPMENT = QName.create(module, "top-level-equipment");
+ }
+
+ public String getRevision() {
+ return module.getRevision().get().toString();
+ }
+
+ @Override
+ public QName getQName(String localName) {
+ return QName.create(module, localName);
+ }
+
+ public QName getControlConstructQName() {
+ return CONTROL_CONSTRUCT;
+ }
+
+ public YangInstanceIdentifier getTopLevelEquipment_IId() {
+ return YangInstanceIdentifier.builder().node(getControlConstructQName()).node(TOP_LEVEL_EQUIPMENT).build();
+ }
+
+ private YangInstanceIdentifier getLtp_IID() {
+ return YangInstanceIdentifier.builder().node(getQName("control-construct"))
+ .node(getQName("logical-termination-point")).build();
+ }
+
+ public YangInstanceIdentifier getLayerProtocolIId(String ltpUuid, String localId) {
+ return YangInstanceIdentifier.builder().node(getQName("control-construct"))
+ .node(getQName("logical-termination-point"))
+ .nodeWithKey(getQName("logical-termination-point"),
+ QName.create(getQName("logical-termination-point"), "uuid").intern(), ltpUuid)
+ .node(getQName("layer-protocol")).nodeWithKey(getQName("layer-protocol"),
+ QName.create(getQName("layer-protocol"), "local-id").intern(), localId)
+ .build();
+ }
+
+ public Optional<NormalizedNode> readLtpData(NetconfDomAccessor netconfDomAccessor) {
+ LOG.info("Reading Logical Termination Point data");
+ return netconfDomAccessor.readDataNode(LogicalDatastoreType.CONFIGURATION, getLtp_IID());
+ }
+
+ /**
+ * Get the LP list, which should contain only 1 entry. the Layer Protocol list should contain only one item, since
+ * we have an 1:1 relationship between the LTP and the LP
+ *
+ * @param ltp
+ * @return
+ */
+ private Collection<MapEntryNode> getInterfaceKeyList(DataContainerNode ltp) {
+ MapNode lpList = (MapNode) ltp.childByArg(new NodeIdentifier(getQName("layer-protocol")));
+ // the Layer Protocol list should contain only one item, since we have an 1:1
+ // relationship between the LTP and the LP
+ if (lpList != null && lpList.size() != 1) {
+ LOG.debug("Layer protocol has no 1:1 relationship with the LTP.");
+ return Collections.emptyList();
+ }
+ // accessing the LP, which should be only 1
+ return lpList.body();
+ }
+
+ /**
+ * Search through the LayerProtocol list for specific layerProtocolNamesValues
+ * @param ltp
+ * @param lp
+ * @param layerProtocolNameValue
+ * @return
+ */
+ private List<TechnologySpecificPacKeys> getTechnologySpecificPackKeys(DataContainerNode ltp, Collection<MapEntryNode> lp,
+ String layerProtocolNameValue) {
+ List<TechnologySpecificPacKeys> interfaceList = new ArrayList<>();
+ for (MapEntryNode lpEntry : lp) {
+ String layerProtocolName = Onf14DMDOMUtility.getLeafValue(lpEntry, getQName("layer-protocol-name"));
+ if (layerProtocolName != null && layerProtocolName.contains(layerProtocolNameValue)) {
+ TechnologySpecificPacKeys interfaceKey =
+ new TechnologySpecificPacKeys(Onf14DMDOMUtility.getLeafValue(ltp, getQName("uuid")),
+ Onf14DMDOMUtility.getLeafValue(lpEntry, getQName("local-id")));
+ interfaceList.add(interfaceKey);
+ LOG.debug("Adding Ltp with uuid {} and local-id {} to the {} list", interfaceKey.getLtpUuid(),
+ interfaceKey.getLocalId(), layerProtocolNameValue);
+ }
+ }
+ return interfaceList;
+ }
+
+ public Onf14Interfaces readKeys(Onf14Interfaces interfaces) {
+
+ Optional<NormalizedNode> ltpData = readLtpData(netconfDomAccessor);
+ LOG.debug("LTP Data is - {}", ltpData);
+ if (ltpData.isPresent()) {
+ LOG.debug("In readKeys - ltpData = {}", ltpData.get());
+
+ MapNode ccLtp = (MapNode) ltpData.get();
+ if (ccLtp != null) {
+ LOG.debug("Iterating the LTP list for node {}", netconfDomAccessor.getNodeId().getValue());
+ Collection<MapEntryNode> ltpList = ccLtp.body();
+
+ // iterating all the Logical Termination Point list
+ for (MapEntryNode ltp : ltpList) {
+ Collection<MapEntryNode> lp = getInterfaceKeyList(ltp);
+
+ interfaces.add(Onf14Interfaces.Key.AIRINTERFACE,
+ getTechnologySpecificPackKeys(ltp, lp, "LAYER_PROTOCOL_NAME_TYPE_AIR_LAYER"));
+ interfaces.add(Onf14Interfaces.Key.ETHERNETCONTAINER,
+ getTechnologySpecificPackKeys(ltp, lp, "LAYER_PROTOCOL_NAME_TYPE_ETHERNET_CONTAINER_LAYER"));
+ interfaces.add(Onf14Interfaces.Key.WIREINTERFACE,
+ getTechnologySpecificPackKeys(ltp, lp, "LAYER_PROTOCOL_NAME_TYPE_WIRE_LAYER"));
+ }
+ }
+ }
+ return interfaces;
+ }
+
+ /**
+ * Get specific module for device, depending on capabilities
+ */
+ public static Optional<CoreModel14> getModule(NetconfDomAccessor netconfDomAccessor) {
+
+ Capabilities capabilities = netconfDomAccessor.getCapabilites();
+ for (QNameModule module : MODULES) {
+
+ if (capabilities.isSupportingNamespaceAndRevision(module)) {
+ return Optional.of(new CoreModel14(netconfDomAccessor, module));
+ }
+ }
+ return Optional.empty();
+ }
+
+}
diff --git a/sdnr/wt/devicemanager-onap/onf14/provider/src/main/java/org/onap/ccsdk/features/sdnr/wt/devicemanager/onf14/dom/impl/yangspecs/EthernetContainer20.java b/sdnr/wt/devicemanager-onap/onf14/provider/src/main/java/org/onap/ccsdk/features/sdnr/wt/devicemanager/onf14/dom/impl/yangspecs/EthernetContainer20.java
new file mode 100644
index 000000000..81aec9dd0
--- /dev/null
+++ b/sdnr/wt/devicemanager-onap/onf14/provider/src/main/java/org/onap/ccsdk/features/sdnr/wt/devicemanager/onf14/dom/impl/yangspecs/EthernetContainer20.java
@@ -0,0 +1,145 @@
+/*
+ * ============LICENSE_START=======================================================
+ * ONAP : ccsdk features
+ * ================================================================================
+ * Copyright (C) 2020 highstreet technologies GmbH Intellectual Property.
+ * All rights reserved.
+ * ================================================================================
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ * ============LICENSE_END=========================================================
+ *
+ */
+package org.onap.ccsdk.features.sdnr.wt.devicemanager.onf14.dom.impl.yangspecs;
+
+import com.google.common.collect.Sets;
+import java.util.Arrays;
+import java.util.Collection;
+import java.util.List;
+import java.util.Optional;
+import org.eclipse.jdt.annotation.NonNull;
+import org.onap.ccsdk.features.sdnr.wt.devicemanager.onf14.dom.impl.dataprovider.InternalDataModelSeverity;
+import org.onap.ccsdk.features.sdnr.wt.devicemanager.onf14.dom.impl.interfaces.TechnologySpecificPacKeys;
+import org.onap.ccsdk.features.sdnr.wt.devicemanager.onf14.dom.impl.util.Debug;
+import org.onap.ccsdk.features.sdnr.wt.devicemanager.onf14.dom.impl.util.Onf14DMDOMUtility;
+import org.onap.ccsdk.features.sdnr.wt.devicemanager.types.FaultData;
+import org.onap.ccsdk.features.sdnr.wt.netconfnodestateservice.Capabilities;
+import org.onap.ccsdk.features.sdnr.wt.netconfnodestateservice.NetconfDomAccessor;
+import org.opendaylight.mdsal.common.api.LogicalDatastoreType;
+import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.yang.types.rev130715.DateAndTime;
+import org.opendaylight.yangtools.yang.common.QNameModule;
+import org.opendaylight.yangtools.yang.common.Revision;
+import org.opendaylight.yangtools.yang.common.XMLNamespace;
+import org.opendaylight.yangtools.yang.data.api.YangInstanceIdentifier;
+import org.opendaylight.yangtools.yang.data.api.YangInstanceIdentifier.AugmentationIdentifier;
+import org.opendaylight.yangtools.yang.data.api.YangInstanceIdentifier.InstanceIdentifierBuilder;
+import org.opendaylight.yangtools.yang.data.api.YangInstanceIdentifier.NodeIdentifier;
+import org.opendaylight.yangtools.yang.data.api.schema.AugmentationNode;
+import org.opendaylight.yangtools.yang.data.api.schema.MapEntryNode;
+import org.opendaylight.yangtools.yang.data.api.schema.MapNode;
+import org.opendaylight.yangtools.yang.data.api.schema.NormalizedNode;
+import org.slf4j.Logger;
+import org.slf4j.LoggerFactory;
+
+public class EthernetContainer20 extends YangModule {
+
+ private static final Logger LOG = LoggerFactory.getLogger(EthernetContainer20.class);
+
+ private static String NAMESPACE = "urn:onf:yang:ethernet-container-2-0";
+ private static final List<QNameModule> MODULES =
+ Arrays.asList(QNameModule.create(XMLNamespace.of(NAMESPACE), Revision.of("2020-01-21")));
+
+ private final CoreModel14 coreModel14;
+
+ public EthernetContainer20(NetconfDomAccessor netconfDomAccessor, QNameModule module, CoreModel14 coreModel14) {
+ super(netconfDomAccessor, module);
+ this.coreModel14 = coreModel14;
+ }
+
+ private FaultData readEthernetContainerCurrentProblemForLtp(String ltpUuid, String localId, FaultData resultList) {
+
+ LOG.debug(
+ "DBRead Get current problems for Ethernet Container from mountpoint {} for LTP uuid {} and local-id {}",
+ netconfDomAccessor.getNodeId().getValue(), ltpUuid, localId);
+
+ // constructing the IID needs the augmentation exposed by the
+ // ethernet-container-2-0 model
+ YangInstanceIdentifier layerProtocolIID = coreModel14.getLayerProtocolIId(ltpUuid, localId);
+
+ @NonNull
+ AugmentationIdentifier ethernetContainerIID = YangInstanceIdentifier.AugmentationIdentifier
+ .create(Sets.newHashSet(getQName("ethernet-container-pac")));
+
+ InstanceIdentifierBuilder augmentedEthernetContainerConfigurationIID =
+ YangInstanceIdentifier.builder(layerProtocolIID).node(ethernetContainerIID);
+
+ // reading all the current-problems list for this specific LTP and LP
+ Optional<NormalizedNode> etherntContainerConfigurationOpt = netconfDomAccessor
+ .readDataNode(LogicalDatastoreType.OPERATIONAL, augmentedEthernetContainerConfigurationIID.build());
+
+ if (etherntContainerConfigurationOpt.isPresent()) {
+ AugmentationNode etherntContainerConfiguration = (AugmentationNode) etherntContainerConfigurationOpt.get();
+ MapNode ethernetContainerCurrentProblemsList = (MapNode) etherntContainerConfiguration
+ .childByArg(new NodeIdentifier(getQName("current-problem-list")));
+ if (ethernetContainerCurrentProblemsList != null) {
+ Collection<MapEntryNode> ethernetContainerProblemsCollection =
+ ethernetContainerCurrentProblemsList.body();
+ for (MapEntryNode ethernetContainerProblem : ethernetContainerProblemsCollection) {
+ resultList.add(netconfDomAccessor.getNodeId(),
+ Integer.parseInt(Onf14DMDOMUtility.getLeafValue(ethernetContainerProblem,
+ getQName("sequence-number"))),
+ new DateAndTime(
+ Onf14DMDOMUtility.getLeafValue(ethernetContainerProblem, getQName("timestamp"))),
+ ltpUuid, Onf14DMDOMUtility.getLeafValue(ethernetContainerProblem, getQName("problem-name")),
+ InternalDataModelSeverity.mapSeverity(Onf14DMDOMUtility
+ .getLeafValue(ethernetContainerProblem, getQName("problem-severity"))));
+ }
+ } else {
+ LOG.debug("DBRead Id {} empty CurrentProblemList", ltpUuid);
+ }
+ }
+ return resultList;
+ }
+
+ public FaultData readAllCurrentProblems(FaultData resultList,
+ List<TechnologySpecificPacKeys> ethernetContainerList) {
+
+ int idxStart; // Start index for debug messages
+
+ for (TechnologySpecificPacKeys key : ethernetContainerList) {
+ idxStart = resultList.size();
+
+ resultList = readEthernetContainerCurrentProblemForLtp(key.getLtpUuid(), key.getLocalId(), resultList);
+ Debug.debugResultList(key.getLtpUuid(), resultList, idxStart);
+ }
+ return resultList;
+ }
+
+
+
+ /**
+ * Get specific module for device, depending on capabilities
+ */
+ public static Optional<EthernetContainer20> getModule(NetconfDomAccessor netconfDomAccessor,
+ CoreModel14 coreModel14) {
+
+ Capabilities capabilities = netconfDomAccessor.getCapabilites();
+ for (QNameModule module : MODULES) {
+
+ if (capabilities.isSupportingNamespaceAndRevision(module)) {
+ return Optional.of(new EthernetContainer20(netconfDomAccessor, module, coreModel14));
+ }
+ }
+ return Optional.empty();
+ }
+
+}
diff --git a/sdnr/wt/devicemanager-onap/onf14/provider/src/main/java/org/onap/ccsdk/features/sdnr/wt/devicemanager/onf14/dom/impl/yangspecs/WireInterface20.java b/sdnr/wt/devicemanager-onap/onf14/provider/src/main/java/org/onap/ccsdk/features/sdnr/wt/devicemanager/onf14/dom/impl/yangspecs/WireInterface20.java
new file mode 100644
index 000000000..c97449d69
--- /dev/null
+++ b/sdnr/wt/devicemanager-onap/onf14/provider/src/main/java/org/onap/ccsdk/features/sdnr/wt/devicemanager/onf14/dom/impl/yangspecs/WireInterface20.java
@@ -0,0 +1,142 @@
+/*
+ * ============LICENSE_START=======================================================
+ * ONAP : ccsdk features
+ * ================================================================================
+ * Copyright (C) 2020 highstreet technologies GmbH Intellectual Property.
+ * All rights reserved.
+ * ================================================================================
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ * ============LICENSE_END=========================================================
+ *
+ */
+package org.onap.ccsdk.features.sdnr.wt.devicemanager.onf14.dom.impl.yangspecs;
+
+import com.google.common.collect.Sets;
+import java.util.Arrays;
+import java.util.Collection;
+import java.util.List;
+import java.util.Optional;
+import org.eclipse.jdt.annotation.NonNull;
+import org.onap.ccsdk.features.sdnr.wt.devicemanager.onf14.dom.impl.dataprovider.InternalDataModelSeverity;
+import org.onap.ccsdk.features.sdnr.wt.devicemanager.onf14.dom.impl.interfaces.TechnologySpecificPacKeys;
+import org.onap.ccsdk.features.sdnr.wt.devicemanager.onf14.dom.impl.qnames.Onf14DevicemanagerQNames;
+import org.onap.ccsdk.features.sdnr.wt.devicemanager.onf14.dom.impl.util.Debug;
+import org.onap.ccsdk.features.sdnr.wt.devicemanager.onf14.dom.impl.util.Onf14DMDOMUtility;
+import org.onap.ccsdk.features.sdnr.wt.devicemanager.types.FaultData;
+import org.onap.ccsdk.features.sdnr.wt.netconfnodestateservice.Capabilities;
+import org.onap.ccsdk.features.sdnr.wt.netconfnodestateservice.NetconfDomAccessor;
+import org.opendaylight.mdsal.common.api.LogicalDatastoreType;
+import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.yang.types.rev130715.DateAndTime;
+import org.opendaylight.yangtools.yang.common.QNameModule;
+import org.opendaylight.yangtools.yang.common.Revision;
+import org.opendaylight.yangtools.yang.common.XMLNamespace;
+import org.opendaylight.yangtools.yang.data.api.YangInstanceIdentifier;
+import org.opendaylight.yangtools.yang.data.api.YangInstanceIdentifier.AugmentationIdentifier;
+import org.opendaylight.yangtools.yang.data.api.YangInstanceIdentifier.InstanceIdentifierBuilder;
+import org.opendaylight.yangtools.yang.data.api.YangInstanceIdentifier.NodeIdentifier;
+import org.opendaylight.yangtools.yang.data.api.schema.AugmentationNode;
+import org.opendaylight.yangtools.yang.data.api.schema.MapEntryNode;
+import org.opendaylight.yangtools.yang.data.api.schema.MapNode;
+import org.opendaylight.yangtools.yang.data.api.schema.NormalizedNode;
+import org.slf4j.Logger;
+import org.slf4j.LoggerFactory;
+
+public class WireInterface20 extends YangModule {
+
+ private static final Logger LOG = LoggerFactory.getLogger(WireInterface20.class);
+
+ private static String NAMESPACE = "urn:onf:yang:wire-interface-2-0";
+ private static final List<QNameModule> MODULES =
+ Arrays.asList(QNameModule.create(XMLNamespace.of(NAMESPACE), Revision.of("2020-01-23")));
+
+ private final CoreModel14 coreModel14;
+
+ private WireInterface20(NetconfDomAccessor netconfDomAccessor, QNameModule module, CoreModel14 coreModel14) {
+ super(netconfDomAccessor, module);
+ this.coreModel14 = coreModel14;
+ }
+
+ private FaultData readWireInterfaceCurrentProblemForLtp(String ltpUuid, String localId, FaultData resultList) {
+
+ LOG.debug("DBRead Get current problems for Wire Interface from mountpoint {} for LTP uuid {} and local-id {}",
+ netconfDomAccessor.getNodeId().getValue(), ltpUuid, localId);
+
+ // constructing the IID needs the augmentation exposed by the wire-interface-2-0
+ // model
+ YangInstanceIdentifier layerProtocolIID = coreModel14.getLayerProtocolIId(ltpUuid, localId);
+
+ @NonNull
+ AugmentationIdentifier wireInterfacePacIID = YangInstanceIdentifier.AugmentationIdentifier
+ .create(Sets.newHashSet(Onf14DevicemanagerQNames.WIRE_INTERFACE_PAC));
+
+ InstanceIdentifierBuilder augmentedWireInterfaceConfigurationIID =
+ YangInstanceIdentifier.builder(layerProtocolIID).node(wireInterfacePacIID);
+
+ // reading all the current-problems list for this specific LTP and LP
+ Optional<NormalizedNode> wireInterfaceConfigurationOpt = netconfDomAccessor
+ .readDataNode(LogicalDatastoreType.OPERATIONAL, augmentedWireInterfaceConfigurationIID.build());
+
+ if (wireInterfaceConfigurationOpt.isPresent()) {
+ AugmentationNode wireInterfaceConfiguration = (AugmentationNode) wireInterfaceConfigurationOpt.get();
+ MapNode wireInterfaceCurrentProblemsList = (MapNode) wireInterfaceConfiguration
+ .childByArg(new NodeIdentifier(Onf14DevicemanagerQNames.WIRE_INTERFACE_CURRENT_PROBLEMS_LIST));
+ if (wireInterfaceCurrentProblemsList != null) {
+ Collection<MapEntryNode> wireInterfaceProblemsCollection = wireInterfaceCurrentProblemsList.body();
+ for (MapEntryNode wireInterfaceProblem : wireInterfaceProblemsCollection) {
+ resultList.add(netconfDomAccessor.getNodeId(),
+ Integer.parseInt(Onf14DMDOMUtility.getLeafValue(wireInterfaceProblem,
+ Onf14DevicemanagerQNames.WIRE_INTERFACE_CURRENT_PROBLEMS_SEQ_NO)),
+ new DateAndTime(Onf14DMDOMUtility.getLeafValue(wireInterfaceProblem,
+ Onf14DevicemanagerQNames.WIRE_INTERFACE_CURRENT_PROBLEMS_TIMESTAMP)),
+ ltpUuid,
+ Onf14DMDOMUtility.getLeafValue(wireInterfaceProblem,
+ Onf14DevicemanagerQNames.WIRE_INTERFACE_CURRENT_PROBLEMS_PROBLEM_NAME),
+ InternalDataModelSeverity.mapSeverity(Onf14DMDOMUtility.getLeafValue(wireInterfaceProblem,
+ Onf14DevicemanagerQNames.WIRE_INTERFACE_CURRENT_PROBLEMS_PROBLEM_SEVERITY)));
+ }
+ } else {
+ LOG.debug("DBRead Id {} empty CurrentProblemList", ltpUuid);
+ }
+ }
+ return resultList;
+ }
+
+ public FaultData readAllCurrentProblems(FaultData resultList,
+ List<TechnologySpecificPacKeys> wireInterfaceList) {
+
+ int idxStart; // Start index for debug messages
+
+ for (TechnologySpecificPacKeys key : wireInterfaceList) {
+ idxStart = resultList.size();
+
+ resultList = readWireInterfaceCurrentProblemForLtp(key.getLtpUuid(), key.getLocalId(), resultList);
+ Debug.debugResultList(key.getLtpUuid(), resultList, idxStart);
+ }
+ return resultList;
+ }
+
+ /**
+ * Get specific module for device, depending on capabilities
+ */
+ public static Optional<WireInterface20> getModule(NetconfDomAccessor netconfDomAccessor, CoreModel14 coreModel14) {
+
+ Capabilities capabilities = netconfDomAccessor.getCapabilites();
+ for (QNameModule module : MODULES) {
+
+ if (capabilities.isSupportingNamespaceAndRevision(module)) {
+ return Optional.of(new WireInterface20(netconfDomAccessor, module, coreModel14));
+ }
+ }
+ return Optional.empty();
+ }
+}
diff --git a/sdnr/wt/devicemanager-onap/onf14/provider/src/main/java/org/onap/ccsdk/features/sdnr/wt/devicemanager/onf14/dom/impl/yangspecs/YangModule.java b/sdnr/wt/devicemanager-onap/onf14/provider/src/main/java/org/onap/ccsdk/features/sdnr/wt/devicemanager/onf14/dom/impl/yangspecs/YangModule.java
new file mode 100644
index 000000000..915f2fa95
--- /dev/null
+++ b/sdnr/wt/devicemanager-onap/onf14/provider/src/main/java/org/onap/ccsdk/features/sdnr/wt/devicemanager/onf14/dom/impl/yangspecs/YangModule.java
@@ -0,0 +1,51 @@
+/*
+ * ============LICENSE_START=======================================================
+ * ONAP : ccsdk features
+ * ================================================================================
+ * Copyright (C) 2020 highstreet technologies GmbH Intellectual Property.
+ * All rights reserved.
+ * ================================================================================
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ * ============LICENSE_END=========================================================
+ *
+ */
+package org.onap.ccsdk.features.sdnr.wt.devicemanager.onf14.dom.impl.yangspecs;
+
+import org.onap.ccsdk.features.sdnr.wt.netconfnodestateservice.NetconfDomAccessor;
+import org.opendaylight.yangtools.yang.common.QName;
+import org.opendaylight.yangtools.yang.common.QNameModule;
+
+public class YangModule {
+
+ protected final NetconfDomAccessor netconfDomAccessor;
+ protected final QNameModule module;
+
+ YangModule(NetconfDomAccessor netconfDomAccessor, QNameModule module) {
+ super();
+ this.netconfDomAccessor = netconfDomAccessor;
+ this.module = module;
+ }
+
+ NetconfDomAccessor getNetconfDomAccessor() {
+ return netconfDomAccessor;
+ }
+
+ public QNameModule getQNameModule() {
+ return module;
+ }
+
+ public QName getQName(String localName) {
+ return QName.create(module, localName);
+ }
+
+}