Consolidate portmapping-topo for ROADM
[transportpce.git] / networkmodel / src / main / java / org / opendaylight / transportpce / networkmodel / service / NetworkModelServiceImpl.java
1 /*
2  * Copyright © 2016 AT&T and others.  All rights reserved.
3  *
4  * This program and the accompanying materials are made available under the
5  * terms of the Eclipse Public License v1.0 which accompanies this distribution,
6  * and is available at http://www.eclipse.org/legal/epl-v10.html
7  */
8 package org.opendaylight.transportpce.networkmodel.service;
9
10 import java.util.HashMap;
11 import java.util.concurrent.ExecutionException;
12 import java.util.concurrent.TimeUnit;
13 import java.util.concurrent.TimeoutException;
14
15 import org.eclipse.jdt.annotation.Nullable;
16 import org.opendaylight.controller.md.sal.common.api.data.LogicalDatastoreType;
17 import org.opendaylight.transportpce.common.NetworkUtils;
18 import org.opendaylight.transportpce.common.device.DeviceTransactionManager;
19 import org.opendaylight.transportpce.common.mapping.PortMapping;
20 import org.opendaylight.transportpce.common.network.NetworkTransactionService;
21 import org.opendaylight.transportpce.networkmodel.R2RLinkDiscovery;
22 import org.opendaylight.transportpce.networkmodel.dto.TopologyShard;
23 import org.opendaylight.transportpce.networkmodel.util.ClliNetwork;
24 import org.opendaylight.transportpce.networkmodel.util.OpenRoadmFactory;
25 import org.opendaylight.transportpce.networkmodel.util.OpenRoadmNetwork;
26 import org.opendaylight.yang.gen.v1.http.org.opendaylight.transportpce.portmapping.rev170228.network.Nodes.OpenroadmVersion;
27 import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.network.rev180226.NetworkId;
28 import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.network.rev180226.Networks;
29 import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.network.rev180226.NodeId;
30 import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.network.rev180226.networks.Network;
31 import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.network.rev180226.networks.NetworkKey;
32 import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.network.rev180226.networks.network.Node;
33 import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.network.rev180226.networks.network.NodeKey;
34 import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.network.topology.rev180226.Network1;
35 import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.network.topology.rev180226.networks.network.Link;
36 import org.opendaylight.yang.gen.v1.urn.opendaylight.netconf.node.topology.rev150114.NetconfNodeConnectionStatus;
37 import org.opendaylight.yangtools.yang.binding.InstanceIdentifier;
38 import org.slf4j.Logger;
39 import org.slf4j.LoggerFactory;
40
41 public class NetworkModelServiceImpl implements NetworkModelService {
42
43     private static final Logger LOG = LoggerFactory.getLogger(NetworkModelServiceImpl.class);
44     private static final boolean CREATE_MISSING_PARENTS = true;
45
46     private NetworkTransactionService networkTransactionService;
47     //private final R2RLinkDiscoveryFactoryMethod linkDiscovery;
48     private final R2RLinkDiscovery linkDiscovery;
49     private final DeviceTransactionManager deviceTransactionManager;
50     private final OpenRoadmFactory openRoadmFactory;
51     private final PortMapping portMapping;
52     private HashMap<String,TopologyShard> topologyShardMountedDevice;
53
54     public NetworkModelServiceImpl(final NetworkTransactionService networkTransactionService,
55         final R2RLinkDiscovery linkDiscovery, DeviceTransactionManager deviceTransactionManager,
56             OpenRoadmFactory openRoadmFactory, PortMapping portMapping) {
57
58         this.networkTransactionService = networkTransactionService;
59         this.linkDiscovery = linkDiscovery;
60         this.deviceTransactionManager = deviceTransactionManager;
61         this.openRoadmFactory = openRoadmFactory;
62         this.portMapping = portMapping;
63         this.topologyShardMountedDevice = new HashMap<String,TopologyShard>();
64     }
65
66     public void init() {
67         LOG.info("init ...");
68     }
69
70     public void close() {
71     }
72
73     @Override
74     public void createOpenRoadmNode(String nodeId, String openRoadmVersion) {
75         try {
76             LOG.info("createOpenROADMNode: {} ", nodeId);
77
78             if (!portMapping.createMappingData(nodeId, openRoadmVersion)) {
79                 LOG.warn("Could not generate port mapping for {} skipping network model creation", nodeId);
80                 return;
81             }
82
83             if (portMapping.getNode(nodeId).getNodeType().getIntValue() == 1) {
84                 this.linkDiscovery.readLLDP(new NodeId(nodeId), openRoadmVersion);
85             }
86
87             Node clliNode = ClliNetwork.createNode(this.deviceTransactionManager, nodeId, openRoadmVersion);
88             if (clliNode == null) {
89                 LOG.error("Unable to create clli node! Node id: {}", nodeId);
90                 return;
91             }
92
93             InstanceIdentifier<Node> iiClliNode = InstanceIdentifier.builder(Networks.class)
94                 .child(Network.class, new NetworkKey(new NetworkId(NetworkUtils.CLLI_NETWORK_ID)))
95                 .child(Node.class, clliNode.key())
96                 .build();
97
98
99             LOG.info("creating node in {}", NetworkUtils.CLLI_NETWORK_ID);
100             networkTransactionService.merge(LogicalDatastoreType.CONFIGURATION, iiClliNode, clliNode,
101                 CREATE_MISSING_PARENTS);
102
103             Node openRoadmNode = OpenRoadmNetwork.createNode(nodeId, this.deviceTransactionManager, openRoadmVersion);
104             if (openRoadmNode == null) {
105                 LOG.error("Unable to create OpenRoadm node! Node id: {}", nodeId);
106                 return;
107             }
108             InstanceIdentifier<Node> iiOpenRoadmNode = InstanceIdentifier.builder(Networks.class)
109                 .child(Network.class, new NetworkKey(new NetworkId(NetworkUtils.UNDERLAY_NETWORK_ID)))
110                 .child(Node.class, openRoadmNode.key())
111                 .build();
112
113             LOG.info("creating node in {}", NetworkUtils.UNDERLAY_NETWORK_ID);
114             networkTransactionService.merge(LogicalDatastoreType.CONFIGURATION, iiOpenRoadmNode, openRoadmNode,
115                 CREATE_MISSING_PARENTS);
116
117             TopologyShard topologyShard =
118                 openRoadmFactory.createTopologyShardVersionControl(portMapping.getNode(nodeId));
119
120             if (topologyShard == null) {
121                 LOG.error("Unable to create topology shard for node {}!", nodeId);
122                 return;
123             }
124             this.topologyShardMountedDevice.put(nodeId, topologyShard);
125
126             for (Node openRoadmTopologyNode: topologyShard.getNodes()) {
127                 LOG.info("creating node {} in {}", openRoadmTopologyNode.getNodeId().getValue(),
128                         NetworkUtils.OVERLAY_NETWORK_ID);
129                 InstanceIdentifier<Node> iiOpenRoadmTopologyNode = InstanceIdentifier.builder(Networks.class)
130                     .child(Network.class, new NetworkKey(new NetworkId(NetworkUtils.OVERLAY_NETWORK_ID)))
131                     .child(Node.class, openRoadmTopologyNode.key())
132                     .build();
133                 networkTransactionService.merge(LogicalDatastoreType.CONFIGURATION, iiOpenRoadmTopologyNode,
134                     openRoadmTopologyNode, CREATE_MISSING_PARENTS);
135             }
136             for (Link openRoadmTopologyLink: topologyShard.getLinks()) {
137                 LOG.info("creating link {} in {}", openRoadmTopologyLink.getLinkId().getValue(),
138                         NetworkUtils.OVERLAY_NETWORK_ID);
139                 InstanceIdentifier<Link> iiOpenRoadmTopologyLink = InstanceIdentifier.builder(Networks.class)
140                     .child(Network.class, new NetworkKey(new NetworkId(NetworkUtils.OVERLAY_NETWORK_ID)))
141                     .augmentation(Network1.class)
142                     .child(Link.class, openRoadmTopologyLink.key())
143                     .build();
144                 networkTransactionService.merge(LogicalDatastoreType.CONFIGURATION, iiOpenRoadmTopologyLink,
145                     openRoadmTopologyLink, CREATE_MISSING_PARENTS);
146             }
147             networkTransactionService.submit().get();
148             //linkDiscovery.readLLDP(nodeId);
149             LOG.info("all nodes and links created");
150         } catch (InterruptedException | ExecutionException e) {
151             LOG.error("ERROR: ", e);
152         }
153
154     }
155
156     @Override
157     public void setOpenRoadmNodeStatus(String nodeId, NetconfNodeConnectionStatus.ConnectionStatus connectionStatus) {
158         LOG.info("setOpenROADMNodeStatus: {} {}", nodeId, connectionStatus.name());
159         /*
160           TODO: set connection status of the device in model,
161           TODO: so we don't need to keep it in memory (Set<String> currentMountedDevice)
162           TODO: unfortunately there is no connection status OpenROADM in network models
163           TODO: waiting for new model version
164          */
165     }
166
167     /* (non-Javadoc)
168      * @see org.opendaylight.transportpce.networkmodel.service.NetworkModelService#deleteOpenROADMnode(java.lang.String)
169      */
170
171
172
173     @Override
174     public void deleteOpenRoadmnode(String nodeId) {
175         try {
176             @Nullable
177             OpenroadmVersion deviceVersion = this.portMapping.getNode(nodeId).getOpenroadmVersion();
178             LOG.info("deleteOpenROADMnode: {} version {}", nodeId, deviceVersion.getName());
179             this.portMapping.deleteMappingData(nodeId);
180
181             NodeKey nodeIdKey = new NodeKey(new NodeId(nodeId));
182
183             LOG.info("deleting node in {}", NetworkUtils.UNDERLAY_NETWORK_ID);
184             InstanceIdentifier<Node> iiOpenRoadmNode = InstanceIdentifier.builder(Networks.class)
185                 .child(Network.class, new NetworkKey(new NetworkId(NetworkUtils.UNDERLAY_NETWORK_ID)))
186                 .child(Node.class, nodeIdKey)
187                 .build();
188             this.networkTransactionService.delete(LogicalDatastoreType.CONFIGURATION, iiOpenRoadmNode);
189
190             TopologyShard topologyShard = this.topologyShardMountedDevice.get(nodeId);
191             if (topologyShard != null) {
192                 LOG.info("TopologyShard for node '{}' is present", nodeId);
193                 for (Node openRoadmTopologyNode: topologyShard .getNodes()) {
194                     LOG.info("deleting node {} in {}", openRoadmTopologyNode.getNodeId().getValue(),
195                             NetworkUtils.OVERLAY_NETWORK_ID);
196                     InstanceIdentifier<Node> iiOpenRoadmTopologyNode = InstanceIdentifier.builder(Networks.class)
197                         .child(Network.class, new NetworkKey(new NetworkId(NetworkUtils.OVERLAY_NETWORK_ID)))
198                         .child(Node.class, openRoadmTopologyNode.key())
199                         .build();
200                     this.networkTransactionService.delete(LogicalDatastoreType.CONFIGURATION, iiOpenRoadmTopologyNode);
201                 }
202                 for (Link openRoadmTopologyLink: topologyShard.getLinks()) {
203                     LOG.info("deleting link {} in {}", openRoadmTopologyLink.getLinkId().getValue(),
204                             NetworkUtils.OVERLAY_NETWORK_ID);
205                     InstanceIdentifier<Link> iiOpenRoadmTopologyLink = InstanceIdentifier.builder(Networks.class)
206                         .child(Network.class, new NetworkKey(new NetworkId(NetworkUtils.OVERLAY_NETWORK_ID)))
207                         .augmentation(Network1.class)
208                         .child(Link.class, openRoadmTopologyLink.key())
209                         .build();
210                     this.networkTransactionService.delete(LogicalDatastoreType.CONFIGURATION, iiOpenRoadmTopologyLink);
211                 }
212             } else {
213                 LOG.warn("TopologyShard for node '{}' is not present", nodeId);
214             }
215             this.networkTransactionService.submit().get(1, TimeUnit.SECONDS);
216             LOG.info("all nodes and links deleted ! ");
217         } catch (InterruptedException | ExecutionException | TimeoutException e) {
218             LOG.error("Error when trying to delete node : {}", nodeId, e);
219         }
220     }
221 }