X-Git-Url: https://git.opendaylight.org/gerrit/gitweb?a=blobdiff_plain;f=bgpmanager%2Fbgpmanager-impl%2Fsrc%2Fmain%2Fjava%2Forg%2Fopendaylight%2Fbgpmanager%2FFibDSWriter.java;h=b916e3dd5a1528e61076e2a29cf3a1b21360c8b1;hb=HEAD;hp=496f3cfa847b356c4cd9090373a8eac090177ca1;hpb=743924cc48deb9dc595b93f999335411d78a96f1;p=vpnservice.git diff --git a/bgpmanager/bgpmanager-impl/src/main/java/org/opendaylight/bgpmanager/FibDSWriter.java b/bgpmanager/bgpmanager-impl/src/main/java/org/opendaylight/bgpmanager/FibDSWriter.java index 496f3cfa..b916e3dd 100644 --- a/bgpmanager/bgpmanager-impl/src/main/java/org/opendaylight/bgpmanager/FibDSWriter.java +++ b/bgpmanager/bgpmanager-impl/src/main/java/org/opendaylight/bgpmanager/FibDSWriter.java @@ -1,15 +1,18 @@ +/* + * Copyright (c) 2015 Ericsson India Global Services Pvt Ltd. 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, + * and is available at http://www.eclipse.org/legal/epl-v10.html + */ + package org.opendaylight.bgpmanager; -import com.google.common.util.concurrent.Futures; import org.opendaylight.controller.md.sal.binding.api.DataBroker; import org.opendaylight.controller.md.sal.common.api.data.LogicalDatastoreType; import org.opendaylight.yangtools.yang.binding.DataObject; import org.opendaylight.yangtools.yang.binding.InstanceIdentifier; import org.opendaylight.yangtools.yang.binding.InstanceIdentifier.InstanceIdentifierBuilder; -import org.opendaylight.controller.md.sal.binding.api.ReadOnlyTransaction; -import org.opendaylight.controller.md.sal.binding.api.WriteTransaction; -import org.opendaylight.controller.md.sal.common.api.data.AsyncDataBroker.DataChangeScope; -import org.opendaylight.yang.gen.v1.urn.opendaylight.vpnservice.fibmanager.rev150330.VrfEntries; import org.opendaylight.yang.gen.v1.urn.opendaylight.vpnservice.fibmanager.rev150330.vrfentries.VrfEntry; import org.opendaylight.yang.gen.v1.urn.opendaylight.vpnservice.fibmanager.rev150330.vrfentries.VrfEntryBuilder; import org.opendaylight.yang.gen.v1.urn.opendaylight.vpnservice.fibmanager.rev150330.fibentries.VrfTables; @@ -21,12 +24,8 @@ import org.opendaylight.yang.gen.v1.urn.opendaylight.vpnservice.fibmanager.rev15 import org.slf4j.Logger; import org.slf4j.LoggerFactory; -import java.util.ArrayList; -import java.util.List; -import java.util.Iterator; +import java.util.*; -import com.google.common.util.concurrent.FutureCallback; -import com.google.common.base.Optional; /** * Created by emhamla on 4/14/2015. @@ -41,61 +40,52 @@ public class FibDSWriter { public synchronized void addFibEntryToDS(String rd, String prefix, String nexthop, int label) { + if (rd == null || rd.isEmpty()) { + logger.error("Prefix {} not associated with vpn", prefix); + return; + } VrfEntry vrfEntry = new VrfEntryBuilder().setDestPrefix(prefix). setNextHopAddress(nexthop).setLabel((long)label).build(); - logger.debug("Created vrfEntry for {} nexthop {} label {}", prefix, nexthop, label); - - List vrfEntryList = new ArrayList(); - vrfEntryList.add(vrfEntry); - - InstanceIdentifierBuilder idBuilder = - InstanceIdentifier.builder(FibEntries.class).child(VrfTables.class, new VrfTablesKey(rd)); - InstanceIdentifier vrfTableId = idBuilder.build(); - VrfTables vrfTableNew = new VrfTablesBuilder().setRouteDistinguisher(rd). - setVrfEntry(vrfEntryList).build(); + logger.debug("Created vrfEntry for {} nexthop {} label {}", prefix, nexthop, label); - write(LogicalDatastoreType.CONFIGURATION, vrfTableId, vrfTableNew); + InstanceIdentifier.InstanceIdentifierBuilder idBuilder = + InstanceIdentifier.builder(FibEntries.class) + .child(VrfTables.class, new VrfTablesKey(rd)) + .child(VrfEntry.class, new VrfEntryKey(vrfEntry.getDestPrefix())); + InstanceIdentifier vrfEntryId= idBuilder.build(); + BgpUtil.write(broker, LogicalDatastoreType.CONFIGURATION, + vrfEntryId, vrfEntry); } public synchronized void removeFibEntryFromDS(String rd, String prefix) { + if (rd == null || rd.isEmpty()) { + logger.error("Prefix {} not associated with vpn", prefix); + return; + } logger.debug("Removing fib entry with destination prefix {} from vrf table for rd {}", prefix, rd); InstanceIdentifierBuilder idBuilder = InstanceIdentifier.builder(FibEntries.class).child(VrfTables.class, new VrfTablesKey(rd)).child(VrfEntry.class, new VrfEntryKey(prefix)); InstanceIdentifier vrfEntryId = idBuilder.build(); - delete(LogicalDatastoreType.CONFIGURATION, vrfEntryId); + BgpUtil.delete(broker, LogicalDatastoreType.CONFIGURATION, vrfEntryId); } - private Optional read(LogicalDatastoreType datastoreType, - InstanceIdentifier path) { + public synchronized void removeVrfFromDS(String rd) { + logger.debug("Removing vrf table for rd {}", rd); - ReadOnlyTransaction tx = broker.newReadOnlyTransaction(); + InstanceIdentifierBuilder idBuilder = + InstanceIdentifier.builder(FibEntries.class).child(VrfTables.class, new VrfTablesKey(rd)); + InstanceIdentifier vrfTableId = idBuilder.build(); - Optional result = Optional.absent(); - try { - result = tx.read(datastoreType, path).get(); - } catch (Exception e) { - throw new RuntimeException(e); - } + BgpUtil.delete(broker, LogicalDatastoreType.CONFIGURATION, vrfTableId); - return result; } - private void write(LogicalDatastoreType datastoreType, - InstanceIdentifier path, T data) { - WriteTransaction tx = broker.newWriteOnlyTransaction(); - tx.merge(datastoreType, path, data, true); - tx.submit(); - } - private void delete(LogicalDatastoreType datastoreType, InstanceIdentifier path) { - WriteTransaction tx = broker.newWriteOnlyTransaction(); - tx.delete(datastoreType, path); - tx.submit(); - } + }