X-Git-Url: https://git.opendaylight.org/gerrit/gitweb?a=blobdiff_plain;f=pce%2Fsrc%2Fmain%2Fjava%2Forg%2Fopendaylight%2Ftransportpce%2Fpce%2Fimpl%2FPceServiceRPCImpl.java;h=f742c2d70b34cfbb72b1158c64a304de427a15c4;hb=703ea2446974f96c2b57cd96c2d55edd4b3f99b2;hp=b108b169a0be6f76c2b6e53eba075842c202bcc8;hpb=80b5cdcc604a1d13918c30e4a1bb389a4b834fc3;p=transportpce.git diff --git a/pce/src/main/java/org/opendaylight/transportpce/pce/impl/PceServiceRPCImpl.java b/pce/src/main/java/org/opendaylight/transportpce/pce/impl/PceServiceRPCImpl.java index b108b169a..f742c2d70 100644 --- a/pce/src/main/java/org/opendaylight/transportpce/pce/impl/PceServiceRPCImpl.java +++ b/pce/src/main/java/org/opendaylight/transportpce/pce/impl/PceServiceRPCImpl.java @@ -7,20 +7,28 @@ */ package org.opendaylight.transportpce.pce.impl; +import com.google.common.collect.ImmutableClassToInstanceMap; import com.google.common.util.concurrent.ListenableFuture; import java.util.concurrent.ExecutionException; +import org.opendaylight.mdsal.binding.api.RpcProviderService; import org.opendaylight.transportpce.pce.service.PathComputationService; +import org.opendaylight.yang.gen.v1.http.org.opendaylight.transportpce.pce.rev220808.CancelResourceReserve; import org.opendaylight.yang.gen.v1.http.org.opendaylight.transportpce.pce.rev220808.CancelResourceReserveInput; import org.opendaylight.yang.gen.v1.http.org.opendaylight.transportpce.pce.rev220808.CancelResourceReserveOutput; +import org.opendaylight.yang.gen.v1.http.org.opendaylight.transportpce.pce.rev220808.PathComputationRequest; import org.opendaylight.yang.gen.v1.http.org.opendaylight.transportpce.pce.rev220808.PathComputationRequestInput; 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.PathComputationRerouteRequest; import org.opendaylight.yang.gen.v1.http.org.opendaylight.transportpce.pce.rev220808.PathComputationRerouteRequestInput; import org.opendaylight.yang.gen.v1.http.org.opendaylight.transportpce.pce.rev220808.PathComputationRerouteRequestOutput; import org.opendaylight.yang.gen.v1.http.org.opendaylight.transportpce.pce.rev220808.TransportpcePceService; +import org.opendaylight.yangtools.concepts.Registration; +import org.opendaylight.yangtools.yang.binding.Rpc; import org.opendaylight.yangtools.yang.common.RpcResult; import org.opendaylight.yangtools.yang.common.RpcResultBuilder; import org.osgi.service.component.annotations.Activate; import org.osgi.service.component.annotations.Component; +import org.osgi.service.component.annotations.Deactivate; import org.osgi.service.component.annotations.Reference; import org.slf4j.Logger; import org.slf4j.LoggerFactory; @@ -28,21 +36,35 @@ import org.slf4j.LoggerFactory; /** * PceService implementation. */ -@Component +@Component(immediate = true) public class PceServiceRPCImpl implements TransportpcePceService { private static final Logger LOG = LoggerFactory.getLogger(PceServiceRPCImpl.class); private final PathComputationService pathComputationService; + private Registration reg; @Activate - public PceServiceRPCImpl(@Reference PathComputationService pathComputationService) { + public PceServiceRPCImpl(@Reference RpcProviderService rpcProviderService, + @Reference PathComputationService pathComputationService) { this.pathComputationService = pathComputationService; + this.reg = rpcProviderService.registerRpcImplementations(ImmutableClassToInstanceMap.>builder() + .put(CancelResourceReserve.class, this::cancelResourceReserve) + .put(PathComputationRequest.class, this::pathComputationRequest) + .put(PathComputationRerouteRequest.class, this::pathComputationRerouteRequest) + .build()); + LOG.info("PceServiceRPCImpl instantiated"); } + @Deactivate + public void close() { + this.reg.close(); + LOG.info("PceServiceRPCImpl Closed"); + } + @Override - public ListenableFuture> + public final ListenableFuture> cancelResourceReserve(CancelResourceReserveInput input) { LOG.info("RPC cancelResourceReserve request received"); try { @@ -57,7 +79,7 @@ public class PceServiceRPCImpl implements TransportpcePceService { } @Override - public ListenableFuture> + public final ListenableFuture> pathComputationRequest(PathComputationRequestInput input) { LOG.info("RPC path computation request received"); LOG.debug("input parameters are : input = {}", input); @@ -73,7 +95,7 @@ public class PceServiceRPCImpl implements TransportpcePceService { } @Override - public ListenableFuture> pathComputationRerouteRequest( + public final ListenableFuture> pathComputationRerouteRequest( PathComputationRerouteRequestInput input) { LOG.info("RPC path computation reroute request received"); LOG.debug("input parameters are : input = {}", input); @@ -87,4 +109,8 @@ public class PceServiceRPCImpl implements TransportpcePceService { return RpcResultBuilder.success((PathComputationRerouteRequestOutput) null).buildFuture(); } } + + public Registration getRegisteredRpc() { + return reg; + } }