BgpManager: Changes to FIB Ds add and remove code 82/19882/1
authorManisha Malla <manisha.malla@ericsson.com>
Fri, 8 May 2015 07:29:03 +0000 (12:59 +0530)
committerManisha Malla <manisha.malla@ericsson.com>
Fri, 8 May 2015 07:31:25 +0000 (13:01 +0530)
Change-Id: I02150972e9876a7c1158d39a145981b6da99372f
Signed-off-by: Manisha Malla <manisha.malla@ericsson.com>
bgpmanager/bgpmanager-impl/src/main/java/org/opendaylight/bgpmanager/FibDSWriter.java

index 8cab61572c9553386d0f581f695e8fd4b2fc51b5..28d196a093992fe7f1281eff8da85c8119f5885b 100644 (file)
@@ -15,6 +15,7 @@ import org.opendaylight.yang.gen.v1.urn.opendaylight.vpnservice.fibmanager.rev15
 import org.opendaylight.yang.gen.v1.urn.opendaylight.vpnservice.fibmanager.rev150330.fibentries.VrfTables;
 import org.opendaylight.yang.gen.v1.urn.opendaylight.vpnservice.fibmanager.rev150330.fibentries.VrfTablesBuilder;
 import org.opendaylight.yang.gen.v1.urn.opendaylight.vpnservice.fibmanager.rev150330.fibentries.VrfTablesKey;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.vpnservice.fibmanager.rev150330.vrfentries.VrfEntryKey;
 import org.opendaylight.yang.gen.v1.urn.opendaylight.vpnservice.fibmanager.rev150330.FibEntries;
 
 import org.slf4j.Logger;
@@ -43,37 +44,19 @@ public class FibDSWriter {
 
         VrfEntry vrfEntry = new VrfEntryBuilder().setDestPrefix(prefix).
             setNextHopAddress(nexthop).setLabel((long)label).build();
+        logger.debug("Created vrfEntry for " + prefix + " nexthop " + nexthop + " label " + label);
+
+        List<VrfEntry> vrfEntryList = new ArrayList<VrfEntry>();
+        vrfEntryList.add(vrfEntry);
 
-        logger.info("Created vrfEntry for " + prefix + " nexthop " + nexthop + " label " + label);
         InstanceIdentifierBuilder<VrfTables> idBuilder =
             InstanceIdentifier.builder(FibEntries.class).child(VrfTables.class, new VrfTablesKey(rd));
-
-
         InstanceIdentifier<VrfTables> vrfTableId = idBuilder.build();
-        Optional<VrfTables> vrfTable = read(LogicalDatastoreType.CONFIGURATION, vrfTableId);
-        if (vrfTable.isPresent()) {
-            List<VrfEntry> vrfEntryListExisting = vrfTable.get().getVrfEntry();
-            vrfEntryListExisting.add(vrfEntry);
 
+        VrfTables vrfTableNew = new VrfTablesBuilder().setRouteDistinguisher(rd).
+            setVrfEntry(vrfEntryList).build();
 
-            VrfTables vrfTableUpdate = new VrfTablesBuilder().setRouteDistinguisher(rd).
-                setVrfEntry(vrfEntryListExisting).build();
-            write(LogicalDatastoreType.CONFIGURATION, vrfTableId, vrfTableUpdate);
-        }
-        else {
-            List<VrfEntry> vrfEntryList = new ArrayList<VrfEntry>();
-            vrfEntryList.add(vrfEntry);
-
-            //add a new vrf table with this vrf entry
-            VrfTables vrfTableNew = new VrfTablesBuilder().setRouteDistinguisher(rd).
-                setVrfEntry(vrfEntryList).build();
-
-
-            InstanceIdentifier<VrfTables> vrfTableNewId = InstanceIdentifier.builder(FibEntries.class)
-                .child(VrfTables.class, new VrfTablesKey(rd)).build();
-
-            write(LogicalDatastoreType.CONFIGURATION, vrfTableNewId, vrfTableNew);
-        }
+        write(LogicalDatastoreType.CONFIGURATION, vrfTableId, vrfTableNew);
 
     }
 
@@ -81,26 +64,11 @@ public class FibDSWriter {
 
         logger.debug("Removing fib entry with destination prefix " + prefix + " from vrf table for rd " + rd);
 
-        InstanceIdentifierBuilder<VrfTables> idBuilder =
-            InstanceIdentifier.builder(FibEntries.class).child(VrfTables.class, new VrfTablesKey(rd));
-        InstanceIdentifier<VrfTables> vrfTableId = idBuilder.build();
-        Optional<VrfTables> vrfTable = read(LogicalDatastoreType.CONFIGURATION, vrfTableId);
-        if (vrfTable.isPresent()) {
-            String searchPfx = prefix;
-
-            List<VrfEntry> vrfEntryListExisting = vrfTable.get().getVrfEntry();
-            for (Iterator<VrfEntry> it = vrfEntryListExisting.iterator(); it.hasNext(); ) {
-                VrfEntry elem = it.next();
-                if (elem.getDestPrefix().equals(searchPfx)) {
-                    it.remove();
-                    break;
-                }
-            }
-
-            VrfTables vrfTableUpdate = new VrfTablesBuilder().setRouteDistinguisher(rd).
-                setVrfEntry(vrfEntryListExisting).build();
-            write(LogicalDatastoreType.CONFIGURATION, vrfTableId, vrfTableUpdate);
-        }
+        InstanceIdentifierBuilder<VrfEntry> idBuilder =
+            InstanceIdentifier.builder(FibEntries.class).child(VrfTables.class, new VrfTablesKey(rd)).child(VrfEntry.class, new VrfEntryKey(prefix));
+        InstanceIdentifier<VrfEntry> vrfEntryId = idBuilder.build();
+        delete(LogicalDatastoreType.CONFIGURATION, vrfEntryId);
+
     }
 
     private <T extends DataObject> Optional<T> read(LogicalDatastoreType datastoreType,
@@ -121,7 +89,13 @@ public class FibDSWriter {
     private <T extends DataObject> void write(LogicalDatastoreType datastoreType,
                                                    InstanceIdentifier<T> path, T data) {
         WriteTransaction tx = broker.newWriteOnlyTransaction();
-        tx.put(datastoreType, path, data, true);
+        tx.merge(datastoreType, path, data, true);
+        tx.submit();
+    }
+
+    private <T extends DataObject> void delete(LogicalDatastoreType datastoreType, InstanceIdentifier<T> path) {
+        WriteTransaction tx = broker.newWriteOnlyTransaction();
+        tx.delete(datastoreType, path);
         tx.submit();
     }
 }