*/
package org.opendaylight.controller.sal.restconf.rpc.impl;
-import java.util.concurrent.ExecutionException;
-
-import javax.ws.rs.core.Response.Status;
+import java.util.concurrent.Future;
import org.opendaylight.controller.sal.core.api.mount.MountInstance;
-import org.opendaylight.controller.sal.restconf.impl.ResponseException;
import org.opendaylight.yangtools.yang.common.RpcResult;
import org.opendaylight.yangtools.yang.data.api.CompositeNode;
import org.opendaylight.yangtools.yang.model.api.RpcDefinition;
import com.google.common.base.Preconditions;
-import com.google.common.util.concurrent.ListenableFuture;
/**
* Provides an implementation which invokes rpc methods via a mounted yang data model.
}
@Override
- public RpcResult<CompositeNode> invokeRpc( CompositeNode rpcRequest ) throws ResponseException {
- ListenableFuture<RpcResult<CompositeNode>> rpcFuture =
- mountPoint.rpc( getRpcDefinition().getQName(), rpcRequest);
- try {
- return rpcFuture.get();
- } catch (InterruptedException | ExecutionException e) {
- throw new ResponseException(Status.INTERNAL_SERVER_ERROR,
- e.getCause().getMessage() );
- }
+ protected Future<RpcResult<CompositeNode>> invokeRpcUnchecked( CompositeNode rpcRequest ) {
+ return mountPoint.rpc( getRpcDefinition().getQName(), rpcRequest );
}
}
\ No newline at end of file