Stale MIP FIB/Flow entries present upon deletion of VRRP master
[netvirt.git] / fibmanager / api / src / main / java / org / opendaylight / netvirt / fibmanager / api / IFibManager.java
index 4984f89bfcfafc031123641cc950ce8e95973673..0b687463f56f3f172c14e86d08a3f1ee87b4ec5a 100644 (file)
@@ -10,25 +10,31 @@ package org.opendaylight.netvirt.fibmanager.api;
 
 import com.google.common.util.concurrent.FutureCallback;
 
-import java.math.BigInteger;
 import java.util.List;
 
+import org.eclipse.jdt.annotation.Nullable;
+import org.opendaylight.controller.md.sal.binding.api.DataBroker;
 import org.opendaylight.controller.md.sal.binding.api.WriteTransaction;
+import org.opendaylight.genius.infra.Datastore.Configuration;
+import org.opendaylight.genius.infra.TypedWriteTransaction;
+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);
 
@@ -43,38 +49,44 @@ 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, WriteTransaction 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, WriteTransaction writeConfigTxn);
+                                       RouterInterface routerInterface, Uint32 label,
+                                       TypedWriteTransaction<Configuration> writeConfigTxn);
 
     void removeOrUpdateFibEntry(String rd, String prefix, String nextHopToRemove,
-                                WriteTransaction writeConfigTxn);
+                                TypedWriteTransaction<Configuration> writeConfigTxn);
 
-    void removeFibEntry(String rd, String prefix, WriteTransaction 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);
+                                    Uint32 label, boolean nextHopAdd, WriteTransaction writeConfigTxn);
 
     void addVrfTable(String rd, WriteTransaction writeConfigTxn);
 
-    void removeVrfTable(String rd, WriteTransaction writeConfigTxn);
+    void removeVrfTable(String rd, TypedWriteTransaction<Configuration> writeConfigTxn);
 
     void removeInterVPNLinkRouteFlows(String interVpnLinkName,
                                       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);
 }