private final OpenroadmNodeType nodeType;
private final String pceNodeType;
private final String otnServiceType;
+ private String modeType;
private Map<String, List<Uint16>> tpAvailableTribPort = new TreeMap<>();
private Map<String, List<Uint16>> tpAvailableTribSlot = new TreeMap<>();
LOG.info("PceOtnNode: initXndrTps for node {}", this.nodeId.getValue());
this.availableXponderTp.clear();
+ this.modeType = mode;
+
org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.network.topology.rev180226.Node1 nodeTp
= this.node.augmentation(org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang
.ietf.network.topology.rev180226.Node1.class);
List<org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.network.topology.rev180226.networks.network
- .node.TerminationPoint> allTps = nodeTp.getTerminationPoint();
+ .node.TerminationPoint> allTps = nodeTp.getTerminationPoint();
this.valid = false;
if (allTps == null) {
LOG.error("PceOtnNode: initXndrTps: XPONDER TerminationPoint list is empty for node {}", this);
}
for (org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.network.topology.rev180226.networks.network
- .node.TerminationPoint tp : allTps) {
+ .node.TerminationPoint tp : allTps) {
org.opendaylight.yang.gen.v1.http.org.openroadm.common.network.rev181130.@Nullable TerminationPoint1 ocnTp1
= tp.augmentation(org.opendaylight.yang.gen.v1.http.org.openroadm.common.network.rev181130
.TerminationPoint1.class);
if ((this.otnServiceType.equals("ODU4") && mode.equals("AZ"))
|| ((this.otnServiceType.equals("10GE") || this.otnServiceType.equals("1GE"))
- && mode.equals("AZ") && checkSwPool(availableXpdrClientTps, availableXpdrNWTps, 1, 1))
- || ((this.otnServiceType.equals("10GE") || this.otnServiceType.equals("1GE"))
- && mode.equals("intermediate") && checkSwPool(null, availableXpdrNWTps, 0, 2))) {
+ && ((mode.equals("AZ") && checkSwPool(availableXpdrClientTps, availableXpdrNWTps, 1, 1))
+ || (mode.equals("intermediate") && checkSwPool(null, availableXpdrNWTps, 0, 2)))
+ )) {
this.valid = true;
} else {
this.valid = false;
&& ontTp1.getXpdrTpPortConnectionAttributes().getOdtuTpnPool() != null
&& ontTp1.getXpdrTpPortConnectionAttributes().getOdtuTpnPool().get(0).getOdtuType()
.equals(ODTU4TsAllocated.class)
- && ontTp1.getXpdrTpPortConnectionAttributes().getOdtuTpnPool().get(0).getTpnPool().isEmpty()
+ && !ontTp1.getXpdrTpPortConnectionAttributes().getOdtuTpnPool().get(0).getTpnPool().isEmpty()
&& (ontTp1.getXpdrTpPortConnectionAttributes().getTsPool().size() >= tsNb)) {
return true;
}
return false;
}
- private Boolean findClientCompliantInterface(List<SupportedInterfaceCapability> sic) {
- boolean compliant = false;
- for (SupportedInterfaceCapability sit : sic) {
- String interfacetype = sit.getIfCapType().getName();
- switch (interfacetype) {
- case "If1GEODU0":
- case "If1GE":
- if ("1GE".equals(this.otnServiceType)) {
- compliant = true;
- }
- break;
- case "If10GEODU2e":
- case "If10GE":
- if ("10GE".equals(this.otnServiceType)) {
- compliant = true;
- }
- break;
- case "If100GEODU4":
- case "If100GE":
- if ("100GE".equals(this.otnServiceType)) {
- compliant = true;
- }
- break;
- case "IfOTU4ODU4":
- case "IfOCHOTU4ODU4":
- if ("OTU4".equals(this.otnServiceType) || "ODU4".equals(this.otnServiceType)) {
- compliant = true;
- }
- break;
- default:
- compliant = false;
- break;
- }
- }
- return compliant;
- }
-
- private Boolean findNetworkCompliantInterface(List<SupportedInterfaceCapability> sic) {
- boolean compliant = false;
- for (SupportedInterfaceCapability sit : sic) {
- String interfacetype = sit.getIfCapType().toString();
- switch (interfacetype) {
- case "IfOTU4ODU4":
- case "IfOCHOTU4ODU4":
- compliant = true;
- break;
- case "IfOTU2ODU2":
- case "IfOCHOTU2ODU2":
- if (("1GE".equals(this.otnServiceType)) || ("10GE".equals(this.otnServiceType))) {
- compliant = true;
- }
- break;
- // add all use case with higher rate interfaces when it shows up
- default:
- compliant = false;
- break;
- }
- }
- return compliant;
- }
-
public void validateXponder(String anodeId, String znodeId) {
if (!isValid()) {
return;
public boolean validateSwitchingPoolBandwidth(
org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang
- .ietf.network.topology.rev180226.networks.network.node.TerminationPoint tp1,
+ .ietf.network.topology.rev180226.networks.network.node.TerminationPoint tp1,
org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang
- .ietf.network.topology.rev180226.networks.network.node.TerminationPoint tp2,
+ .ietf.network.topology.rev180226.networks.network.node.TerminationPoint tp2,
Long neededBW) {
if (this.nodeType != OpenroadmNodeType.TPDR) {
return true;
}
org.opendaylight.yang.gen.v1.http.org.openroadm.otn.network.topology.rev181130.Node1 node1 =
node.augmentation(
- org.opendaylight.yang.gen.v1.http.org.openroadm.otn.network.topology.rev181130.Node1.class);
+ org.opendaylight.yang.gen.v1.http.org.openroadm.otn.network.topology.rev181130.Node1.class);
SwitchingPools sp = node1.getSwitchingPools();
List<OduSwitchingPools> osp = sp.getOduSwitchingPools();
for (OduSwitchingPools ospx : osp) {
return valid;
}
+ public boolean isPceOtnNodeValid(final PceOtnNode pceOtnNode) {
+ if (pceOtnNode == null || pceOtnNode.node == null
+ || pceOtnNode.getNodeId() == null || pceOtnNode.nodeType == null || pceOtnNode.getSupNetworkNodeId() == null
+ || pceOtnNode.getSupClliNodeId() == null || pceOtnNode.otnServiceType == null) {
+ LOG.error(
+ "PceOtnNode: one of parameters is not populated : nodeId, node type, supporting nodeId, otnServiceType"
+ );
+ return false;
+ }
+
+ if (!isNodeTypeValid(pceOtnNode)) {
+ LOG.error("PceOtnNode node type: node type isn't one of MUXPDR or SWITCH or TPDR");
+ return false;
+ }
+
+ return isOtnServiceTypeValid(pceOtnNode);
+ }
+
+ private boolean isOtnServiceTypeValid(PceOtnNode pceOtnNode) {
+ if (pceOtnNode.modeType == null) {
+ return false;
+ }
+
+ //Todo refactor Strings (mode and otnServiceType ) to enums
+ if ((pceOtnNode.otnServiceType.equals("ODU4") && pceOtnNode.modeType.equals("AZ"))) {
+ return true;
+ }
+
+ if ((pceOtnNode.otnServiceType.equals("10GE") || pceOtnNode.otnServiceType.equals("1GE"))
+ && (isAz(pceOtnNode) || isIntermediate(pceOtnNode))) {
+ return true;
+ }
+
+ return false;
+ }
+
+ private boolean isIntermediate(PceOtnNode pceOtnNode) {
+ return pceOtnNode.modeType.equals("intermediate")
+ && checkSwPool(null, pceOtnNode.availableXpdrNWTps, 0, 2);
+ }
+
+ private boolean isAz(PceOtnNode pceOtnNode) {
+ return pceOtnNode.modeType.equals("AZ")
+ && checkSwPool(pceOtnNode.availableXpdrClientTps, pceOtnNode.availableXpdrNWTps, 1, 1);
+ }
+
+ private boolean isNodeTypeValid(final PceOtnNode pceOtnNode) {
+ return (pceOtnNode.nodeType == OpenroadmNodeType.MUXPDR)
+ || (pceOtnNode.nodeType == OpenroadmNodeType.SWITCH)
+ || (pceOtnNode.nodeType == OpenroadmNodeType.TPDR);
+ }
+
@Override
public void addOutgoingLink(PceLink outLink) {
this.outgoingLinks.add(outLink);