2 * Copyright IBM Corporation, 2013. All rights reserved.
\r
4 * This program and the accompanying materials are made available under the
\r
5 * terms of the Eclipse Public License v1.0 which accompanies this distribution,
\r
6 * and is available at http://www.eclipse.org/legal/epl-v10.html
\r
9 package org.opendaylight.controller.networkconfig.neutron;
\r
12 * This interface defines the methods a service that wishes to be aware of Neutron Routers needs to implement
\r
16 public interface INeutronRouterAware {
\r
19 * Services provide this interface method to indicate if the specified router can be created
\r
22 * instance of proposed new Neutron Router object
\r
24 * the return value is understood to be a HTTP status code. A return value outside of 200 through 299
\r
25 * results in the create operation being interrupted and the returned status value reflected in the
\r
28 public int canCreateRouter(NeutronRouter router);
\r
31 * Services provide this interface method for taking action after a router has been created
\r
34 * instance of new Neutron Router object
\r
37 public void neutronRouterCreated(NeutronRouter router);
\r
40 * Services provide this interface method to indicate if the specified router can be changed using the specified
\r
44 * updates to the router object using patch semantics
\r
46 * instance of the Neutron Router object to be updated
\r
48 * the return value is understood to be a HTTP status code. A return value outside of 200 through 299
\r
49 * results in the update operation being interrupted and the returned status value reflected in the
\r
52 public int canUpdateRouter(NeutronRouter delta, NeutronRouter original);
\r
55 * Services provide this interface method for taking action after a router has been updated
\r
58 * instance of modified Neutron Router object
\r
61 public void neutronRouterUpdated(NeutronRouter router);
\r
64 * Services provide this interface method to indicate if the specified router can be deleted
\r
67 * instance of the Neutron Router object to be deleted
\r
69 * the return value is understood to be a HTTP status code. A return value outside of 200 through 299
\r
70 * results in the delete operation being interrupted and the returned status value reflected in the
\r
73 public int canDeleteRouter(NeutronRouter router);
\r
76 * Services provide this interface method for taking action after a router has been deleted
\r
79 * instance of deleted Router Network object
\r
82 public void neutronRouterDeleted(NeutronRouter router);
\r
85 * Services provide this interface method for taking action after an interface has been added to a router
\r
88 * instance of the base Neutron Router object
\r
89 * @param routerInterface
\r
90 * instance of the NeutronRouter_Interface being attached to the router
\r
93 public void neutronRouterInterfaceAttached(NeutronRouter router, NeutronRouter_Interface routerInterface);
\r
96 * Services provide this interface method for taking action after an interface has been removed from a router
\r
99 * instance of the base Neutron Router object
\r
100 * @param routerInterface
\r
101 * instance of the NeutronRouter_Interface being detached from the router
\r
104 public void neutronRouterInterfaceDetached(NeutronRouter router, NeutronRouter_Interface routerInterface);
\r