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
10 package org.opendaylight.controller.networkconfig.neutron;
13 * This interface defines the methods required to be aware of Neutron Security Rules
16 public interface INeutronSecurityRuleAware {
19 * Services provide this interface method to indicate if the specified security rule can be created
21 * @param securityRule instance of proposed new Neutron Security Rule object
23 * the return value is understood to be a HTTP status code. A return value outside of 200 through 299
24 * results in the create operation being interrupted and the returned status value reflected in the
27 public int canCreateNeutronSecurityRule(NeutronSecurityRule securityRule);
30 * Services provide this interface method for taking action after a security rule has been created
32 * @param securityRule instance of new Neutron Security Rule object
35 public void neutronSecurityRuleCreated(NeutronSecurityRule securityRule);
38 * Services provide this interface method to indicate if the specified security rule can be changed using the specified
41 * @param delta updates to the security rule object using patch semantics
42 * @param original instance of the Neutron Security Rule object to be updated
44 * the return value is understood to be a HTTP status code. A return value outside of 200 through 299
45 * results in the update operation being interrupted and the returned status value reflected in the
48 public int canUpdateNeutronSecurityRule(NeutronSecurityRule delta, NeutronSecurityRule original);
51 * Services provide this interface method for taking action after a security rule has been updated
53 * @param securityRule instance of modified Neutron Security Rule object
56 public void neutronSecurityRuleUpdated(NeutronSecurityRule securityRule);
59 * Services provide this interface method to indicate if the specified security rule can be deleted
61 * @param securityRule instance of the Neutron Security Rule object to be deleted
63 * the return value is understood to be a HTTP status code. A return value outside of 200 through 299
64 * results in the delete operation being interrupted and the returned status value reflected in the
67 public int canDeleteNeutronSecurityRule(NeutronSecurityRule securityRule);
70 * Services provide this interface method for taking action after a security rule has been deleted
72 * @param securityRule instance of deleted Neutron Security Rule object
75 public void neutronSecurityRuleDeleted(NeutronSecurityRule securityRule);