Improve property-based configuration
[openflowplugin.git] / openflowplugin-api / src / main / java / org / opendaylight / openflowplugin / api / openflow / device / DeviceManager.java
index e86e06fdd80b7adc4ad847c3f1efb76a69aa8205..64cfd864d1aca65c72602fcad1126714aea96e10 100644 (file)
@@ -1,5 +1,5 @@
 /*
- * Copyright (c) 2015 Cisco Systems, Inc. and others.  All rights reserved.
+ * Copyright (c) 2015, 2017 Cisco Systems, Inc. and others.  All rights reserved.
  *
  * This program and the accompanying materials are made available under the
  * terms of the Eclipse Public License v1.0 which accompanies this distribution,
@@ -9,11 +9,14 @@
 package org.opendaylight.openflowplugin.api.openflow.device;
 
 import com.google.common.util.concurrent.CheckedFuture;
+import javax.annotation.Nonnull;
 import org.opendaylight.controller.md.sal.common.api.data.TransactionCommitFailedException;
 import org.opendaylight.openflowplugin.api.openflow.OFPManager;
-import org.opendaylight.openflowplugin.api.openflow.device.handlers.DeviceConnectedHandler;
-import org.opendaylight.openflowplugin.api.openflow.device.handlers.DeviceDisconnectedHandler;
+import org.opendaylight.openflowplugin.api.openflow.connection.ConnectionContext;
 import org.opendaylight.openflowplugin.api.openflow.translator.TranslatorLibrarian;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.inventory.rev130819.nodes.Node;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.inventory.rev130819.nodes.NodeKey;
+import org.opendaylight.yangtools.yang.binding.KeyedInstanceIdentifier;
 
 /**
  * This interface is responsible for instantiating DeviceContext and
@@ -22,12 +25,10 @@ import org.opendaylight.openflowplugin.api.openflow.translator.TranslatorLibrari
  */
 public interface DeviceManager extends
         OFPManager,
-        DeviceConnectedHandler,
-        DeviceDisconnectedHandler,
         TranslatorLibrarian {
 
     /**
-     * invoked after all services injected
+     * invoked after all services injected.
      */
     void initialize();
 
@@ -35,6 +36,10 @@ public interface DeviceManager extends
 
     boolean isFlowRemovedNotificationOn();
 
+    void setGlobalNotificationQuota(long globalNotificationQuota);
+
+    void setSwitchFeaturesMandatory(boolean switchFeaturesMandatory);
+
     void setSkipTableFeatures(boolean skipTableFeatures);
 
     void setBarrierCountLimit(int barrierCountLimit);
@@ -43,6 +48,16 @@ public interface DeviceManager extends
 
     CheckedFuture<Void, TransactionCommitFailedException> removeDeviceFromOperationalDS(DeviceInfo deviceInfo);
 
-    void setUseSingleLayerSerialization(Boolean useSingleLayerSerilization);
+    CheckedFuture<Void, TransactionCommitFailedException> removeDeviceFromOperationalDS(final KeyedInstanceIdentifier<Node, NodeKey> ii);
+
+    void setUseSingleLayerSerialization(Boolean useSingleLayerSerialization);
+
+    DeviceContext createContext(@Nonnull final ConnectionContext connectionContext);
+
+    long getBarrierIntervalNanos();
+
+    int getBarrierCountLimit();
+
+    void sendNodeAddedNotification(@Nonnull final DeviceInfo deviceInfo);
 }