2 * Copyright (c) 2015 IBM Corporation and others. All rights reserved.
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.spi;
12 * This interface defines the methods a service that wishes to be aware of NeutronVPNService needs to implement
16 public interface INeutronVPNServiceAware {
19 * Services provide this interface method to indicate if the specified NeutronVPNService can be created
22 * instance of proposed new NeutronVPNService 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 int canCreateNeutronVPNService(NeutronVPNService vpnService);
31 * Services provide this interface method for taking action after a NeutronVPNService has been created
34 * instance of new NeutronVPNService object
36 void neutronVPNServiceCreated(NeutronVPNService vpnService);
39 * Services provide this interface method to indicate if the
40 * specified NeutronVPNService can be changed using the specified
44 * updates to the NeutronVPNService object using patch semantics
46 * instance of the NeutronVPNService 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 int canUpdateNeutronVPNService(NeutronVPNService delta, NeutronVPNService original);
55 * Services provide this interface method for taking action after a NeutronVPNService has been updated
58 * instance of modified NeutronVPNService object
60 void neutronVPNServiceUpdated(NeutronVPNService vpnService);
63 * Services provide this interface method to indicate if the specified NeutronVPNService can be deleted
66 * instance of the NeutronVPNService object to be deleted
68 * the return value is understood to be a HTTP status code. A return value outside of 200 through 299
69 * results in the delete operation being interrupted and the returned status value reflected in the
72 int canDeleteNeutronVPNService(NeutronVPNService vpnService);
75 * Services provide this interface method for taking action after a NeutronVPNService has been deleted
78 * instance of deleted NeutronVPNService object
80 void neutronVPNServiceDeleted(NeutronVPNService vpnService);