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.controller.networkconfig.neutron;
12 * This interface defines the methods a service that wishes to be aware of LoadBalancerPool Rules needs to implement
16 public interface INeutronLoadBalancerPoolAware {
19 * Services provide this interface method to indicate if the specified loadBalancerPool can be created
21 * @param loadBalancerPool
22 * instance of proposed new LoadBalancerPool object
24 * the return value is understood to be a HTTP status code. A return value outside of 200 through 299
25 * results in the create operation being interrupted and the returned status value reflected in the
28 public int canCreateNeutronLoadBalancerPool(NeutronLoadBalancerPool loadBalancerPool);
31 * Services provide this interface method for taking action after a loadBalancerPool has been created
33 * @param loadBalancerPool
34 * instance of new LoadBalancerPool object
37 public void neutronLoadBalancerPoolCreated(NeutronLoadBalancerPool loadBalancerPool);
40 * Services provide this interface method to indicate if the specified loadBalancerPool can be changed using the specified
44 * updates to the loadBalancerPool object using patch semantics
46 * instance of the LoadBalancerPool object to be updated
48 * the return value is understood to be a HTTP status code. A return value outside of 200 through 299
49 * results in the update operation being interrupted and the returned status value reflected in the
52 public int canUpdateNeutronLoadBalancerPool(NeutronLoadBalancerPool delta, NeutronLoadBalancerPool original);
55 * Services provide this interface method for taking action after a loadBalancerPool has been updated
57 * @param loadBalancerPool
58 * instance of modified LoadBalancerPool object
61 public void neutronLoadBalancerPoolUpdated(NeutronLoadBalancerPool loadBalancerPool);
64 * Services provide this interface method to indicate if the specified loadBalancerPool can be deleted
66 * @param loadBalancerPool
67 * instance of the LoadBalancerPool object to be deleted
69 * the return value is understood to be a HTTP status code. A return value outside of 200 through 299
70 * results in the delete operation being interrupted and the returned status value reflected in the
73 public int canDeleteNeutronLoadBalancerPool(NeutronLoadBalancerPool loadBalancerPool);
76 * Services provide this interface method for taking action after a loadBalancerPool has been deleted
78 * @param loadBalancerPool
79 * instance of deleted LoadBalancerPool object
82 public void neutronLoadBalancerPoolDeleted(NeutronLoadBalancerPool loadBalancerPool);