2 * Copyright (c) 2013, 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 Neutron Ports needs to implement
16 public interface INeutronPortAware {
19 * Services provide this interface method to indicate if the specified port can be created
22 * instance of proposed new Neutron Port 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 canCreatePort(NeutronPort port);
31 * Services provide this interface method for taking action after a port has been created
34 * instance of new Neutron Port object
36 void neutronPortCreated(NeutronPort port);
39 * Services provide this interface method to indicate if the specified port can be changed using the specified
43 * updates to the port object using patch semantics
45 * instance of the Neutron Port object to be updated
47 * the return value is understood to be a HTTP status code. A return value outside of 200 through 299
48 * results in the update operation being interrupted and the returned status value reflected in the
51 int canUpdatePort(NeutronPort delta, NeutronPort original);
54 * Services provide this interface method for taking action after a port has been updated
57 * instance of modified Neutron Port object
59 void neutronPortUpdated(NeutronPort port);
62 * Services provide this interface method to indicate if the specified port can be deleted
65 * instance of the Neutron Port object to be deleted
67 * the return value is understood to be a HTTP status code. A return value outside of 200 through 299
68 * results in the delete operation being interrupted and the returned status value reflected in the
71 int canDeletePort(NeutronPort port);
74 * Services provide this interface method for taking action after a port has been deleted
77 * instance of deleted Port Network object
79 void neutronPortDeleted(NeutronPort port);