L2gateway: Added yang, APIs,Transcriber for L2gateway.
[neutron.git] / neutron-spi / src / main / java / org / opendaylight / neutron / spi / INeutronNetworkCRUD.java
1 /*
2  * Copyright (c) 2013, 2015 IBM Corporation and others.  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 network objects
15  *
16  */
17
18 public interface INeutronNetworkCRUD
19     extends INeutronCRUD<NeutronNetwork> {
20     /**
21      * Applications call this interface method to determine if a particular
22      * Network object exists
23      *
24      * @param uuid
25      *            UUID of the Network object
26      * @return boolean
27      */
28
29     boolean networkExists(String uuid);
30
31     /**
32      * Applications call this interface method to return if a particular
33      * Network object exists
34      *
35      * @param uuid
36      *            UUID of the Network object
37      * @return {@link org.opendaylight.neutron.spi.NeutronNetwork}
38      *          OpenStack Network class
39      */
40
41     NeutronNetwork getNetwork(String uuid);
42
43     /**
44      * Applications call this interface method to return all Network objects
45      *
46      * @return List of OpenStackNetworks objects
47      */
48
49     List<NeutronNetwork> getAllNetworks();
50
51     /**
52      * Applications call this interface method to add a Network 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 addNetwork(NeutronNetwork input);
61
62     /**
63      * Applications call this interface method to remove a Network object to the
64      * concurrent map
65      *
66      * @param uuid
67      *            identifier for the network object
68      * @return boolean on whether the object was removed or not
69      */
70
71     boolean removeNetwork(String uuid);
72
73     /**
74      * Applications call this interface method to edit a Network object
75      *
76      * @param uuid
77      *            identifier of the network object
78      * @param delta
79      *            OpenStackNetwork object containing changes to apply
80      * @return boolean on whether the object was updated or not
81      */
82
83     boolean updateNetwork(String uuid, NeutronNetwork delta);
84
85     /**
86      * Applications call this interface method to determine if a Network object
87      * is use
88      *
89      * @param netUUID
90      *            identifier of the network object
91      *
92      * @return boolean on whether the network is in use or not
93      */
94
95     boolean networkInUse(String netUUID);
96 }