From 296538943af12a4f907661e8390413ba08888181 Mon Sep 17 00:00:00 2001 From: Jozef Gloncak Date: Wed, 20 May 2015 15:35:04 +0200 Subject: [PATCH] Returning of future from request context - FlowCapableTransactionService. Change-Id: Ie0d56eea35035378e96cc61c620de46f2e14fc4f Signed-off-by: Jozef Gloncak --- .../FlowCapableTransactionServiceImpl.java | 16 +++++++++------- 1 file changed, 9 insertions(+), 7 deletions(-) diff --git a/openflowplugin-impl/src/main/java/org/opendaylight/openflowplugin/impl/services/FlowCapableTransactionServiceImpl.java b/openflowplugin-impl/src/main/java/org/opendaylight/openflowplugin/impl/services/FlowCapableTransactionServiceImpl.java index 5a3a478f38..4450a82613 100644 --- a/openflowplugin-impl/src/main/java/org/opendaylight/openflowplugin/impl/services/FlowCapableTransactionServiceImpl.java +++ b/openflowplugin-impl/src/main/java/org/opendaylight/openflowplugin/impl/services/FlowCapableTransactionServiceImpl.java @@ -8,7 +8,6 @@ package org.opendaylight.openflowplugin.impl.services; import com.google.common.util.concurrent.FutureCallback; -import com.google.common.util.concurrent.SettableFuture; import java.util.concurrent.Future; import org.opendaylight.openflowjava.protocol.api.connection.OutboundQueue; import org.opendaylight.openflowplugin.api.openflow.device.DeviceContext; @@ -43,7 +42,6 @@ public class FlowCapableTransactionServiceImpl extends CommonService implements return failedFuture(); } - final DeviceContext deviceContext = getDeviceContext(); final BarrierInputBuilder barrierInputOFJavaBuilder = new BarrierInputBuilder(); final Xid xid = requestContext.getXid(); @@ -53,25 +51,29 @@ public class FlowCapableTransactionServiceImpl extends CommonService implements LOG.trace("Hooking xid {} to device context - precaution.", requestContext.getXid().getValue()); final OutboundQueue outboundQueue = getDeviceContext().getPrimaryConnectionContext().getOutboundQueueProvider(); - final SettableFuture> settableFuture = SettableFuture.create(); final BarrierInput barrierInput = barrierInputOFJavaBuilder.build(); outboundQueue.commitEntry(xid.getValue(), barrierInput, new FutureCallback() { + + RpcResultBuilder rpcResultBuilder; @Override public void onSuccess(final OfHeader ofHeader) { + rpcResultBuilder = RpcResultBuilder.success(); + requestContext.setResult(rpcResultBuilder.build()); RequestContextUtil.closeRequstContext(requestContext); + getMessageSpy().spyMessage(barrierInput.getImplementedInterface(), MessageSpy.STATISTIC_GROUP.TO_SWITCH_SUBMIT_SUCCESS); - settableFuture.set(RpcResultBuilder.success().build()); } @Override public void onFailure(final Throwable throwable) { - RpcResultBuilder rpcResultBuilder = RpcResultBuilder.failed().withError(RpcError.ErrorType.APPLICATION, throwable.getMessage(), throwable); + rpcResultBuilder = RpcResultBuilder.failed().withError(RpcError.ErrorType.APPLICATION, throwable.getMessage(), throwable); + requestContext.setResult(rpcResultBuilder.build()); RequestContextUtil.closeRequstContext(requestContext); + getMessageSpy().spyMessage(barrierInput.getImplementedInterface(), MessageSpy.STATISTIC_GROUP.TO_SWITCH_SUBMIT_FAILURE); - settableFuture.set(rpcResultBuilder.build()); } }); - return settableFuture; + return requestContext.getFuture(); } } -- 2.36.6