Prepare NetworkModel to support ordm 2.2.x devices
[transportpce.git] / networkmodel / src / main / java / org / opendaylight / transportpce / networkmodel / service / NetworkModelServiceImpl.java
index 39d8921128dee99a3ca1515928d79c272aa9158e..73bcecd5da9e1e7fb7b724870110069f80edfef1 100644 (file)
@@ -9,23 +9,19 @@ package org.opendaylight.transportpce.networkmodel.service;
 
 import java.util.HashMap;
 import java.util.concurrent.ExecutionException;
-import org.opendaylight.controller.md.sal.binding.api.DataBroker;
-import org.opendaylight.controller.md.sal.binding.api.WriteTransaction;
 import org.opendaylight.controller.md.sal.common.api.data.LogicalDatastoreType;
 import org.opendaylight.transportpce.common.NetworkUtils;
 import org.opendaylight.transportpce.common.device.DeviceTransactionManager;
 import org.opendaylight.transportpce.common.mapping.PortMapping;
-import org.opendaylight.transportpce.networkmodel.R2RLinkDiscovery;
+import org.opendaylight.transportpce.common.network.NetworkTransactionService;
 import org.opendaylight.transportpce.networkmodel.dto.TopologyShard;
 import org.opendaylight.transportpce.networkmodel.util.ClliNetwork;
+import org.opendaylight.transportpce.networkmodel.util.OpenRoadmFactory;
 import org.opendaylight.transportpce.networkmodel.util.OpenRoadmNetwork;
-import org.opendaylight.transportpce.networkmodel.util.OpenRoadmTopology;
 import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.network.rev150608.Network;
 import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.network.rev150608.NetworkId;
 import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.network.rev150608.NetworkKey;
-import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.network.rev150608.NodeId;
 import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.network.rev150608.network.Node;
-import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.network.rev150608.network.NodeKey;
 import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.network.topology.rev150608.Network1;
 import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.network.topology.rev150608.network.Link;
 import org.opendaylight.yang.gen.v1.urn.opendaylight.netconf.node.topology.rev150114.NetconfNodeConnectionStatus;
@@ -38,20 +34,21 @@ public class NetworkModelServiceImpl implements NetworkModelService {
     private static final Logger LOG = LoggerFactory.getLogger(NetworkModelServiceImpl.class);
     private static final boolean CREATE_MISSING_PARENTS = true;
 
-    private final DataBroker dataBroker;
-    private final R2RLinkDiscovery linkDiscovery;
+    private NetworkTransactionService networkTransactionService;
+    //private final R2RLinkDiscoveryFactoryMethod linkDiscovery;
     private final DeviceTransactionManager deviceTransactionManager;
-    private final OpenRoadmTopology openRoadmTopology;
+    private final OpenRoadmFactory openRoadmFactory;
     private final PortMapping portMapping;
     private HashMap<String,TopologyShard> topologyShardMountedDevice;
 
-    public NetworkModelServiceImpl(final DataBroker dataBroker, final R2RLinkDiscovery linkDiscovery,
-            DeviceTransactionManager deviceTransactionManager,
-            OpenRoadmTopology openRoadmTopology, PortMapping portMapping) {
-        this.dataBroker = dataBroker;
-        this.linkDiscovery = linkDiscovery;
+    public NetworkModelServiceImpl(final NetworkTransactionService networkTransactionService,
+                                   DeviceTransactionManager deviceTransactionManager,
+                                   OpenRoadmFactory openRoadmFactory, PortMapping portMapping) {
+
+        this.networkTransactionService = networkTransactionService;
+        //this.linkDiscovery = linkDiscovery;
         this.deviceTransactionManager = deviceTransactionManager;
-        this.openRoadmTopology = openRoadmTopology;
+        this.openRoadmFactory = openRoadmFactory;
         this.portMapping = portMapping;
         this.topologyShardMountedDevice = new HashMap<String,TopologyShard>();
     }
@@ -64,81 +61,89 @@ public class NetworkModelServiceImpl implements NetworkModelService {
     }
 
     @Override
-    public void createOpenROADMnode(String nodeId, String nodeVersion) {
+    public void createOpenROADMnode(String nodeId, String openRoadmVersion) {
         try {
             LOG.info("createOpenROADMNode: {} ", nodeId);
 
-            boolean isPortMapping = this.portMapping.createMappingData(nodeId, nodeVersion);
-            if (isPortMapping && "1.2.1".equals(this.portMapping.getNode(nodeId).getOpenroadmVersion().getName())) {
-                this.linkDiscovery.readLLDP(new NodeId(nodeId));
+            if (!portMapping.createMappingData(nodeId,openRoadmVersion)) {
+                LOG.warn("Could not generate port mapping for {} skipping network model creation",nodeId);
+                return;
+            }
+            //this.linkDiscovery.readLLDP(new NodeId(nodeId));
 
-                Node clliNode = ClliNetwork.createNode(this.deviceTransactionManager, nodeId);
-                if (clliNode == null) {
-                    LOG.error("Unable to create clli node! Node id: {}", nodeId);
-                    return;
-                }
+            Node clliNode = ClliNetwork.createNode(this.deviceTransactionManager, nodeId,openRoadmVersion);
+            if (clliNode == null) {
+                LOG.error("Unable to create clli node! Node id: {}", nodeId);
+                return;
+            }
 
-                Node openRoadmNode = OpenRoadmNetwork.createNode(nodeId, this.deviceTransactionManager);
-                if (openRoadmNode == null) {
-                    LOG.error("Unable to create OpenRoadm node! Node id: {}", nodeId);
-                    return;
-                }
+            InstanceIdentifier<Node> iiClliNode = InstanceIdentifier
+                .builder(Network.class, new NetworkKey(new
+                            NetworkId(NetworkUtils.CLLI_NETWORK_ID)))
+                .child(Node.class, clliNode.key())
+                .build();
 
-                TopologyShard topologyShard = this.openRoadmTopology.createTopologyShard(nodeId);
-                if (topologyShard == null) {
-                    LOG.error("Unable to create topology shard for node {}!", nodeId);
-                    return;
-                }
-                this.topologyShardMountedDevice.put(nodeId, topologyShard);
 
-                WriteTransaction writeTransaction = this.dataBroker.newWriteOnlyTransaction();
-                LOG.info("creating node in {}", NetworkUtils.CLLI_NETWORK_ID);
-                InstanceIdentifier<Node> iiClliNode = InstanceIdentifier
-                        .builder(Network.class, new NetworkKey(new NetworkId(NetworkUtils.CLLI_NETWORK_ID)))
-                        .child(Node.class, clliNode.key())
-                        .build();
-                writeTransaction.merge(LogicalDatastoreType.CONFIGURATION, iiClliNode, clliNode,
-                        CREATE_MISSING_PARENTS);
-                LOG.info("creating node in {}", NetworkUtils.UNDERLAY_NETWORK_ID);
-                InstanceIdentifier<Node> iiOpenRoadmNode = InstanceIdentifier
-                        .builder(Network.class, new NetworkKey(new NetworkId(NetworkUtils.UNDERLAY_NETWORK_ID)))
-                        .child(Node.class, openRoadmNode.key())
-                        .build();
-                writeTransaction.merge(LogicalDatastoreType.CONFIGURATION, iiOpenRoadmNode, openRoadmNode,
-                        CREATE_MISSING_PARENTS);
-                for (Node openRoadmTopologyNode: topologyShard.getNodes()) {
-                    LOG.info("creating node {} in {}", openRoadmTopologyNode.getNodeId().getValue(),
-                            NetworkUtils.OVERLAY_NETWORK_ID);
-                    InstanceIdentifier<Node> iiOpenRoadmTopologyNode = InstanceIdentifier
-                            .builder(Network.class, new NetworkKey(new NetworkId(NetworkUtils.OVERLAY_NETWORK_ID)))
-                            .child(Node.class, openRoadmTopologyNode.key())
-                            .build();
-                    writeTransaction.merge(LogicalDatastoreType.CONFIGURATION, iiOpenRoadmTopologyNode,
-                            openRoadmTopologyNode, CREATE_MISSING_PARENTS);
-                }
-                for (Link openRoadmTopologyLink: topologyShard.getLinks()) {
-                    LOG.info("creating link {} in {}", openRoadmTopologyLink.getLinkId().getValue(),
-                            NetworkUtils.OVERLAY_NETWORK_ID);
-                    InstanceIdentifier<Link> iiOpenRoadmTopologyLink = InstanceIdentifier
-                            .builder(Network.class, new NetworkKey(new NetworkId(NetworkUtils.OVERLAY_NETWORK_ID)))
-                            .augmentation(Network1.class)
-                            .child(Link.class, openRoadmTopologyLink.key())
-                            .build();
-                    writeTransaction.merge(LogicalDatastoreType.CONFIGURATION, iiOpenRoadmTopologyLink,
-                            openRoadmTopologyLink, CREATE_MISSING_PARENTS);
-                }
-                writeTransaction.submit().get();
-                LOG.info("all nodes and links created");
-            } else {
-                LOG.warn("openroadm-topology is not managed yet with openROADM device 2.2.1");
+            LOG.info("creating node in {}", NetworkUtils.CLLI_NETWORK_ID);
+            networkTransactionService.merge(LogicalDatastoreType.CONFIGURATION, iiClliNode, clliNode,
+                CREATE_MISSING_PARENTS);
+
+            Node openRoadmNode = OpenRoadmNetwork.createNode(nodeId, this.deviceTransactionManager,openRoadmVersion);
+            if (openRoadmNode == null) {
+                LOG.error("Unable to create OpenRoadm node! Node id: {}", nodeId);
+                return;
+            }
+            InstanceIdentifier<Node> iiOpenRoadmNode = InstanceIdentifier
+                .builder(Network.class, new NetworkKey(new
+                            NetworkId(NetworkUtils.UNDERLAY_NETWORK_ID)))
+                .child(Node.class, openRoadmNode.key())
+                .build();
+
+            LOG.info("creating node in {}", NetworkUtils.UNDERLAY_NETWORK_ID);
+            networkTransactionService.merge(LogicalDatastoreType.CONFIGURATION, iiOpenRoadmNode, openRoadmNode,
+                CREATE_MISSING_PARENTS);
+
+
+            TopologyShard topologyShard = openRoadmFactory.createTopologyShardVersionControl(nodeId);
+
+            if (topologyShard == null) {
+                LOG.error("Unable to create topology shard for node {}!", nodeId);
+                return;
             }
+            this.topologyShardMountedDevice.put(nodeId, topologyShard);
+
+            for (Node openRoadmTopologyNode: topologyShard.getNodes()) {
+                LOG.info("creating node {} in {}", openRoadmTopologyNode.getNodeId().getValue(),
+                        NetworkUtils.OVERLAY_NETWORK_ID);
+                InstanceIdentifier<Node> iiOpenRoadmTopologyNode = InstanceIdentifier
+                    .builder(Network.class, new NetworkKey(new NetworkId(NetworkUtils.OVERLAY_NETWORK_ID)))
+                    .child(Node.class, openRoadmTopologyNode.key())
+                    .build();
+                networkTransactionService.merge(LogicalDatastoreType.CONFIGURATION, iiOpenRoadmTopologyNode,
+                    openRoadmTopologyNode, CREATE_MISSING_PARENTS);
+            }
+            for (Link openRoadmTopologyLink: topologyShard.getLinks()) {
+                LOG.info("creating link {} in {}", openRoadmTopologyLink.getLinkId().getValue(),
+                        NetworkUtils.OVERLAY_NETWORK_ID);
+                InstanceIdentifier<Link> iiOpenRoadmTopologyLink = InstanceIdentifier
+                    .builder(Network.class, new NetworkKey(new NetworkId(NetworkUtils.OVERLAY_NETWORK_ID)))
+                    .augmentation(Network1.class)
+                    .child(Link.class, openRoadmTopologyLink.key())
+                    .build();
+                networkTransactionService.merge(LogicalDatastoreType.CONFIGURATION, iiOpenRoadmTopologyLink,
+                    openRoadmTopologyLink, CREATE_MISSING_PARENTS);
+            }
+            networkTransactionService.submit().get();
+            //linkDiscovery.readLLDP(nodeId);
+            LOG.info("all nodes and links created");
         } catch (InterruptedException | ExecutionException e) {
             LOG.error("ERROR: ", e);
         }
+
     }
 
     @Override
-    public void setOpenROADMnodeStatus(String nodeId, NetconfNodeConnectionStatus.ConnectionStatus connectionStatus) {
+    public void setOpenRoadmNodeStatus(String nodeId, NetconfNodeConnectionStatus.ConnectionStatus connectionStatus) {
         LOG.info("setOpenROADMNodeStatus: {} {}", nodeId, connectionStatus.name());
         /*
           TODO: set connection status of the device in model,
@@ -151,9 +156,12 @@ public class NetworkModelServiceImpl implements NetworkModelService {
     /* (non-Javadoc)
      * @see org.opendaylight.transportpce.networkmodel.service.NetworkModelService#deleteOpenROADMnode(java.lang.String)
      */
+
+
+
     @Override
-    public void deleteOpenROADMnode(String nodeId) {
-        try {
+    public void deleteOpenRoadmnode(String nodeId) {
+        /*try {
             LOG.info("deleteOpenROADMnode: {} ", nodeId);
             this.portMapping.deleteMappingData(nodeId);
 
@@ -161,15 +169,17 @@ public class NetworkModelServiceImpl implements NetworkModelService {
             WriteTransaction writeTransaction = this.dataBroker.newWriteOnlyTransaction();
             LOG.info("deleting node in {}", NetworkUtils.CLLI_NETWORK_ID);
             InstanceIdentifier<Node> iiClliNode = InstanceIdentifier
-                    .builder(Network.class, new NetworkKey(new NetworkId(NetworkUtils.CLLI_NETWORK_ID)))
-                    .child(Node.class, nodeIdKey)
-                    .build();
+                .builder(Networks.class)
+                .child(Network.class, new NetworkKey(new NetworkId(NetworkUtils.CLLI_NETWORK_ID)))
+                .child(Node.class, nodeIdKey)
+                .build();
             writeTransaction.delete(LogicalDatastoreType.CONFIGURATION, iiClliNode);
             LOG.info("deleting node in {}", NetworkUtils.UNDERLAY_NETWORK_ID);
             InstanceIdentifier<Node> iiOpenRoadmNode = InstanceIdentifier
-                    .builder(Network.class, new NetworkKey(new NetworkId(NetworkUtils.UNDERLAY_NETWORK_ID)))
-                    .child(Node.class, nodeIdKey)
-                    .build();
+                .builder(Networks.class)
+                .child(Network.class, new NetworkKey(new NetworkId(NetworkUtils.UNDERLAY_NETWORK_ID)))
+                .child(Node.class, nodeIdKey)
+                .build();
             writeTransaction.delete(LogicalDatastoreType.CONFIGURATION, iiOpenRoadmNode);
             TopologyShard topologyShard = this.topologyShardMountedDevice.get(nodeId);
             if (topologyShard != null) {
@@ -178,19 +188,21 @@ public class NetworkModelServiceImpl implements NetworkModelService {
                     LOG.info("deleting node {} in {}", openRoadmTopologyNode.getNodeId().getValue(),
                             NetworkUtils.OVERLAY_NETWORK_ID);
                     InstanceIdentifier<Node> iiOpenRoadmTopologyNode = InstanceIdentifier
-                            .builder(Network.class, new NetworkKey(new NetworkId(NetworkUtils.OVERLAY_NETWORK_ID)))
-                            .child(Node.class, openRoadmTopologyNode.key())
-                            .build();
+                        .builder(Networks.class)
+                        .child(Network.class, new NetworkKey(new NetworkId(NetworkUtils.OVERLAY_NETWORK_ID)))
+                        .child(Node.class, openRoadmTopologyNode.key())
+                        .build();
                     writeTransaction.delete(LogicalDatastoreType.CONFIGURATION, iiOpenRoadmTopologyNode);
                 }
                 for (Link openRoadmTopologyLink: topologyShard.getLinks()) {
                     LOG.info("deleting link {} in {}", openRoadmTopologyLink.getLinkId().getValue(),
                             NetworkUtils.OVERLAY_NETWORK_ID);
                     InstanceIdentifier<Link> iiOpenRoadmTopologyLink = InstanceIdentifier
-                            .builder(Network.class, new NetworkKey(new NetworkId(NetworkUtils.OVERLAY_NETWORK_ID)))
-                            .augmentation(Network1.class)
-                            .child(Link.class, openRoadmTopologyLink.key())
-                            .build();
+                        .builder(Networks.class)
+                        .child(Network.class, new NetworkKey(new NetworkId(NetworkUtils.OVERLAY_NETWORK_ID)))
+                        .augmentation(Network1.class)
+                        .child(Link.class, openRoadmTopologyLink.key())
+                        .build();
                     writeTransaction.delete(LogicalDatastoreType.CONFIGURATION, iiOpenRoadmTopologyLink);
                 }
             } else {
@@ -200,6 +212,6 @@ public class NetworkModelServiceImpl implements NetworkModelService {
             LOG.info("all nodes and links deleted ! ");
         } catch (InterruptedException | ExecutionException e) {
             LOG.error("Error when trying to delete node : {}", nodeId, e);
-        }
+        }*/
     }
 }