X-Git-Url: https://git.opendaylight.org/gerrit/gitweb?p=controller.git;a=blobdiff_plain;f=opendaylight%2Fmd-sal%2Fsal-remoterpc-connector%2Fsrc%2Fmain%2Fjava%2Forg%2Fopendaylight%2Fcontroller%2Fremote%2Frpc%2FRpcListener.java;h=28ff1523cbb676c5bf47d6180d96c9e7f1304230;hp=dee98521ae9f2d56893d591b30bc30a8489d89ef;hb=9c34ce103df5efac991297dc25a64c9b8d6019f3;hpb=d771aa3f949bae84facc8db5abc2af5bdcca6fc9 diff --git a/opendaylight/md-sal/sal-remoterpc-connector/src/main/java/org/opendaylight/controller/remote/rpc/RpcListener.java b/opendaylight/md-sal/sal-remoterpc-connector/src/main/java/org/opendaylight/controller/remote/rpc/RpcListener.java index dee98521ae..28ff1523cb 100644 --- a/opendaylight/md-sal/sal-remoterpc-connector/src/main/java/org/opendaylight/controller/remote/rpc/RpcListener.java +++ b/opendaylight/md-sal/sal-remoterpc-connector/src/main/java/org/opendaylight/controller/remote/rpc/RpcListener.java @@ -10,42 +10,55 @@ package org.opendaylight.controller.remote.rpc; import akka.actor.ActorRef; +import com.google.common.base.Preconditions; +import java.util.ArrayList; +import java.util.Collection; +import java.util.List; +import javax.annotation.Nonnull; +import org.opendaylight.controller.md.sal.dom.api.DOMRpcAvailabilityListener; +import org.opendaylight.controller.md.sal.dom.api.DOMRpcIdentifier; import org.opendaylight.controller.remote.rpc.registry.RpcRegistry; import org.opendaylight.controller.sal.connector.api.RpcRouter; -import org.opendaylight.controller.sal.core.api.RpcRegistrationListener; -import org.opendaylight.yangtools.yang.common.QName; import org.slf4j.Logger; import org.slf4j.LoggerFactory; -import java.util.ArrayList; -import java.util.List; - -public class RpcListener implements RpcRegistrationListener{ +public class RpcListener implements DOMRpcAvailabilityListener{ private static final Logger LOG = LoggerFactory.getLogger(RpcListener.class); private final ActorRef rpcRegistry; - public RpcListener(ActorRef rpcRegistry) { + public RpcListener(final ActorRef rpcRegistry) { this.rpcRegistry = rpcRegistry; } - @Override - public void onRpcImplementationAdded(QName rpc) { - LOG.debug("Adding registration for [{}]", rpc); - RpcRouter.RouteIdentifier routeId = new RouteIdentifierImpl(null, rpc, null); - List> routeIds = new ArrayList<>(); - routeIds.add(routeId); - RpcRegistry.Messages.AddOrUpdateRoutes addRpcMsg = new RpcRegistry.Messages.AddOrUpdateRoutes(routeIds); - rpcRegistry.tell(addRpcMsg, ActorRef.noSender()); - } + @Override + public void onRpcAvailable(@Nonnull final Collection rpcs) { + Preconditions.checkArgument(rpcs != null, "Input Collection of DOMRpcIdentifier can not be null."); + if (LOG.isDebugEnabled()) { + LOG.debug("Adding registration for [{}]", rpcs); + } + final List> routeIds = new ArrayList<>(); - @Override - public void onRpcImplementationRemoved(QName rpc) { - LOG.debug("Removing registration for [{}]", rpc); - RpcRouter.RouteIdentifier routeId = new RouteIdentifierImpl(null, rpc, null); - List> routeIds = new ArrayList<>(); - routeIds.add(routeId); - RpcRegistry.Messages.RemoveRoutes removeRpcMsg = new RpcRegistry.Messages.RemoveRoutes(routeIds); - rpcRegistry.tell(removeRpcMsg, ActorRef.noSender()); - } + for (final DOMRpcIdentifier rpc : rpcs) { + final RpcRouter.RouteIdentifier routeId = new RouteIdentifierImpl(null, rpc.getType().getLastComponent(), null); + routeIds.add(routeId); + } + final RpcRegistry.Messages.AddOrUpdateRoutes addRpcMsg = new RpcRegistry.Messages.AddOrUpdateRoutes(routeIds); + rpcRegistry.tell(addRpcMsg, ActorRef.noSender()); + } + + @Override + public void onRpcUnavailable(@Nonnull final Collection rpcs) { + Preconditions.checkArgument(rpcs != null, "Input Collection of DOMRpcIdentifier can not be null."); + if(LOG.isDebugEnabled()) { + LOG.debug("Removing registration for [{}]", rpcs); + } + final List> routeIds = new ArrayList<>(); + for (final DOMRpcIdentifier rpc : rpcs) { + final RpcRouter.RouteIdentifier routeId = new RouteIdentifierImpl(null, rpc.getType().getLastComponent(), null); + routeIds.add(routeId); + } + final RpcRegistry.Messages.RemoveRoutes removeRpcMsg = new RpcRegistry.Messages.RemoveRoutes(routeIds); + rpcRegistry.tell(removeRpcMsg, ActorRef.noSender()); + } }