package org.opendaylight.openflowplugin.api.openflow.device;
+import org.opendaylight.controller.md.sal.binding.api.NotificationPublishService;
+import org.opendaylight.controller.md.sal.binding.api.NotificationService;
import org.opendaylight.openflowplugin.api.openflow.device.handlers.DeviceConnectedHandler;
-import org.opendaylight.openflowplugin.api.openflow.device.handlers.DeviceContextReadyHandler;
+import org.opendaylight.openflowplugin.api.openflow.device.handlers.DeviceContextClosedHandler;
+import org.opendaylight.openflowplugin.api.openflow.device.handlers.DeviceInitializationPhaseHandler;
+import org.opendaylight.openflowplugin.api.openflow.device.handlers.DeviceInitializator;
import org.opendaylight.openflowplugin.api.openflow.translator.TranslatorLibrarian;
/**
* This interface is responsible for instantiating DeviceContext and
* registering transaction chain for each DeviceContext. Each device
* has its own device context managed by this manager.
- * <p>
* Created by Martin Bobak <mbobak@cisco.com> on 25.2.2015.
*/
-public interface DeviceManager extends DeviceConnectedHandler, TranslatorLibrarian {
+public interface DeviceManager extends DeviceConnectedHandler,
+ TranslatorLibrarian,
+ DeviceInitializator,
+ DeviceInitializationPhaseHandler, DeviceContextClosedHandler {
/**
- * Method registers handler responsible for handling operations related to connected device after
- * request context is created.
+ * Sets notification receiving service
*
- * @param deviceContextReadyHandler
+ * @param notificationService
*/
- public void addRequestContextReadyHandler(DeviceContextReadyHandler deviceContextReadyHandler);
+ void setNotificationService(NotificationService notificationService);
+
+ /**
+ * Sets notification publish service
+ *
+ * @param notificationPublishService
+ */
+ void setNotificationPublishService(NotificationPublishService notificationPublishService);
}