Remove GENIUS UTIL references in Elanmanager Module
[netvirt.git] / elanmanager / impl / src / main / java / org / opendaylight / netvirt / elan / utils / ElanForwardingEntriesHandler.java
index 05ee64fb3d5bb746b3d8b6ca957bb490b3a021b4..f28be73986546344b75c740f66cbc06bcf59167d 100644 (file)
@@ -7,20 +7,23 @@
  */
 package org.opendaylight.netvirt.elan.utils;
 
-import com.google.common.base.Optional;
+import static org.opendaylight.mdsal.binding.util.Datastore.CONFIGURATION;
+import static org.opendaylight.mdsal.binding.util.Datastore.OPERATIONAL;
+
 import com.google.common.util.concurrent.ListenableFuture;
 import java.util.ArrayList;
 import java.util.List;
+import java.util.Optional;
+import java.util.concurrent.ExecutionException;
 import javax.inject.Inject;
 import javax.inject.Singleton;
-import org.opendaylight.controller.md.sal.binding.api.DataBroker;
-import org.opendaylight.controller.md.sal.binding.api.WriteTransaction;
-import org.opendaylight.controller.md.sal.common.api.data.LogicalDatastoreType;
-import org.opendaylight.genius.infra.ManagedNewTransactionRunner;
-import org.opendaylight.genius.infra.ManagedNewTransactionRunnerImpl;
 import org.opendaylight.genius.interfacemanager.globals.InterfaceInfo;
-import org.opendaylight.infrautils.utils.concurrent.ListenableFutures;
-import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.yang.types.rev130715.PhysAddress;
+import org.opendaylight.infrautils.utils.concurrent.LoggingFutures;
+import org.opendaylight.mdsal.binding.api.DataBroker;
+import org.opendaylight.mdsal.binding.util.Datastore.Operational;
+import org.opendaylight.mdsal.binding.util.ManagedNewTransactionRunner;
+import org.opendaylight.mdsal.binding.util.ManagedNewTransactionRunnerImpl;
+import org.opendaylight.mdsal.binding.util.TypedReadWriteTransaction;
 import org.opendaylight.yang.gen.v1.urn.opendaylight.netvirt.elan.rev150602.elan.instances.ElanInstance;
 import org.opendaylight.yang.gen.v1.urn.opendaylight.netvirt.elan.rev150602.elan.interfaces.elan._interface.StaticMacEntries;
 import org.opendaylight.yang.gen.v1.urn.opendaylight.netvirt.elan.rev150602.forwarding.entries.MacEntry;
@@ -35,32 +38,29 @@ public class ElanForwardingEntriesHandler {
 
     private static final Logger LOG = LoggerFactory.getLogger(ElanForwardingEntriesHandler.class);
 
-    private final DataBroker broker;
     private final ManagedNewTransactionRunner txRunner;
     private final ElanUtils elanUtils;
 
     @Inject
     public ElanForwardingEntriesHandler(DataBroker dataBroker, ElanUtils elanUtils) {
-        this.broker = dataBroker;
         this.txRunner = new ManagedNewTransactionRunnerImpl(dataBroker);
         this.elanUtils = elanUtils;
     }
 
     public void updateElanInterfaceForwardingTablesList(String elanInstanceName, String interfaceName,
-            String existingInterfaceName, MacEntry mac, WriteTransaction tx) {
+            String existingInterfaceName, MacEntry mac, TypedReadWriteTransaction<Operational> tx)
+            throws ExecutionException, InterruptedException {
         if (existingInterfaceName.equals(interfaceName)) {
-            LOG.error(String.format(
-                    "Static MAC address %s has already been added for the same ElanInstance "
-                            + "%s on the same Logical Interface Port %s."
+            LOG.error("Static MAC address {} has already been added for the same ElanInstance "
+                            + "{} on the same Logical Interface Port {}."
                             + " No operation will be done.",
-                    mac.getMacAddress().toString(), elanInstanceName, interfaceName));
+                    mac.getMacAddress().toString(), elanInstanceName, interfaceName);
         } else {
-            LOG.warn(String.format(
-                    "Static MAC address %s had already been added for ElanInstance %s on Logical Interface Port %s. "
+            LOG.warn("Static MAC address {} had already been added for ElanInstance {} on Logical Interface Port {}. "
                             + "This would be considered as MAC movement scenario and old static mac will be removed "
                             + "and new static MAC will be added"
-                            + "for ElanInstance %s on Logical Interface Port %s",
-                    mac.getMacAddress().toString(), elanInstanceName, interfaceName, elanInstanceName, interfaceName));
+                            + "for ElanInstance {} on Logical Interface Port {}",
+                    mac.getMacAddress().toString(), elanInstanceName, interfaceName, elanInstanceName, interfaceName);
             //Update the  ElanInterface Forwarding Container & ElanForwarding Container
             deleteElanInterfaceForwardingTablesList(existingInterfaceName, mac, tx);
             createElanInterfaceForwardingTablesList(interfaceName, mac, tx);
@@ -70,85 +70,79 @@ public class ElanForwardingEntriesHandler {
     }
 
     public void addElanInterfaceForwardingTableList(String elanInstanceName, String interfaceName,
-                                                    StaticMacEntries staticMacEntries, WriteTransaction tx) {
+            StaticMacEntries staticMacEntries, TypedReadWriteTransaction<Operational> tx)
+            throws ExecutionException, InterruptedException {
         MacEntry macEntry = new MacEntryBuilder().setIsStaticAddress(true)
                 .setMacAddress(staticMacEntries.getMacAddress())
                 .setIpPrefix(staticMacEntries.getIpPrefix())
-                .setInterface(interfaceName).setKey(new MacEntryKey(staticMacEntries.getMacAddress())).build();
+                .setInterface(interfaceName).withKey(new MacEntryKey(staticMacEntries.getMacAddress())).build();
 
         createElanForwardingTablesList(elanInstanceName, macEntry, tx);
         createElanInterfaceForwardingTablesList(interfaceName, macEntry, tx);
     }
 
-    public void deleteElanInterfaceForwardingTablesList(String interfaceName, MacEntry mac, WriteTransaction tx) {
+    public void deleteElanInterfaceForwardingTablesList(String interfaceName, MacEntry mac,
+                                                        TypedReadWriteTransaction<Operational> interfaceTx)
+            throws ExecutionException, InterruptedException {
         InstanceIdentifier<MacEntry> existingMacEntryId = ElanUtils
                 .getInterfaceMacEntriesIdentifierOperationalDataPath(interfaceName, mac.getMacAddress());
         MacEntry existingInterfaceMacEntry = elanUtils
-                .getInterfaceMacEntriesOperationalDataPathFromId(existingMacEntryId);
+                .getInterfaceMacEntriesOperationalDataPathFromId(interfaceTx, existingMacEntryId);
         if (existingInterfaceMacEntry != null) {
-            tx.delete(LogicalDatastoreType.OPERATIONAL, existingMacEntryId);
+            interfaceTx.delete(existingMacEntryId);
         }
     }
 
-    public void createElanInterfaceForwardingTablesList(String interfaceName, MacEntry mac, WriteTransaction tx) {
+    public void createElanInterfaceForwardingTablesList(String interfaceName, MacEntry mac,
+            TypedReadWriteTransaction<Operational> tx) throws ExecutionException, InterruptedException {
         InstanceIdentifier<MacEntry> existingMacEntryId = ElanUtils
                 .getInterfaceMacEntriesIdentifierOperationalDataPath(interfaceName, mac.getMacAddress());
         MacEntry existingInterfaceMacEntry = elanUtils
-                .getInterfaceMacEntriesOperationalDataPathFromId(existingMacEntryId);
+                .getInterfaceMacEntriesOperationalDataPathFromId(tx, existingMacEntryId);
         if (existingInterfaceMacEntry == null) {
             MacEntry macEntry = new MacEntryBuilder().setMacAddress(mac.getMacAddress()).setIpPrefix(mac.getIpPrefix())
                     .setInterface(interfaceName)
-                    .setIsStaticAddress(true).setKey(new MacEntryKey(mac.getMacAddress())).build();
-            tx.put(LogicalDatastoreType.OPERATIONAL, existingMacEntryId, macEntry,
-                    WriteTransaction.CREATE_MISSING_PARENTS);
+                    .setIsStaticAddress(true).withKey(new MacEntryKey(mac.getMacAddress())).build();
+            tx.mergeParentStructurePut(existingMacEntryId, macEntry);
         }
     }
 
     public void updateElanForwardingTablesList(String elanName, String interfaceName, MacEntry mac,
-            WriteTransaction tx) {
+            TypedReadWriteTransaction<Operational> tx) throws ExecutionException, InterruptedException {
         InstanceIdentifier<MacEntry> macEntryId = ElanUtils.getMacEntryOperationalDataPath(elanName,
                 mac.getMacAddress());
-        MacEntry existingMacEntry = elanUtils.getMacEntryFromElanMacId(macEntryId);
+        MacEntry existingMacEntry = elanUtils.getMacEntryFromElanMacId(tx, macEntryId);
         if (existingMacEntry != null && elanUtils.getElanMacTable(elanName) != null) {
             MacEntry newMacEntry = new MacEntryBuilder().setInterface(interfaceName).setIsStaticAddress(true)
                     .setMacAddress(mac.getMacAddress()).setIpPrefix(mac.getIpPrefix())
-                    .setKey(new MacEntryKey(mac.getMacAddress())).build();
-            tx.put(LogicalDatastoreType.OPERATIONAL, macEntryId, newMacEntry);
+                    .withKey(new MacEntryKey(mac.getMacAddress())).build();
+            tx.put(macEntryId, newMacEntry);
         }
     }
 
-    private void createElanForwardingTablesList(String elanName, MacEntry macEntry, WriteTransaction tx) {
+    private void createElanForwardingTablesList(String elanName, MacEntry macEntry,
+            TypedReadWriteTransaction<Operational> tx) throws ExecutionException, InterruptedException {
         InstanceIdentifier<MacEntry> macEntryId = ElanUtils.getMacEntryOperationalDataPath(elanName,
                 macEntry.getMacAddress());
-        Optional<MacEntry> existingMacEntry = ElanUtils.read(broker, LogicalDatastoreType.OPERATIONAL, macEntryId);
+        Optional<MacEntry> existingMacEntry = tx.read(macEntryId).get();
         if (!existingMacEntry.isPresent() && elanUtils.getElanMacTable(elanName) != null) {
-            tx.put(LogicalDatastoreType.OPERATIONAL, macEntryId, macEntry, WriteTransaction.CREATE_MISSING_PARENTS);
+            tx.mergeParentStructurePut(macEntryId, macEntry);
         }
     }
 
     public void deleteElanInterfaceForwardingEntries(ElanInstance elanInfo, InterfaceInfo interfaceInfo,
             MacEntry macEntry) {
-        List<ListenableFuture<Void>> futures = new ArrayList<>();
-        futures.add(txRunner.callWithNewWriteOnlyTransactionAndSubmit(interfaceTx -> {
+        List<ListenableFuture<?>> futures = new ArrayList<>();
+        futures.add(txRunner.callWithNewReadWriteTransactionAndSubmit(OPERATIONAL, interfaceTx -> {
             InstanceIdentifier<MacEntry> macEntryId = ElanUtils
                     .getMacEntryOperationalDataPath(elanInfo.getElanInstanceName(), macEntry.getMacAddress());
-            interfaceTx.delete(LogicalDatastoreType.OPERATIONAL, macEntryId);
+            interfaceTx.delete(macEntryId);
             deleteElanInterfaceForwardingTablesList(interfaceInfo.getInterfaceName(), macEntry, interfaceTx);
-            futures.add(txRunner.callWithNewWriteOnlyTransactionAndSubmit(flowTx -> {
-                elanUtils.deleteMacFlows(elanInfo, interfaceInfo, macEntry, flowTx);
-            }));
+            futures.add(txRunner.callWithNewReadWriteTransactionAndSubmit(CONFIGURATION,
+                flowTx -> elanUtils.deleteMacFlows(elanInfo, interfaceInfo, macEntry, flowTx)));
         }));
-        for (ListenableFuture<Void> future : futures) {
-            ListenableFutures.addErrorLogging(future, LOG, "Error deleting ELAN interface forwarding entries");
+        for (ListenableFuture<?> future : futures) {
+            LoggingFutures.addErrorLogging(future, LOG, "Error deleting ELAN interface forwarding entries");
         }
     }
-
-    public void deleteElanInterfaceMacForwardingEntries(String interfaceName, PhysAddress physAddress,
-            WriteTransaction tx) {
-        InstanceIdentifier<MacEntry> macEntryId = ElanUtils
-                .getInterfaceMacEntriesIdentifierOperationalDataPath(interfaceName, physAddress);
-        tx.delete(LogicalDatastoreType.OPERATIONAL, macEntryId);
-    }
-
-
 }