*/
package org.opendaylight.openflowplugin.impl.connection;
-import com.google.common.util.concurrent.ListenableFuture;
-import com.google.common.util.concurrent.SettableFuture;
-import java.util.Collection;
import org.opendaylight.openflowjava.protocol.api.connection.ConnectionAdapter;
+import org.opendaylight.openflowjava.protocol.api.connection.OutboundQueue;
+import org.opendaylight.openflowjava.protocol.api.connection.OutboundQueueHandlerRegistration;
import org.opendaylight.openflowplugin.api.openflow.connection.ConnectionContext;
-import org.opendaylight.openflowplugin.api.openflow.connection.MultiMsgCollector;
+import org.opendaylight.openflowplugin.api.openflow.connection.OutboundQueueProvider;
+import org.opendaylight.openflowplugin.api.openflow.device.handlers.DeviceDisconnectedHandler;
import org.opendaylight.yang.gen.v1.urn.opendaylight.inventory.rev130819.NodeId;
import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.FeaturesReply;
-import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.MultipartReply;
+import org.slf4j.Logger;
+import org.slf4j.LoggerFactory;
/**
*
private final ConnectionAdapter connectionAdapter;
private CONNECTION_STATE connectionState;
private FeaturesReply featuresReply;
- private final MultiMsgCollector multipartCollector;
private NodeId nodeId;
+ private DeviceDisconnectedHandler deviceDisconnectedHandler;
+ private static final Logger LOG = LoggerFactory.getLogger(ConnectionContextImpl.class);
+ private OutboundQueueProvider outboundQueueProvider;
+ private OutboundQueueHandlerRegistration<OutboundQueueProvider> outboundQueueHandlerRegistration;
/**
* @param connectionAdapter
*/
public ConnectionContextImpl(final ConnectionAdapter connectionAdapter) {
this.connectionAdapter = connectionAdapter;
- multipartCollector = new MultiMsgCollectorImpl();
}
@Override
return connectionAdapter;
}
+ @Override
+ public OutboundQueue getOutboundQueueProvider() {
+ return this.outboundQueueProvider;
+ }
+
+ @Override
+ public void setOutboundQueueProvider(final OutboundQueueProvider outboundQueueProvider) {
+ this.outboundQueueProvider = outboundQueueProvider;
+ }
+
@Override
public CONNECTION_STATE getConnectionState() {
return connectionState;
}
@Override
- public void setNodeId(NodeId nodeId) {
+ public void setNodeId(final NodeId nodeId) {
this.nodeId = nodeId;
}
}
@Override
- public void setFeatures(final FeaturesReply featuresReply) {
- this.featuresReply = featuresReply;
+ public void setDeviceDisconnectedHandler(final DeviceDisconnectedHandler deviceDisconnectedHandler) {
+ this.deviceDisconnectedHandler = deviceDisconnectedHandler;
+ }
+ @Override
+ public void propagateClosingConnection() {
+ if (null != deviceDisconnectedHandler) {
+ LOG.trace("Populating connection closed event.");
+ this.deviceDisconnectedHandler.onDeviceDisconnected(this);
+ }
}
@Override
- public ListenableFuture<Collection<MultipartReply>> registerMultipartMsg(final long xid) {
- return multipartCollector.registerMultipartMsg(xid);
+ public void setFeatures(final FeaturesReply featuresReply) {
+ this.featuresReply = featuresReply;
}
@Override
- public void addMultipartMsg(final MultipartReply reply) {
- multipartCollector.addMultipartMsg(reply);
+ public void close() {
+ if (getConnectionAdapter().isAlive()) {
+ setConnectionState(ConnectionContext.CONNECTION_STATE.RIP);
+ getConnectionAdapter().disconnect();
+ }
+ if (outboundQueueHandlerRegistration != null) {
+ outboundQueueHandlerRegistration.close();
+ outboundQueueHandlerRegistration = null;
+ }
}
@Override
- public void registerMultipartFutureMsg(final long xid, final SettableFuture<Collection<MultipartReply>> future) {
- multipartCollector.registerMultipartFutureMsg(xid, future);
+ public void setOutboundQueueHandleRegistration(OutboundQueueHandlerRegistration<OutboundQueueProvider> outboundQueueHandlerRegistration) {
+ this.outboundQueueHandlerRegistration = outboundQueueHandlerRegistration;
}
}