keystone/keystone/conf/oauth2.py

53 lines
1.7 KiB
Python

# Copyright 2022 OpenStack Foundation
#
# 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 oslo_config import cfg
from keystone.conf import utils
oauth2_authn_methods = cfg.ListOpt(
'oauth2_authn_methods',
default=['tls_client_auth', 'client_secret_basic'],
help=utils.fmt("""
The OAuth2.0 authentication method supported by the system when user obtains
an access token through the OAuth2.0 token endpoint. This option can be set to
certificate or secret. If the option is not set, the default value is
certificate. When the option is set to secret, the OAuth2.0 token endpoint
uses client_secret_basic method for authentication, otherwise tls_client_auth
method is used for authentication.
"""))
oauth2_cert_dn_mapping_id = cfg.StrOpt(
'oauth2_cert_dn_mapping_id',
default='oauth2_mapping',
help=utils.fmt("""
Used to define the mapping rule id. When not set, the mapping rule id is
oauth2_mapping.
"""))
GROUP_NAME = __name__.split('.')[-1]
ALL_OPTS = [
oauth2_authn_methods,
oauth2_cert_dn_mapping_id
]
def register_opts(conf):
conf.register_opts(ALL_OPTS, group=GROUP_NAME)
def list_opts():
return {GROUP_NAME: ALL_OPTS}