0f0499b89e
The ml2 plugin uses mechanism drivers to determine which network segment and what VIF driver to use for a port. Mechanism drivers supporting the openvswitch, linuxbridge, and hyperv agents are added. The binding:host attribute is set on ports belonging to the dhcp and l3 agents so that they can be bound. To use with devstack until it is updated, set "Q_ML2_PLUGIN_MECHANISM_DRIVERS=openvswitch,linuxbridge" in localrc. The hyperv L2 agent does not currently implement the agents_db RPC, and will therefore not work with its ml2 mechanism driver. This issue will be tracked as a bug to be fixed in a separate merge. implements blueprint: ml2-portbinding Change-Id: Icb9c70d8b0d7fcb34b57adc760bb713b740e5dad
119 lines
4.5 KiB
Python
119 lines
4.5 KiB
Python
# Copyright (c) 2013 OpenStack Foundation
|
|
# All Rights Reserved.
|
|
#
|
|
# 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 neutron.openstack.common import log
|
|
from neutron.plugins.ml2 import driver_api as api
|
|
|
|
LOG = log.getLogger(__name__)
|
|
|
|
|
|
class LoggerMechanismDriver(api.MechanismDriver):
|
|
"""Mechanism driver that logs all calls and parameters made.
|
|
|
|
Generally used for testing and debugging.
|
|
"""
|
|
|
|
def initialize(self):
|
|
pass
|
|
|
|
def _log_network_call(self, method_name, context):
|
|
LOG.info(_("%(method)s called with network settings %(current)s "
|
|
"(original settings %(original)s) and "
|
|
"network segments %(segments)s"),
|
|
{'method': method_name,
|
|
'current': context.current,
|
|
'original': context.original,
|
|
'segments': context.network_segments})
|
|
|
|
def create_network_precommit(self, context):
|
|
self._log_network_call("create_network_precommit", context)
|
|
|
|
def create_network_postcommit(self, context):
|
|
self._log_network_call("create_network_postcommit", context)
|
|
|
|
def update_network_precommit(self, context):
|
|
self._log_network_call("update_network_precommit", context)
|
|
|
|
def update_network_postcommit(self, context):
|
|
self._log_network_call("update_network_postcommit", context)
|
|
|
|
def delete_network_precommit(self, context):
|
|
self._log_network_call("delete_network_precommit", context)
|
|
|
|
def delete_network_postcommit(self, context):
|
|
self._log_network_call("delete_network_postcommit", context)
|
|
|
|
def _log_subnet_call(self, method_name, context):
|
|
LOG.info(_("%(method)s called with subnet settings %(current)s "
|
|
"(original settings %(original)s)"),
|
|
{'method': method_name,
|
|
'current': context.current,
|
|
'original': context.original})
|
|
|
|
def create_subnet_precommit(self, context):
|
|
self._log_subnet_call("create_subnet_precommit", context)
|
|
|
|
def create_subnet_postcommit(self, context):
|
|
self._log_subnet_call("create_subnet_postcommit", context)
|
|
|
|
def update_subnet_precommit(self, context):
|
|
self._log_subnet_call("update_subnet_precommit", context)
|
|
|
|
def update_subnet_postcommit(self, context):
|
|
self._log_subnet_call("update_subnet_postcommit", context)
|
|
|
|
def delete_subnet_precommit(self, context):
|
|
self._log_subnet_call("delete_subnet_precommit", context)
|
|
|
|
def delete_subnet_postcommit(self, context):
|
|
self._log_subnet_call("delete_subnet_postcommit", context)
|
|
|
|
def _log_port_call(self, method_name, context):
|
|
network_context = context.network
|
|
LOG.info(_("%(method)s called with port settings %(current)s "
|
|
"(original settings %(original)s) on network %(network)s"),
|
|
{'method': method_name,
|
|
'current': context.current,
|
|
'original': context.original,
|
|
'segment': context.bound_segment,
|
|
'network': network_context.current})
|
|
|
|
def create_port_precommit(self, context):
|
|
self._log_port_call("create_port_precommit", context)
|
|
|
|
def create_port_postcommit(self, context):
|
|
self._log_port_call("create_port_postcommit", context)
|
|
|
|
def update_port_precommit(self, context):
|
|
self._log_port_call("update_port_precommit", context)
|
|
|
|
def update_port_postcommit(self, context):
|
|
self._log_port_call("update_port_postcommit", context)
|
|
|
|
def delete_port_precommit(self, context):
|
|
self._log_port_call("delete_port_precommit", context)
|
|
|
|
def delete_port_postcommit(self, context):
|
|
self._log_port_call("delete_port_postcommit", context)
|
|
|
|
def bind_port(self, context):
|
|
self._log_port_call("bind_port", context)
|
|
|
|
def validate_port_binding(self, context):
|
|
self._log_port_call("validate_port_binding", context)
|
|
|
|
def unbind_port(self, context):
|
|
self._log_port_call("unbind_port", context)
|