Merge "Bug 4224 - remote_ip_prefix of metering rule should be type of ip-prefix"
[neutron.git] / neutron-spi / src / main / java / org / opendaylight / neutron / spi / INeutronFirewallRuleCRUD.java
1 /*
2  * Copyright (C) 2014 Red Hat, Inc.  All rights reserved.
3  *
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
7  */
8
9 package org.opendaylight.neutron.spi;
10
11 import java.util.List;
12
13 /**
14  * This interface defines the methods for CRUD of NB OpenStack Firewall Rule objects
15  *
16  */
17
18 public interface INeutronFirewallRuleCRUD
19     extends INeutronCRUD<NeutronFirewallRule> {
20     /**
21      * Applications call this interface method to determine if a particular
22      *FirewallRule object exists
23      *
24      * @param uuid
25      *            UUID of the Firewall Rule object
26      * @return boolean
27      */
28
29     boolean neutronFirewallRuleExists(String uuid);
30
31     /**
32      * Applications call this interface method to return if a particular
33      * FirewallRule object exists
34      *
35      * @param uuid
36      *            UUID of the Firewall Rule object
37      * @return {@link NeutronFirewallRule}
38      *          OpenStackFirewall Rule class
39      */
40
41     NeutronFirewallRule getNeutronFirewallRule(String uuid);
42
43     /**
44      * Applications call this interface method to return all Firewall Rule objects
45      *
46      * @return List of OpenStackNetworks objects
47      */
48
49     List<NeutronFirewallRule> getAllNeutronFirewallRules();
50
51     /**
52      * Applications call this interface method to add a Firewall Rule object to the
53      * concurrent map
54      *
55      * @param input
56      *            OpenStackNetwork object
57      * @return boolean on whether the object was added or not
58      */
59
60     boolean addNeutronFirewallRule(NeutronFirewallRule input);
61
62     /**
63      * Applications call this interface method to remove a Neutron FirewallRule object to the
64      * concurrent map
65      *
66      * @param uuid
67      *            identifier for the Firewall Rule object
68      * @return boolean on whether the object was removed or not
69      */
70
71     boolean removeNeutronFirewallRule(String uuid);
72
73     /**
74      * Applications call this interface method to edit a FirewallRule object
75      *
76      * @param uuid
77      *            identifier of the Firewall Rule object
78      * @param delta
79      *            OpenStackFirewallRule object containing changes to apply
80      * @return boolean on whether the object was updated or not
81      */
82
83     boolean updateNeutronFirewallRule(String uuid, NeutronFirewallRule delta);
84
85     /**
86      * Applications call this interface method to see if a MAC address is in use
87      *
88      * @param uuid
89      *            identifier of the Firewall Rule object
90      * @return boolean on whether the macAddress is already associated with a
91      * port or not
92      */
93
94     boolean neutronFirewallRuleInUse(String uuid);
95
96 }