X-Git-Url: https://git.opendaylight.org/gerrit/gitweb?a=blobdiff_plain;f=servicehandler%2Fsrc%2Fmain%2Fjava%2Forg%2Fopendaylight%2Ftransportpce%2Fservicehandler%2FModelMappingUtils.java;h=7ef1bab194177f298809ca0f4e12f9983232c7fc;hb=c6b93e8d8dd5a5597ca891140212229d99431614;hp=1f3ff47f7bf11c04666f8e99d7ff9ee422789fde;hpb=e14bba1b91c605df2106d3068f92168a2abd5d87;p=transportpce.git diff --git a/servicehandler/src/main/java/org/opendaylight/transportpce/servicehandler/ModelMappingUtils.java b/servicehandler/src/main/java/org/opendaylight/transportpce/servicehandler/ModelMappingUtils.java index 1f3ff47f7..7ef1bab19 100644 --- a/servicehandler/src/main/java/org/opendaylight/transportpce/servicehandler/ModelMappingUtils.java +++ b/servicehandler/src/main/java/org/opendaylight/transportpce/servicehandler/ModelMappingUtils.java @@ -7,371 +7,629 @@ */ package org.opendaylight.transportpce.servicehandler; +import com.google.common.collect.ImmutableMap; import com.google.common.util.concurrent.ListenableFuture; -import java.util.ArrayList; -import java.util.List; -import org.opendaylight.yang.gen.v1.http.org.opendaylight.transportpce.pce.rev170426.PathComputationRequestOutput; -import org.opendaylight.yang.gen.v1.http.org.opendaylight.transportpce.pce.rev170426.path.computation.request.input.ServiceAEnd; -import org.opendaylight.yang.gen.v1.http.org.opendaylight.transportpce.pce.rev170426.path.computation.request.input.ServiceAEndBuilder; -import org.opendaylight.yang.gen.v1.http.org.opendaylight.transportpce.pce.rev170426.path.computation.request.input.ServiceZEnd; -import org.opendaylight.yang.gen.v1.http.org.opendaylight.transportpce.pce.rev170426.path.computation.request.input.ServiceZEndBuilder; -import org.opendaylight.yang.gen.v1.http.org.openroadm.common.service.types.rev161014.configuration.response.common.ConfigurationResponseCommon; -import org.opendaylight.yang.gen.v1.http.org.openroadm.common.service.types.rev161014.configuration.response.common.ConfigurationResponseCommonBuilder; -import org.opendaylight.yang.gen.v1.http.org.openroadm.common.service.types.rev161014.response.parameters.ResponseParametersBuilder; -import org.opendaylight.yang.gen.v1.http.org.openroadm.common.service.types.rev161014.service.Topology; -import org.opendaylight.yang.gen.v1.http.org.openroadm.common.service.types.rev161014.service.TopologyBuilder; -import org.opendaylight.yang.gen.v1.http.org.openroadm.common.types.rev161014.LifecycleState; -import org.opendaylight.yang.gen.v1.http.org.openroadm.common.types.rev161014.RpcStatus; -import org.opendaylight.yang.gen.v1.http.org.openroadm.common.types.rev161014.State; -import org.opendaylight.yang.gen.v1.http.org.openroadm.service.rev161014.ServiceCreateInput; -import org.opendaylight.yang.gen.v1.http.org.openroadm.service.rev161014.ServiceCreateOutput; -import org.opendaylight.yang.gen.v1.http.org.openroadm.service.rev161014.ServiceCreateOutputBuilder; -import org.opendaylight.yang.gen.v1.http.org.openroadm.service.rev161014.ServiceDeleteInput; -import org.opendaylight.yang.gen.v1.http.org.openroadm.service.rev161014.ServiceDeleteOutput; -import org.opendaylight.yang.gen.v1.http.org.openroadm.service.rev161014.ServiceDeleteOutputBuilder; -import org.opendaylight.yang.gen.v1.http.org.openroadm.service.rev161014.ServiceReconfigureInput; -import org.opendaylight.yang.gen.v1.http.org.openroadm.service.rev161014.ServiceRerouteInput; -import org.opendaylight.yang.gen.v1.http.org.openroadm.service.rev161014.ServiceRerouteOutput; -import org.opendaylight.yang.gen.v1.http.org.openroadm.service.rev161014.ServiceRerouteOutputBuilder; -import org.opendaylight.yang.gen.v1.http.org.openroadm.service.rev161014.service.list.Services; -import org.opendaylight.yang.gen.v1.http.org.openroadm.service.rev161014.service.list.ServicesBuilder; -import org.opendaylight.yang.gen.v1.http.org.openroadm.topology.rev161014.topology.AToZ; -import org.opendaylight.yang.gen.v1.http.org.openroadm.topology.rev161014.topology.AToZBuilder; -import org.opendaylight.yang.gen.v1.http.org.openroadm.topology.rev161014.topology.AToZKey; -import org.opendaylight.yang.gen.v1.http.org.openroadm.topology.rev161014.topology.ZToA; -import org.opendaylight.yang.gen.v1.http.org.openroadm.topology.rev161014.topology.ZToABuilder; -import org.opendaylight.yang.gen.v1.http.org.openroadm.topology.rev161014.topology.ZToAKey; -import org.opendaylight.yang.gen.v1.http.org.transportpce.b.c._interface.routing.constraints.rev170426.routing.constraints.sp.HardConstraintsBuilder; -import org.opendaylight.yang.gen.v1.http.org.transportpce.b.c._interface.routing.constraints.rev170426.routing.constraints.sp.SoftConstraintsBuilder; -import org.opendaylight.yang.gen.v1.http.org.transportpce.b.c._interface.service.types.rev170426.service.endpoint.sp.RxDirection; -import org.opendaylight.yang.gen.v1.http.org.transportpce.b.c._interface.service.types.rev170426.service.endpoint.sp.RxDirectionBuilder; -import org.opendaylight.yang.gen.v1.http.org.transportpce.b.c._interface.service.types.rev170426.service.endpoint.sp.TxDirection; -import org.opendaylight.yang.gen.v1.http.org.transportpce.b.c._interface.service.types.rev170426.service.endpoint.sp.TxDirectionBuilder; -import org.opendaylight.yang.gen.v1.http.org.transportpce.b.c._interface.service.types.rev170426.service.handler.header.ServiceHandlerHeaderBuilder; -import org.opendaylight.yang.gen.v1.http.org.transportpce.b.c._interface.service.types.rev170426.service.path.PathDescriptionBuilder; -import org.opendaylight.yang.gen.v1.http.org.transportpce.b.c._interface.servicepath.rev170426.ServiceDeleteInputBuilder; -import org.opendaylight.yang.gen.v1.http.org.transportpce.b.c._interface.servicepath.rev170426.ServiceImplementationRequestInput; -import org.opendaylight.yang.gen.v1.http.org.transportpce.b.c._interface.servicepath.rev170426.ServiceImplementationRequestInputBuilder; -import org.opendaylight.yang.gen.v1.http.org.transportpce.b.c._interface.servicepath.rev170426.service.path.list.ServicePaths; -import org.opendaylight.yang.gen.v1.http.org.transportpce.b.c._interface.servicepath.rev170426.service.path.list.ServicePathsBuilder; +import org.opendaylight.yang.gen.v1.http.org.opendaylight.transportpce.pce.rev220808.PathComputationRequestOutput; +import org.opendaylight.yang.gen.v1.http.org.opendaylight.transportpce.pce.rev220808.path.computation.request.input.ServiceAEnd; +import org.opendaylight.yang.gen.v1.http.org.opendaylight.transportpce.pce.rev220808.path.computation.request.input.ServiceAEndBuilder; +import org.opendaylight.yang.gen.v1.http.org.opendaylight.transportpce.pce.rev220808.path.computation.request.input.ServiceZEnd; +import org.opendaylight.yang.gen.v1.http.org.opendaylight.transportpce.pce.rev220808.path.computation.request.input.ServiceZEndBuilder; +import org.opendaylight.yang.gen.v1.http.org.opendaylight.transportpce.pce.rev220808.service.path.rpc.result.PathDescription; +import org.opendaylight.yang.gen.v1.http.org.opendaylight.transportpce.renderer.rev210915.ServiceDeleteInputBuilder; +import org.opendaylight.yang.gen.v1.http.org.opendaylight.transportpce.renderer.rev210915.ServiceImplementationRequestInput; +import org.opendaylight.yang.gen.v1.http.org.opendaylight.transportpce.renderer.rev210915.ServiceImplementationRequestInputBuilder; +import org.opendaylight.yang.gen.v1.http.org.openroadm.common.node.types.rev210528.NodeIdType; +import org.opendaylight.yang.gen.v1.http.org.openroadm.common.service.types.rev211210.ServiceEndpoint; +import org.opendaylight.yang.gen.v1.http.org.openroadm.common.service.types.rev211210.configuration.response.common.ConfigurationResponseCommonBuilder; +import org.opendaylight.yang.gen.v1.http.org.openroadm.common.service.types.rev211210.response.parameters.ResponseParametersBuilder; +import org.opendaylight.yang.gen.v1.http.org.openroadm.common.state.types.rev191129.LifecycleState; +import org.opendaylight.yang.gen.v1.http.org.openroadm.common.state.types.rev191129.State; +import org.opendaylight.yang.gen.v1.http.org.openroadm.equipment.states.types.rev191129.AdminStates; +import org.opendaylight.yang.gen.v1.http.org.openroadm.otn.common.types.rev210924.ODU0; +import org.opendaylight.yang.gen.v1.http.org.openroadm.otn.common.types.rev210924.ODU1; +import org.opendaylight.yang.gen.v1.http.org.openroadm.otn.common.types.rev210924.ODU2; +import org.opendaylight.yang.gen.v1.http.org.openroadm.otn.common.types.rev210924.ODU2e; +import org.opendaylight.yang.gen.v1.http.org.openroadm.otn.common.types.rev210924.ODU3; +import org.opendaylight.yang.gen.v1.http.org.openroadm.otn.common.types.rev210924.ODU4; +import org.opendaylight.yang.gen.v1.http.org.openroadm.otn.common.types.rev210924.ODUCn; +import org.opendaylight.yang.gen.v1.http.org.openroadm.otn.common.types.rev210924.ODUflexCbr; +import org.opendaylight.yang.gen.v1.http.org.openroadm.otn.common.types.rev210924.ODUflexFlexe; +import org.opendaylight.yang.gen.v1.http.org.openroadm.otn.common.types.rev210924.ODUflexGfp; +import org.opendaylight.yang.gen.v1.http.org.openroadm.otn.common.types.rev210924.ODUflexImp; +import org.opendaylight.yang.gen.v1.http.org.openroadm.otn.common.types.rev210924.OTU0; +import org.opendaylight.yang.gen.v1.http.org.openroadm.otn.common.types.rev210924.OTU1; +import org.opendaylight.yang.gen.v1.http.org.openroadm.otn.common.types.rev210924.OTU2; +import org.opendaylight.yang.gen.v1.http.org.openroadm.otn.common.types.rev210924.OTU2e; +import org.opendaylight.yang.gen.v1.http.org.openroadm.otn.common.types.rev210924.OTU3; +import org.opendaylight.yang.gen.v1.http.org.openroadm.otn.common.types.rev210924.OTU4; +import org.opendaylight.yang.gen.v1.http.org.openroadm.otn.common.types.rev210924.OTUCn; +import org.opendaylight.yang.gen.v1.http.org.openroadm.otn.common.types.rev210924.OTUflex; +import org.opendaylight.yang.gen.v1.http.org.openroadm.otn.common.types.rev210924.OduRateIdentity; +import org.opendaylight.yang.gen.v1.http.org.openroadm.otn.common.types.rev210924.OtuRateIdentity; +import org.opendaylight.yang.gen.v1.http.org.openroadm.service.rev211210.ServiceCreateInput; +import org.opendaylight.yang.gen.v1.http.org.openroadm.service.rev211210.ServiceCreateOutput; +import org.opendaylight.yang.gen.v1.http.org.openroadm.service.rev211210.ServiceCreateOutputBuilder; +import org.opendaylight.yang.gen.v1.http.org.openroadm.service.rev211210.ServiceDeleteInput; +import org.opendaylight.yang.gen.v1.http.org.openroadm.service.rev211210.ServiceDeleteOutput; +import org.opendaylight.yang.gen.v1.http.org.openroadm.service.rev211210.ServiceDeleteOutputBuilder; +import org.opendaylight.yang.gen.v1.http.org.openroadm.service.rev211210.ServiceFeasibilityCheckInput; +import org.opendaylight.yang.gen.v1.http.org.openroadm.service.rev211210.ServiceFeasibilityCheckOutput; +import org.opendaylight.yang.gen.v1.http.org.openroadm.service.rev211210.ServiceFeasibilityCheckOutputBuilder; +import org.opendaylight.yang.gen.v1.http.org.openroadm.service.rev211210.ServiceReconfigureInput; +import org.opendaylight.yang.gen.v1.http.org.openroadm.service.rev211210.ServiceReconfigureOutput; +import org.opendaylight.yang.gen.v1.http.org.openroadm.service.rev211210.ServiceReconfigureOutputBuilder; +import org.opendaylight.yang.gen.v1.http.org.openroadm.service.rev211210.ServiceRerouteInput; +import org.opendaylight.yang.gen.v1.http.org.openroadm.service.rev211210.ServiceRerouteOutput; +import org.opendaylight.yang.gen.v1.http.org.openroadm.service.rev211210.ServiceRerouteOutputBuilder; +import org.opendaylight.yang.gen.v1.http.org.openroadm.service.rev211210.ServiceRestorationInput; +import org.opendaylight.yang.gen.v1.http.org.openroadm.service.rev211210.ServiceRestorationOutput; +import org.opendaylight.yang.gen.v1.http.org.openroadm.service.rev211210.ServiceRestorationOutputBuilder; +import org.opendaylight.yang.gen.v1.http.org.openroadm.service.rev211210.TempServiceCreateInput; +import org.opendaylight.yang.gen.v1.http.org.openroadm.service.rev211210.TempServiceCreateOutput; +import org.opendaylight.yang.gen.v1.http.org.openroadm.service.rev211210.TempServiceCreateOutputBuilder; +import org.opendaylight.yang.gen.v1.http.org.openroadm.service.rev211210.TempServiceDeleteInput; +import org.opendaylight.yang.gen.v1.http.org.openroadm.service.rev211210.TempServiceDeleteOutput; +import org.opendaylight.yang.gen.v1.http.org.openroadm.service.rev211210.TempServiceDeleteOutputBuilder; +import org.opendaylight.yang.gen.v1.http.org.openroadm.service.rev211210.service.list.Services; +import org.opendaylight.yang.gen.v1.http.org.openroadm.service.rev211210.service.list.ServicesBuilder; +import org.opendaylight.yang.gen.v1.http.org.openroadm.service.rev211210.service.list.ServicesKey; +import org.opendaylight.yang.gen.v1.http.org.transportpce.b.c._interface.service.types.rev220118.service.endpoint.sp.RxDirection; +import org.opendaylight.yang.gen.v1.http.org.transportpce.b.c._interface.service.types.rev220118.service.endpoint.sp.RxDirectionBuilder; +import org.opendaylight.yang.gen.v1.http.org.transportpce.b.c._interface.service.types.rev220118.service.endpoint.sp.TxDirection; +import org.opendaylight.yang.gen.v1.http.org.transportpce.b.c._interface.service.types.rev220118.service.endpoint.sp.TxDirectionBuilder; +import org.opendaylight.yang.gen.v1.http.org.transportpce.b.c._interface.service.types.rev220118.service.handler.header.ServiceHandlerHeaderBuilder; +import org.opendaylight.yang.gen.v1.http.org.transportpce.b.c._interface.service.types.rev220118.service.path.PathDescriptionBuilder; +import org.opendaylight.yang.gen.v1.http.org.transportpce.b.c._interface.servicepath.rev171017.service.path.list.ServicePaths; +import org.opendaylight.yang.gen.v1.http.org.transportpce.b.c._interface.servicepath.rev171017.service.path.list.ServicePathsBuilder; +import org.opendaylight.yang.gen.v1.http.org.transportpce.b.c._interface.servicepath.rev171017.service.path.list.ServicePathsKey; import org.opendaylight.yangtools.yang.common.RpcResult; import org.opendaylight.yangtools.yang.common.RpcResultBuilder; +import org.slf4j.Logger; +import org.slf4j.LoggerFactory; public final class ModelMappingUtils { + private static final Logger LOG = LoggerFactory.getLogger(ModelMappingUtils.class); + + private static final ImmutableMap ODU_RATE_MAP = + ImmutableMap.builder() + .put("ODU0", ODU0.VALUE) + .put("ODU1", ODU1.VALUE) + .put("ODU2", ODU2.VALUE) + .put("ODU2e", ODU2e.VALUE) + .put("ODU3", ODU3.VALUE) + .put("ODU4", ODU4.VALUE) + .put("ODUCn", ODUCn.VALUE) + .put("ODUflexCbr", ODUflexCbr.VALUE) + .put("ODUflexFlexe", ODUflexFlexe.VALUE) + .put("ODUflexGfp", ODUflexGfp.VALUE) + .put("ODUflexImp", ODUflexImp.VALUE) + .build(); + + private static final ImmutableMap OTU_RATE_MAP = + ImmutableMap.builder() + .put("OTU0", OTU0.VALUE) + .put("OTU1", OTU1.VALUE) + .put("OTU2", OTU2.VALUE) + .put("OTU2e", OTU2e.VALUE) + .put("OTU3", OTU3.VALUE) + .put("OTU4", OTU4.VALUE) + .put("OTUCn", OTUCn.VALUE) + .put("OTUflex", OTUflex.VALUE) + .build(); private ModelMappingUtils() { } - public static ServiceImplementationRequestInput createServiceImplementationRequest(ServiceCreateInput input, - PathComputationRequestOutput pceResponse) { - - ServiceImplementationRequestInputBuilder serviceImplementationRequestInputBuilder = - new ServiceImplementationRequestInputBuilder(); - serviceImplementationRequestInputBuilder.setServiceName(input.getServiceName()); - org.opendaylight.yang.gen.v1.http.org.transportpce.b.c._interface.servicepath - .rev170426.service.implementation.request.input.ServiceAEndBuilder serviceAEnd = - new org.opendaylight.yang.gen.v1.http.org.transportpce.b.c._interface.servicepath - .rev170426.service.implementation.request.input.ServiceAEndBuilder(); - serviceAEnd.setServiceFormat(input.getServiceAEnd().getServiceFormat()) - .setServiceRate(input.getServiceAEnd().getServiceRate()).setClli(input.getServiceAEnd().getClli()) - .setNodeId(input.getServiceAEnd().getNodeId()) - .setTxDirection(new org.opendaylight.yang.gen.v1.http.org.transportpce.b.c._interface.service.types - .rev170426.service.endpoint.sp.TxDirectionBuilder() - .setPort(input.getServiceAEnd().getTxDirection().getPort()).build()) - .setRxDirection(new org.opendaylight.yang.gen.v1.http.org.transportpce.b.c._interface.service.types - .rev170426.service.endpoint.sp.RxDirectionBuilder() - .setPort(input.getServiceAEnd().getRxDirection().getPort()).build()); - org.opendaylight.yang.gen.v1.http.org.transportpce.b.c._interface.servicepath - .rev170426.service.implementation.request.input.ServiceZEndBuilder serviceZEnd = - new org.opendaylight.yang.gen.v1.http.org.transportpce.b.c._interface.servicepath - .rev170426.service.implementation.request.input.ServiceZEndBuilder(); - serviceZEnd.setServiceFormat(input.getServiceZEnd().getServiceFormat()) - .setServiceRate(input.getServiceZEnd().getServiceRate()).setClli(input.getServiceZEnd().getClli()) - .setNodeId(input.getServiceZEnd().getNodeId()) - .setTxDirection(new org.opendaylight.yang.gen.v1.http.org.transportpce.b.c._interface.service.types - .rev170426.service.endpoint.sp.TxDirectionBuilder() - .setPort(input.getServiceZEnd().getTxDirection().getPort()).build()) - .setRxDirection(new org.opendaylight.yang.gen.v1.http.org.transportpce.b.c._interface.service.types - .rev170426.service.endpoint.sp.RxDirectionBuilder() - .setPort(input.getServiceZEnd().getRxDirection().getPort()).build()); - serviceImplementationRequestInputBuilder.setServiceAEnd(serviceAEnd.build()); - serviceImplementationRequestInputBuilder.setServiceZEnd(serviceZEnd.build()); - serviceImplementationRequestInputBuilder.setServiceHandlerHeader( - new ServiceHandlerHeaderBuilder().setRequestId(input.getSdncRequestHeader().getRequestId()).build()); - org.opendaylight.yang.gen.v1.http.org.transportpce.b.c._interface.servicepath - .rev170426.service.implementation.request.input.PathDescriptionBuilder pathDescBuilder = - new org.opendaylight.yang.gen.v1.http.org.transportpce.b.c._interface.servicepath - .rev170426.service.implementation.request.input - .PathDescriptionBuilder(); - pathDescBuilder.setAToZDirection(pceResponse.getResponseParameters() - .getPathDescription().getAToZDirection()); - pathDescBuilder.setZToADirection(pceResponse.getResponseParameters() - .getPathDescription().getZToADirection()); - serviceImplementationRequestInputBuilder.setPathDescription(pathDescBuilder.build()); - return serviceImplementationRequestInputBuilder.build(); + public static ServiceImplementationRequestInput createServiceImplementationRequest( + ServiceInput input, + PathDescription pathDescription) { + return new ServiceImplementationRequestInputBuilder() + .setConnectionType(input.getConnectionType()) + .setServiceName( + input.isServiceReconfigure() + ? input.getNewServiceName() + : input.getServiceName()) + .setServiceAEnd( + new org.opendaylight.yang.gen.v1.http.org.opendaylight.transportpce.renderer.rev210915 + .service.implementation.request.input.ServiceAEndBuilder() + .setServiceFormat(input.getServiceAEnd().getServiceFormat()) + .setServiceRate(input.getServiceAEnd().getServiceRate()) + .setOtuServiceRate(getOtuServiceRate(input.getServiceAEnd().getOtuServiceRate())) + .setOduServiceRate(getOduServiceRate(input.getServiceAEnd().getOduServiceRate())) + .setClli(input.getServiceAEnd().getClli()) + .setNodeId(new NodeIdType(input.getServiceAEnd().getNodeId().getValue()).getValue()) + .setTxDirection( + new org.opendaylight.yang.gen.v1.http.org.transportpce.b.c._interface.service.types.rev220118 + .service.endpoint.sp.TxDirectionBuilder() + .setPort( + input.getServiceAEnd().getTxDirection().values().stream().findFirst().get().getPort()) + .build()) + .setRxDirection( + new org.opendaylight.yang.gen.v1.http.org.transportpce.b.c._interface.service.types.rev220118 + .service.endpoint.sp.RxDirectionBuilder() + .setPort( + input.getServiceAEnd().getRxDirection().values().stream().findFirst().get().getPort()) + .build()) + .build()) + .setServiceZEnd( + new org.opendaylight.yang.gen.v1.http.org.opendaylight.transportpce.renderer.rev210915 + .service.implementation.request.input.ServiceZEndBuilder() + .setServiceFormat(input.getServiceZEnd().getServiceFormat()) + .setServiceRate(input.getServiceZEnd().getServiceRate()) + .setOtuServiceRate(getOtuServiceRate(input.getServiceZEnd().getOtuServiceRate())) + .setOduServiceRate(getOduServiceRate(input.getServiceZEnd().getOduServiceRate())) + .setClli(input.getServiceZEnd().getClli()) + .setNodeId(new NodeIdType(input.getServiceZEnd().getNodeId().getValue()).getValue()) + .setTxDirection( + new org.opendaylight.yang.gen.v1.http.org.transportpce.b.c._interface.service.types.rev220118 + .service.endpoint.sp.TxDirectionBuilder() + .setPort( + input.getServiceZEnd().getTxDirection().values().stream().findFirst().get().getPort()) + .build()) + .setRxDirection( + new org.opendaylight.yang.gen.v1.http.org.transportpce.b.c._interface.service.types.rev220118 + .service.endpoint.sp.RxDirectionBuilder() + .setPort( + input.getServiceZEnd().getRxDirection().values().stream().findFirst().get().getPort()) + .build()) + .build()) + .setConnectionType(input.getConnectionType()) + .setServiceHandlerHeader( + new ServiceHandlerHeaderBuilder().setRequestId(input.getSdncRequestHeader().getRequestId()).build()) + .setPathDescription( + new org.opendaylight.yang.gen.v1.http.org.opendaylight.transportpce.renderer.rev210915 + .service.implementation.request.input.PathDescriptionBuilder() + .setAToZDirection(pathDescription.getAToZDirection()) + .setZToADirection(pathDescription.getZToADirection()) + .build()) + .build(); + } + + private static OduRateIdentity getOduServiceRate(OduRateIdentity oduServiceRate) { + if (oduServiceRate == null || !ODU_RATE_MAP.containsKey(oduServiceRate.toString())) { + LOG.error("ODU rate {} not recognized", oduServiceRate); + return null; + } + return ODU_RATE_MAP.get(oduServiceRate.toString()); + } + + private static OtuRateIdentity getOtuServiceRate(OtuRateIdentity otuServiceRate) { + if (otuServiceRate == null || !OTU_RATE_MAP.containsKey(otuServiceRate.toString())) { + LOG.error("OTU rate {} not recognized", otuServiceRate); + return null; + } + return OTU_RATE_MAP.get(otuServiceRate.toString()); + } + + public static org.opendaylight.yang.gen.v1.http.org.opendaylight.transportpce.renderer.rev210915 + .ServiceDeleteInput createServiceDeleteInput(ServiceInput serviceInput) { + return new ServiceDeleteInputBuilder() + .setServiceName(serviceInput.getServiceName()) + .setServiceHandlerHeader( + new ServiceHandlerHeaderBuilder() + .setRequestId(serviceInput.getSdncRequestHeader().getRequestId()) + .build()) + .build(); + } + + public static org.opendaylight.yang.gen.v1.http.org.opendaylight.transportpce.renderer.rev210915 + .ServiceDeleteInput createServiceDeleteInput( + ServiceRerouteInput serviceRerouteinput, + Services services) { + return new ServiceDeleteInputBuilder() + .setServiceName(serviceRerouteinput.getServiceName()) + .setServiceHandlerHeader( + new ServiceHandlerHeaderBuilder() + .setRequestId(services.getSdncRequestHeader().getRequestId()) + .build()) + .build(); } - public static org.opendaylight.yang.gen.v1.http.org.transportpce.b.c._interface.servicepath.rev170426 - .ServiceDeleteInput createServiceDeleteInput(ServiceDeleteInput serviceDeleteInput) { - ServiceDeleteInputBuilder builder = new ServiceDeleteInputBuilder(); - builder.setServiceName(serviceDeleteInput.getServiceDeleteReqInfo().getServiceName()); - builder.setServiceHandlerHeader(new ServiceHandlerHeaderBuilder().setRequestId( - serviceDeleteInput.getSdncRequestHeader().getRequestId()).build()); - return builder.build(); + public static org.opendaylight.yang.gen.v1.http.org.opendaylight.transportpce.renderer.rev210915 + .ServiceDeleteInput createServiceDeleteInput( + ServiceRestorationInput serviceRestorationInput, + Services services) { + return new ServiceDeleteInputBuilder() + .setServiceName(serviceRestorationInput.getServiceName()) + .setServiceHandlerHeader( + new ServiceHandlerHeaderBuilder() + .setRequestId(services.getSdncRequestHeader().getRequestId()) + .build()) + .build(); } - public static org.opendaylight.yang.gen.v1.http.org.transportpce.b.c._interface.servicepath.rev170426 - .ServiceDeleteInput createServiceDeleteInput(ServiceRerouteInput serviceRerouteInput, Services service) { - ServiceDeleteInputBuilder builder = new ServiceDeleteInputBuilder(); - builder.setServiceName(serviceRerouteInput.getServiceName()); - builder.setServiceHandlerHeader(new ServiceHandlerHeaderBuilder().setRequestId( - service.getSdncRequestHeader().getRequestId()).build()); - return builder.build(); + public static org.opendaylight.yang.gen.v1.http.org.opendaylight.transportpce.renderer.rev210915 + .ServiceDeleteInput createServiceDeleteInput(ServiceReconfigureInput serviceReconfigureInput) { + String serviceName = serviceReconfigureInput.getServiceName(); + return new ServiceDeleteInputBuilder() + .setServiceName(serviceName) + .setServiceHandlerHeader( + new ServiceHandlerHeaderBuilder().setRequestId(serviceName + "-reconfigure").build()) + .build(); } - public static ServiceAEnd createServiceAEnd( - org.opendaylight.yang.gen.v1.http.org.openroadm.service.rev161014.service.create.input - .ServiceAEnd serviceAEnd) { - ServiceAEndBuilder serviceAEndBuilder = new ServiceAEndBuilder(); - serviceAEndBuilder.setClli(serviceAEnd.getClli()); - serviceAEndBuilder.setNodeId(serviceAEnd.getNodeId()); - serviceAEndBuilder.setRxDirection(createRxDirection(serviceAEnd.getRxDirection())); - serviceAEndBuilder.setServiceFormat(serviceAEnd.getServiceFormat()); - serviceAEndBuilder.setServiceRate(serviceAEnd.getServiceRate()); - serviceAEndBuilder.setTxDirection(createTxDirection(serviceAEnd.getTxDirection())); - return serviceAEndBuilder.build(); + public static ServiceAEnd createServiceAEnd(ServiceEndpoint serviceAEnd) { + return new ServiceAEndBuilder() + .setClli(serviceAEnd.getClli()) + .setNodeId(serviceAEnd.getNodeId().getValue()) + .setRxDirection(createRxDirection(serviceAEnd.getRxDirection().values().stream().findFirst().get())) + .setServiceFormat(serviceAEnd.getServiceFormat()) + .setServiceRate(serviceAEnd.getServiceRate()) + .setTxDirection(createTxDirection(serviceAEnd.getTxDirection().values().stream().findFirst().get())) + .build(); } - public static ServiceZEnd createServiceZEnd( - org.opendaylight.yang.gen.v1.http.org.openroadm.service.rev161014.service.create.input.ServiceZEnd - serviceZEnd) { - ServiceZEndBuilder serviceZEndBuilder = new ServiceZEndBuilder(); - serviceZEndBuilder.setClli(serviceZEnd.getClli()); - serviceZEndBuilder.setNodeId(serviceZEnd.getNodeId()); - serviceZEndBuilder.setRxDirection(createRxDirection(serviceZEnd.getRxDirection())); - serviceZEndBuilder.setServiceFormat(serviceZEnd.getServiceFormat()); - serviceZEndBuilder.setServiceRate(serviceZEnd.getServiceRate()); - serviceZEndBuilder.setTxDirection(createTxDirection(serviceZEnd.getTxDirection())); - return serviceZEndBuilder.build(); + public static org.opendaylight.yang.gen.v1.http.org.opendaylight.transportpce.pce.rev220808 + .path.computation.reroute.request.input.ServiceAEnd createServiceAEndReroute(ServiceEndpoint serviceAEnd) { + return new org.opendaylight.yang.gen.v1.http.org.opendaylight.transportpce.pce.rev220808 + .path.computation.reroute.request.input.ServiceAEndBuilder() + .setClli(serviceAEnd.getClli()) + .setNodeId(serviceAEnd.getNodeId().getValue()) + .setRxDirection(createRxDirection(serviceAEnd.getRxDirection().values().stream().findFirst().get())) + .setServiceFormat(serviceAEnd.getServiceFormat()) + .setServiceRate(serviceAEnd.getServiceRate()) + .setTxDirection(createTxDirection(serviceAEnd.getTxDirection().values().stream().findFirst().get())) + .build(); + } + + public static ServiceZEnd createServiceZEnd(ServiceEndpoint serviceZEnd) { + return new ServiceZEndBuilder() + .setClli(serviceZEnd.getClli()) + .setNodeId(serviceZEnd.getNodeId().getValue()) + .setRxDirection(createRxDirection(serviceZEnd.getRxDirection().values().stream().findFirst().get())) + .setServiceFormat(serviceZEnd.getServiceFormat()) + .setServiceRate(serviceZEnd.getServiceRate()) + .setTxDirection(createTxDirection(serviceZEnd.getTxDirection().values().stream().findFirst().get())) + .build(); + } + + public static org.opendaylight.yang.gen.v1.http.org.opendaylight.transportpce.pce.rev220808 + .path.computation.reroute.request.input.ServiceZEnd createServiceZEndReroute(ServiceEndpoint serviceZEnd) { + return new org.opendaylight.yang.gen.v1.http.org.opendaylight.transportpce.pce.rev220808 + .path.computation.reroute.request.input.ServiceZEndBuilder() + .setClli(serviceZEnd.getClli()) + .setNodeId(serviceZEnd.getNodeId().getValue()) + .setRxDirection(createRxDirection(serviceZEnd.getRxDirection().values().stream().findFirst().get())) + .setServiceFormat(serviceZEnd.getServiceFormat()) + .setServiceRate(serviceZEnd.getServiceRate()) + .setTxDirection(createTxDirection(serviceZEnd.getTxDirection().values().stream().findFirst().get())) + .build(); } public static RxDirection createRxDirection( - org.opendaylight.yang.gen.v1.http.org.openroadm.common.service.types.rev161014.service.endpoint.RxDirection - rxDirection) { - RxDirectionBuilder rxDirectionBuilder = new RxDirectionBuilder(); - rxDirectionBuilder.setPort(rxDirection.getPort()); - return rxDirectionBuilder.build(); + org.opendaylight.yang.gen.v1.http.org.openroadm.common.service.types.rev211210 + .service.endpoint.RxDirection rxDirection) { + return new RxDirectionBuilder().setPort(rxDirection.getPort()).build(); } public static TxDirection createTxDirection( - org.opendaylight.yang.gen.v1.http.org.openroadm.common.service.types.rev161014.service.endpoint.TxDirection - txDirection) { - TxDirectionBuilder txDirectionBuilder = new TxDirectionBuilder(); - txDirectionBuilder.setPort(txDirection.getPort()); - return txDirectionBuilder.build(); + org.opendaylight.yang.gen.v1.http.org.openroadm.common.service.types.rev211210 + .service.endpoint.TxDirection txDirection) { + return new TxDirectionBuilder().setPort(txDirection.getPort()).build(); } - public static ListenableFuture> createDeleteServiceReply(ServiceDeleteInput input, - String finalAck, String message, String responseCode) { - ConfigurationResponseCommonBuilder builder = new ConfigurationResponseCommonBuilder() - .setAckFinalIndicator(finalAck).setResponseMessage(message).setResponseCode(responseCode); - if (input.getSdncRequestHeader() != null) { - builder.setRequestId(input.getSdncRequestHeader().getRequestId()); - } else { - builder.setRequestId(null); - } - ConfigurationResponseCommon configurationResponseCommon = builder.build(); - ServiceDeleteOutput output = new ServiceDeleteOutputBuilder() - .setConfigurationResponseCommon(configurationResponseCommon).build(); - return RpcResultBuilder.success(output).buildFuture(); + public static ListenableFuture> createDeleteServiceReply( + ServiceDeleteInput input, String finalAck, String message, String responseCode) { + return RpcResultBuilder + .success( + new ServiceDeleteOutputBuilder() + .setConfigurationResponseCommon( + new ConfigurationResponseCommonBuilder() + .setAckFinalIndicator(finalAck) + .setResponseMessage(message) + .setResponseCode(responseCode) + .setRequestId( + input.getSdncRequestHeader() == null + ? null + : input.getSdncRequestHeader().getRequestId()) + .build()) + .build()) + .buildFuture(); + } + + public static ListenableFuture> createDeleteServiceReply( + TempServiceDeleteInput input, String finalAck, String message, String responseCode) { + return RpcResultBuilder + .success( + new TempServiceDeleteOutputBuilder() + .setConfigurationResponseCommon( + new ConfigurationResponseCommonBuilder() + .setAckFinalIndicator(finalAck) + .setResponseMessage(message) + .setResponseCode(responseCode) + .setRequestId(null) + .build()) + .build()) + .buildFuture(); } + public static ListenableFuture> createCreateServiceReply( + ServiceCreateInput input, String finalAck, String message, String responseCode) { + return RpcResultBuilder + .success( + new ServiceCreateOutputBuilder() + .setConfigurationResponseCommon( + new ConfigurationResponseCommonBuilder() + .setAckFinalIndicator(finalAck) + .setResponseMessage(message) + .setResponseCode(responseCode) + .setRequestId( + input.getSdncRequestHeader() == null + ? null + : input.getSdncRequestHeader().getRequestId()) + .build()) + .setResponseParameters(new ResponseParametersBuilder().build()) + .build()) + .buildFuture(); + } - public static ListenableFuture> createRerouteServiceReply(ServiceRerouteInput input, - String finalAck, String message, RpcStatus rpcStatus) { - ServiceRerouteOutputBuilder output = new ServiceRerouteOutputBuilder() - .setHardConstraints(null) - .setSoftConstraints(null) - .setStatusMessage(message) - .setStatus(rpcStatus); - return RpcResultBuilder.success(output.build()).buildFuture(); + public static ListenableFuture> createCreateServiceReply( + TempServiceCreateInput input, String finalAck, String message, String responseCode) { + return RpcResultBuilder + .success( + new TempServiceCreateOutputBuilder() + .setConfigurationResponseCommon( + new ConfigurationResponseCommonBuilder() + .setAckFinalIndicator(finalAck) + .setResponseMessage(message) + .setResponseCode(responseCode) + .setRequestId( + input.getSdncRequestHeader() == null + ? null + : input.getSdncRequestHeader().getRequestId()) + .build()) + .setResponseParameters(new ResponseParametersBuilder().build()) + .build()) + .buildFuture(); } - public static ListenableFuture> createCreateServiceReply(ServiceCreateInput input, - String finalAck, - String message, String responseCode) { - ResponseParametersBuilder responseParameters = new ResponseParametersBuilder(); - ConfigurationResponseCommonBuilder configurationResponseCommon - = new ConfigurationResponseCommonBuilder().setAckFinalIndicator(finalAck) - .setResponseMessage(message) - .setResponseCode(responseCode); - if (input.getSdncRequestHeader() != null) { - configurationResponseCommon.setRequestId(input.getSdncRequestHeader().getRequestId()); - } else { - configurationResponseCommon.setRequestId(null); - } - ServiceCreateOutputBuilder output = new ServiceCreateOutputBuilder() - .setConfigurationResponseCommon(configurationResponseCommon.build()) - .setResponseParameters(responseParameters.build()); - return RpcResultBuilder.success(output.build()).buildFuture(); + public static ListenableFuture> createCreateServiceReply( + ServiceFeasibilityCheckInput input, String finalAck, String message, String responseCode) { + return RpcResultBuilder + .success( + new ServiceFeasibilityCheckOutputBuilder() + .setConfigurationResponseCommon( + new ConfigurationResponseCommonBuilder() + .setAckFinalIndicator(finalAck) + .setResponseMessage(message) + .setResponseCode(responseCode) + .setRequestId( + input.getSdncRequestHeader() == null + ? null + : input.getSdncRequestHeader().getRequestId()) + .build()) + .setResponseParameters(new ResponseParametersBuilder().build()) + .build()) + .buildFuture(); } - /* - * Map Input (ServiceCreateInmput, ServiceReconfigureInput) & output - * (PathComputationRequestOutput) to Service. - * @param serviceCreateInput - * ServiceCreateInput parameter - * @param serviceReconfigureInput - * serviceReconfigureInput parameter - * @param output - * PathComputationRequestOutput parameter - * @return Services Service data - */ - public static Services mappingServices(ServiceCreateInput serviceCreateInput, - ServiceReconfigureInput serviceReconfigureInput, PathComputationRequestOutput output) { - org.opendaylight.yang.gen.v1.http.org.openroadm.common.service.types.rev161014.service.ServiceAEnd aend = null; - org.opendaylight.yang.gen.v1.http.org.openroadm.common.service.types.rev161014.service.ServiceZEnd zend = null; - ServicesBuilder service = new ServicesBuilder(); + public static ListenableFuture> createCreateServiceReply( + ServiceReconfigureInput input, String message) { + return RpcResultBuilder + .success( + new ServiceReconfigureOutputBuilder() + .setConfigurationResponseCommon( + new ConfigurationResponseCommonBuilder() + .setResponseMessage(message) + .build()) + .build()) + .buildFuture(); + } + + public static ListenableFuture> createRerouteServiceReply( + ServiceRerouteInput input, String finalAckYes, String message, String responseCode) { + return RpcResultBuilder + .success( + new ServiceRerouteOutputBuilder() + .setConfigurationResponseCommon( + new ConfigurationResponseCommonBuilder() + .setAckFinalIndicator(finalAckYes) + .setResponseCode(responseCode) + .setResponseMessage(message) + .build()) + .setHardConstraints(null) + .setSoftConstraints(null) + .build()) + .buildFuture(); + } + + public static ListenableFuture> createRestoreServiceReply(String message) { + return RpcResultBuilder + .success( + new ServiceRestorationOutputBuilder() + .setConfigurationResponseCommon( + new ConfigurationResponseCommonBuilder() + .setResponseMessage(message) + .build()) + .build()) + .buildFuture(); + } + + public static Services mappingServices( + ServiceCreateInput serviceCreateInput, + ServiceReconfigureInput serviceReconfigureInput) { if (serviceCreateInput != null) { - aend = new org.opendaylight.yang.gen.v1.http.org.openroadm.common.service.types.rev161014.service - .ServiceAEndBuilder(serviceCreateInput.getServiceAEnd()).build(); - zend = new org.opendaylight.yang.gen.v1.http.org.openroadm.common.service.types.rev161014.service - .ServiceZEndBuilder(serviceCreateInput.getServiceZEnd()).build(); - service.setServiceName(serviceCreateInput.getServiceName()).setAdministrativeState(State.OutOfService) - .setOperationalState(State.OutOfService).setCommonId(serviceCreateInput.getCommonId()) + return new ServicesBuilder() + .setServiceName(serviceCreateInput.getServiceName()) + .setAdministrativeState(AdminStates.OutOfService) + .setOperationalState(State.OutOfService) + .setCommonId(serviceCreateInput.getCommonId()) .setConnectionType(serviceCreateInput.getConnectionType()) .setCustomer(serviceCreateInput.getCustomer()) .setCustomerContact(serviceCreateInput.getCustomerContact()) + .setServiceResiliency(serviceCreateInput.getServiceResiliency()) .setHardConstraints(serviceCreateInput.getHardConstraints()) .setSoftConstraints(serviceCreateInput.getSoftConstraints()) .setSdncRequestHeader(serviceCreateInput.getSdncRequestHeader()) - .setLifecycleState(LifecycleState.Planned).setServiceAEnd(aend).setServiceZEnd(zend); - - } else if (serviceReconfigureInput != null) { - aend = new org.opendaylight.yang.gen.v1.http.org.openroadm.common.service.types.rev161014.service - .ServiceAEndBuilder(serviceReconfigureInput.getServiceAEnd()).build(); - zend = new org.opendaylight.yang.gen.v1.http.org.openroadm.common.service.types.rev161014.service - .ServiceZEndBuilder(serviceReconfigureInput.getServiceZEnd()).build(); - service.setServiceName(serviceReconfigureInput.getNewServiceName()) - .setAdministrativeState(State.OutOfService).setOperationalState(State.OutOfService) + .setLifecycleState(LifecycleState.Planned) + .setServiceAEnd( + new org.opendaylight.yang.gen.v1.http.org.openroadm.common.service.types.rev211210 + .service.ServiceAEndBuilder(serviceCreateInput.getServiceAEnd()) + .build()) + .setServiceZEnd( + new org.opendaylight.yang.gen.v1.http.org.openroadm.common.service.types.rev211210 + .service.ServiceZEndBuilder(serviceCreateInput.getServiceZEnd()) + .build()) + .build(); + } + if (serviceReconfigureInput != null) { + return new ServicesBuilder() + .setServiceName(serviceReconfigureInput.getServiceName()) + .setAdministrativeState(AdminStates.OutOfService) + .setOperationalState(State.OutOfService) .setCommonId(serviceReconfigureInput.getCommonId()) .setConnectionType(serviceReconfigureInput.getConnectionType()) .setCustomer(serviceReconfigureInput.getCustomer()) .setCustomerContact(serviceReconfigureInput.getCustomerContact()) .setHardConstraints(serviceReconfigureInput.getHardConstraints()) .setSoftConstraints(serviceReconfigureInput.getSoftConstraints()) - .setLifecycleState(LifecycleState.Planned).setServiceAEnd(aend).setServiceZEnd(zend); + .setLifecycleState(LifecycleState.Planned) + .setServiceAEnd( + new org.opendaylight.yang.gen.v1.http.org.openroadm.common.service.types.rev211210 + .service.ServiceAEndBuilder(serviceReconfigureInput.getServiceAEnd()) + .build()) + .setServiceZEnd( + new org.opendaylight.yang.gen.v1.http.org.openroadm.common.service.types.rev211210 + .service.ServiceZEndBuilder(serviceReconfigureInput.getServiceZEnd()) + .build()) + .build(); } - if (output != null) { - org.opendaylight.yang.gen.v1.http.org.transportpce.b.c._interface.service.types.rev170426.response - .parameters.sp.ResponseParameters responseParameters = output.getResponseParameters(); - if (responseParameters != null) { - // service.setPceMetric(responseParameters.getPceMetric()); - org.opendaylight.yang.gen.v1.http.org.transportpce.b.c._interface.service.types.rev170426 - .response.parameters.sp.response.parameters.PathDescription pathDescription = - responseParameters.getPathDescription(); - if (pathDescription != null) { - List atozList = new ArrayList<>(); - List ztoaList = new ArrayList<>(); - - for (org.opendaylight.yang.gen.v1.http.org.transportpce.b.c._interface.pathdescription.rev170426 - .path.description.atoz.direction.AToZ tmp : pathDescription.getAToZDirection().getAToZ()) { - - AToZKey key = new AToZKey(tmp.key().getId()); - AToZ atoz = new AToZBuilder().setId(tmp.getId()).withKey(key) - // .setResource(tmp.getResource()) - .build(); - atozList.add(atoz); - } + //FIXME: Because of Silicon, we cannot have empty key. + //it's this case possible ? There is a Junit test covering null + //temporary workaround as now there is a null key check done by yangtools. + //Functional review is needed + LOG.warn("ServiceCreateInput and ServiceReconfigureInput are null"); + return new ServicesBuilder().withKey(new ServicesKey("unknown")).build(); + } - for (org.opendaylight.yang.gen.v1.http.org.transportpce.b.c._interface.pathdescription.rev170426 - .path.description.ztoa.direction.ZToA - tmp : pathDescription.getZToADirection().getZToA()) { - ZToAKey key = new ZToAKey(tmp.key().getId()); - ZToA ztoa = new ZToABuilder().setId(tmp.getId()).withKey(key) - // .setResource(tmp.getResource()) - .build(); - ztoaList.add(ztoa); - } + public static org.opendaylight.yang.gen.v1.http.org.openroadm.service.rev211210 + .temp.service.list.Services mappingServices(TempServiceCreateInput tempServiceCreateInput) { + return new org.opendaylight.yang.gen.v1.http.org.openroadm.service.rev211210 + .temp.service.list.ServicesBuilder() + .setServiceName(tempServiceCreateInput.getCommonId()) + .setAdministrativeState(AdminStates.OutOfService) + .setOperationalState(State.OutOfService) + .setCommonId(tempServiceCreateInput.getCommonId()) + .setConnectionType(tempServiceCreateInput.getConnectionType()) + .setCustomer(tempServiceCreateInput.getCustomer()) + .setCustomerContact(tempServiceCreateInput.getCustomerContact()) + .setHardConstraints(tempServiceCreateInput.getHardConstraints()) + .setSoftConstraints(tempServiceCreateInput.getSoftConstraints()) + .setSdncRequestHeader(tempServiceCreateInput.getSdncRequestHeader()) + .setLifecycleState(LifecycleState.Planned) + .setServiceAEnd( + new org.opendaylight.yang.gen.v1.http.org.openroadm.common.service.types.rev211210 + .service.ServiceAEndBuilder(tempServiceCreateInput.getServiceAEnd()).build()) + .setServiceZEnd( + new org.opendaylight.yang.gen.v1.http.org.openroadm.common.service.types.rev211210 + .service.ServiceZEndBuilder(tempServiceCreateInput.getServiceZEnd()).build()) + .build(); + } - Topology topology = new TopologyBuilder().setAToZ(atozList).setZToA(ztoaList).build(); - service.setTopology(topology); - } - } + public static ServicePaths mappingServicePaths(ServiceInput serviceInput, PathComputationRequestOutput output) { + if (serviceInput == null) { + //FIXME: Because of Silicon, we cannot have empty key. + //it's this case possible ? There is a Junit test covering null + //temporary workaround as now there is a null key check done by yangtools. + //Functional review is needed + LOG.warn("ServiceInput is null"); + return new ServicePathsBuilder().withKey(new ServicePathsKey("unknown")).build(); + } + + ServicePathsBuilder servicePathBuilder = + new ServicePathsBuilder() + .setServiceAEnd( + new org.opendaylight.yang.gen.v1.http.org.transportpce.b.c._interface.service.types.rev220118 + .service.path.ServiceAEndBuilder() + .setServiceFormat(serviceInput.getServiceAEnd().getServiceFormat()) + .setServiceRate(serviceInput.getServiceAEnd().getServiceRate()) + .setClli(serviceInput.getServiceAEnd().getClli()) + .setNodeId(new NodeIdType(serviceInput.getServiceAEnd().getNodeId().getValue()).getValue()) + .setTxDirection( + new org.opendaylight.yang.gen.v1 + .http.org.transportpce.b.c._interface.service.types.rev220118 + .service.endpoint.sp.TxDirectionBuilder() + .setPort( + serviceInput.getServiceAEnd().getTxDirection() + .values().stream().findFirst().get().getPort()) + .build()) + .setRxDirection( + new org.opendaylight.yang.gen.v1 + .http.org.transportpce.b.c._interface.service.types.rev220118 + .service.endpoint.sp.RxDirectionBuilder() + .setPort( + serviceInput.getServiceAEnd().getRxDirection() + .values().stream().findFirst().get().getPort()) + .build()) + .build()) + .setServiceZEnd( + new org.opendaylight.yang.gen.v1.http.org.transportpce.b.c._interface.service.types.rev220118 + .service.path.ServiceZEndBuilder() + .setServiceFormat(serviceInput.getServiceZEnd().getServiceFormat()) + .setServiceRate(serviceInput.getServiceZEnd().getServiceRate()) + .setClli(serviceInput.getServiceZEnd().getClli()) + .setNodeId(new NodeIdType(serviceInput.getServiceZEnd().getNodeId().getValue()).getValue()) + .setTxDirection( + new org.opendaylight.yang.gen.v1 + .http.org.transportpce.b.c._interface.service.types.rev220118 + .service.endpoint.sp.TxDirectionBuilder() + .setPort( + serviceInput.getServiceZEnd().getTxDirection() + .values().stream().findFirst().get().getPort()) + .build()) + .setRxDirection( + new org.opendaylight.yang.gen.v1 + .http.org.transportpce.b.c._interface.service.types.rev220118 + .service.endpoint.sp.RxDirectionBuilder() + .setPort( + serviceInput.getServiceZEnd().getRxDirection() + .values().stream().findFirst().get().getPort()) + .build()) + .build()) + .setServicePathName(serviceInput.getServiceName()) + .setServiceHandlerHeader( + new ServiceHandlerHeaderBuilder() + .setRequestId(serviceInput.getSdncRequestHeader() + .getRequestId()) + .build()); + if (serviceInput.getHardConstraints() != null) { + servicePathBuilder.setHardConstraints(serviceInput.getHardConstraints()); } - return service.build(); + if (serviceInput.getSoftConstraints() != null) { + servicePathBuilder.setSoftConstraints(serviceInput.getSoftConstraints()); + } + + if (output.getResponseParameters().getPathDescription() != null) { + servicePathBuilder.setPathDescription( + new PathDescriptionBuilder(output.getResponseParameters().getPathDescription()).build()); + } + return servicePathBuilder.build(); } - /* - * Map Input (ServiceCreateInmput, ServiceReconfigureInput) & output - * (PathComputationRequestOutput) to ServicePath. - * @param serviceCreateInput - * ServiceCreateInput parameter - * @param serviceReconfigureInput - * serviceReconfigureInput parameter - * @param output - * PathComputationRequestOutput parameter - * @return ServicesPaths Service Path data - */ - public static ServicePaths mappingServicePaths(ServiceCreateInput serviceCreateInput, - ServiceReconfigureInput serviceReconfigureInput, PathComputationRequestOutput output) { - ServicePathsBuilder servicePathBuilder = new ServicePathsBuilder(); - if (serviceCreateInput != null) { - org.opendaylight.yang.gen.v1.http.org.transportpce.b.c._interface - .service.types.rev170426.service.path.ServiceAEndBuilder serviceAEnd = - new org.opendaylight.yang.gen.v1.http.org.transportpce.b.c._interface - .service.types.rev170426.service.path.ServiceAEndBuilder(); - serviceAEnd.setServiceFormat(serviceCreateInput.getServiceAEnd().getServiceFormat()) - .setServiceRate(serviceCreateInput.getServiceAEnd().getServiceRate()) - .setClli(serviceCreateInput.getServiceAEnd().getClli()) - .setNodeId(serviceCreateInput.getServiceAEnd().getNodeId()) - .setTxDirection(new org.opendaylight.yang.gen.v1.http.org.transportpce.b.c._interface.service.types - .rev170426.service.endpoint.sp.TxDirectionBuilder() - .setPort(serviceCreateInput.getServiceAEnd().getTxDirection().getPort()).build()) - .setRxDirection(new org.opendaylight.yang.gen.v1.http.org.transportpce.b.c._interface.service.types - .rev170426.service.endpoint.sp.RxDirectionBuilder() - .setPort(serviceCreateInput.getServiceAEnd().getRxDirection().getPort()).build()); - org.opendaylight.yang.gen.v1.http.org.transportpce.b.c._interface - .service.types.rev170426.service.path.ServiceZEndBuilder serviceZEnd = - new org.opendaylight.yang.gen.v1.http.org.transportpce.b.c._interface - .service.types.rev170426.service.path.ServiceZEndBuilder(); - serviceZEnd.setServiceFormat(serviceCreateInput.getServiceZEnd().getServiceFormat()) - .setServiceRate(serviceCreateInput.getServiceZEnd().getServiceRate()) - .setClli(serviceCreateInput.getServiceZEnd().getClli()) - .setNodeId(serviceCreateInput.getServiceZEnd().getNodeId()) - .setTxDirection(new org.opendaylight.yang.gen.v1.http.org.transportpce.b.c._interface.service.types - .rev170426.service.endpoint.sp.TxDirectionBuilder() - .setPort(serviceCreateInput.getServiceZEnd().getTxDirection().getPort()).build()) - .setRxDirection(new org.opendaylight.yang.gen.v1.http.org.transportpce.b.c._interface.service.types - .rev170426.service.endpoint.sp.RxDirectionBuilder() - .setPort(serviceCreateInput.getServiceZEnd().getRxDirection().getPort()).build()); - - servicePathBuilder.setServiceAEnd(serviceAEnd.build()); - servicePathBuilder.setServiceZEnd(serviceZEnd.build()); - MappingConstraints mapConstraints = new MappingConstraints(serviceCreateInput.getHardConstraints(), - serviceCreateInput.getSoftConstraints()); - mapConstraints.serviceToServicePathConstarints(); - if (mapConstraints.getServicePathHardConstraints() != null) { - HardConstraintsBuilder hardConstraintBuilder = new HardConstraintsBuilder(); - hardConstraintBuilder.setCustomerCode(serviceCreateInput.getHardConstraints().getCustomerCode()); - hardConstraintBuilder.setCoRoutingOrGeneral(mapConstraints.getServicePathHardConstraints() - .getCoRoutingOrGeneral()); - servicePathBuilder.setHardConstraints(hardConstraintBuilder.build()); - } - if (mapConstraints.getServicePathSoftConstraints() != null) { - SoftConstraintsBuilder softConstraintBuilder = new SoftConstraintsBuilder(); - softConstraintBuilder.setCustomerCode(mapConstraints.getServicePathSoftConstraints().getCustomerCode()); - softConstraintBuilder.setCoRoutingOrGeneral(mapConstraints.getServicePathSoftConstraints() - .getCoRoutingOrGeneral()); - servicePathBuilder.setSoftConstraints(softConstraintBuilder.build()); + + @edu.umd.cs.findbugs.annotations.SuppressFBWarnings( + value = "PZLA_PREFER_ZERO_LENGTH_ARRAYS", + justification = "not relevant to return and zero length array as we need real pos") + public static int[] findTheLongestSubstring(String s1, String s2) { + if ((s1 == null) || (s2 == null)) { + return null; + } + int[][] dp = new int[s1.length() + 1][s2.length() + 1]; + int maxLen = 0; + int endPos = 0; + for (int i = 1; i < dp.length; i++) { + for (int j = 1; j < dp[0].length; j++) { + char ch1 = s1.charAt(i - 1); + char ch2 = s2.charAt(j - 1); + if (ch1 == ch2) { + dp[i][j] = dp[i - 1][j - 1] + 1; + if (dp[i][j] >= maxLen) { + maxLen = dp[i][j]; + endPos = i; + } + } } - servicePathBuilder.setServicePathName(serviceCreateInput.getServiceName()); - servicePathBuilder.setServiceHandlerHeader(new ServiceHandlerHeaderBuilder() - .setRequestId(serviceCreateInput.getSdncRequestHeader().getRequestId()).build()); - PathDescriptionBuilder pathDescBuilder = new PathDescriptionBuilder(output.getResponseParameters() - .getPathDescription()); - servicePathBuilder.setPathDescription(pathDescBuilder.build()); } - return servicePathBuilder.build(); + return new int[] { endPos - maxLen, endPos }; } }