NETVIRT-1630 migrate to md-sal APIs
[netvirt.git] / fibmanager / api / src / main / java / org / opendaylight / netvirt / fibmanager / api / IFibManager.java
index c1511fc1aaad69b2dbd36cfed78247dd4cdb2dd5..e0a929e048530b6e19cf48580cd3a4be8ef309b1 100644 (file)
@@ -9,29 +9,30 @@
 package org.opendaylight.netvirt.fibmanager.api;
 
 import com.google.common.util.concurrent.FutureCallback;
-
-import java.math.BigInteger;
 import java.util.List;
-
-import org.opendaylight.controller.md.sal.binding.api.WriteTransaction;
+import org.eclipse.jdt.annotation.Nullable;
 import org.opendaylight.genius.infra.Datastore.Configuration;
 import org.opendaylight.genius.infra.TypedWriteTransaction;
+import org.opendaylight.mdsal.binding.api.DataBroker;
+import org.opendaylight.mdsal.binding.api.WriteTransaction;
 import org.opendaylight.yang.gen.v1.urn.opendaylight.genius.interfacemanager.rev160406.TunnelTypeBase;
 import org.opendaylight.yang.gen.v1.urn.opendaylight.netvirt.fibmanager.rev150330.RouterInterface;
 import org.opendaylight.yang.gen.v1.urn.opendaylight.netvirt.fibmanager.rev150330.vrfentries.VrfEntry;
+import org.opendaylight.yangtools.yang.common.Uint32;
+import org.opendaylight.yangtools.yang.common.Uint64;
 
 public interface IFibManager {
-    void populateFibOnNewDpn(BigInteger dpnId, long vpnId, String rd,
-                             FutureCallback<List<Void>> callback);
+    void populateFibOnNewDpn(Uint64 dpnId, Uint32 vpnId, String rd,
+                             @Nullable FutureCallback<List<Void>> callback);
 
-    void cleanUpExternalRoutesOnDpn(BigInteger dpnId, long vpnId, String rd,
+    void cleanUpExternalRoutesOnDpn(Uint64 dpnId, Uint32 vpnId, String rd,
                                     String localNextHopIp, String remoteNextHopIp);
 
-    void populateExternalRoutesOnDpn(BigInteger localDpnId, long vpnId, String rd,
+    void populateExternalRoutesOnDpn(Uint64 localDpnId, Uint32 vpnId, String rd,
                                      String localNextHopIp, String remoteNextHopIp);
 
-    void cleanUpDpnForVpn(BigInteger dpnId, long vpnId, String rd,
-                          FutureCallback<List<Void>> callback);
+    void cleanUpDpnForVpn(Uint64 dpnId, Uint32 vpnId, String rd,
+                          @Nullable FutureCallback<List<Void>> callback);
 
     void setConfTransType(String service, String transportType);
 
@@ -46,29 +47,30 @@ public interface IFibManager {
     String getTransportTypeStr(String tunType);
 
     void manageRemoteRouteOnDPN(boolean action,
-                                BigInteger localDpnId,
-                                long vpnId,
+                                Uint64 localDpnId,
+                                Uint32 vpnId,
                                 String rd,
                                 String destPrefix,
                                 String destTepIp,
-                                long label);
+                                Uint32 label);
 
-    void addOrUpdateFibEntry(String rd, String macAddress, String prefix, List<String> nextHopList,
-                             VrfEntry.EncapType encapType, long label, long l3vni, String gwMacAddress,
-                             String parentVpnRd, RouteOrigin origin,
-                             TypedWriteTransaction<Configuration> writeConfigTxn);
+    void addOrUpdateFibEntry(String rd, @Nullable String macAddress, String prefix, List<String> nextHopList,
+                             VrfEntry.EncapType encapType, Uint32 label, Uint32 l3vni, @Nullable String gwMacAddress,
+                             @Nullable String parentVpnRd, RouteOrigin origin,
+                             @Nullable TypedWriteTransaction<Configuration> writeConfigTxn);
 
     void addFibEntryForRouterInterface(String rd, String prefix,
-                                       RouterInterface routerInterface, long label,
+                                       RouterInterface routerInterface, Uint32 label,
                                        TypedWriteTransaction<Configuration> writeConfigTxn);
 
     void removeOrUpdateFibEntry(String rd, String prefix, String nextHopToRemove,
                                 TypedWriteTransaction<Configuration> writeConfigTxn);
 
-    void removeFibEntry(String rd, String prefix, TypedWriteTransaction<Configuration> writeConfigTxn);
+    void removeFibEntry(String rd, String prefix, String eventSource,
+                        @Nullable TypedWriteTransaction<Configuration> writeConfigTxn);
 
-    void updateRoutePathForFibEntry(String rd, String prefix, String nextHop,
-                                    long label, boolean nextHopAdd, WriteTransaction writeConfigTxn);
+    void updateRoutePathForFibEntry(String rd, String prefix, String nextHop, Uint32 label, boolean nextHopAdd,
+                                    TypedWriteTransaction<Configuration> writeConfigTxn);
 
     void addVrfTable(String rd, WriteTransaction writeConfigTxn);
 
@@ -78,8 +80,10 @@ public interface IFibManager {
                                       boolean isVpnFirstEndPoint,
                                       VrfEntry vrfEntry);
 
-    void programDcGwLoadBalancingGroup(List<String> availableDcGws, BigInteger dpnId, String destinationIp,
-                                       int addRemoveOrUpdate, boolean isTunnelUp,
+    boolean checkFibEntryExist(DataBroker broker, String rd, String prefix, String nextHopIp);
+
+    void programDcGwLoadBalancingGroup(Uint64 dpnId,
+            String destinationIp, int addRemoveOrUpdate, boolean isTunnelUp,
                                        Class<? extends TunnelTypeBase> tunnelType);
 
     void refreshVrfEntry(String rd, String prefix);