a37e11f637
keystoneauth was split out last cycle as a library specifically to deal with doing auth functions so that people who do not need to do keystone CRUD operations can just consume only the auth session parts. As part of modernizing keystone interactions, use keystoneauth instead of keystoneclient. Depends-On: I1f754a9a949ef92f4e427a91bbd1b1e73e86c8c4 Change-Id: Ia6fb7d8bb07d3101cf1b1afc318f3dcac0a37afc
287 lines
8.9 KiB
Python
287 lines
8.9 KiB
Python
# 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.
|
|
|
|
import copy
|
|
import itertools
|
|
import operator
|
|
|
|
from keystoneauth1 import loading as ks_loading
|
|
from oslo_config import cfg
|
|
|
|
import neutron.agent.common.config
|
|
import neutron.agent.common.ovs_lib
|
|
import neutron.agent.dhcp.config
|
|
import neutron.agent.l2.extensions.manager
|
|
import neutron.agent.l3.config
|
|
import neutron.agent.l3.ha
|
|
import neutron.agent.linux.interface
|
|
import neutron.agent.metadata.config
|
|
import neutron.agent.ovsdb.api
|
|
import neutron.agent.securitygroups_rpc
|
|
import neutron.db.agents_db
|
|
import neutron.db.agentschedulers_db
|
|
import neutron.db.dvr_mac_db
|
|
import neutron.db.extraroute_db
|
|
import neutron.db.l3_agentschedulers_db
|
|
import neutron.db.l3_dvr_db
|
|
import neutron.db.l3_gwmode_db
|
|
import neutron.db.l3_hamode_db
|
|
import neutron.db.migration.cli
|
|
import neutron.extensions.allowedaddresspairs
|
|
import neutron.extensions.l3
|
|
import neutron.extensions.securitygroup
|
|
import neutron.openstack.common.cache.cache
|
|
import neutron.plugins.ml2.config
|
|
import neutron.plugins.ml2.drivers.linuxbridge.agent.common.config
|
|
import neutron.plugins.ml2.drivers.mech_sriov.agent.common.config
|
|
import neutron.plugins.ml2.drivers.mech_sriov.mech_driver.mech_driver
|
|
import neutron.plugins.ml2.drivers.openvswitch.agent.common.config
|
|
import neutron.plugins.ml2.drivers.type_flat
|
|
import neutron.plugins.ml2.drivers.type_geneve
|
|
import neutron.plugins.ml2.drivers.type_gre
|
|
import neutron.plugins.ml2.drivers.type_vlan
|
|
import neutron.plugins.ml2.drivers.type_vxlan
|
|
import neutron.quota
|
|
import neutron.service
|
|
import neutron.services.metering.agents.metering_agent
|
|
import neutron.services.qos.notification_drivers.manager
|
|
import neutron.wsgi
|
|
|
|
|
|
NOVA_GROUP = 'nova'
|
|
|
|
CONF = cfg.CONF
|
|
|
|
deprecations = {'nova.cafile': [cfg.DeprecatedOpt('ca_certificates_file',
|
|
group=NOVA_GROUP)],
|
|
'nova.insecure': [cfg.DeprecatedOpt('api_insecure',
|
|
group=NOVA_GROUP)],
|
|
'nova.timeout': [cfg.DeprecatedOpt('url_timeout',
|
|
group=NOVA_GROUP)]}
|
|
|
|
_nova_options = ks_loading.register_session_conf_options(
|
|
CONF, NOVA_GROUP, deprecated_opts=deprecations)
|
|
|
|
|
|
def list_agent_opts():
|
|
return [
|
|
('agent',
|
|
itertools.chain(
|
|
neutron.agent.common.config.ROOT_HELPER_OPTS,
|
|
neutron.agent.common.config.AGENT_STATE_OPTS,
|
|
neutron.agent.common.config.IPTABLES_OPTS,
|
|
neutron.agent.common.config.PROCESS_MONITOR_OPTS,
|
|
neutron.agent.common.config.AVAILABILITY_ZONE_OPTS)
|
|
),
|
|
('DEFAULT',
|
|
itertools.chain(
|
|
neutron.agent.common.config.INTERFACE_DRIVER_OPTS,
|
|
neutron.agent.metadata.config.SHARED_OPTS,
|
|
neutron.agent.metadata.config.DRIVER_OPTS)
|
|
)
|
|
]
|
|
|
|
|
|
def list_extension_opts():
|
|
return [
|
|
('DEFAULT',
|
|
neutron.extensions.allowedaddresspairs.allowed_address_pair_opts),
|
|
('quotas',
|
|
itertools.chain(
|
|
neutron.extensions.l3.l3_quota_opts,
|
|
neutron.extensions.securitygroup.security_group_quota_opts)
|
|
)
|
|
]
|
|
|
|
|
|
def list_db_opts():
|
|
return [
|
|
('DEFAULT',
|
|
itertools.chain(
|
|
neutron.db.agents_db.AGENT_OPTS,
|
|
neutron.db.extraroute_db.extra_route_opts,
|
|
neutron.db.l3_gwmode_db.OPTS,
|
|
neutron.db.agentschedulers_db.AGENTS_SCHEDULER_OPTS,
|
|
neutron.db.dvr_mac_db.dvr_mac_address_opts,
|
|
neutron.db.l3_dvr_db.router_distributed_opts,
|
|
neutron.db.l3_agentschedulers_db.L3_AGENTS_SCHEDULER_OPTS,
|
|
neutron.db.l3_hamode_db.L3_HA_OPTS)
|
|
),
|
|
('database',
|
|
neutron.db.migration.cli.get_engine_config())
|
|
]
|
|
|
|
|
|
def list_opts():
|
|
return [
|
|
('DEFAULT',
|
|
itertools.chain(
|
|
neutron.common.config.core_cli_opts,
|
|
neutron.common.config.core_opts,
|
|
neutron.wsgi.socket_opts,
|
|
neutron.service.service_opts)
|
|
),
|
|
(neutron.common.config.NOVA_CONF_SECTION,
|
|
itertools.chain(
|
|
neutron.common.config.nova_opts)
|
|
),
|
|
('quotas', neutron.quota.quota_opts)
|
|
]
|
|
|
|
|
|
def list_qos_opts():
|
|
return [
|
|
('DEFAULT',
|
|
neutron.services.qos.notification_drivers.manager.QOS_PLUGIN_OPTS)
|
|
]
|
|
|
|
|
|
def list_base_agent_opts():
|
|
return [
|
|
('DEFAULT',
|
|
itertools.chain(
|
|
neutron.agent.linux.interface.OPTS,
|
|
neutron.agent.common.config.INTERFACE_DRIVER_OPTS,
|
|
neutron.agent.common.ovs_lib.OPTS)
|
|
),
|
|
('AGENT', neutron.agent.common.config.AGENT_STATE_OPTS)
|
|
]
|
|
|
|
|
|
def list_dhcp_agent_opts():
|
|
return [
|
|
('DEFAULT',
|
|
itertools.chain(
|
|
neutron.agent.dhcp.config.DHCP_AGENT_OPTS,
|
|
neutron.agent.dhcp.config.DHCP_OPTS,
|
|
neutron.agent.dhcp.config.DNSMASQ_OPTS)
|
|
)
|
|
]
|
|
|
|
|
|
def list_linux_bridge_opts():
|
|
return [
|
|
('linux_bridge',
|
|
neutron.plugins.ml2.drivers.linuxbridge.agent.common.config.
|
|
bridge_opts),
|
|
('vxlan',
|
|
neutron.plugins.ml2.drivers.linuxbridge.agent.common.config.
|
|
vxlan_opts),
|
|
('agent',
|
|
neutron.plugins.ml2.drivers.linuxbridge.agent.common.config.
|
|
agent_opts),
|
|
('securitygroup',
|
|
neutron.agent.securitygroups_rpc.security_group_opts)
|
|
]
|
|
|
|
|
|
def list_l3_agent_opts():
|
|
return [
|
|
('DEFAULT',
|
|
itertools.chain(
|
|
neutron.agent.l3.config.OPTS,
|
|
neutron.service.service_opts,
|
|
neutron.agent.l3.ha.OPTS)
|
|
)
|
|
]
|
|
|
|
|
|
def list_metadata_agent_opts():
|
|
return [
|
|
('DEFAULT',
|
|
itertools.chain(
|
|
neutron.agent.metadata.config.SHARED_OPTS,
|
|
neutron.agent.metadata.config.METADATA_PROXY_HANDLER_OPTS,
|
|
neutron.agent.metadata.config.UNIX_DOMAIN_METADATA_PROXY_OPTS,
|
|
neutron.openstack.common.cache.cache._get_oslo_configs())
|
|
),
|
|
('AGENT', neutron.agent.common.config.AGENT_STATE_OPTS)
|
|
]
|
|
|
|
|
|
def list_metering_agent_opts():
|
|
return [
|
|
('DEFAULT',
|
|
itertools.chain(
|
|
neutron.services.metering.agents.metering_agent.MeteringAgent.
|
|
Opts,
|
|
neutron.agent.common.config.INTERFACE_DRIVER_OPTS)
|
|
)
|
|
]
|
|
|
|
|
|
def list_ml2_conf_opts():
|
|
return [
|
|
('ml2',
|
|
neutron.plugins.ml2.config.ml2_opts),
|
|
('ml2_type_flat',
|
|
neutron.plugins.ml2.drivers.type_flat.flat_opts),
|
|
('ml2_type_vlan',
|
|
neutron.plugins.ml2.drivers.type_vlan.vlan_opts),
|
|
('ml2_type_gre',
|
|
neutron.plugins.ml2.drivers.type_gre.gre_opts),
|
|
('ml2_type_vxlan',
|
|
neutron.plugins.ml2.drivers.type_vxlan.vxlan_opts),
|
|
('ml2_type_geneve',
|
|
neutron.plugins.ml2.drivers.type_geneve.geneve_opts),
|
|
('securitygroup',
|
|
neutron.agent.securitygroups_rpc.security_group_opts)
|
|
]
|
|
|
|
|
|
def list_ml2_conf_sriov_opts():
|
|
return [
|
|
('ml2_sriov',
|
|
neutron.plugins.ml2.drivers.mech_sriov.mech_driver.mech_driver.
|
|
sriov_opts)
|
|
]
|
|
|
|
|
|
def list_ovs_opts():
|
|
return [
|
|
('ovs',
|
|
itertools.chain(
|
|
neutron.plugins.ml2.drivers.openvswitch.agent.common.config.
|
|
ovs_opts,
|
|
neutron.agent.ovsdb.api.OPTS)
|
|
),
|
|
('agent',
|
|
neutron.plugins.ml2.drivers.openvswitch.agent.common.config.
|
|
agent_opts),
|
|
('securitygroup',
|
|
neutron.agent.securitygroups_rpc.security_group_opts)
|
|
]
|
|
|
|
|
|
def list_sriov_agent_opts():
|
|
return [
|
|
('ml2_sriov',
|
|
neutron.plugins.ml2.drivers.mech_sriov.agent.common.config.
|
|
sriov_nic_opts),
|
|
('agent',
|
|
neutron.agent.l2.extensions.manager.L2_AGENT_EXT_MANAGER_OPTS)
|
|
]
|
|
|
|
|
|
def list_auth_opts():
|
|
opt_list = copy.deepcopy(_nova_options)
|
|
opt_list.insert(0, ks_loading.get_auth_common_conf_options()[0])
|
|
# NOTE(mhickey): There are a lot of auth plugins, we just generate
|
|
# the config options for a few common ones
|
|
plugins = ['password', 'v2password', 'v3password']
|
|
for name in plugins:
|
|
for plugin_option in ks_loading.get_plugin_loader(name).get_options():
|
|
if all(option.name != plugin_option.name for option in opt_list):
|
|
opt_list.append(plugin_option)
|
|
opt_list.sort(key=operator.attrgetter('name'))
|
|
return [(NOVA_GROUP, opt_list)]
|