package org.opendaylight.openflowplugin.openflow.md.core;
import java.net.InetAddress;
+import java.util.concurrent.ScheduledThreadPoolExecutor;
+import java.util.concurrent.TimeUnit;
import org.opendaylight.openflowjava.protocol.api.connection.ConnectionAdapter;
import org.opendaylight.openflowjava.protocol.api.connection.SwitchConnectionHandler;
+import org.opendaylight.openflowplugin.api.openflow.md.core.ConnectionConductor;
+import org.opendaylight.openflowplugin.api.openflow.md.core.ErrorHandler;
import org.opendaylight.openflowplugin.openflow.md.core.session.OFSessionUtil;
-import org.opendaylight.openflowplugin.openflow.md.queue.QueueKeeperLightImpl;
+import org.opendaylight.openflowplugin.openflow.md.queue.QueueProcessorLightImpl;
+import org.opendaylight.openflowplugin.api.openflow.statistics.MessageSpy;
+import org.opendaylight.yangtools.yang.binding.DataContainer;
/**
- * @author mirehak
- *
+ * basic interconnecting piece between plugin and library
*/
public class SwitchConnectionHandlerImpl implements SwitchConnectionHandler {
+
+ private ScheduledThreadPoolExecutor spyPool;
- private QueueKeeperLightImpl queueKeeper;
+ private QueueProcessorLightImpl queueProcessor;
private ErrorHandler errorHandler;
+ private MessageSpy<DataContainer> messageSpy;
+ private int spyRate = 10;
/**
*
*/
public SwitchConnectionHandlerImpl() {
- queueKeeper = new QueueKeeperLightImpl();
- queueKeeper.setTranslatorMapping(OFSessionUtil.getTranslatorMap());
- queueKeeper.setPopListenersMapping(OFSessionUtil.getPopListenerMapping());
- queueKeeper.init();
+ queueProcessor = new QueueProcessorLightImpl();
+
+ //TODO: implement shutdown invocation upon service stop event
+ spyPool = new ScheduledThreadPoolExecutor(1);
+ }
- errorHandler = new ErrorHandlerQueueImpl();
- new Thread(errorHandler).start();
+ /**
+ * wire all up
+ */
+ public void init() {
+ queueProcessor.setTranslatorMapping(OFSessionUtil.getTranslatorMap());
+ queueProcessor.setPopListenersMapping(OFSessionUtil.getPopListenerMapping());
+ queueProcessor.setMessageSpy(messageSpy);
+
+ queueProcessor.init();
+
+ spyPool.scheduleAtFixedRate(messageSpy, spyRate, spyRate, TimeUnit.SECONDS);
}
@Override
@Override
public void onSwitchConnected(ConnectionAdapter connectionAdapter) {
ConnectionConductor conductor = ConnectionConductorFactory.createConductor(
- connectionAdapter, queueKeeper);
+ connectionAdapter, queueProcessor);
conductor.setErrorHandler(errorHandler);
}
+
+ /**
+ * @param messageSpy the messageSpy to set
+ */
+ public void setMessageSpy(MessageSpy<DataContainer> messageSpy) {
+ this.messageSpy = messageSpy;
+ }
+
+ /**
+ * @param errorHandler the errorHandler to set
+ */
+ public void setErrorHandler(ErrorHandler errorHandler) {
+ this.errorHandler = errorHandler;
+ }
}