/*
- * 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,
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.ietf.params.xml.ns.yang.ietf.yang.types.rev130715.Uuid;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.neutron.fwaas.rev141002.firewalls.attributes.Firewalls;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.neutron.fwaas.rev141002.firewalls.attributes.firewalls.Firewall;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.neutron.fwaas.rev141002.firewalls.attributes.firewalls.FirewallBuilder;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.neutron.rev150325.Neutron;
+
import org.opendaylight.yangtools.yang.binding.InstanceIdentifier;
import org.osgi.framework.BundleContext;
import org.osgi.framework.ServiceRegistration;
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,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
- public List<NeutronFirewall> getAllNeutronFirewalls() {
+ public List<NeutronFirewall> getAll() {
Set<NeutronFirewall> allFirewalls = new HashSet<NeutronFirewall>();
- for (Entry<String, NeutronFirewall> entry : firewallDB.entrySet()) {
- NeutronFirewall firewall = entry.getValue();
- allFirewalls.add(firewall);
+ Firewalls firewalls = readMd(createInstanceIdentifier());
+ if (firewalls != null) {
+ for (Firewall firewall: firewalls.getFirewall()) {
+ allFirewalls.add(fromMd(firewall));
+ }
}
LOGGER.debug("Exiting getFirewalls, Found {} OpenStackFirewall", allFirewalls.size());
List<NeutronFirewall> ans = new ArrayList<NeutronFirewall>();
return ans;
}
+ @Override
+ public List<NeutronFirewall> getAllNeutronFirewalls() {
+ 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());
+ }
+
+ protected InstanceIdentifier<Firewalls> createInstanceIdentifier() {
+ return InstanceIdentifier.create(Neutron.class)
+ .child(Firewalls.class);
+ }
+
+ protected NeutronFirewall fromMd(Firewall firewall) {
+ 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().getValue().replace("-",""));
+ }
+ 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 DataObject toMd(Object neutronObject) {
- // TODO Auto-generated method stub
- return null;
+ protected Firewall toMd(NeutronFirewall firewall) {
+ 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) {
+ FirewallBuilder firewallBuilder = new FirewallBuilder();
+ firewallBuilder.setUuid(toUuid(uuid));
+ return firewallBuilder.build();
}
public static void registerNewInterface(BundleContext context,
ProviderContext providerContext,
- List<ServiceRegistration<?>> registrations) throws Exception {
+ List<ServiceRegistration<?>> registrations) {
NeutronFirewallInterface neutronFirewallInterface = new NeutronFirewallInterface(providerContext);
ServiceRegistration<INeutronFirewallCRUD> neutronFirewallInterfaceRegistration = context.registerService(INeutronFirewallCRUD.class, neutronFirewallInterface, null);
if(neutronFirewallInterfaceRegistration != null) {