X-Git-Url: https://git.opendaylight.org/gerrit/gitweb?a=blobdiff_plain;f=pce%2Fsrc%2Fmain%2Fjava%2Forg%2Fopendaylight%2Ftransportpce%2Fpce%2FPcePathDescription.java;h=d0ae6968174cff6cc9470393fecd90b896e43d1d;hb=bae3a804f39421d6206357d3e771f4089368ead0;hp=b067745918879a7e84949cc05540db2cae96416e;hpb=98de423782828b8b44b9cb341a581e1e90a16971;p=transportpce.git diff --git a/pce/src/main/java/org/opendaylight/transportpce/pce/PcePathDescription.java b/pce/src/main/java/org/opendaylight/transportpce/pce/PcePathDescription.java index b06774591..d0ae69681 100644 --- a/pce/src/main/java/org/opendaylight/transportpce/pce/PcePathDescription.java +++ b/pce/src/main/java/org/opendaylight/transportpce/pce/PcePathDescription.java @@ -12,24 +12,29 @@ import java.util.HashMap; import java.util.List; import java.util.Map; import org.opendaylight.transportpce.common.ResponseCodes; +import org.opendaylight.transportpce.common.StringConstants; +import org.opendaylight.transportpce.common.fixedflex.GridConstant; import org.opendaylight.transportpce.pce.networkanalyzer.PceLink; import org.opendaylight.transportpce.pce.networkanalyzer.PceResult; -import org.opendaylight.yang.gen.v1.http.org.transportpce.b.c._interface.pathdescription.rev200629.path.description.AToZDirectionBuilder; -import org.opendaylight.yang.gen.v1.http.org.transportpce.b.c._interface.pathdescription.rev200629.path.description.ZToADirectionBuilder; -import org.opendaylight.yang.gen.v1.http.org.transportpce.b.c._interface.pathdescription.rev200629.path.description.atoz.direction.AToZ; -import org.opendaylight.yang.gen.v1.http.org.transportpce.b.c._interface.pathdescription.rev200629.path.description.atoz.direction.AToZBuilder; -import org.opendaylight.yang.gen.v1.http.org.transportpce.b.c._interface.pathdescription.rev200629.path.description.atoz.direction.AToZKey; -import org.opendaylight.yang.gen.v1.http.org.transportpce.b.c._interface.pathdescription.rev200629.path.description.ztoa.direction.ZToA; -import org.opendaylight.yang.gen.v1.http.org.transportpce.b.c._interface.pathdescription.rev200629.path.description.ztoa.direction.ZToABuilder; -import org.opendaylight.yang.gen.v1.http.org.transportpce.b.c._interface.pathdescription.rev200629.path.description.ztoa.direction.ZToAKey; -import org.opendaylight.yang.gen.v1.http.org.transportpce.b.c._interface.pathdescription.rev200629.pce.resource.Resource; -import org.opendaylight.yang.gen.v1.http.org.transportpce.b.c._interface.pathdescription.rev200629.pce.resource.ResourceBuilder; -import org.opendaylight.yang.gen.v1.http.org.transportpce.b.c._interface.pathdescription.rev200629.pce.resource.resource.resource.LinkBuilder; -import org.opendaylight.yang.gen.v1.http.org.transportpce.b.c._interface.pathdescription.rev200629.pce.resource.resource.resource.NodeBuilder; -import org.opendaylight.yang.gen.v1.http.org.transportpce.b.c._interface.pathdescription.rev200629.pce.resource.resource.resource.TerminationPoint; -import org.opendaylight.yang.gen.v1.http.org.transportpce.b.c._interface.pathdescription.rev200629.pce.resource.resource.resource.TerminationPointBuilder; +import org.opendaylight.yang.gen.v1.http.org.openroadm.common.optical.channel.types.rev200529.FrequencyTHz; +import org.opendaylight.yang.gen.v1.http.org.openroadm.common.state.types.rev191129.State; +import org.opendaylight.yang.gen.v1.http.org.openroadm.common.types.rev181019.ModulationFormat; +import org.opendaylight.yang.gen.v1.http.org.openroadm.otn.common.types.rev181130.OpucnTribSlotDef; +import org.opendaylight.yang.gen.v1.http.org.transportpce.b.c._interface.pathdescription.rev210705.path.description.AToZDirectionBuilder; +import org.opendaylight.yang.gen.v1.http.org.transportpce.b.c._interface.pathdescription.rev210705.path.description.ZToADirectionBuilder; +import org.opendaylight.yang.gen.v1.http.org.transportpce.b.c._interface.pathdescription.rev210705.path.description.atoz.direction.AToZ; +import org.opendaylight.yang.gen.v1.http.org.transportpce.b.c._interface.pathdescription.rev210705.path.description.atoz.direction.AToZBuilder; +import org.opendaylight.yang.gen.v1.http.org.transportpce.b.c._interface.pathdescription.rev210705.path.description.atoz.direction.AToZKey; +import org.opendaylight.yang.gen.v1.http.org.transportpce.b.c._interface.pathdescription.rev210705.path.description.ztoa.direction.ZToA; +import org.opendaylight.yang.gen.v1.http.org.transportpce.b.c._interface.pathdescription.rev210705.path.description.ztoa.direction.ZToABuilder; +import org.opendaylight.yang.gen.v1.http.org.transportpce.b.c._interface.pathdescription.rev210705.path.description.ztoa.direction.ZToAKey; +import org.opendaylight.yang.gen.v1.http.org.transportpce.b.c._interface.pathdescription.rev210705.pce.resource.Resource; +import org.opendaylight.yang.gen.v1.http.org.transportpce.b.c._interface.pathdescription.rev210705.pce.resource.ResourceBuilder; +import org.opendaylight.yang.gen.v1.http.org.transportpce.b.c._interface.pathdescription.rev210705.pce.resource.resource.resource.LinkBuilder; +import org.opendaylight.yang.gen.v1.http.org.transportpce.b.c._interface.pathdescription.rev210705.pce.resource.resource.resource.NodeBuilder; +import org.opendaylight.yang.gen.v1.http.org.transportpce.b.c._interface.pathdescription.rev210705.pce.resource.resource.resource.TerminationPoint; +import org.opendaylight.yang.gen.v1.http.org.transportpce.b.c._interface.pathdescription.rev210705.pce.resource.resource.resource.TerminationPointBuilder; import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.network.topology.rev180226.LinkId; -import org.opendaylight.yangtools.yang.common.Uint16; import org.opendaylight.yangtools.yang.common.Uint32; import org.slf4j.Logger; import org.slf4j.LoggerFactory; @@ -39,7 +44,6 @@ public class PcePathDescription { private static final Logger LOG = LoggerFactory.getLogger(PcePathDescription.class); private List pathAtoZ = null; - private List pathZtoA = null; private PceResult rc; private Map allPceLinks = null; @@ -52,65 +56,118 @@ public class PcePathDescription { public PceResult buildDescriptions() { LOG.info("In buildDescriptions: AtoZ = {}", pathAtoZ); - Map atozList = new HashMap<>(); + Map atozMap = new HashMap<>(); if (pathAtoZ == null) { rc.setRC(ResponseCodes.RESPONSE_FAILED); LOG.error("In buildDescriptions: there is empty AtoZ path"); return rc; } - buildAtoZ(atozList, pathAtoZ); - AToZDirectionBuilder atoZDirectionBldr = new AToZDirectionBuilder() - .setRate(Uint32.valueOf(rc.getRate())) - .setAToZ(atozList); - if ("100GE".equals(rc.getServiceType()) || "OTU4".equals(rc.getServiceType())) { - atoZDirectionBldr.setAToZWavelengthNumber(Uint32.valueOf(rc.getResultWavelength())); - } else if ("10GE".equals(rc.getServiceType()) || "1GE".equals(rc.getServiceType()) - || "ODU4".equals(rc.getServiceType())) { - if (rc.getResultTribSlot() != null && rc.getResultTribPort() != null) { - List tribSlotList = (List) rc.getResultTribSlot().values().toArray()[0]; - atoZDirectionBldr.setAToZWavelengthNumber(Uint32.valueOf(0)) - .setTribPortNumber(Uint16.valueOf(rc.getResultTribPort().values().toArray()[0].toString())) - .setTribSlotNumber(tribSlotList.get(0)); - } else { - LOG.error("Trib port and trib slot number should be present"); - atoZDirectionBldr.setTribSlotNumber(Uint16.valueOf(0)).setTribPortNumber(Uint16.valueOf(0)); - } - } - rc.setAtoZDirection(atoZDirectionBldr.build()); - pathZtoA = ImmutableList.copyOf(pathAtoZ).reverse(); + buildAtoZ(atozMap, pathAtoZ); + rc.setAtoZDirection(buildAtoZDirection(atozMap).build()); + List pathZtoA = ImmutableList.copyOf(pathAtoZ).reverse(); LOG.info("In buildDescriptions: ZtoA {}", pathZtoA); - Map ztoaList = new HashMap<>(); + Map ztoaMap = new HashMap<>(); if (pathZtoA == null) { rc.setRC(ResponseCodes.RESPONSE_FAILED); LOG.error("In buildDescriptions: there is empty ZtoA path"); return rc; } - buildZtoA(ztoaList, pathZtoA); - ZToADirectionBuilder ztoADirectionBldr = new ZToADirectionBuilder() + buildZtoA(ztoaMap, pathZtoA); + rc.setZtoADirection(buildZtoADirection(ztoaMap).build()); + + return rc; + } + + /** + * Create a builder for AtoZDirection object. + * @param atozMap Map of AToZ object + * @return a builder for AtoZDirection object + */ + private AToZDirectionBuilder buildAtoZDirection(Map atozMap) { + AToZDirectionBuilder atoZDirectionBldr = new AToZDirectionBuilder() .setRate(Uint32.valueOf(rc.getRate())) - .setZToA(ztoaList); - if ("100GE".equals(rc.getServiceType()) || "OTU4".equals(rc.getServiceType())) { - ztoADirectionBldr.setZToAWavelengthNumber(Uint32.valueOf(rc.getResultWavelength())); - } else if ("10GE".equals(rc.getServiceType()) || "1GE".equals(rc.getServiceType()) - || "ODU4".equals(rc.getServiceType())) { - if (rc.getResultTribSlot() != null && rc.getResultTribPort() != null) { - List tribSlotList = (List) rc.getResultTribSlot().values().toArray()[0]; - ztoADirectionBldr.setZToAWavelengthNumber(Uint32.valueOf(0)) - .setTribPortNumber(Uint16.valueOf(rc.getResultTribPort().values().toArray()[0].toString())) - .setTribSlotNumber(tribSlotList.get(0)); - } else { - LOG.error("Trib port and trib slot number should be present"); - ztoADirectionBldr.setTribSlotNumber(Uint16.valueOf(0)).setTribPortNumber(Uint16.valueOf(0)); - } + .setModulationFormat(GridConstant.RATE_MODULATION_FORMAT_MAP + .getOrDefault(Uint32.valueOf(rc.getRate()), ModulationFormat.DpQpsk).getName()) + .setAToZ(atozMap); + switch (rc.getServiceType()) { + case StringConstants.SERVICE_TYPE_400GE: + case StringConstants.SERVICE_TYPE_OTUC4: + case StringConstants.SERVICE_TYPE_100GE_T: + case StringConstants.SERVICE_TYPE_OTU4: + atoZDirectionBldr.setAToZMaxFrequency(new FrequencyTHz(rc.getMaxFreq())); + atoZDirectionBldr.setAToZMinFrequency(new FrequencyTHz(rc.getMinFreq())); + atoZDirectionBldr.setAToZWavelengthNumber(Uint32.valueOf(rc.getResultWavelength())); + break; + case StringConstants.SERVICE_TYPE_100GE_M: + case StringConstants.SERVICE_TYPE_100GE_S: + case StringConstants.SERVICE_TYPE_10GE: + case StringConstants.SERVICE_TYPE_1GE: + case StringConstants.SERVICE_TYPE_ODU4: + case StringConstants.SERVICE_TYPE_ODUC4: + if (rc.getResultTribPortTribSlot().get(0) != null && rc.getResultTribPortTribSlot().get(1) != null) { + atoZDirectionBldr.setAToZWavelengthNumber(Uint32.valueOf(0)) + .setMinTribSlot(rc.getResultTribPortTribSlot().get(0)) + .setMaxTribSlot(rc.getResultTribPortTribSlot().get(1)); + } else { + LOG.error("Trib port and trib slot number should be present"); + atoZDirectionBldr.setMinTribSlot(new OpucnTribSlotDef("0.0")) + .setMaxTribSlot(new OpucnTribSlotDef("0.0")); + } + break; + default: + LOG.warn("unknown service type : unable to set Min/Max frequencies"); + break; } - rc.setZtoADirection(ztoADirectionBldr.build()); + return atoZDirectionBldr; + } - return rc; + /** + * Create a builder for ZtoADirection object. + * @param ztoaMap Map of ZToA object + * @return a builder for ZtoADirection object + */ + private ZToADirectionBuilder buildZtoADirection(Map ztoaMap) { + ZToADirectionBuilder ztoADirectionBldr = new ZToADirectionBuilder().setRate(Uint32.valueOf(rc.getRate())) + .setModulationFormat(GridConstant.RATE_MODULATION_FORMAT_MAP + .getOrDefault(Uint32.valueOf(rc.getRate()), ModulationFormat.DpQpsk).getName()) + .setZToA(ztoaMap); + switch (rc.getServiceType()) { + case StringConstants.SERVICE_TYPE_400GE: + case StringConstants.SERVICE_TYPE_OTUC4: + case StringConstants.SERVICE_TYPE_100GE_T: + case StringConstants.SERVICE_TYPE_OTU4: + ztoADirectionBldr.setZToAMaxFrequency(new FrequencyTHz(rc.getMaxFreq())); + ztoADirectionBldr.setZToAMinFrequency(new FrequencyTHz(rc.getMinFreq())); + ztoADirectionBldr.setZToAWavelengthNumber(Uint32.valueOf(rc.getResultWavelength())); + break; + case StringConstants.SERVICE_TYPE_100GE_M: + case StringConstants.SERVICE_TYPE_100GE_S: + case StringConstants.SERVICE_TYPE_10GE: + case StringConstants.SERVICE_TYPE_1GE: + case StringConstants.SERVICE_TYPE_ODU4: + if (rc.getResultTribPortTribSlot().get(0) != null && rc.getResultTribPortTribSlot().get(1) != null) { + ztoADirectionBldr.setZToAWavelengthNumber(Uint32.valueOf(0)) + .setMinTribSlot(rc.getResultTribPortTribSlot().get(0)) + .setMaxTribSlot(rc.getResultTribPortTribSlot().get(1)); + } else { + LOG.error("Trib port and trib slot number should be present"); + ztoADirectionBldr.setMinTribSlot(new OpucnTribSlotDef("0.0")) + .setMaxTribSlot(new OpucnTribSlotDef("0.0")); + } + break; + default: + LOG.warn("unknown service type : unable to set Min/Max frequencies"); + break; + } + return ztoADirectionBldr; } - private void buildAtoZ(Map atozList, List path) { + @SuppressWarnings("java:S138") + //sonar issue This method has 77 lines, which is greater than the 75 lines authorized. Split it into smaller + //ignore as it's not relevant to split it from functional point + private void buildAtoZ(Map atozMap, List path) { Integer index = 0; PceLink lastLink = null; AToZ lastResource = null; @@ -123,81 +180,81 @@ public class PcePathDescription { .build(); AToZKey clientKey = new AToZKey(index.toString()); - Resource clientResource = new ResourceBuilder().setResource(stp).build(); + Resource clientResource = new ResourceBuilder().setResource(stp).setState(State.InService).build(); AToZ firstResource = new AToZBuilder().setId(tpName).withKey(clientKey).setResource(clientResource).build(); - atozList.put(firstResource.key(),firstResource); + atozMap.put(firstResource.key(),firstResource); index += 1; for (PceLink pcelink : path) { String srcName = pcelink.getSourceId().getValue(); // Nodes - org.opendaylight.yang.gen.v1.http.org.transportpce.b.c._interface.pathdescription.rev200629.pce + org.opendaylight.yang.gen.v1.http.org.transportpce.b.c._interface.pathdescription.rev210705.pce .resource.resource.resource.Node sourceNode = new NodeBuilder() .setNodeId(srcName) .build(); // Source Resource AToZKey sourceKey = new AToZKey(index.toString()); - Resource nodeResource1 = new ResourceBuilder().setResource(sourceNode).build(); + Resource nodeResource1 = new ResourceBuilder().setResource(sourceNode).setState(State.InService).build(); AToZ srcResource = new AToZBuilder().setId(srcName).withKey(sourceKey).setResource(nodeResource1).build(); index += 1; - atozList.put(srcResource.key(),srcResource); + atozMap.put(srcResource.key(),srcResource); // source TP - tpName = pcelink.getSourceTP().toString(); + tpName = pcelink.getSourceTP().getValue(); stp = new TerminationPointBuilder() .setTpNodeId(srcName).setTpId(tpName) .build(); // Resource AToZKey srcTPKey = new AToZKey(index.toString()); - Resource tpResource1 = new ResourceBuilder().setResource(stp).build(); + Resource tpResource1 = new ResourceBuilder().setResource(stp).setState(State.InService).build(); AToZ stpResource = new AToZBuilder().setId(tpName).withKey(srcTPKey).setResource(tpResource1).build(); index += 1; - atozList.put(stpResource.key(),stpResource); + atozMap.put(stpResource.key(),stpResource); String linkName = pcelink.getLinkId().getValue(); // Link - org.opendaylight.yang.gen.v1.http.org.transportpce.b.c._interface.pathdescription.rev200629.pce + org.opendaylight.yang.gen.v1.http.org.transportpce.b.c._interface.pathdescription.rev210705.pce .resource.resource.resource.Link atozLink = new LinkBuilder() .setLinkId(linkName) .build(); // Link Resource AToZKey linkKey = new AToZKey(index.toString()); - Resource nodeResource2 = new ResourceBuilder().setResource(atozLink).build(); + Resource nodeResource2 = new ResourceBuilder().setResource(atozLink).setState(pcelink.getState()).build(); AToZ linkResource = new AToZBuilder().setId(linkName).withKey(linkKey).setResource(nodeResource2).build(); index += 1; - atozList.put(linkResource.key(),linkResource); + atozMap.put(linkResource.key(),linkResource); String destName = pcelink.getDestId().getValue(); // target TP - tpName = pcelink.getDestTP().toString(); + tpName = pcelink.getDestTP().getValue(); TerminationPoint dtp = new TerminationPointBuilder() .setTpNodeId(destName).setTpId(tpName) .build(); // Resource AToZKey destTPKey = new AToZKey(index.toString()); - Resource tpResource2 = new ResourceBuilder().setResource(dtp).build(); + Resource tpResource2 = new ResourceBuilder().setResource(dtp).setState(State.InService).build(); AToZ ttpResource = new AToZBuilder().setId(tpName).withKey(destTPKey).setResource(tpResource2).build(); index += 1; - atozList.put(ttpResource.key(),ttpResource); + atozMap.put(ttpResource.key(),ttpResource); - org.opendaylight.yang.gen.v1.http.org.transportpce.b.c._interface.pathdescription.rev200629.pce + org.opendaylight.yang.gen.v1.http.org.transportpce.b.c._interface.pathdescription.rev210705.pce .resource.resource.resource.Node targetNode = new NodeBuilder() .setNodeId(destName) .build(); // Target Resource AToZKey targetKey = new AToZKey(index.toString()); - Resource nodeResource3 = new ResourceBuilder().setResource(targetNode).build(); + Resource nodeResource3 = new ResourceBuilder().setResource(targetNode).setState(State.InService).build(); lastResource = new AToZBuilder().setId(destName).withKey(targetKey).setResource(nodeResource3).build(); lastLink = pcelink; } if (lastResource != null) { - atozList.put(lastResource.key(),lastResource); + atozMap.put(lastResource.key(),lastResource); } // build Z side Client TP @@ -209,9 +266,9 @@ public class PcePathDescription { index += 1; clientKey = new AToZKey(index.toString()); - clientResource = new ResourceBuilder().setResource(stp).build(); + clientResource = new ResourceBuilder().setResource(stp).setState(State.InService).build(); lastResource = new AToZBuilder().setId(tpName).withKey(clientKey).setResource(clientResource).build(); - atozList.put(lastResource.key(),lastResource); + atozMap.put(lastResource.key(),lastResource); } @@ -229,7 +286,7 @@ public class PcePathDescription { .build(); ZToAKey clientKey = new ZToAKey(index.toString()); - Resource clientResource = new ResourceBuilder().setResource(stp).build(); + Resource clientResource = new ResourceBuilder().setResource(stp).setState(State.InService).build(); ZToA firstResource = new ZToABuilder().setId(tpName).withKey(clientKey).setResource(clientResource).build(); ztoaList.put(firstResource.key(),firstResource); index += 1; @@ -243,64 +300,64 @@ public class PcePathDescription { // Nodes - org.opendaylight.yang.gen.v1.http.org.transportpce.b.c._interface.pathdescription.rev200629.pce + org.opendaylight.yang.gen.v1.http.org.transportpce.b.c._interface.pathdescription.rev210705.pce .resource.resource.resource.Node sourceNode = new NodeBuilder() .setNodeId(srcName).build(); // Source Resource ZToAKey sourceKey = new ZToAKey(index.toString()); - Resource nodeResource1 = new ResourceBuilder().setResource(sourceNode).build(); + Resource nodeResource1 = new ResourceBuilder().setResource(sourceNode).setState(State.InService).build(); ZToA srcResource = new ZToABuilder().setId(srcName).withKey(sourceKey).setResource(nodeResource1).build(); index += 1; ztoaList.put(srcResource.key(),srcResource); // source TP - tpName = pcelink.getSourceTP().toString(); + tpName = pcelink.getSourceTP().getValue(); stp = new TerminationPointBuilder() .setTpNodeId(srcName).setTpId(tpName) .build(); // Resource ZToAKey srcTPKey = new ZToAKey(index.toString()); - Resource tpResource1 = new ResourceBuilder().setResource(stp).build(); + Resource tpResource1 = new ResourceBuilder().setResource(stp).setState(State.InService).build(); ZToA stpResource = new ZToABuilder().setId(tpName).withKey(srcTPKey).setResource(tpResource1).build(); index += 1; ztoaList.put(stpResource.key(),stpResource); String linkName = pcelink.getLinkId().getValue(); // Link - org.opendaylight.yang.gen.v1.http.org.transportpce.b.c._interface.pathdescription.rev200629.pce + org.opendaylight.yang.gen.v1.http.org.transportpce.b.c._interface.pathdescription.rev210705.pce .resource.resource.resource.Link ztoaLink = new LinkBuilder() .setLinkId(linkName).build(); // Link Resource ZToAKey linkKey = new ZToAKey(index.toString()); - Resource nodeResource2 = new ResourceBuilder().setResource(ztoaLink).build(); + Resource nodeResource2 = new ResourceBuilder().setResource(ztoaLink).setState(State.InService).build(); ZToA linkResource = new ZToABuilder().setId(linkName).withKey(linkKey).setResource(nodeResource2).build(); index += 1; ztoaList.put(linkResource.key(),linkResource); String destName = pcelink.getDestId().getValue(); // target TP - tpName = pcelink.getDestTP().toString(); + tpName = pcelink.getDestTP().getValue(); TerminationPoint ttp = new TerminationPointBuilder() .setTpNodeId(destName).setTpId(tpName).build(); // Resource ZToAKey destTPKey = new ZToAKey(index.toString()); - Resource tpResource2 = new ResourceBuilder().setResource(ttp).build(); + Resource tpResource2 = new ResourceBuilder().setResource(ttp).setState(State.InService).build(); ZToA ttpResource = new ZToABuilder().setId(tpName).withKey(destTPKey).setResource(tpResource2).build(); index += 1; ztoaList.put(ttpResource.key(),ttpResource); - org.opendaylight.yang.gen.v1.http.org.transportpce.b.c._interface.pathdescription.rev200629.pce + org.opendaylight.yang.gen.v1.http.org.transportpce.b.c._interface.pathdescription.rev210705.pce .resource.resource.resource.Node targetNode = new NodeBuilder() .setNodeId(destName).build(); // Target Resource ZToAKey targetKey = new ZToAKey(index.toString()); - Resource nodeResource3 = new ResourceBuilder().setResource(targetNode).build(); + Resource nodeResource3 = new ResourceBuilder().setResource(targetNode).setState(State.InService).build(); lastResource = new ZToABuilder().setId(destName).withKey(targetKey).setResource(nodeResource3).build(); lastLink = pcelink; @@ -317,7 +374,7 @@ public class PcePathDescription { index += 1; clientKey = new ZToAKey(index.toString()); - clientResource = new ResourceBuilder().setResource(stp).build(); + clientResource = new ResourceBuilder().setResource(stp).setState(State.InService).build(); lastResource = new ZToABuilder().setId(tpName).withKey(clientKey).setResource(clientResource).build(); ztoaList.put(lastResource.key(),lastResource); }