Handle first iand last prefix for vrf on a dpn. 84/20284/4
authorDeepthi V V <deepthi.v.v@ericsson.com>
Wed, 13 May 2015 18:32:05 +0000 (00:02 +0530)
committerDeepthi V V <deepthi.v.v@ericsson.com>
Thu, 14 May 2015 08:38:50 +0000 (08:38 +0000)
Signed-off-by: Deepthi V V <deepthi.v.v@ericsson.com>
Change-Id: Ibd44c679995c1633a77a0eb190f95adf455634d8

fibmanager/fibmanager-api/pom.xml
fibmanager/fibmanager-api/src/main/java/org/opendaylight/fibmanager/api/IFibManager.java [new file with mode: 0644]
fibmanager/fibmanager-api/src/main/yang/fibmanager-api.yang [new file with mode: 0644]
fibmanager/fibmanager-impl/src/main/config/default-config.xml
fibmanager/fibmanager-impl/src/main/java/org/opendaylight/vpnservice/fibmanager/FibManager.java
fibmanager/fibmanager-impl/src/main/java/org/opendaylight/vpnservice/fibmanager/FibManagerProvider.java
fibmanager/fibmanager-impl/src/main/yang/fibmanager-impl.yang

index d82fe10a92a3fcf0cff008bf34f99de1219e7f39..b5e06b928e3106bdafcc0560521978f5d50f62c3 100644 (file)
@@ -9,7 +9,7 @@ and is available at http://www.eclipse.org/legal/epl-v10.html
 <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
   <parent>
     <groupId>org.opendaylight.vpnservice</groupId>
-    <artifactId>binding-parent</artifactId>
+    <artifactId>config-parent</artifactId>
     <version>0.1.0-SNAPSHOT</version>
     <relativePath>../../commons/binding-parent</relativePath>
   </parent>
@@ -56,5 +56,9 @@ and is available at http://www.eclipse.org/legal/epl-v10.html
       <artifactId>model-inventory</artifactId>
       <version>${mdsal.version}</version>
     </dependency>
+    <dependency>
+      <groupId>org.opendaylight.controller</groupId>
+      <artifactId>config-api</artifactId>
+    </dependency>
   </dependencies>
 </project>
diff --git a/fibmanager/fibmanager-api/src/main/java/org/opendaylight/fibmanager/api/IFibManager.java b/fibmanager/fibmanager-api/src/main/java/org/opendaylight/fibmanager/api/IFibManager.java
new file mode 100644 (file)
index 0000000..4c16d2f
--- /dev/null
@@ -0,0 +1,6 @@
+package org.opendaylight.fibmanager.api;
+
+public interface IFibManager {
+    void populateFibOnNewDpn(long dpnId, long vpnId, String rd);
+    void cleanUpDpnForVpn(long dpnId, long vpnId, String rd);
+}
diff --git a/fibmanager/fibmanager-api/src/main/yang/fibmanager-api.yang b/fibmanager/fibmanager-api/src/main/yang/fibmanager-api.yang
new file mode 100644 (file)
index 0000000..de27e90
--- /dev/null
@@ -0,0 +1,20 @@
+module fibmanager-api {
+    yang-version 1;
+    namespace "urn:opendaylight:params:xml:ns:yang:fibmanager:api";
+    prefix "fibmanager-api";
+
+    import config { prefix config; revision-date 2013-04-05; }
+
+    description
+        "Service definition for vpnmanager project";
+
+    revision "2015-05-08" {
+        description
+            "Initial revision";
+    }
+
+    identity fibmanager-api {
+        base "config:service-type";
+        config:java-class "org.opendaylight.fibmanager.api.IFibManager";
+    }
+}
\ No newline at end of file
index 166d22cb19a798510c26e46b630cabe460e040e4..ebf0531b3ec7a97ec92ad656310629165692e399 100644 (file)
@@ -35,6 +35,15 @@ and is available at http://www.eclipse.org/legal/epl-v10.html
           </vpnmanager>
         </module>
       </modules>
+      <services xmlns="urn:opendaylight:params:xml:ns:yang:controller:config">
+        <service>
+          <type xmlns:prefix="urn:opendaylight:params:xml:ns:yang:fibmanager:api">prefix:fibmanager-api</type>
+          <instance>
+            <name>fibmanager</name>
+            <provider>/modules/module[type='fibmanager-impl'][name='fibmanager-default']</provider>
+          </instance>
+        </service>
+      </services>
     </data>
   </configuration>
 </snapshot>
index 70a6d209ee2551cafafeb67a0b76b5655598f7b7..fed6b9b09f104eddebe29847c559e7c09e28d5e8 100644 (file)
@@ -36,6 +36,7 @@ import org.opendaylight.yang.gen.v1.urn.opendaylight.vpnservice.fibmanager.rev15
 import org.opendaylight.yang.gen.v1.urn.opendaylight.vpnservice.l3nexthop.rev150409.GetEgressPointerInputBuilder;
 import org.opendaylight.yang.gen.v1.urn.opendaylight.vpnservice.l3nexthop.rev150409.GetEgressPointerOutput;
 import org.opendaylight.yang.gen.v1.urn.opendaylight.vpnservice.l3nexthop.rev150409.L3nexthopService;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.vpnservice.l3nexthop.rev150409.RemoveLocalNextHopInputBuilder;
 import org.opendaylight.yangtools.concepts.ListenerRegistration;
 import org.opendaylight.yangtools.yang.binding.DataObject;
 import org.opendaylight.yangtools.yang.binding.InstanceIdentifier;
@@ -251,6 +252,7 @@ public class FibManager extends AbstractDataChangeListener<VrfEntry> implements
 
     if (isLocalRoute) {
       makeLFibTableEntry(dpId, vrfEntry.getLabel(), groupId, vrfEntry.getNextHopAddress(), NwConstants.DEL_FLOW);
+      deleteLocalAdjacency(dpId, vpnId, vrfEntry);
     }
 
     LOG.debug("Successfully delete fib entry for "+ vrfEntry.getDestPrefix() + " vpnId "+vpnId);
@@ -343,6 +345,55 @@ public class FibManager extends AbstractDataChangeListener<VrfEntry> implements
     LOG.debug("LFIB Entry for dpID {} : label : {} group {} modified successfully {}",dpId, label, groupId );
   }
 
+  private void deleteLocalAdjacency(final long dpId, final long vpnId, final VrfEntry vrfEntry) {
+    LOG.trace("deleteLocalAdjacency called with dpid {}, vpnId{}, VrfEntry {}",dpId, vpnId, vrfEntry);;
+    try {
+      Future<RpcResult<Void>> result =
+          l3nexthopService.removeLocalNextHop(new RemoveLocalNextHopInputBuilder().setDpnId(dpId)
+                                                  .setIpPrefix(vrfEntry.getDestPrefix())
+                                                  .setNexthopIp(vrfEntry.getNextHopAddress())
+                                                  .setVpnId(vpnId)
+                                                  .build());
+      RpcResult<Void> rpcResult = result.get();
+      if (rpcResult.isSuccessful()) {
+        LOG.debug("Local Next hop for {} on dpn {} successfully deleted", vrfEntry.getDestPrefix(), dpId);
+      } else {
+        LOG.error("Local Next hop for {} on dpn {} not deleted", vrfEntry.getDestPrefix(), dpId);
+      }
+    } catch (NullPointerException | InterruptedException | ExecutionException e) {
+      LOG.trace("", e);
+    }
+  }
+
+  public void populateFibOnNewDpn(long dpnId, long vpnId, String rd) {
+    LOG.trace("New dpn {} for vpn {} : populateFibOnNewDpn", dpnId, rd);
+    InstanceIdentifier<VrfTables> id = buildVrfId(rd);
+    Optional<VrfTables> vrfTable = read(LogicalDatastoreType.OPERATIONAL, id);
+    if(vrfTable.isPresent()) {
+      for(VrfEntry vrfEntry : vrfTable.get().getVrfEntry()) {
+        addRouteInternal(dpnId, vpnId, vrfTable.get().getKey(), vrfEntry);
+      }
+    }
+  }
+
+  public void cleanUpDpnForVpn(long dpnId, long vpnId, String rd) {
+    LOG.trace("Remove dpn {} for vpn {} : cleanUpDpnForVpn", dpnId, rd);
+    InstanceIdentifier<VrfTables> id = buildVrfId(rd);
+    Optional<VrfTables> vrfTable = read(LogicalDatastoreType.OPERATIONAL, id);
+    if(vrfTable.isPresent()) {
+      for(VrfEntry vrfEntry : vrfTable.get().getVrfEntry()) {
+        deleteRoute(dpnId, vpnId, vrfTable.get().getKey(), vrfEntry);
+      }
+    }
+  }
+
+  public static InstanceIdentifier<VrfTables> buildVrfId(String rd) {
+    InstanceIdentifierBuilder<VrfTables> idBuilder =
+        InstanceIdentifier.builder(FibEntries.class).child(VrfTables.class, new VrfTablesKey(rd));
+    InstanceIdentifier<VrfTables> id = idBuilder.build();
+    return id;
+  }
+
   private String getFlowRef(long dpnId, short tableId, long label, String nextHop) {
     return new StringBuilder(64).append(FLOWID_PREFIX).append(dpnId).append(NwConstants.FLOWID_SEPARATOR)
         .append(tableId).append(NwConstants.FLOWID_SEPARATOR)
index d08ec0959ca2aa02d95ca4e13d7ab62d0dd74317..bb16187c2bd507dc420ab78e69fe711d0318d98f 100644 (file)
@@ -10,6 +10,7 @@ package org.opendaylight.vpnservice.fibmanager;
 import org.opendaylight.controller.md.sal.binding.api.DataBroker;
 import org.opendaylight.controller.sal.binding.api.BindingAwareBroker.ProviderContext;
 import org.opendaylight.controller.sal.binding.api.BindingAwareProvider;
+import org.opendaylight.fibmanager.api.IFibManager;
 import org.opendaylight.vpnmanager.api.IVpnManager;
 import org.opendaylight.vpnservice.mdsalutil.interfaces.IMdsalApiManager;
 import org.opendaylight.yang.gen.v1.urn.opendaylight.vpnservice.l3nexthop.rev150409.L3nexthopService;
@@ -17,7 +18,7 @@ import org.opendaylight.yangtools.yang.binding.RpcService;
 import org.slf4j.Logger;
 import org.slf4j.LoggerFactory;
 
-public class FibManagerProvider implements BindingAwareProvider, AutoCloseable {
+public class FibManagerProvider implements BindingAwareProvider, IFibManager, AutoCloseable {
 
   private static final Logger LOG = LoggerFactory.getLogger(FibManagerProvider.class);
 
@@ -55,4 +56,14 @@ public class FibManagerProvider implements BindingAwareProvider, AutoCloseable {
   public void setVpnmanager(IVpnManager vpnmanager) {
     this.vpnmanager = vpnmanager;
   }
-}
\ No newline at end of file
+
+  @Override
+  public void populateFibOnNewDpn(long dpnId, long vpnId, String rd) {
+    fibManager.populateFibOnNewDpn(dpnId, vpnId, rd);
+  }
+
+  @Override
+  public void cleanUpDpnForVpn(long dpnId, long vpnId, String rd) {
+    fibManager.populateFibOnNewDpn(dpnId, vpnId, rd);
+  }
+}
index 42e0a05a300d491fde1f96cbf629a8dde742da32..ac676b8cbecf5157e9d94de96d6d47834e9e7971 100644 (file)
@@ -3,7 +3,8 @@ module fibmanager-impl {
     namespace "urn:opendaylight:params:xml:ns:yang:fibmanager:impl";
     prefix "fibmanager-impl";
 
-    import config { prefix config; revision-date 2013-04-05; }
+    import config { prefix config; revision-date 2013-04-05;}
+    import fibmanager-api { prefix fibmgr-api; revision-date 2015-05-08;}
     import opendaylight-md-sal-binding { prefix md-sal-binding; revision-date 2013-10-28;}
     import odl-mdsalutil { prefix odl-mdsal; revision-date 2015-04-10;}
     import vpnmanager-api { prefix odl-vpn; revision-date 2015-05-08;}
@@ -18,6 +19,7 @@ module fibmanager-impl {
 
     identity fibmanager-impl {
         base config:module-type;
+        config:provided-service fibmgr-api:fibmanager-api;
         config:java-name-prefix FibmanagerImpl;
     }