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=b108b169a0be6f76c2b6e53eba075842c202bcc8;hb=80b5cdcc604a1d13918c30e4a1bb389a4b834fc3;hp=091ed56763590e617ed9821f03b90582cda1a547;hpb=0779ad5796bb645690874959c9a891c42e2f7175;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 old mode 100755 new mode 100644 index 091ed5676..b108b169a --- a/pce/src/main/java/org/opendaylight/transportpce/pce/impl/PceServiceRPCImpl.java +++ b/pce/src/main/java/org/opendaylight/transportpce/pce/impl/PceServiceRPCImpl.java @@ -8,43 +8,83 @@ package org.opendaylight.transportpce.pce.impl; import com.google.common.util.concurrent.ListenableFuture; +import java.util.concurrent.ExecutionException; import org.opendaylight.transportpce.pce.service.PathComputationService; -import org.opendaylight.yang.gen.v1.http.org.opendaylight.transportpce.pce.rev171017.CancelResourceReserveInput; -import org.opendaylight.yang.gen.v1.http.org.opendaylight.transportpce.pce.rev171017.CancelResourceReserveOutput; -import org.opendaylight.yang.gen.v1.http.org.opendaylight.transportpce.pce.rev171017.PathComputationRequestInput; -import org.opendaylight.yang.gen.v1.http.org.opendaylight.transportpce.pce.rev171017.PathComputationRequestOutput; -import org.opendaylight.yang.gen.v1.http.org.opendaylight.transportpce.pce.rev171017.TransportpcePceService; +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.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.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.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.Reference; import org.slf4j.Logger; import org.slf4j.LoggerFactory; /** * PceService implementation. */ +@Component public class PceServiceRPCImpl implements TransportpcePceService { private static final Logger LOG = LoggerFactory.getLogger(PceServiceRPCImpl.class); private final PathComputationService pathComputationService; - public PceServiceRPCImpl(PathComputationService pathComputationService) { + @Activate + public PceServiceRPCImpl(@Reference PathComputationService pathComputationService) { this.pathComputationService = pathComputationService; + LOG.info("PceServiceRPCImpl instantiated"); } @Override public ListenableFuture> cancelResourceReserve(CancelResourceReserveInput input) { LOG.info("RPC cancelResourceReserve request received"); - return RpcResultBuilder.success(this.pathComputationService.cancelResourceReserve(input)).buildFuture(); + try { + return RpcResultBuilder + .success( + this.pathComputationService.cancelResourceReserve(input).get()) + .buildFuture(); + } catch (InterruptedException | ExecutionException e) { + LOG.error("RPC cancelResourceReserve failed !", e); + return RpcResultBuilder.success((CancelResourceReserveOutput) null).buildFuture(); + } } - @Override public ListenableFuture> pathComputationRequest(PathComputationRequestInput input) { LOG.info("RPC path computation request received"); - return RpcResultBuilder.success(this.pathComputationService.pathComputationRequest(input)).buildFuture(); + LOG.debug("input parameters are : input = {}", input); + try { + return RpcResultBuilder + .success( + this.pathComputationService.pathComputationRequest(input).get()) + .buildFuture(); + } catch (InterruptedException | ExecutionException e) { + LOG.error("RPC path computation request failed !", e); + } + return RpcResultBuilder.success((PathComputationRequestOutput) null).buildFuture(); } + @Override + public ListenableFuture> pathComputationRerouteRequest( + PathComputationRerouteRequestInput input) { + LOG.info("RPC path computation reroute request received"); + LOG.debug("input parameters are : input = {}", input); + try { + return RpcResultBuilder + .success( + this.pathComputationService.pathComputationRerouteRequest(input).get()) + .buildFuture(); + } catch (InterruptedException | ExecutionException e) { + LOG.error("RPC path computation request failed !", e); + return RpcResultBuilder.success((PathComputationRerouteRequestOutput) null).buildFuture(); + } + } }