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.slf4j.Logger;
25 import org.slf4j.LoggerFactory;
27 public class NeutronFirewallRuleInterface extends AbstractNeutronInterface implements INeutronFirewallRuleCRUD {
28 private static final Logger LOGGER = LoggerFactory.getLogger(NeutronFirewallRuleInterface.class);
30 private ConcurrentMap<String, NeutronFirewallRule> firewallRuleDB = new ConcurrentHashMap<String, NeutronFirewallRule>();
33 NeutronFirewallRuleInterface(ProviderContext providerContext) {
34 super(providerContext);
38 public boolean neutronFirewallRuleExists(String uuid) {
39 return firewallRuleDB.containsKey(uuid);
43 public NeutronFirewallRule getNeutronFirewallRule(String uuid) {
44 if (!neutronFirewallRuleExists(uuid)) {
45 LOGGER.debug("No Firewall Rule Have Been Defined");
48 return firewallRuleDB.get(uuid);
52 public List<NeutronFirewallRule> getAllNeutronFirewallRules() {
53 Set<NeutronFirewallRule> allFirewallRules = new HashSet<NeutronFirewallRule>();
54 for (Entry<String, NeutronFirewallRule> entry : firewallRuleDB.entrySet()) {
55 NeutronFirewallRule firewallRule = entry.getValue();
56 allFirewallRules.add(firewallRule);
58 LOGGER.debug("Exiting getFirewallRules, Found {} OpenStackFirewallRule", allFirewallRules.size());
59 List<NeutronFirewallRule> ans = new ArrayList<NeutronFirewallRule>();
60 ans.addAll(allFirewallRules);
65 public boolean addNeutronFirewallRule(NeutronFirewallRule input) {
66 if (neutronFirewallRuleExists(input.getFirewallRuleUUID())) {
69 firewallRuleDB.putIfAbsent(input.getFirewallRuleUUID(), input);
74 public boolean removeNeutronFirewallRule(String uuid) {
75 if (!neutronFirewallRuleExists(uuid)) {
78 firewallRuleDB.remove(uuid);
83 public boolean updateNeutronFirewallRule(String uuid, NeutronFirewallRule delta) {
84 if (!neutronFirewallRuleExists(uuid)) {
87 NeutronFirewallRule target = firewallRuleDB.get(uuid);
88 return overwrite(target, delta);
92 public boolean neutronFirewallRuleInUse(String firewallRuleUUID) {
93 return !neutronFirewallRuleExists(firewallRuleUUID);
97 protected InstanceIdentifier createInstanceIdentifier(DataObject item) {
98 // TODO Auto-generated method stub
103 protected DataObject toMd(Object neutronObject) {
104 // TODO Auto-generated method stub
109 protected DataObject toMd(String uuid) {
110 // TODO Auto-generated method stub