2 * Copyright (C) 2014 Red Hat, Inc.
4 * This program and the accompanying materials are made available under the
5 * terms of the Eclipse Public License v1.0 which accompanies this distribution,
6 * and is available at http://www.eclipse.org/legal/epl-v10.html
9 package org.opendaylight.neutron.transcriber;
11 import java.util.ArrayList;
12 import java.util.HashSet;
13 import java.util.List;
14 import java.util.Map.Entry;
16 import java.util.concurrent.ConcurrentHashMap;
17 import java.util.concurrent.ConcurrentMap;
19 import org.opendaylight.controller.sal.binding.api.BindingAwareBroker.ProviderContext;
20 import org.opendaylight.neutron.spi.INeutronFirewallRuleCRUD;
21 import org.opendaylight.neutron.spi.NeutronFirewallRule;
22 import org.opendaylight.yangtools.yang.binding.DataObject;
23 import org.opendaylight.yangtools.yang.binding.InstanceIdentifier;
24 import org.osgi.framework.BundleContext;
25 import org.osgi.framework.ServiceRegistration;
26 import org.slf4j.Logger;
27 import org.slf4j.LoggerFactory;
29 public class NeutronFirewallRuleInterface extends AbstractNeutronInterface implements INeutronFirewallRuleCRUD {
30 private static final Logger LOGGER = LoggerFactory.getLogger(NeutronFirewallRuleInterface.class);
32 private ConcurrentMap<String, NeutronFirewallRule> firewallRuleDB = new ConcurrentHashMap<String, NeutronFirewallRule>();
35 NeutronFirewallRuleInterface(ProviderContext providerContext) {
36 super(providerContext);
40 public boolean neutronFirewallRuleExists(String uuid) {
41 return firewallRuleDB.containsKey(uuid);
45 public NeutronFirewallRule getNeutronFirewallRule(String uuid) {
46 if (!neutronFirewallRuleExists(uuid)) {
47 LOGGER.debug("No Firewall Rule Have Been Defined");
50 return firewallRuleDB.get(uuid);
54 public List<NeutronFirewallRule> getAllNeutronFirewallRules() {
55 Set<NeutronFirewallRule> allFirewallRules = new HashSet<NeutronFirewallRule>();
56 for (Entry<String, NeutronFirewallRule> entry : firewallRuleDB.entrySet()) {
57 NeutronFirewallRule firewallRule = entry.getValue();
58 allFirewallRules.add(firewallRule);
60 LOGGER.debug("Exiting getFirewallRules, Found {} OpenStackFirewallRule", allFirewallRules.size());
61 List<NeutronFirewallRule> ans = new ArrayList<NeutronFirewallRule>();
62 ans.addAll(allFirewallRules);
67 public boolean addNeutronFirewallRule(NeutronFirewallRule input) {
68 if (neutronFirewallRuleExists(input.getFirewallRuleUUID())) {
71 firewallRuleDB.putIfAbsent(input.getFirewallRuleUUID(), input);
76 public boolean removeNeutronFirewallRule(String uuid) {
77 if (!neutronFirewallRuleExists(uuid)) {
80 firewallRuleDB.remove(uuid);
85 public boolean updateNeutronFirewallRule(String uuid, NeutronFirewallRule delta) {
86 if (!neutronFirewallRuleExists(uuid)) {
89 NeutronFirewallRule target = firewallRuleDB.get(uuid);
90 return overwrite(target, delta);
94 public boolean neutronFirewallRuleInUse(String firewallRuleUUID) {
95 return !neutronFirewallRuleExists(firewallRuleUUID);
99 protected InstanceIdentifier createInstanceIdentifier(DataObject item) {
100 // TODO Auto-generated method stub
105 protected DataObject toMd(Object neutronObject) {
106 // TODO Auto-generated method stub
111 protected DataObject toMd(String uuid) {
112 // TODO Auto-generated method stub
116 public static void registerNewInterface(BundleContext context,
117 ProviderContext providerContext,
118 List<ServiceRegistration<?>> registrations) {
119 NeutronFirewallRuleInterface neutronFirewallRuleInterface = new NeutronFirewallRuleInterface(providerContext);
120 ServiceRegistration<INeutronFirewallRuleCRUD> neutronFirewallRuleInterfaceRegistration = context.registerService(INeutronFirewallRuleCRUD.class, neutronFirewallRuleInterface, null);
121 if(neutronFirewallRuleInterfaceRegistration != null) {
122 registrations.add(neutronFirewallRuleInterfaceRegistration);