*/
package org.opendaylight.transportpce.common.mapping;
+import java.util.ArrayList;
+import java.util.List;
import java.util.Optional;
import java.util.concurrent.ExecutionException;
-import org.opendaylight.controller.md.sal.binding.api.DataBroker;
-import org.opendaylight.controller.md.sal.binding.api.ReadOnlyTransaction;
-import org.opendaylight.controller.md.sal.common.api.data.LogicalDatastoreType;
+import org.opendaylight.mdsal.binding.api.DataBroker;
+import org.opendaylight.mdsal.binding.api.ReadTransaction;
+import org.opendaylight.mdsal.common.api.LogicalDatastoreType;
import org.opendaylight.transportpce.common.StringConstants;
-import org.opendaylight.yang.gen.v1.http.org.opendaylight.transportpce.portmapping.rev170228.Network;
-import org.opendaylight.yang.gen.v1.http.org.opendaylight.transportpce.portmapping.rev170228.network.Nodes;
-import org.opendaylight.yang.gen.v1.http.org.opendaylight.transportpce.portmapping.rev170228.network.NodesKey;
+import org.opendaylight.yang.gen.v1.http.org.opendaylight.transportpce.portmapping.rev210315.Network;
+import org.opendaylight.yang.gen.v1.http.org.opendaylight.transportpce.portmapping.rev210315.mc.capabilities.McCapabilities;
+import org.opendaylight.yang.gen.v1.http.org.opendaylight.transportpce.portmapping.rev210315.network.Nodes;
+import org.opendaylight.yang.gen.v1.http.org.opendaylight.transportpce.portmapping.rev210315.network.NodesKey;
+import org.opendaylight.yang.gen.v1.http.org.opendaylight.transportpce.portmapping.rev210315.network.nodes.NodeInfo;
import org.opendaylight.yangtools.yang.binding.InstanceIdentifier;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
/*
* Getting physical mapping corresponding to logical connection point
*/
- InstanceIdentifier<Nodes> portMappingIID = InstanceIdentifier.builder(Network.class).child(Nodes.class,
- new NodesKey(nodeId)).build();
- try (ReadOnlyTransaction readTx = dataBroker.newReadOnlyTransaction()) {
- Optional<Nodes> mapObject =
- readTx.read(LogicalDatastoreType.CONFIGURATION, portMappingIID).get().toJavaUtil();
- if (mapObject.isPresent()) {
- Nodes mapping = mapObject.get();
- switch (mapping.getOpenroadmVersion()) {
- case _22:
- return StringConstants.OPENROADM_DEVICE_VERSION_2_2;
+ InstanceIdentifier<NodeInfo> nodeInfoIID = InstanceIdentifier.builder(Network.class).child(Nodes.class,
+ new NodesKey(nodeId)).child(NodeInfo.class).build();
+ try (ReadTransaction readTx = dataBroker.newReadOnlyTransaction()) {
+ Optional<NodeInfo> nodeInfoObj =
+ readTx.read(LogicalDatastoreType.CONFIGURATION, nodeInfoIID).get();
+ if (nodeInfoObj.isPresent()) {
+ NodeInfo nodInfo = nodeInfoObj.get();
+ switch (nodInfo.getOpenroadmVersion()) {
+ case _710:
+ return StringConstants.OPENROADM_DEVICE_VERSION_7_1_0;
+ case _221:
+ return StringConstants.OPENROADM_DEVICE_VERSION_2_2_1;
case _121:
return StringConstants.OPENROADM_DEVICE_VERSION_1_2_1;
default:
- return StringConstants.OPENROADM_DEVICE_VERSION_1_2_1;
+ LOG.warn("unknown openROADM device version");
}
} else {
- LOG.warn("Could not find mapping for nodeId {}",
- nodeId);
+ LOG.warn("Could not find mapping for nodeId {}", nodeId);
}
} catch (InterruptedException | ExecutionException ex) {
LOG.error("Unable to read mapping for nodeId {}",nodeId, ex);
}
return null;
}
+
+ /*
+ * (non-Javadoc)
+ *
+ * @see org.opendaylight.transportpce.common.mapping.MappingUtils#getMcCapabilitiesForNode(java.lang.String)
+ */
+ @Override
+ public List<McCapabilities> getMcCapabilitiesForNode(String nodeId) {
+ List<McCapabilities> mcCapabilities = new ArrayList<>();
+ InstanceIdentifier<Nodes> nodePortMappingIID = InstanceIdentifier.builder(Network.class)
+ .child(Nodes.class, new NodesKey(nodeId)).build();
+ try (ReadTransaction readTx = this.dataBroker.newReadOnlyTransaction()) {
+ Optional<Nodes> nodePortMapObject = readTx.read(LogicalDatastoreType.CONFIGURATION, nodePortMappingIID)
+ .get();
+ if (nodePortMapObject.isPresent()) {
+ LOG.info("Found node {}", nodeId);
+ Nodes node = nodePortMapObject.get();
+ mcCapabilities.addAll(node.nonnullMcCapabilities().values());
+ }
+ } catch (ExecutionException e) {
+ LOG.error("Something went wrong while getting node {}", nodeId, e);
+ } catch (InterruptedException e) {
+ LOG.error("Request interrupted for node {} interrupted", nodeId, e);
+ Thread.currentThread().interrupt();
+ }
+ LOG.info("Capabilitities for node {}: {}", nodeId, mcCapabilities);
+ return mcCapabilities;
+ }
}