X-Git-Url: https://git.opendaylight.org/gerrit/gitweb?a=blobdiff_plain;f=opendaylight%2Fmd-sal%2Fsal-remoterpc-connector%2Fsrc%2Fmain%2Fjava%2Forg%2Fopendaylight%2Fcontroller%2Fremote%2Frpc%2FRemoteRpcImplementation.java;h=3046f7e6dde0284fefa3f6e5bbbc07d3e1a9a374;hb=HEAD;hp=404a109741b56a0344ec5d413342badfe41ee06c;hpb=164ac72a0b71c4639854e54024c69d4ab55afe76;p=controller.git diff --git a/opendaylight/md-sal/sal-remoterpc-connector/src/main/java/org/opendaylight/controller/remote/rpc/RemoteRpcImplementation.java b/opendaylight/md-sal/sal-remoterpc-connector/src/main/java/org/opendaylight/controller/remote/rpc/RemoteRpcImplementation.java index 404a109741..3046f7e6dd 100644 --- a/opendaylight/md-sal/sal-remoterpc-connector/src/main/java/org/opendaylight/controller/remote/rpc/RemoteRpcImplementation.java +++ b/opendaylight/md-sal/sal-remoterpc-connector/src/main/java/org/opendaylight/controller/remote/rpc/RemoteRpcImplementation.java @@ -1,29 +1,37 @@ +/* + * Copyright (c) 2014, 2017 Cisco Systems, Inc. and others. All rights reserved. + * + * This program and the accompanying materials are made available under the + * terms of the Eclipse Public License v1.0 which accompanies this distribution, + * and is available at http://www.eclipse.org/legal/epl-v10.html + */ package org.opendaylight.controller.remote.rpc; -import static akka.pattern.Patterns.ask; - import akka.actor.ActorRef; -import com.google.common.util.concurrent.CheckedFuture; -import org.opendaylight.controller.md.sal.dom.api.DOMRpcException; -import org.opendaylight.controller.md.sal.dom.api.DOMRpcIdentifier; -import org.opendaylight.controller.md.sal.dom.api.DOMRpcImplementation; -import org.opendaylight.controller.md.sal.dom.api.DOMRpcResult; -import org.opendaylight.controller.remote.rpc.messages.InvokeRpc; -import org.opendaylight.yangtools.yang.data.api.schema.NormalizedNode; +import com.google.common.util.concurrent.ListenableFuture; +import org.opendaylight.controller.remote.rpc.messages.ExecuteRpc; +import org.opendaylight.mdsal.dom.api.DOMRpcIdentifier; +import org.opendaylight.mdsal.dom.api.DOMRpcImplementation; +import org.opendaylight.mdsal.dom.api.DOMRpcResult; +import org.opendaylight.yangtools.yang.data.api.schema.ContainerNode; -public class RemoteRpcImplementation implements DOMRpcImplementation { - private final ActorRef rpcBroker; - private final RemoteRpcProviderConfig config; +/** + * A {@link DOMRpcImplementation} which routes invocation requests to a remote invoker actor. + * + * @author Robert Varga + */ +final class RemoteRpcImplementation extends AbstractRemoteImplementation implements DOMRpcImplementation { + RemoteRpcImplementation(final ActorRef remoteInvoker, final RemoteOpsProviderConfig config) { + super(remoteInvoker, config); + } - public RemoteRpcImplementation(final ActorRef rpcBroker, final RemoteRpcProviderConfig config) { - this.rpcBroker = rpcBroker; - this.config = config; + @Override + public ListenableFuture invokeRpc(final DOMRpcIdentifier rpc, final ContainerNode input) { + return new RemoteDOMRpcFuture(rpc.getType(), ask(ExecuteRpc.from(rpc, input))); } @Override - public CheckedFuture invokeRpc(final DOMRpcIdentifier rpc, final NormalizedNode input) { - final InvokeRpc rpcMsg = new InvokeRpc(rpc.getType().getLastComponent(), rpc.getContextReference(), input); - final scala.concurrent.Future future = ask(rpcBroker, rpcMsg, config.getAskDuration()); - return RemoteDOMRpcFuture.from(future); + public long invocationCost() { + return COST; } }