Bug 3902 : Local variables to be declared final.
[neutron.git] / transcriber / src / main / java / org / opendaylight / neutron / transcriber / NeutronFirewallInterface.java
index ea9d2de395de4c07230a6e0bed9b1f05e9b8fb74..64b651f7a4053dcf7e0812f4d4635356eeb399bc 100644 (file)
@@ -1,5 +1,5 @@
 /*
- * Copyright (C) 2014 Red Hat, Inc.
+ * Copyright (c) 2014, 2015 Red Hat, Inc. 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,
@@ -11,7 +11,12 @@ package org.opendaylight.neutron.transcriber;
 import org.opendaylight.controller.sal.binding.api.BindingAwareBroker.ProviderContext;
 import org.opendaylight.neutron.spi.INeutronFirewallCRUD;
 import org.opendaylight.neutron.spi.NeutronFirewall;
-import org.opendaylight.yangtools.yang.binding.DataObject;
+
+import org.opendaylight.yang.gen.v1.urn.opendaylight.neutron.fwaas.rev150712.firewalls.attributes.Firewalls;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.neutron.fwaas.rev150712.firewalls.attributes.firewalls.Firewall;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.neutron.fwaas.rev150712.firewalls.attributes.firewalls.FirewallBuilder;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.neutron.rev150712.Neutron;
+
 import org.opendaylight.yangtools.yang.binding.InstanceIdentifier;
 import org.osgi.framework.BundleContext;
 import org.osgi.framework.ServiceRegistration;
@@ -19,107 +24,138 @@ import org.osgi.framework.ServiceRegistration;
 import org.slf4j.Logger;
 import org.slf4j.LoggerFactory;
 
-import java.util.ArrayList;
-import java.util.HashSet;
 import java.util.List;
-import java.util.Map.Entry;
-import java.util.Set;
-import java.util.concurrent.ConcurrentHashMap;
-import java.util.concurrent.ConcurrentMap;
 
-public class NeutronFirewallInterface extends AbstractNeutronInterface implements INeutronFirewallCRUD {
+public class NeutronFirewallInterface extends AbstractNeutronInterface<Firewall, Firewalls, NeutronFirewall> implements INeutronFirewallCRUD {
 
     private static final Logger LOGGER = LoggerFactory.getLogger(NeutronFirewallInterface.class);
 
-    private ConcurrentMap<String, NeutronFirewall> firewallDB  = new ConcurrentHashMap<String, NeutronFirewall>();
-
-
     NeutronFirewallInterface(ProviderContext providerContext) {
         super(providerContext);
     }
 
     @Override
     public boolean neutronFirewallExists(String uuid) {
-        return firewallDB.containsKey(uuid);
+        return exists(uuid);
     }
 
     @Override
     public NeutronFirewall getNeutronFirewall(String uuid) {
-        if (!neutronFirewallExists(uuid)) {
-            LOGGER.debug("No Firewall Have Been Defined");
-            return null;
-        }
-        return firewallDB.get(uuid);
+        return get(uuid);
+    }
+
+    @Override
+    protected List<Firewall> getDataObjectList(Firewalls firewalls) {
+        return firewalls.getFirewall();
     }
 
     @Override
     public List<NeutronFirewall> getAllNeutronFirewalls() {
-        Set<NeutronFirewall> allFirewalls = new HashSet<NeutronFirewall>();
-        for (Entry<String, NeutronFirewall> entry : firewallDB.entrySet()) {
-            NeutronFirewall firewall = entry.getValue();
-            allFirewalls.add(firewall);
-        }
-        LOGGER.debug("Exiting getFirewalls, Found {} OpenStackFirewall", allFirewalls.size());
-        List<NeutronFirewall> ans = new ArrayList<NeutronFirewall>();
-        ans.addAll(allFirewalls);
-        return ans;
+        return getAll();
     }
 
     @Override
     public boolean addNeutronFirewall(NeutronFirewall input) {
-        if (neutronFirewallExists(input.getFirewallUUID())) {
-            return false;
-        }
-        firewallDB.putIfAbsent(input.getFirewallUUID(), input);
-        return true;
+        return add(input);
     }
 
     @Override
     public boolean removeNeutronFirewall(String uuid) {
-        if (!neutronFirewallExists(uuid)) {
-            return false;
-        }
-        firewallDB.remove(uuid);
-        return true;
+        return remove(uuid);
     }
 
     @Override
     public boolean updateNeutronFirewall(String uuid, NeutronFirewall delta) {
-        if (!neutronFirewallExists(uuid)) {
-            return false;
-        }
-        NeutronFirewall target = firewallDB.get(uuid);
-        return overwrite(target, delta);
+        return update(uuid, delta);
     }
 
     @Override
     public boolean neutronFirewallInUse(String firewallUUID) {
-        return !neutronFirewallExists(firewallUUID);
+        return !exists(firewallUUID);
     }
 
     @Override
-    protected InstanceIdentifier createInstanceIdentifier(DataObject item) {
-        // TODO Auto-generated method stub
-        return null;
+    protected InstanceIdentifier<Firewall> createInstanceIdentifier(Firewall item) {
+        return InstanceIdentifier.create(Neutron.class)
+                .child(Firewalls.class)
+                .child(Firewall.class, item.getKey());
     }
 
     @Override
-    protected DataObject toMd(Object neutronObject) {
-        // TODO Auto-generated method stub
-        return null;
+    protected InstanceIdentifier<Firewalls> createInstanceIdentifier() {
+        return InstanceIdentifier.create(Neutron.class)
+                .child(Firewalls.class);
+    }
+
+    protected NeutronFirewall fromMd(Firewall firewall) {
+        final NeutronFirewall answer = new NeutronFirewall();
+        if (firewall.getUuid() != null) {
+            answer.setID(firewall.getUuid().getValue());
+        }
+        if (firewall.getName() != null) {
+            answer.setFirewallName(firewall.getName());
+        }
+        if (firewall.getTenantId() != null) {
+            answer.setTenantID(firewall.getTenantId());
+        }
+        answer.setFirewallAdminStateIsUp(firewall.isAdminStateUp());
+        if (firewall.getStatus() != null) {
+            answer.setFirewallStatus(firewall.getStatus());
+        }
+        if (firewall.getDescr() != null) {
+            answer.setFirewallDescription(firewall.getDescr());
+        }
+        if (firewall.isShared() != null) {
+            answer.setFirewallIsShared(firewall.isShared());
+        }
+        if (firewall.getFirewallPolicyId() != null) {
+             answer.setFirewallPolicyID(firewall.getFirewallPolicyId().getValue());
+        }
+        return answer;
+    }
+
+    @Override
+    protected Firewall toMd(NeutronFirewall firewall) {
+        final FirewallBuilder firewallBuilder = new FirewallBuilder();
+        if (firewall.getID() != null) {
+            firewallBuilder.setUuid(toUuid(firewall.getID()));
+        }
+        if (firewall.getFirewallName() != null) {
+            firewallBuilder.setName(firewall.getFirewallName());
+        }
+        if (firewall.getTenantID() != null) {
+            firewallBuilder.setTenantId(toUuid(firewall.getTenantID()));
+        }
+        if (firewall.getFirewallAdminStateIsUp() != null) {
+            firewallBuilder.setAdminStateUp(firewall.getFirewallAdminStateIsUp());
+        }
+        if (firewall.getFirewallStatus() != null) {
+            firewallBuilder.setStatus(firewall.getFirewallStatus());
+        }
+        if (firewall.getFirewallDescription() != null) {
+            firewallBuilder.setDescr(firewall.getFirewallDescription());
+        }
+        if (firewall.getFirewallIsShared() != null) {
+            firewallBuilder.setShared(firewall.getFirewallIsShared());
+        }
+        if (firewall.getFirewallPolicyID() != null) {
+            firewallBuilder.setFirewallPolicyId(toUuid(firewall.getFirewallPolicyID()));
+        }
+        return firewallBuilder.build();
     }
 
     @Override
-    protected DataObject toMd(String uuid) {
-        // TODO Auto-generated method stub
-        return null;
+    protected Firewall toMd(String uuid) {
+        final FirewallBuilder firewallBuilder = new FirewallBuilder();
+        firewallBuilder.setUuid(toUuid(uuid));
+        return firewallBuilder.build();
     }
 
     public static void registerNewInterface(BundleContext context,
                                             ProviderContext providerContext,
                                             List<ServiceRegistration<?>> registrations) {
-        NeutronFirewallInterface neutronFirewallInterface = new NeutronFirewallInterface(providerContext);
-        ServiceRegistration<INeutronFirewallCRUD> neutronFirewallInterfaceRegistration = context.registerService(INeutronFirewallCRUD.class, neutronFirewallInterface, null);
+        final NeutronFirewallInterface neutronFirewallInterface = new NeutronFirewallInterface(providerContext);
+        final ServiceRegistration<INeutronFirewallCRUD> neutronFirewallInterfaceRegistration = context.registerService(INeutronFirewallCRUD.class, neutronFirewallInterface, null);
         if(neutronFirewallInterfaceRegistration != null) {
             registrations.add(neutronFirewallInterfaceRegistration);
         }