Blueprint l3-ext-gw-modes This patch introduces an API extension for enabling or disabling source/destination NAT on the router gateway interface, and implements support for this extension in the l3 agent, which has also been refactored in order to ensure SNAT rules are applied (or removed) in a single place in the process_router routine. The patch therefore enables the extension on all plugins which leverage this agent. In this patch the validate_boolean function is re-introduced, as it used for validating a field of the external_gateway_info dict. The resource extension process is also slightly changed so that an API extension can specify which extension should be processed before its attributes can be processed. This is needed to ensure the proper validator for external_gateway_info is installed. Change-Id: Ia80cb56135229366b1706dd3c6d366e40cde1500
70 lines
2.4 KiB
Python
70 lines
2.4 KiB
Python
# vim: tabstop=4 shiftwidth=4 softtabstop=4
|
|
#
|
|
# Copyright 2012, Nachi Ueno, NTT MCL, Inc.
|
|
#
|
|
# Licensed under the Apache License, Version 2.0 (the "License"); you may
|
|
# not use this file except in compliance with the License. You may obtain
|
|
# a copy of the License at
|
|
#
|
|
# http://www.apache.org/licenses/LICENSE-2.0
|
|
#
|
|
# Unless required by applicable law or agreed to in writing, software
|
|
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
|
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
|
# License for the specific language governing permissions and limitations
|
|
# under the License.
|
|
|
|
from quantum.db import db_base_plugin_v2
|
|
from quantum.db import l3_gwmode_db
|
|
|
|
|
|
class Fake1(db_base_plugin_v2.QuantumDbPluginV2,
|
|
l3_gwmode_db.L3_NAT_db_mixin):
|
|
supported_extension_aliases = ['router']
|
|
|
|
def fake_func(self):
|
|
return 'fake1'
|
|
|
|
def create_network(self, context, network):
|
|
session = context.session
|
|
with session.begin(subtransactions=True):
|
|
net = super(Fake1, self).create_network(context, network)
|
|
self._process_l3_create(context, network['network'], net['id'])
|
|
self._extend_network_dict_l3(context, net)
|
|
return net
|
|
|
|
def update_network(self, context, id, network):
|
|
session = context.session
|
|
with session.begin(subtransactions=True):
|
|
net = super(Fake1, self).update_network(context, id,
|
|
network)
|
|
self._process_l3_update(context, network['network'], id)
|
|
self._extend_network_dict_l3(context, net)
|
|
return net
|
|
|
|
def delete_network(self, context, id):
|
|
return super(Fake1, self).delete_network(context, id)
|
|
|
|
def create_port(self, context, port):
|
|
port = super(Fake1, self).create_port(context, port)
|
|
return port
|
|
|
|
def create_subnet(self, context, subnet):
|
|
subnet = super(Fake1, self).create_subnet(context, subnet)
|
|
return subnet
|
|
|
|
def update_port(self, context, id, port):
|
|
port = super(Fake1, self).update_port(context, id, port)
|
|
return port
|
|
|
|
def delete_port(self, context, id, l3_port_check=True):
|
|
return super(Fake1, self).delete_port(context, id)
|
|
|
|
|
|
class Fake2(Fake1):
|
|
def fake_func(self):
|
|
return 'fake2'
|
|
|
|
def fake_func2(self):
|
|
return 'fake2'
|