| {% from "keystone/map.jinja" import server with context %} |
| [DEFAULT] |
| |
| # |
| # From keystone |
| # |
| |
| # Using this feature is *NOT* recommended. Instead, use the `keystone-manage |
| # bootstrap` command. The value of this option is treated as a "shared secret" |
| # that can be used to bootstrap Keystone through the API. This "token" does not |
| # represent a user (it has no identity), and carries no explicit authorization |
| # (it effectively bypasses most authorization checks). If set to `None`, the |
| # value is ignored and the `admin_token` middleware is effectively disabled. |
| # However, to completely disable `admin_token` in production (highly |
| # recommended, as it presents a security risk), remove |
| # `AdminTokenAuthMiddleware` (the `admin_token_auth` filter) from your paste |
| # application pipelines (for example, in `keystone-paste.ini`). (string value) |
| #admin_token = <None> |
| admin_token={{ server.service_token }} |
| |
| # The base public endpoint URL for Keystone that is advertised to clients |
| # (NOTE: this does NOT affect how Keystone listens for connections). Defaults |
| # to the base host URL of the request. For example, if keystone receives a |
| # request to `http://server:5000/v3/users`, then this will option will be |
| # automatically treated as `http://server:5000`. You should only need to set |
| # option if either the value of the base URL contains a path that keystone does |
| # not automatically infer (`/prefix/v3`), or if the endpoint should be found on |
| # a different host. (string value) |
| #public_endpoint = <None> |
| |
| # The base admin endpoint URL for Keystone that is advertised to clients (NOTE: |
| # this does NOT affect how Keystone listens for connections). Defaults to the |
| # base host URL of the request. For example, if keystone receives a request to |
| # `http://server:35357/v3/users`, then this will option will be automatically |
| # treated as `http://server:35357`. You should only need to set option if |
| # either the value of the base URL contains a path that keystone does not |
| # automatically infer (`/prefix/v3`), or if the endpoint should be found on a |
| # different host. (string value) |
| #admin_endpoint = <None> |
| |
| # Maximum depth of the project hierarchy, excluding the project acting as a |
| # domain at the top of the hierarchy. WARNING: Setting it to a large value may |
| # adversely impact performance. (integer value) |
| #max_project_tree_depth = 5 |
| |
| # Limit the sizes of user & project ID/names. (integer value) |
| #max_param_size = 64 |
| |
| # Similar to `[DEFAULT] max_param_size`, but provides an exception for token |
| # values. With PKI / PKIZ tokens, this needs to be set close to 8192 (any |
| # higher, and other HTTP implementations may break), depending on the size of |
| # your service catalog and other factors. With Fernet tokens, this can be set |
| # as low as 255. With UUID tokens, this should be set to 32). (integer value) |
| #max_token_size = 8192 |
| |
| # Similar to the `[DEFAULT] member_role_name` option, this represents the |
| # default role ID used to associate users with their default projects in the v2 |
| # API. This will be used as the explicit role where one is not specified by the |
| # v2 API. You do not need to set this value unless you want keystone to use an |
| # existing role with a different ID, other than the arbitrarily defined |
| # `_member_` role (in which case, you should set `[DEFAULT] member_role_name` |
| # as well). (string value) |
| #member_role_id = 9fe2ff9ee4384b1894a90878d3e92bab |
| |
| # This is the role name used in combination with the `[DEFAULT] member_role_id` |
| # option; see that option for more detail. You do not need to set this option |
| # unless you want keystone to use an existing role (in which case, you should |
| # set `[DEFAULT] member_role_id` as well). (string value) |
| #member_role_name = _member_ |
| |
| # The value passed as the keyword "rounds" to passlib's encrypt method. This |
| # option represents a trade off between security and performance. Higher values |
| # lead to slower performance, but higher security. Changing this option will |
| # only affect newly created passwords as existing password hashes already have |
| # a fixed number of rounds applied, so it is safe to tune this option in a |
| # running cluster. For more information, see |
| # https://pythonhosted.org/passlib/password_hash_api.html#choosing-the-right- |
| # rounds-value (integer value) |
| # Minimum value: 1000 |
| # Maximum value: 100000 |
| #crypt_strength = 10000 |
| |
| # The maximum number of entities that will be returned in a collection. This |
| # global limit may be then overridden for a specific driver, by specifying a |
| # list_limit in the appropriate section (for example, `[assignment]`). No limit |
| # is set by default. In larger deployments, it is recommended that you set this |
| # to a reasonable number to prevent operations like listing all users and |
| # projects from placing an unnecessary load on the system. (integer value) |
| #list_limit = <None> |
| |
| # DEPRECATED: Set this to false if you want to enable the ability for user, |
| # group and project entities to be moved between domains by updating their |
| # `domain_id` attribute. Allowing such movement is not recommended if the scope |
| # of a domain admin is being restricted by use of an appropriate policy file |
| # (see `etc/policy.v3cloudsample.json` as an example). This feature is |
| # deprecated and will be removed in a future release, in favor of strictly |
| # immutable domain IDs. (boolean value) |
| # This option is deprecated for removal since M. |
| # Its value may be silently ignored in the future. |
| # Reason: The option to set domain_id_immutable to false has been deprecated in |
| # the M release and will be removed in the O release. |
| #domain_id_immutable = true |
| |
| # If set to true, strict password length checking is performed for password |
| # manipulation. If a password exceeds the maximum length, the operation will |
| # fail with an HTTP 403 Forbidden error. If set to false, passwords are |
| # automatically truncated to the maximum length. (boolean value) |
| #strict_password_check = false |
| |
| # DEPRECATED: The HTTP header used to determine the scheme for the original |
| # request, even if it was removed by an SSL terminating proxy. (string value) |
| # This option is deprecated for removal since N. |
| # Its value may be silently ignored in the future. |
| # Reason: This option has been deprecated in the N release and will be removed |
| # in the P release. Use oslo.middleware.http_proxy_to_wsgi configuration |
| # instead. |
| #secure_proxy_ssl_header = HTTP_X_FORWARDED_PROTO |
| secure_proxy_ssl_header = "HTTP_X_FORWARDED_PROTO" |
| |
| # If set to true, then the server will return information in HTTP responses |
| # that may allow an unauthenticated or authenticated user to get more |
| # information than normal, such as additional details about why authentication |
| # failed. This may be useful for debugging but is insecure. (boolean value) |
| #insecure_debug = false |
| |
| # Default `publisher_id` for outgoing notifications. If left undefined, |
| # Keystone will default to using the server's host name. (string value) |
| #default_publisher_id = <None> |
| |
| # Define the notification format for identity service events. A `basic` |
| # notification only has information about the resource being operated on. A |
| # `cadf` notification has the same information, as well as information about |
| # the initiator of the event. The `cadf` option is entirely backwards |
| # compatible with the `basic` option, but is fully CADF-compliant, and is |
| # recommended for auditing use cases. (string value) |
| # Allowed values: basic, cadf |
| #notification_format = basic |
| notification_format = {{ server.get("notification_format", "basic") }} |
| |
| # If left undefined, keystone will emit notifications for all types of events. |
| # You can reduce the number of notifications keystone emits by using this |
| # option to enumerate notification topics that should be suppressed. Values are |
| # expected to be in the form `identity.<resource_type>.<operation>`. This field |
| # can be set multiple times in order to opt-out of multiple notification |
| # topics. For example: notification_opt_out=identity.user.create |
| # notification_opt_out=identity.authenticate.success (multi valued) |
| #notification_opt_out = |
| |
| # |
| # From oslo.log |
| # |
| |
| # If set to true, the logging level will be set to DEBUG instead of the default |
| # INFO level. (boolean value) |
| # Note: This option can be changed without restarting. |
| #debug = false |
| debug = false |
| |
| # DEPRECATED: If set to false, the logging level will be set to WARNING instead |
| # of the default INFO level. (boolean value) |
| # This option is deprecated for removal. |
| # Its value may be silently ignored in the future. |
| #verbose = true |
| verbose = true |
| |
| # The name of a logging configuration file. This file is appended to any |
| # existing logging configuration files. For details about logging configuration |
| # files, see the Python logging module documentation. Note that when logging |
| # configuration files are used then all logging configuration is set in the |
| # configuration file and other logging configuration options are ignored (for |
| # example, logging_context_format_string). (string value) |
| # Note: This option can be changed without restarting. |
| # Deprecated group/name - [DEFAULT]/log_config |
| #log_config_append=<None> |
| {%- if server.logging.log_appender %} |
| log_config_append=/etc/keystone/logging.conf |
| {%- endif %} |
| |
| # Defines the format string for %%(asctime)s in log records. Default: |
| # %(default)s . This option is ignored if log_config_append is set. (string |
| # value) |
| #log_date_format = %Y-%m-%d %H:%M:%S |
| |
| # (Optional) Name of log file to send logging output to. If no default is set, |
| # logging will go to stderr as defined by use_stderr. This option is ignored if |
| # log_config_append is set. (string value) |
| # Deprecated group/name - [DEFAULT]/logfile |
| #log_file = <None> |
| |
| # (Optional) The base directory used for relative log_file paths. This option |
| # is ignored if log_config_append is set. (string value) |
| # Deprecated group/name - [DEFAULT]/logdir |
| #log_dir = <None> |
| log_dir = /var/log/keystone |
| |
| # Uses logging handler designed to watch file system. When log file is moved or |
| # removed this handler will open a new log file with specified path |
| # instantaneously. It makes sense only if log_file option is specified and |
| # Linux platform is used. This option is ignored if log_config_append is set. |
| # (boolean value) |
| #watch_log_file = false |
| |
| # Use syslog for logging. Existing syslog format is DEPRECATED and will be |
| # changed later to honor RFC5424. This option is ignored if log_config_append |
| # is set. (boolean value) |
| #use_syslog = false |
| |
| # Syslog facility to receive log lines. This option is ignored if |
| # log_config_append is set. (string value) |
| #syslog_log_facility = LOG_USER |
| |
| # Log output to standard error. This option is ignored if log_config_append is |
| # set. (boolean value) |
| #use_stderr = true |
| |
| # Format string to use for log messages with context. (string value) |
| #logging_context_format_string = %(asctime)s.%(msecs)03d %(process)d %(levelname)s %(name)s [%(request_id)s %(user_identity)s] %(instance)s%(message)s |
| |
| # Format string to use for log messages when context is undefined. (string |
| # value) |
| #logging_default_format_string = %(asctime)s.%(msecs)03d %(process)d %(levelname)s %(name)s [-] %(instance)s%(message)s |
| |
| # Additional data to append to log message when logging level for the message |
| # is DEBUG. (string value) |
| #logging_debug_format_suffix = %(funcName)s %(pathname)s:%(lineno)d |
| |
| # Prefix each line of exception output with this format. (string value) |
| #logging_exception_prefix = %(asctime)s.%(msecs)03d %(process)d ERROR %(name)s %(instance)s |
| |
| # Defines the format string for %(user_identity)s that is used in |
| # logging_context_format_string. (string value) |
| #logging_user_identity_format = %(user)s %(tenant)s %(domain)s %(user_domain)s %(project_domain)s |
| |
| # List of package logging levels in logger=LEVEL pairs. This option is ignored |
| # if log_config_append is set. (list value) |
| #default_log_levels = amqp=WARN,amqplib=WARN,boto=WARN,qpid=WARN,sqlalchemy=WARN,suds=INFO,oslo.messaging=INFO,iso8601=WARN,requests.packages.urllib3.connectionpool=WARN,urllib3.connectionpool=WARN,websocket=WARN,requests.packages.urllib3.util.retry=WARN,urllib3.util.retry=WARN,keystonemiddleware=WARN,routes.middleware=WARN,stevedore=WARN,taskflow=WARN,keystoneauth=WARN,oslo.cache=INFO,dogpile.core.dogpile=INFO |
| |
| # Enables or disables publication of error events. (boolean value) |
| #publish_errors = false |
| |
| # The format for an instance that is passed with the log message. (string |
| # value) |
| #instance_format = "[instance: %(uuid)s] " |
| |
| # The format for an instance UUID that is passed with the log message. (string |
| # value) |
| #instance_uuid_format = "[instance: %(uuid)s] " |
| |
| # Enables or disables fatal status of deprecations. (boolean value) |
| #fatal_deprecations = false |
| |
| # |
| # From oslo.messaging |
| # |
| |
| # Size of RPC connection pool. (integer value) |
| # Deprecated group/name - [DEFAULT]/rpc_conn_pool_size |
| #rpc_conn_pool_size = 30 |
| |
| # The pool size limit for connections expiration policy (integer value) |
| #conn_pool_min_size = 2 |
| |
| # The time-to-live in sec of idle connections in the pool (integer value) |
| #conn_pool_ttl = 1200 |
| |
| # ZeroMQ bind address. Should be a wildcard (*), an ethernet interface, or IP. |
| # The "host" option should point or resolve to this address. (string value) |
| # Deprecated group/name - [DEFAULT]/rpc_zmq_bind_address |
| #rpc_zmq_bind_address = * |
| |
| # MatchMaker driver. (string value) |
| # Allowed values: redis, dummy |
| # Deprecated group/name - [DEFAULT]/rpc_zmq_matchmaker |
| #rpc_zmq_matchmaker = redis |
| |
| # Number of ZeroMQ contexts, defaults to 1. (integer value) |
| # Deprecated group/name - [DEFAULT]/rpc_zmq_contexts |
| #rpc_zmq_contexts = 1 |
| |
| # Maximum number of ingress messages to locally buffer per topic. Default is |
| # unlimited. (integer value) |
| # Deprecated group/name - [DEFAULT]/rpc_zmq_topic_backlog |
| #rpc_zmq_topic_backlog = <None> |
| |
| # Directory for holding IPC sockets. (string value) |
| # Deprecated group/name - [DEFAULT]/rpc_zmq_ipc_dir |
| #rpc_zmq_ipc_dir = /var/run/openstack |
| |
| # Name of this node. Must be a valid hostname, FQDN, or IP address. Must match |
| # "host" option, if running Nova. (string value) |
| # Deprecated group/name - [DEFAULT]/rpc_zmq_host |
| #rpc_zmq_host = localhost |
| |
| # Seconds to wait before a cast expires (TTL). The default value of -1 |
| # specifies an infinite linger period. The value of 0 specifies no linger |
| # period. Pending messages shall be discarded immediately when the socket is |
| # closed. Only supported by impl_zmq. (integer value) |
| # Deprecated group/name - [DEFAULT]/rpc_cast_timeout |
| #rpc_cast_timeout = -1 |
| |
| # The default number of seconds that poll should wait. Poll raises timeout |
| # exception when timeout expired. (integer value) |
| # Deprecated group/name - [DEFAULT]/rpc_poll_timeout |
| #rpc_poll_timeout = 1 |
| |
| # Expiration timeout in seconds of a name service record about existing target |
| # ( < 0 means no timeout). (integer value) |
| # Deprecated group/name - [DEFAULT]/zmq_target_expire |
| #zmq_target_expire = 300 |
| |
| # Update period in seconds of a name service record about existing target. |
| # (integer value) |
| # Deprecated group/name - [DEFAULT]/zmq_target_update |
| #zmq_target_update = 180 |
| |
| # Use PUB/SUB pattern for fanout methods. PUB/SUB always uses proxy. (boolean |
| # value) |
| # Deprecated group/name - [DEFAULT]/use_pub_sub |
| #use_pub_sub = true |
| |
| # Use ROUTER remote proxy. (boolean value) |
| # Deprecated group/name - [DEFAULT]/use_router_proxy |
| #use_router_proxy = true |
| |
| # Minimal port number for random ports range. (port value) |
| # Minimum value: 0 |
| # Maximum value: 65535 |
| # Deprecated group/name - [DEFAULT]/rpc_zmq_min_port |
| #rpc_zmq_min_port = 49153 |
| |
| # Maximal port number for random ports range. (integer value) |
| # Minimum value: 1 |
| # Maximum value: 65536 |
| # Deprecated group/name - [DEFAULT]/rpc_zmq_max_port |
| #rpc_zmq_max_port = 65536 |
| |
| # Number of retries to find free port number before fail with ZMQBindError. |
| # (integer value) |
| # Deprecated group/name - [DEFAULT]/rpc_zmq_bind_port_retries |
| #rpc_zmq_bind_port_retries = 100 |
| |
| # Default serialization mechanism for serializing/deserializing |
| # outgoing/incoming messages (string value) |
| # Allowed values: json, msgpack |
| # Deprecated group/name - [DEFAULT]/rpc_zmq_serialization |
| #rpc_zmq_serialization = json |
| |
| # This option configures round-robin mode in zmq socket. True means not keeping |
| # a queue when server side disconnects. False means to keep queue and messages |
| # even if server is disconnected, when the server appears we send all |
| # accumulated messages to it. (boolean value) |
| #zmq_immediate = false |
| |
| # Size of executor thread pool. (integer value) |
| # Deprecated group/name - [DEFAULT]/rpc_thread_pool_size |
| #executor_thread_pool_size = 64 |
| |
| # Seconds to wait for a response from a call. (integer value) |
| #rpc_response_timeout = 60 |
| {%- if server.notification %} |
| # A URL representing the messaging driver to use and its full configuration. |
| # (string value) |
| #transport_url = rabbit://nova:3qVSI7a1m8AdaDQ7BpB0PJu4@192.168.0.4:5673/ |
| |
| {%- set rabbit_port = server.message_queue.get('port', 5671 if server.message_queue.get('ssl',{}).get('enabled', False) else 5672) %} |
| {%- if server.message_queue.members is defined %} |
| transport_url = rabbit://{% for member in server.message_queue.members -%} |
| {{ server.message_queue.user }}:{{ server.message_queue.password }}@{{ member.host }}:{{ member.get('port', rabbit_port) }} |
| {%- if not loop.last -%},{%- endif -%} |
| {%- endfor -%} |
| /{{ server.message_queue.virtual_host }} |
| {%- else %} |
| transport_url = rabbit://{{ server.message_queue.user }}:{{ server.message_queue.password }}@{{ server.message_queue.host }}:{{ rabbit_port }}/{{ server.message_queue.virtual_host }} |
| {%- endif %} |
| |
| # DEPRECATED: The messaging driver to use, defaults to rabbit. Other drivers |
| # include amqp and zmq. (string value) |
| # This option is deprecated for removal. |
| # Its value may be silently ignored in the future. |
| # Reason: Replaced by [DEFAULT]/transport_url |
| #rpc_backend = rabbit |
| {%- endif %} |
| |
| # The default exchange under which topics are scoped. May be overridden by an |
| # exchange name specified in the transport_url option. (string value) |
| #control_exchange = keystone |
| |
| |
| [assignment] |
| |
| # |
| # From keystone |
| # |
| |
| # Entry point for the assignment backend driver (where role assignments are |
| # stored) in the `keystone.assignment` namespace. Only a SQL driver is supplied |
| # by keystone itself. If an assignment driver is not specified, the identity |
| # driver will choose the assignment driver based on the deprecated |
| # `[identity]/driver` option (the behavior will be removed in the "O" release). |
| # Unless you are writing proprietary drivers for keystone, you do not need to |
| # set this option. (string value) |
| #driver = <None> |
| |
| # A list of role names which are prohibited from being an implied role. (list |
| # value) |
| #prohibited_implied_role = admin |
| {%- if server.get("assignment", {}).get("backend", "sql") == "ldap" %} |
| driver = ldap |
| {%- else %} |
| driver = sql |
| {%- endif %} |
| |
| [auth] |
| |
| # |
| # From keystone |
| # |
| |
| # Allowed authentication methods. (list value) |
| #methods = external,password,token,oauth1 |
| {% if server.auth_methods is defined %} |
| methods = {{ server.auth_methods |join(',') }} |
| {%- endif %} |
| |
| {%- if server.get('federation', {}).oidc is defined %} |
| {{ server.federation.oidc.protocol }} = keystone.auth.plugins.mapped.Mapped |
| {%- endif %} |
| {%- if server.get('federation', {}).saml2 is defined %} |
| {{ server.federation.saml2.protocol }} = keystone.auth.plugins.mapped.Mapped |
| {%- endif %} |
| # Entry point for the password auth plugin module in the |
| # `keystone.auth.password` namespace. You do not need to set this unless you |
| # are overriding keystone's own password authentication plugin. (string value) |
| #password = <None> |
| |
| # Entry point for the token auth plugin module in the `keystone.auth.token` |
| # namespace. You do not need to set this unless you are overriding keystone's |
| # own token authentication plugin. (string value) |
| #token = <None> |
| |
| # Entry point for the external (`REMOTE_USER`) auth plugin module in the |
| # `keystone.auth.external` namespace. Supplied drivers are `DefaultDomain` and |
| # `Domain`. The default driver is `DefaultDomain`, which assumes that all users |
| # identified by the username specified to keystone in the `REMOTE_USER` |
| # variable exist within the context of the default domain. The `Domain` option |
| # expects an additional environment variable be presented to keystone, |
| # `REMOTE_DOMAIN`, containing the domain name of the `REMOTE_USER` (if |
| # `REMOTE_DOMAIN` is not set, then the default domain will be used instead). |
| # You do not need to set this unless you are taking advantage of "external |
| # authentication", where the application server (such as Apache) is handling |
| # authentication instead of keystone. (string value) |
| #external = <None> |
| |
| # Entry point for the OAuth 1.0a auth plugin module in the |
| # `keystone.auth.oauth1` namespace. You do not need to set this unless you are |
| # overriding keystone's own `oauth1` authentication plugin. (string value) |
| #oauth1 = <None> |
| |
| |
| [cache] |
| |
| # |
| # From oslo.cache |
| # |
| |
| # Prefix for building the configuration dictionary for the cache region. This |
| # should not need to be changed unless there is another dogpile.cache region |
| # with the same configuration name. (string value) |
| #config_prefix = cache.oslo |
| |
| # Default TTL, in seconds, for any cached item in the dogpile.cache region. |
| # This applies to any cached method that doesn't have an explicit cache |
| # expiration time defined for it. (integer value) |
| #expiration_time = 600 |
| |
| # Dogpile.cache backend module. It is recommended that Memcache or Redis |
| # (dogpile.cache.redis) be used in production deployments. For eventlet-based |
| # or highly threaded servers, Memcache with pooling (oslo_cache.memcache_pool) |
| # is recommended. For low thread servers, dogpile.cache.memcached is |
| # recommended. Test environments with a single instance of the server can use |
| # the dogpile.cache.memory backend. (string value) |
| #backend = dogpile.cache.null |
| backend = oslo_cache.memcache_pool |
| |
| # Arguments supplied to the backend module. Specify this option once per |
| # argument to be passed to the dogpile.cache backend. Example format: |
| # "<argname>:<value>". (multi valued) |
| #backend_argument = |
| |
| # Proxy classes to import that will affect the way the dogpile.cache backend |
| # functions. See the dogpile.cache documentation on changing-backend-behavior. |
| # (list value) |
| #proxies = |
| |
| # Global toggle for caching. (boolean value) |
| #enabled = true |
| enabled = true |
| |
| # Extra debugging from the cache backend (cache keys, get/set/delete/etc |
| # calls). This is only really useful if you need to see the specific cache- |
| # backend get/set/delete calls with the keys/values. Typically this should be |
| # left set to false. (boolean value) |
| #debug_cache_backend = false |
| |
| # Memcache servers in the format of "host:port". (dogpile.cache.memcache and |
| # oslo_cache.memcache_pool backends only). (list value) |
| #memcache_servers = localhost:11211 |
| {%- if server.cache is defined %} |
| {%- if server.cache.members is defined %} |
| memcache_servers = {%- for member in server.cache.members %}{{ member.host }}:{{ member.port }}{% if not loop.last %},{% endif %}{%- endfor %} |
| {%- else %} |
| memcache_servers = ['{{ server.cache.host }}:{{ server.cache.port }}'] |
| {%- endif %} |
| {%- endif %} |
| |
| # Number of seconds memcached server is considered dead before it is tried |
| # again. (dogpile.cache.memcache and oslo_cache.memcache_pool backends only). |
| # (integer value) |
| #memcache_dead_retry = 300 |
| memcache_dead_retry = 300 |
| |
| # Timeout in seconds for every call to a server. (dogpile.cache.memcache and |
| # oslo_cache.memcache_pool backends only). (integer value) |
| #memcache_socket_timeout = 3 |
| memcache_socket_timeout = 1 |
| |
| # Max total number of open connections to every memcached server. |
| # (oslo_cache.memcache_pool backend only). (integer value) |
| #memcache_pool_maxsize = 10 |
| memcache_pool_maxsize = 100 |
| |
| # Number of seconds a connection to memcached is held unused in the pool before |
| # it is closed. (oslo_cache.memcache_pool backend only). (integer value) |
| #memcache_pool_unused_timeout = 60 |
| memcache_pool_unused_timeout = 60 |
| |
| # Number of seconds that an operation will wait to get a memcache client |
| # connection. (integer value) |
| #memcache_pool_connection_get_timeout = 10 |
| |
| |
| [catalog] |
| |
| # |
| # From keystone |
| # |
| |
| # Absolute path to the file used for the templated catalog backend. This option |
| # is only used if the `[catalog] driver` is set to `templated`. (string value) |
| #template_file = default_catalog.templates |
| template_file = default_catalog.templates |
| |
| # Entry point for the catalog driver in the `keystone.catalog` namespace. |
| # Keystone provides a `sql` option (which supports basic CRUD operations |
| # through SQL), a `templated` option (which loads the catalog from a templated |
| # catalog file on disk), and a `endpoint_filter.sql` option (which supports |
| # arbitrary service catalogs per project). (string value) |
| #driver = sql |
| driver = sql |
| |
| # Toggle for catalog caching. This has no effect unless global caching is |
| # enabled. In a typical deployment, there is no reason to disable this. |
| # (boolean value) |
| #caching = true |
| |
| # Time to cache catalog data (in seconds). This has no effect unless global and |
| # catalog caching are both enabled. Catalog data (services, endpoints, etc.) |
| # typically does not change frequently, and so a longer duration than the |
| # global default may be desirable. (integer value) |
| #cache_time = <None> |
| |
| # Maximum number of entities that will be returned in a catalog collection. |
| # There is typically no reason to set this, as it would be unusual for a |
| # deployment to have enough services or endpoints to exceed a reasonable limit. |
| # (integer value) |
| #list_limit = <None> |
| |
| |
| [cors] |
| |
| # |
| # From oslo.middleware |
| # |
| |
| # Indicate whether this resource may be shared with the domain received in the |
| # requests "origin" header. Format: "<protocol>://<host>[:<port>]", no trailing |
| # slash. Example: https://horizon.example.com (list value) |
| #allowed_origin = <None> |
| {% if server.cors.allowed_origin is defined %} |
| allowed_origin = {{ server.cors.allowed_origin }} |
| {% endif %} |
| |
| # Indicate that the actual request can include user credentials (boolean value) |
| #allow_credentials = true |
| {% if server.cors.allow_credentials is defined %} |
| allow_credentials = {{ server.cors.allow_credentials }} |
| {% endif %} |
| |
| # Indicate which headers are safe to expose to the API. Defaults to HTTP Simple |
| # Headers. (list value) |
| #expose_headers = X-Auth-Token,X-Openstack-Request-Id,X-Subject-Token |
| {% if server.cors.expose_headers is defined %} |
| expose_headers = {{ server.cors.expose_headers }} |
| {% endif %} |
| |
| # Maximum cache age of CORS preflight requests. (integer value) |
| #max_age = 3600 |
| {% if server.cors.max_age is defined %} |
| max_age = {{ server.cors.max_age }} |
| {% endif %} |
| |
| |
| # Indicate which methods can be used during the actual request. (list value) |
| #allow_methods = GET,PUT,POST,DELETE,PATCH |
| {% if server.cors.allow_methods is defined %} |
| allow_methods = {{ server.cors.allow_methods }} |
| {% endif %} |
| |
| # Indicate which header field names may be used during the actual request. |
| # (list value) |
| #allow_headers = X-Auth-Token,X-Openstack-Request-Id,X-Subject-Token,X-Project-Id,X-Project-Name,X-Project-Domain-Id,X-Project-Domain-Name,X-Domain-Id,X-Domain-Name |
| {% if server.cors.allow_headers is defined %} |
| allow_headers = {{ server.cors.allow_headers }} |
| {% endif %} |
| |
| |
| [cors.subdomain] |
| |
| # |
| # From oslo.middleware |
| # |
| |
| # Indicate whether this resource may be shared with the domain received in the |
| # requests "origin" header. Format: "<protocol>://<host>[:<port>]", no trailing |
| # slash. Example: https://horizon.example.com (list value) |
| #allowed_origin = <None> |
| |
| # Indicate that the actual request can include user credentials (boolean value) |
| #allow_credentials = true |
| |
| # Indicate which headers are safe to expose to the API. Defaults to HTTP Simple |
| # Headers. (list value) |
| #expose_headers = X-Auth-Token,X-Openstack-Request-Id,X-Subject-Token |
| |
| # Maximum cache age of CORS preflight requests. (integer value) |
| #max_age = 3600 |
| |
| # Indicate which methods can be used during the actual request. (list value) |
| #allow_methods = GET,PUT,POST,DELETE,PATCH |
| |
| # Indicate which header field names may be used during the actual request. |
| # (list value) |
| #allow_headers = X-Auth-Token,X-Openstack-Request-Id,X-Subject-Token,X-Project-Id,X-Project-Name,X-Project-Domain-Id,X-Project-Domain-Name,X-Domain-Id,X-Domain-Name |
| |
| |
| [credential] |
| |
| # |
| # From keystone |
| # |
| |
| # Entry point for the credential backend driver in the `keystone.credential` |
| # namespace. Keystone only provides a `sql` driver, so there's no reason to |
| # change this unless you are providing a custom entry point. (string value) |
| #driver = sql |
| |
| # Entry point for credential encryption and decryption operations in the |
| # `keystone.credential.provider` namespace. Keystone only provides a `fernet` |
| # driver, so there's no reason to change this unless you are providing a custom |
| # entry point to encrypt and decrypt credentials. (string value) |
| #provider = fernet |
| |
| # Directory containing Fernet keys used to encrypt and decrypt credentials |
| # stored in the credential backend. Fernet keys used to encrypt credentials |
| # have no relationship to Fernet keys used to encrypt Fernet tokens. Both sets |
| # of keys should be managed separately and require different rotation policies. |
| # Do not share this repository with the repository used to manage keys for |
| # Fernet tokens. (string value) |
| key_repository = {{ server.credential.location }} |
| |
| |
| [database] |
| |
| # |
| # From oslo.db |
| # |
| |
| # DEPRECATED: The file name to use with SQLite. (string value) |
| # Deprecated group/name - [DEFAULT]/sqlite_db |
| # This option is deprecated for removal. |
| # Its value may be silently ignored in the future. |
| # Reason: Should use config option connection or slave_connection to connect |
| # the database. |
| #sqlite_db = oslo.sqlite |
| |
| # If True, SQLite uses synchronous mode. (boolean value) |
| # Deprecated group/name - [DEFAULT]/sqlite_synchronous |
| #sqlite_synchronous = true |
| |
| # The back end to use for the database. (string value) |
| # Deprecated group/name - [DEFAULT]/db_backend |
| #backend = sqlalchemy |
| |
| # The SQLAlchemy connection string to use to connect to the database. (string |
| # value) |
| # Deprecated group/name - [DEFAULT]/sql_connection |
| # Deprecated group/name - [DATABASE]/sql_connection |
| # Deprecated group/name - [sql]/connection |
| #connection = <None> |
| connection={{ server.database.engine }}+pymysql://{{ server.database.user }}:{{ server.database.password }}@{{ server.database.host }}/{{ server.database.name }}{%- if server.database.get('ssl',{}).get('enabled',False) %}?ssl_ca={{ server.database.ssl.get('cacert_file', server.cacert_file) }}{% endif %} |
| |
| # The SQLAlchemy connection string to use to connect to the slave database. |
| # (string value) |
| #slave_connection = <None> |
| |
| # The SQL mode to be used for MySQL sessions. This option, including the |
| # default, overrides any server-set SQL mode. To use whatever SQL mode is set |
| # by the server configuration, set this to no value. Example: mysql_sql_mode= |
| # (string value) |
| #mysql_sql_mode = TRADITIONAL |
| |
| # Timeout before idle SQL connections are reaped. (integer value) |
| # Deprecated group/name - [DEFAULT]/sql_idle_timeout |
| # Deprecated group/name - [DATABASE]/sql_idle_timeout |
| # Deprecated group/name - [sql]/idle_timeout |
| #idle_timeout = 3600 |
| idle_timeout = 3600 |
| |
| # Minimum number of SQL connections to keep open in a pool. (integer value) |
| # Deprecated group/name - [DEFAULT]/sql_min_pool_size |
| # Deprecated group/name - [DATABASE]/sql_min_pool_size |
| #min_pool_size = 1 |
| |
| # Maximum number of SQL connections to keep open in a pool. Setting a value of |
| # 0 indicates no limit. (integer value) |
| # Deprecated group/name - [DEFAULT]/sql_max_pool_size |
| # Deprecated group/name - [DATABASE]/sql_max_pool_size |
| #max_pool_size = 5 |
| max_pool_size=10 |
| max_overflow=30 |
| max_retries=-1 |
| |
| # Maximum number of database connection retries during startup. Set to -1 to |
| # specify an infinite retry count. (integer value) |
| # Deprecated group/name - [DEFAULT]/sql_max_retries |
| # Deprecated group/name - [DATABASE]/sql_max_retries |
| #max_retries = 10 |
| |
| # Interval between retries of opening a SQL connection. (integer value) |
| # Deprecated group/name - [DEFAULT]/sql_retry_interval |
| # Deprecated group/name - [DATABASE]/reconnect_interval |
| #retry_interval = 10 |
| |
| # If set, use this value for max_overflow with SQLAlchemy. (integer value) |
| # Deprecated group/name - [DEFAULT]/sql_max_overflow |
| # Deprecated group/name - [DATABASE]/sqlalchemy_max_overflow |
| #max_overflow = 50 |
| |
| # Verbosity of SQL debugging information: 0=None, 100=Everything. (integer |
| # value) |
| # Minimum value: 0 |
| # Maximum value: 100 |
| # Deprecated group/name - [DEFAULT]/sql_connection_debug |
| #connection_debug = 0 |
| |
| # Add Python stack traces to SQL as comment strings. (boolean value) |
| # Deprecated group/name - [DEFAULT]/sql_connection_trace |
| #connection_trace = false |
| |
| # If set, use this value for pool_timeout with SQLAlchemy. (integer value) |
| # Deprecated group/name - [DATABASE]/sqlalchemy_pool_timeout |
| #pool_timeout = <None> |
| |
| # Enable the experimental use of database reconnect on connection lost. |
| # (boolean value) |
| #use_db_reconnect = false |
| |
| # Seconds between retries of a database transaction. (integer value) |
| #db_retry_interval = 1 |
| |
| # If True, increases the interval between retries of a database operation up to |
| # db_max_retry_interval. (boolean value) |
| #db_inc_retry_interval = true |
| |
| # If db_inc_retry_interval is set, the maximum seconds between retries of a |
| # database operation. (integer value) |
| #db_max_retry_interval = 10 |
| |
| # Maximum retries in case of connection error or deadlock error before error is |
| # raised. Set to -1 to specify an infinite retry count. (integer value) |
| #db_max_retries = 20 |
| |
| |
| [domain_config] |
| |
| # |
| # From keystone |
| # |
| |
| # Entry point for the domain-specific configuration driver in the |
| # `keystone.resource.domain_config` namespace. Only a `sql` option is provided |
| # by keystone, so there is no reason to set this unless you are providing a |
| # custom entry point. (string value) |
| #driver = sql |
| |
| # Toggle for caching of the domain-specific configuration backend. This has no |
| # effect unless global caching is enabled. There is normally no reason to |
| # disable this. (boolean value) |
| #caching = true |
| |
| # Time-to-live (TTL, in seconds) to cache domain-specific configuration data. |
| # This has no effect unless `[domain_config] caching` is enabled. (integer |
| # value) |
| #cache_time = 300 |
| |
| |
| [endpoint_filter] |
| |
| # |
| # From keystone |
| # |
| |
| # Entry point for the endpoint filter driver in the `keystone.endpoint_filter` |
| # namespace. Only a `sql` option is provided by keystone, so there is no reason |
| # to set this unless you are providing a custom entry point. (string value) |
| #driver = sql |
| |
| # This controls keystone's behavior if the configured endpoint filters do not |
| # result in any endpoints for a user + project pair (and therefore a |
| # potentially empty service catalog). If set to true, keystone will return the |
| # entire service catalog. If set to false, keystone will return an empty |
| # service catalog. (boolean value) |
| #return_all_endpoints_if_no_filter = true |
| |
| |
| [endpoint_policy] |
| |
| # |
| # From keystone |
| # |
| |
| # DEPRECATED: Enable endpoint-policy functionality, which allows policies to be |
| # associated with either specific endpoints, or endpoints of a given service |
| # type. (boolean value) |
| # This option is deprecated for removal since M. |
| # Its value may be silently ignored in the future. |
| # Reason: The option to enable the OS-ENDPOINT-POLICY API extension has been |
| # deprecated in the M release and will be removed in the O release. The OS- |
| # ENDPOINT-POLICY API extension will be enabled by default. |
| #enabled = true |
| |
| # Entry point for the endpoint policy driver in the `keystone.endpoint_policy` |
| # namespace. Only a `sql` driver is provided by keystone, so there is no reason |
| # to set this unless you are providing a custom entry point. (string value) |
| #driver = sql |
| |
| |
| [eventlet_server] |
| |
| # |
| # From keystone |
| # |
| |
| # DEPRECATED: The IP address of the network interface for the public service to |
| # listen on. (string value) |
| # Deprecated group/name - [DEFAULT]/bind_host |
| # Deprecated group/name - [DEFAULT]/public_bind_host |
| # This option is deprecated for removal since K. |
| # Its value may be silently ignored in the future. |
| # Reason: Support for running keystone under eventlet has been removed in the |
| # Newton release. These options remain for backwards compatibility because they |
| # are used for URL substitutions. |
| #public_bind_host = 0.0.0.0 |
| public_bind_host={% if server.bind.address is defined %}{{ server.bind.address }}{% else %}{{ server.bind.public_address }}{% endif %} |
| |
| # DEPRECATED: The port number for the public service to listen on. (port value) |
| # Minimum value: 0 |
| # Maximum value: 65535 |
| # Deprecated group/name - [DEFAULT]/public_port |
| # This option is deprecated for removal since K. |
| # Its value may be silently ignored in the future. |
| # Reason: Support for running keystone under eventlet has been removed in the |
| # Newton release. These options remain for backwards compatibility because they |
| # are used for URL substitutions. |
| #public_port = 5000 |
| public_port = 5000 |
| |
| # DEPRECATED: The IP address of the network interface for the admin service to |
| # listen on. (string value) |
| # Deprecated group/name - [DEFAULT]/bind_host |
| # Deprecated group/name - [DEFAULT]/admin_bind_host |
| # This option is deprecated for removal since K. |
| # Its value may be silently ignored in the future. |
| # Reason: Support for running keystone under eventlet has been removed in the |
| # Newton release. These options remain for backwards compatibility because they |
| # are used for URL substitutions. |
| #admin_bind_host = 0.0.0.0 |
| admin_bind_host={% if server.bind.address is defined %}{{ server.bind.address }}{% else %}{{ server.bind.public_address }}{% endif %} |
| |
| # DEPRECATED: The port number for the admin service to listen on. (port value) |
| # Minimum value: 0 |
| # Maximum value: 65535 |
| # Deprecated group/name - [DEFAULT]/admin_port |
| # This option is deprecated for removal since K. |
| # Its value may be silently ignored in the future. |
| # Reason: Support for running keystone under eventlet has been removed in the |
| # Newton release. These options remain for backwards compatibility because they |
| # are used for URL substitutions. |
| #admin_port = 35357 |
| admin_port = 35357 |
| |
| {%- if server.get('federation', {}).saml2 is defined %} |
| [{{ server.federation.saml2.protocol }}] |
| remote_id_attribute = {{ server.federation.saml2.remote_id_attribute }} |
| {%- endif %} |
| |
| {%- if server.get('federation', {}).oidc is defined %} |
| [{{ server.federation.oidc.protocol }}] |
| remote_id_attribute = {{ server.federation.oidc.remote_id_attribute }} |
| {%- endif %} |
| |
| [federation] |
| |
| # |
| # From keystone |
| # |
| |
| # Entry point for the federation backend driver in the `keystone.federation` |
| # namespace. Keystone only provides a `sql` driver, so there is no reason to |
| # set this option unless you are providing a custom entry point. (string value) |
| #driver = sql |
| {%- if server.get('federation', {}).federation_driver is defined %} |
| driver = {{ server.federation.federation_driver }} |
| {%- endif %} |
| |
| # Prefix to use when filtering environment variable names for federated |
| # assertions. Matched variables are passed into the federated mapping engine. |
| # (string value) |
| #assertion_prefix = |
| |
| # Value to be used to obtain the entity ID of the Identity Provider from the |
| # environment. For `mod_shib`, this would be `Shib-Identity-Provider`. For For |
| # `mod_auth_openidc`, this could be `HTTP_OIDC_ISS`. For `mod_auth_mellon`, |
| # this could be `MELLON_IDP`. (string value) |
| #remote_id_attribute = <None> |
| |
| # An arbitrary domain name that is reserved to allow federated ephemeral users |
| # to have a domain concept. Note that an admin will not be able to create a |
| # domain with this name or update an existing domain to this name. You are not |
| # advised to change this value unless you really have to. (string value) |
| #federated_domain_name = Federated |
| {%- if server.get('federation', {}).federated_domain_name is defined %} |
| federated_domain_name = {{ server.federation.federated_domain_name }} |
| {%- endif %} |
| |
| # A list of trusted dashboard hosts. Before accepting a Single Sign-On request |
| # to return a token, the origin host must be a member of this list. This |
| # configuration option may be repeated for multiple values. You must set this |
| # in order to use web-based SSO flows. For example: |
| # trusted_dashboard=https://acme.example.com/auth/websso |
| # trusted_dashboard=https://beta.example.com/auth/websso (multi valued) |
| #trusted_dashboard = |
| {%- if server.get('federation', {}).trusted_dashboard is defined %} |
| {%- for dashboard in server.federation.trusted_dashboard %} |
| trusted_dashboard = {{ dashboard }} |
| {%- endfor %} |
| {%- endif %} |
| |
| # Absolute path to an HTML file used as a Single Sign-On callback handler. This |
| # page is expected to redirect the user from keystone back to a trusted |
| # dashboard host, by form encoding a token in a POST request. Keystone's |
| # default value should be sufficient for most deployments. (string value) |
| #sso_callback_template = /etc/keystone/sso_callback_template.html |
| |
| # Toggle for federation caching. This has no effect unless global caching is |
| # enabled. There is typically no reason to disable this. (boolean value) |
| #caching = true |
| |
| |
| [fernet_tokens] |
| |
| # |
| # From keystone |
| # |
| |
| # Directory containing Fernet token keys. This directory must exist before |
| # using `keystone-manage fernet_setup` for the first time, must be writable by |
| # the user running `keystone-manage fernet_setup` or `keystone-manage |
| # fernet_rotate`, and of course must be readable by keystone's server process. |
| # The repository may contain keys in one of three states: a single staged key |
| # (always index 0) used for token validation, a single primary key (always the |
| # highest index) used for token creation and validation, and any number of |
| # secondary keys (all other index values) used for token validation. With |
| # multiple keystone nodes, each node must share the same key repository |
| # contents, with the exception of the staged key (index 0). It is safe to run |
| # `keystone-manage fernet_rotate` once on any one node to promote a staged key |
| # (index 0) to be the new primary (incremented from the previous highest |
| # index), and produce a new staged key (a new key with index 0); the resulting |
| # repository can then be atomically replicated to other nodes without any risk |
| # of race conditions (for example, it is safe to run `keystone-manage |
| # fernet_rotate` on host A, wait any amount of time, create a tarball of the |
| # directory on host A, unpack it on host B to a temporary location, and |
| # atomically move (`mv`) the directory into place on host B). Running |
| # `keystone-manage fernet_rotate` *twice* on a key repository without syncing |
| # other nodes will result in tokens that can not be validated by all nodes. |
| # (string value) |
| #key_repository = /etc/keystone/fernet-keys/ |
| key_repository = {{ server.tokens.location }} |
| |
| # This controls how many keys are held in rotation by `keystone-manage |
| # fernet_rotate` before they are discarded. The default value of 3 means that |
| # keystone will maintain one staged key (always index 0), one primary key (the |
| # highest numerical index), and one secondary key (every other index). |
| # Increasing this value means that additional secondary keys will be kept in |
| # the rotation. (integer value) |
| # Minimum value: 1 |
| #max_active_keys = 3 |
| max_active_keys={{ server.tokens.get('max_active_keys', '3') }} |
| |
| |
| [identity] |
| |
| # |
| # From keystone |
| # |
| |
| # This references the domain to use for all Identity API v2 requests (which are |
| # not aware of domains). A domain with this ID can optionally be created for |
| # you by `keystone-manage bootstrap`. The domain referenced by this ID cannot |
| # be deleted on the v3 API, to prevent accidentally breaking the v2 API. There |
| # is nothing special about this domain, other than the fact that it must exist |
| # to order to maintain support for your v2 clients. There is typically no |
| # reason to change this value. (string value) |
| #default_domain_id = default |
| {%- if server.get('domain', {}) %} |
| {%- for name, domain in server.domain.items() %} |
| {%- if domain.get('default', False) %} |
| default_domain_id = {{ name }} |
| {%- endif %} |
| {%- endfor %} |
| {%- endif %} |
| |
| # A subset (or all) of domains can have their own identity driver, each with |
| # their own partial configuration options, stored in either the resource |
| # backend or in a file in a domain configuration directory (depending on the |
| # setting of `[identity] domain_configurations_from_database`). Only values |
| # specific to the domain need to be specified in this manner. This feature is |
| # disabled by default, but may be enabled by default in a future release; set |
| # to true to enable. (boolean value) |
| #domain_specific_drivers_enabled = false |
| {%- if server.get('domain', {}) %} |
| domain_specific_drivers_enabled = true |
| {%- endif %} |
| |
| # By default, domain-specific configuration data is read from files in the |
| # directory identified by `[identity] domain_config_dir`. Enabling this |
| # configuration option allows you to instead manage domain-specific |
| # configurations through the API, which are then persisted in the backend |
| # (typically, a SQL database), rather than using configuration files on disk. |
| # (boolean value) |
| #domain_configurations_from_database = false |
| |
| # Absolute path where keystone should locate domain-specific `[identity]` |
| # configuration files. This option has no effect unless `[identity] |
| # domain_specific_drivers_enabled` is set to true. There is typically no reason |
| # to change this value. (string value) |
| #domain_config_dir = /etc/keystone/domains |
| {%- if server.get('domain', {}) %} |
| domain_config_dir = /etc/keystone/domains |
| {%- endif %} |
| |
| # Entry point for the identity backend driver in the `keystone.identity` |
| # namespace. Keystone provides a `sql` and `ldap` driver. This option is also |
| # used as the default driver selection (along with the other configuration |
| # variables in this section) in the event that `[identity] |
| # domain_specific_drivers_enabled` is enabled, but no applicable domain- |
| # specific configuration is defined for the domain in question. Unless your |
| # deployment primarily relies on `ldap` AND is not using domain-specific |
| # configuration, you should typically leave this set to `sql`. (string value) |
| #driver = sql |
| driver = {{ server.get('backend', 'sql') }} |
| |
| # Toggle for identity caching. This has no effect unless global caching is |
| # enabled. There is typically no reason to disable this. (boolean value) |
| #caching = true |
| |
| # Time to cache identity data (in seconds). This has no effect unless global |
| # and identity caching are enabled. (integer value) |
| #cache_time = 600 |
| |
| # Maximum allowed length for user passwords. Decrease this value to improve |
| # performance. Changing this value does not effect existing passwords. (integer |
| # value) |
| # Maximum value: 4096 |
| #max_password_length = 4096 |
| |
| # Maximum number of entities that will be returned in an identity collection. |
| # (integer value) |
| #list_limit = <None> |
| {%- if server.get("backend", "sql") == "k2k" and server.k2k is defined %} |
| {%- set k2k = server.k2k %} |
| {% include "keystone/files/_k2k.conf" %} |
| {%- endif %} |
| |
| [identity_mapping] |
| |
| # |
| # From keystone |
| # |
| |
| # Entry point for the identity mapping backend driver in the |
| # `keystone.identity.id_mapping` namespace. Keystone only provides a `sql` |
| # driver, so there is no reason to change this unless you are providing a |
| # custom entry point. (string value) |
| #driver = sql |
| |
| # Entry point for the public ID generator for user and group entities in the |
| # `keystone.identity.id_generator` namespace. The Keystone identity mapper only |
| # supports generators that produce 64 bytes or less. Keystone only provides a |
| # `sha256` entry point, so there is no reason to change this value unless |
| # you're providing a custom entry point. (string value) |
| #generator = sha256 |
| |
| # The format of user and group IDs changed in Juno for backends that do not |
| # generate UUIDs (for example, LDAP), with keystone providing a hash mapping to |
| # the underlying attribute in LDAP. By default this mapping is disabled, which |
| # ensures that existing IDs will not change. Even when the mapping is enabled |
| # by using domain-specific drivers (`[identity] |
| # domain_specific_drivers_enabled`), any users and groups from the default |
| # domain being handled by LDAP will still not be mapped to ensure their IDs |
| # remain backward compatible. Setting this value to false will enable the new |
| # mapping for all backends, including the default LDAP driver. It is only |
| # guaranteed to be safe to enable this option if you do not already have |
| # assignments for users and groups from the default LDAP domain, and you |
| # consider it to be acceptable for Keystone to provide the different IDs to |
| # clients than it did previously (existing IDs in the API will suddenly |
| # change). Typically this means that the only time you can set this value to |
| # false is when configuring a fresh installation, although that is the |
| # recommended value. (boolean value) |
| #backward_compatible_ids = true |
| |
| |
| [kvs] |
| |
| # |
| # From keystone |
| # |
| |
| # Extra `dogpile.cache` backend modules to register with the `dogpile.cache` |
| # library. It is not necessary to set this value unless you are providing a |
| # custom KVS backend beyond what `dogpile.cache` already supports. (list value) |
| #backends = |
| |
| # Prefix for building the configuration dictionary for the KVS region. This |
| # should not need to be changed unless there is another `dogpile.cache` region |
| # with the same configuration name. (string value) |
| #config_prefix = keystone.kvs |
| |
| # Set to false to disable using a key-mangling function, which ensures fixed- |
| # length keys are used in the KVS store. This is configurable for debugging |
| # purposes, and it is therefore highly recommended to always leave this set to |
| # true. (boolean value) |
| #enable_key_mangler = true |
| |
| # Number of seconds after acquiring a distributed lock that the backend should |
| # consider the lock to be expired. This option should be tuned relative to the |
| # longest amount of time that it takes to perform a successful operation. If |
| # this value is set too low, then a cluster will end up performing work |
| # redundantly. If this value is set too high, then a cluster will not be able |
| # to efficiently recover and retry after a failed operation. A non-zero value |
| # is recommended if the backend supports lock timeouts, as zero prevents locks |
| # from expiring altogether. (integer value) |
| # Minimum value: 0 |
| #default_lock_timeout = 5 |
| {%- if server.get("backend", "sql") == "ldap" %} |
| {%- set ldap = server.ldap %} |
| {% include "keystone/files/_ldap.conf" %} |
| {%- endif %} |
| |
| [ldap] |
| |
| # |
| # From keystone |
| # |
| |
| # URL(s) for connecting to the LDAP server. Multiple LDAP URLs may be specified |
| # as a comma separated string. The first URL to successfully bind is used for |
| # the connection. (string value) |
| #url = ldap://localhost |
| |
| # The user name of the administrator bind DN to use when querying the LDAP |
| # server, if your LDAP server requires it. (string value) |
| #user = <None> |
| |
| # The password of the administrator bind DN to use when querying the LDAP |
| # server, if your LDAP server requires it. (string value) |
| #password = <None> |
| |
| # The default LDAP server suffix to use, if a DN is not defined via either |
| # `[ldap] user_tree_dn` or `[ldap] group_tree_dn`. (string value) |
| #suffix = cn=example,cn=com |
| |
| # DEPRECATED: If true, keystone will add a dummy member based on the `[ldap] |
| # dumb_member` option when creating new groups. This is required if the object |
| # class for groups requires the `member` attribute. This option is only used |
| # for write operations. (boolean value) |
| # This option is deprecated for removal since M. |
| # Its value may be silently ignored in the future. |
| # Reason: Write support for the LDAP identity backend has been deprecated in |
| # the Mitaka release and will be removed in the Ocata release. |
| #use_dumb_member = false |
| |
| # DEPRECATED: DN of the "dummy member" to use when `[ldap] use_dumb_member` is |
| # enabled. This option is only used for write operations. (string value) |
| # This option is deprecated for removal since M. |
| # Its value may be silently ignored in the future. |
| # Reason: Write support for the LDAP identity backend has been deprecated in |
| # the Mitaka release and will be removed in the Ocata release. |
| #dumb_member = cn=dumb,dc=nonexistent |
| |
| # DEPRECATED: Delete subtrees using the subtree delete control. Only enable |
| # this option if your LDAP server supports subtree deletion. This option is |
| # only used for write operations. (boolean value) |
| # This option is deprecated for removal since M. |
| # Its value may be silently ignored in the future. |
| # Reason: Write support for the LDAP identity backend has been deprecated in |
| # the Mitaka release and will be removed in the Ocata release. |
| #allow_subtree_delete = false |
| |
| # The search scope which defines how deep to search within the search base. A |
| # value of `one` (representing `oneLevel` or `singleLevel`) indicates a search |
| # of objects immediately below to the base object, but does not include the |
| # base object itself. A value of `sub` (representing `subtree` or |
| # `wholeSubtree`) indicates a search of both the base object itself and the |
| # entire subtree below it. (string value) |
| # Allowed values: one, sub |
| #query_scope = one |
| |
| # Defines the maximum number of results per page that keystone should request |
| # from the LDAP server when listing objects. A value of zero (`0`) disables |
| # paging. (integer value) |
| # Minimum value: 0 |
| #page_size = 0 |
| |
| # The LDAP dereferencing option to use for queries involving aliases. A value |
| # of `default` falls back to using default dereferencing behavior configured by |
| # your `ldap.conf`. A value of `never` prevents aliases from being dereferenced |
| # at all. A value of `searching` dereferences aliases only after name |
| # resolution. A value of `finding` dereferences aliases only during name |
| # resolution. A value of `always` dereferences aliases in all cases. (string |
| # value) |
| # Allowed values: never, searching, always, finding, default |
| #alias_dereferencing = default |
| |
| # Sets the LDAP debugging level for LDAP calls. A value of 0 means that |
| # debugging is not enabled. This value is a bitmask, consult your LDAP |
| # documentation for possible values. (integer value) |
| # Minimum value: -1 |
| #debug_level = <None> |
| |
| # Sets keystone's referral chasing behavior across directory partitions. If |
| # left unset, the system's default behavior will be used. (boolean value) |
| #chase_referrals = <None> |
| |
| # The search base to use for users. Defaults to the `[ldap] suffix` value. |
| # (string value) |
| #user_tree_dn = <None> |
| |
| # The LDAP search filter to use for users. (string value) |
| #user_filter = <None> |
| |
| # The LDAP object class to use for users. (string value) |
| #user_objectclass = inetOrgPerson |
| |
| # The LDAP attribute mapped to user IDs in keystone. This must NOT be a |
| # multivalued attribute. User IDs are expected to be globally unique across |
| # keystone domains and URL-safe. (string value) |
| #user_id_attribute = cn |
| |
| # The LDAP attribute mapped to user names in keystone. User names are expected |
| # to be unique only within a keystone domain and are not expected to be URL- |
| # safe. (string value) |
| #user_name_attribute = sn |
| |
| # The LDAP attribute mapped to user descriptions in keystone. (string value) |
| #user_description_attribute = description |
| |
| # The LDAP attribute mapped to user emails in keystone. (string value) |
| #user_mail_attribute = mail |
| |
| # The LDAP attribute mapped to user passwords in keystone. (string value) |
| #user_pass_attribute = userPassword |
| |
| # The LDAP attribute mapped to the user enabled attribute in keystone. If |
| # setting this option to `userAccountControl`, then you may be interested in |
| # setting `[ldap] user_enabled_mask` and `[ldap] user_enabled_default` as well. |
| # (string value) |
| #user_enabled_attribute = enabled |
| |
| # Logically negate the boolean value of the enabled attribute obtained from the |
| # LDAP server. Some LDAP servers use a boolean lock attribute where "true" |
| # means an account is disabled. Setting `[ldap] user_enabled_invert = true` |
| # will allow these lock attributes to be used. This option will have no effect |
| # if either the `[ldap] user_enabled_mask` or `[ldap] user_enabled_emulation` |
| # options are in use. (boolean value) |
| #user_enabled_invert = false |
| |
| # Bitmask integer to select which bit indicates the enabled value if the LDAP |
| # server represents "enabled" as a bit on an integer rather than as a discrete |
| # boolean. A value of `0` indicates that the mask is not used. If this is not |
| # set to `0` the typical value is `2`. This is typically used when `[ldap] |
| # user_enabled_attribute = userAccountControl`. Setting this option causes |
| # keystone to ignore the value of `[ldap] user_enabled_invert`. (integer value) |
| # Minimum value: 0 |
| #user_enabled_mask = 0 |
| |
| # The default value to enable users. This should match an appropriate integer |
| # value if the LDAP server uses non-boolean (bitmask) values to indicate if a |
| # user is enabled or disabled. If this is not set to `True`, then the typical |
| # value is `512`. This is typically used when `[ldap] user_enabled_attribute = |
| # userAccountControl`. (string value) |
| #user_enabled_default = True |
| |
| # DEPRECATED: List of user attributes to ignore on create and update. This is |
| # only used for write operations. (list value) |
| # This option is deprecated for removal since M. |
| # Its value may be silently ignored in the future. |
| # Reason: Write support for the LDAP identity backend has been deprecated in |
| # the Mitaka release and will be removed in the Ocata release. |
| #user_attribute_ignore = default_project_id |
| |
| # The LDAP attribute mapped to a user's default_project_id in keystone. This is |
| # most commonly used when keystone has write access to LDAP. (string value) |
| #user_default_project_id_attribute = <None> |
| |
| # DEPRECATED: If enabled, keystone is allowed to create users in the LDAP |
| # server. (boolean value) |
| # This option is deprecated for removal since M. |
| # Its value may be silently ignored in the future. |
| # Reason: Write support for the LDAP identity backend has been deprecated in |
| # the Mitaka release and will be removed in the Ocata release. |
| #user_allow_create = true |
| |
| # DEPRECATED: If enabled, keystone is allowed to update users in the LDAP |
| # server. (boolean value) |
| # This option is deprecated for removal since M. |
| # Its value may be silently ignored in the future. |
| # Reason: Write support for the LDAP identity backend has been deprecated in |
| # the Mitaka release and will be removed in the Ocata release. |
| #user_allow_update = true |
| |
| # DEPRECATED: If enabled, keystone is allowed to delete users in the LDAP |
| # server. (boolean value) |
| # This option is deprecated for removal since M. |
| # Its value may be silently ignored in the future. |
| # Reason: Write support for the LDAP identity backend has been deprecated in |
| # the Mitaka release and will be removed in the Ocata release. |
| #user_allow_delete = true |
| |
| # If enabled, keystone uses an alternative method to determine if a user is |
| # enabled or not by checking if they are a member of the group defined by the |
| # `[ldap] user_enabled_emulation_dn` option. Enabling this option causes |
| # keystone to ignore the value of `[ldap] user_enabled_invert`. (boolean value) |
| #user_enabled_emulation = false |
| |
| # DN of the group entry to hold enabled users when using enabled emulation. |
| # Setting this option has no effect unless `[ldap] user_enabled_emulation` is |
| # also enabled. (string value) |
| #user_enabled_emulation_dn = <None> |
| |
| # Use the `[ldap] group_member_attribute` and `[ldap] group_objectclass` |
| # settings to determine membership in the emulated enabled group. Enabling this |
| # option has no effect unless `[ldap] user_enabled_emulation` is also enabled. |
| # (boolean value) |
| #user_enabled_emulation_use_group_config = false |
| |
| # A list of LDAP attribute to keystone user attribute pairs used for mapping |
| # additional attributes to users in keystone. The expected format is |
| # `<ldap_attr>:<user_attr>`, where `ldap_attr` is the attribute in the LDAP |
| # object and `user_attr` is the attribute which should appear in the identity |
| # API. (list value) |
| #user_additional_attribute_mapping = |
| |
| # The search base to use for groups. Defaults to the `[ldap] suffix` value. |
| # (string value) |
| #group_tree_dn = <None> |
| |
| # The LDAP search filter to use for groups. (string value) |
| #group_filter = <None> |
| |
| # The LDAP object class to use for groups. If setting this option to |
| # `posixGroup`, you may also be interested in enabling the `[ldap] |
| # group_members_are_ids` option. (string value) |
| #group_objectclass = groupOfNames |
| |
| # The LDAP attribute mapped to group IDs in keystone. This must NOT be a |
| # multivalued attribute. Group IDs are expected to be globally unique across |
| # keystone domains and URL-safe. (string value) |
| #group_id_attribute = cn |
| |
| # The LDAP attribute mapped to group names in keystone. Group names are |
| # expected to be unique only within a keystone domain and are not expected to |
| # be URL-safe. (string value) |
| #group_name_attribute = ou |
| |
| # The LDAP attribute used to indicate that a user is a member of the group. |
| # (string value) |
| #group_member_attribute = member |
| |
| # Enable this option if the members of the group object class are keystone user |
| # IDs rather than LDAP DNs. This is the case when using `posixGroup` as the |
| # group object class in Open Directory. (boolean value) |
| #group_members_are_ids = false |
| |
| # The LDAP attribute mapped to group descriptions in keystone. (string value) |
| #group_desc_attribute = description |
| |
| # DEPRECATED: List of group attributes to ignore on create and update. This is |
| # only used for write operations. (list value) |
| # This option is deprecated for removal since M. |
| # Its value may be silently ignored in the future. |
| # Reason: Write support for the LDAP identity backend has been deprecated in |
| # the Mitaka release and will be removed in the Ocata release. |
| #group_attribute_ignore = |
| |
| # DEPRECATED: If enabled, keystone is allowed to create groups in the LDAP |
| # server. (boolean value) |
| # This option is deprecated for removal since M. |
| # Its value may be silently ignored in the future. |
| # Reason: Write support for the LDAP identity backend has been deprecated in |
| # the Mitaka release and will be removed in the Ocata release. |
| #group_allow_create = true |
| |
| # DEPRECATED: If enabled, keystone is allowed to update groups in the LDAP |
| # server. (boolean value) |
| # This option is deprecated for removal since M. |
| # Its value may be silently ignored in the future. |
| # Reason: Write support for the LDAP identity backend has been deprecated in |
| # the Mitaka release and will be removed in the Ocata release. |
| #group_allow_update = true |
| |
| # DEPRECATED: If enabled, keystone is allowed to delete groups in the LDAP |
| # server. (boolean value) |
| # This option is deprecated for removal since M. |
| # Its value may be silently ignored in the future. |
| # Reason: Write support for the LDAP identity backend has been deprecated in |
| # the Mitaka release and will be removed in the Ocata release. |
| #group_allow_delete = true |
| |
| # A list of LDAP attribute to keystone group attribute pairs used for mapping |
| # additional attributes to groups in keystone. The expected format is |
| # `<ldap_attr>:<group_attr>`, where `ldap_attr` is the attribute in the LDAP |
| # object and `group_attr` is the attribute which should appear in the identity |
| # API. (list value) |
| #group_additional_attribute_mapping = |
| |
| # An absolute path to a CA certificate file to use when communicating with LDAP |
| # servers. This option will take precedence over `[ldap] tls_cacertdir`, so |
| # there is no reason to set both. (string value) |
| #tls_cacertfile = <None> |
| |
| # An absolute path to a CA certificate directory to use when communicating with |
| # LDAP servers. There is no reason to set this option if you've also set |
| # `[ldap] tls_cacertfile`. (string value) |
| #tls_cacertdir = <None> |
| |
| # Enable TLS when communicating with LDAP servers. You should also set the |
| # `[ldap] tls_cacertfile` and `[ldap] tls_cacertdir` options when using this |
| # option. Do not set this option if you are using LDAP over SSL (LDAPS) instead |
| # of TLS. (boolean value) |
| #use_tls = false |
| |
| # Specifies which checks to perform against client certificates on incoming TLS |
| # sessions. If set to `demand`, then a certificate will always be requested and |
| # required from the LDAP server. If set to `allow`, then a certificate will |
| # always be requested but not required from the LDAP server. If set to `never`, |
| # then a certificate will never be requested. (string value) |
| # Allowed values: demand, never, allow |
| #tls_req_cert = demand |
| |
| # Enable LDAP connection pooling for queries to the LDAP server. There is |
| # typically no reason to disable this. (boolean value) |
| #use_pool = true |
| |
| # The size of the LDAP connection pool. This option has no effect unless |
| # `[ldap] use_pool` is also enabled. (integer value) |
| # Minimum value: 1 |
| #pool_size = 10 |
| |
| # The maximum number of times to attempt reconnecting to the LDAP server before |
| # aborting. A value of zero prevents retries. This option has no effect unless |
| # `[ldap] use_pool` is also enabled. (integer value) |
| # Minimum value: 0 |
| #pool_retry_max = 3 |
| |
| # The number of seconds to wait before attempting to reconnect to the LDAP |
| # server. This option has no effect unless `[ldap] use_pool` is also enabled. |
| # (floating point value) |
| #pool_retry_delay = 0.1 |
| |
| # The connection timeout to use with the LDAP server. A value of `-1` means |
| # that connections will never timeout. This option has no effect unless `[ldap] |
| # use_pool` is also enabled. (integer value) |
| # Minimum value: -1 |
| #pool_connection_timeout = -1 |
| |
| # The maximum connection lifetime to the LDAP server in seconds. When this |
| # lifetime is exceeded, the connection will be unbound and removed from the |
| # connection pool. This option has no effect unless `[ldap] use_pool` is also |
| # enabled. (integer value) |
| # Minimum value: 1 |
| #pool_connection_lifetime = 600 |
| |
| # Enable LDAP connection pooling for end user authentication. There is |
| # typically no reason to disable this. (boolean value) |
| #use_auth_pool = true |
| |
| # The size of the connection pool to use for end user authentication. This |
| # option has no effect unless `[ldap] use_auth_pool` is also enabled. (integer |
| # value) |
| # Minimum value: 1 |
| #auth_pool_size = 100 |
| |
| # The maximum end user authentication connection lifetime to the LDAP server in |
| # seconds. When this lifetime is exceeded, the connection will be unbound and |
| # removed from the connection pool. This option has no effect unless `[ldap] |
| # use_auth_pool` is also enabled. (integer value) |
| # Minimum value: 1 |
| #auth_pool_connection_lifetime = 60 |
| |
| |
| [matchmaker_redis] |
| |
| # |
| # From oslo.messaging |
| # |
| |
| # DEPRECATED: Host to locate redis. (string value) |
| # This option is deprecated for removal. |
| # Its value may be silently ignored in the future. |
| # Reason: Replaced by [DEFAULT]/transport_url |
| #host = 127.0.0.1 |
| |
| # DEPRECATED: Use this port to connect to redis host. (port value) |
| # Minimum value: 0 |
| # Maximum value: 65535 |
| # This option is deprecated for removal. |
| # Its value may be silently ignored in the future. |
| # Reason: Replaced by [DEFAULT]/transport_url |
| #port = 6379 |
| |
| # DEPRECATED: Password for Redis server (optional). (string value) |
| # This option is deprecated for removal. |
| # Its value may be silently ignored in the future. |
| # Reason: Replaced by [DEFAULT]/transport_url |
| #password = |
| |
| # DEPRECATED: List of Redis Sentinel hosts (fault tolerance mode) e.g. |
| # [host:port, host1:port ... ] (list value) |
| # This option is deprecated for removal. |
| # Its value may be silently ignored in the future. |
| # Reason: Replaced by [DEFAULT]/transport_url |
| #sentinel_hosts = |
| |
| # Redis replica set name. (string value) |
| #sentinel_group_name = oslo-messaging-zeromq |
| |
| # Time in ms to wait between connection attempts. (integer value) |
| #wait_timeout = 2000 |
| |
| # Time in ms to wait before the transaction is killed. (integer value) |
| #check_timeout = 20000 |
| |
| # Timeout in ms on blocking socket operations (integer value) |
| #socket_timeout = 10000 |
| |
| |
| [memcache] |
| |
| # |
| # From keystone |
| # |
| |
| # Comma-separated list of memcached servers in the format of |
| # `host:port,host:port` that keystone should use for the `memcache` token |
| # persistence provider and other memcache-backed KVS drivers. This |
| # configuration value is NOT used for intermediary caching between keystone and |
| # other backends, such as SQL and LDAP (for that, see the `[cache]` section). |
| # Multiple keystone servers in the same deployment should use the same set of |
| # memcached servers to ensure that data (such as UUID tokens) created by one |
| # node is available to the others. (list value) |
| #servers = localhost:11211 |
| {%- if server.cache is defined %} |
| {%- if server.cache.members is defined %} |
| servers = {%- for member in server.cache.members %}{{ member.host }}:{{ member.port }}{% if not loop.last %},{% endif %}{%- endfor %} |
| {%- else %} |
| servers = ['{{ server.cache.host }}:{{ server.cache.port }}'] |
| {%- endif %} |
| {%- endif %} |
| |
| # Number of seconds memcached server is considered dead before it is tried |
| # again. This is used by the key value store system (including, the `memcache` |
| # and `memcache_pool` options for the `[token] driver` persistence backend). |
| # (integer value) |
| #dead_retry = 300 |
| |
| # Timeout in seconds for every call to a server. This is used by the key value |
| # store system (including, the `memcache` and `memcache_pool` options for the |
| # `[token] driver` persistence backend). (integer value) |
| #socket_timeout = 3 |
| |
| # Max total number of open connections to every memcached server. This is used |
| # by the key value store system (including, the `memcache` and `memcache_pool` |
| # options for the `[token] driver` persistence backend). (integer value) |
| #pool_maxsize = 10 |
| |
| # Number of seconds a connection to memcached is held unused in the pool before |
| # it is closed. This is used by the key value store system (including, the |
| # `memcache` and `memcache_pool` options for the `[token] driver` persistence |
| # backend). (integer value) |
| #pool_unused_timeout = 60 |
| |
| # Number of seconds that an operation will wait to get a memcache client |
| # connection. This is used by the key value store system (including, the |
| # `memcache` and `memcache_pool` options for the `[token] driver` persistence |
| # backend). (integer value) |
| #pool_connection_get_timeout = 10 |
| |
| |
| [oauth1] |
| |
| # |
| # From keystone |
| # |
| |
| # Entry point for the OAuth backend driver in the `keystone.oauth1` namespace. |
| # Typically, there is no reason to set this option unless you are providing a |
| # custom entry point. (string value) |
| #driver = sql |
| |
| # Number of seconds for the OAuth Request Token to remain valid after being |
| # created. This is the amount of time the user has to authorize the token. |
| # Setting this option to zero means that request tokens will last forever. |
| # (integer value) |
| # Minimum value: 0 |
| #request_token_duration = 28800 |
| |
| # Number of seconds for the OAuth Access Token to remain valid after being |
| # created. This is the amount of time the consumer has to interact with the |
| # service provider (which is typically keystone). Setting this option to zero |
| # means that access tokens will last forever. (integer value) |
| # Minimum value: 0 |
| #access_token_duration = 86400 |
| |
| |
| [os_inherit] |
| |
| # |
| # From keystone |
| # |
| |
| # DEPRECATED: This allows domain-based role assignments to be inherited to |
| # projects owned by that domain, or from parent projects to child projects. |
| # (boolean value) |
| # This option is deprecated for removal since M. |
| # Its value may be silently ignored in the future. |
| # Reason: The option to disable the OS-INHERIT functionality has been |
| # deprecated in the Mitaka release and will be removed in the Ocata release. |
| # Starting in the Ocata release, OS-INHERIT functionality will always be |
| # enabled. |
| #enabled = true |
| |
| |
| [oslo_messaging_amqp] |
| |
| # |
| # From oslo.messaging |
| # |
| |
| # Name for the AMQP container. must be globally unique. Defaults to a generated |
| # UUID (string value) |
| # Deprecated group/name - [amqp1]/container_name |
| #container_name = <None> |
| |
| # Timeout for inactive connections (in seconds) (integer value) |
| # Deprecated group/name - [amqp1]/idle_timeout |
| #idle_timeout = 0 |
| |
| # Debug: dump AMQP frames to stdout (boolean value) |
| # Deprecated group/name - [amqp1]/trace |
| #trace = false |
| |
| # CA certificate PEM file to verify server certificate (string value) |
| # Deprecated group/name - [amqp1]/ssl_ca_file |
| #ssl_ca_file = |
| |
| # Identifying certificate PEM file to present to clients (string value) |
| # Deprecated group/name - [amqp1]/ssl_cert_file |
| #ssl_cert_file = |
| |
| # Private key PEM file used to sign cert_file certificate (string value) |
| # Deprecated group/name - [amqp1]/ssl_key_file |
| #ssl_key_file = |
| |
| # Password for decrypting ssl_key_file (if encrypted) (string value) |
| # Deprecated group/name - [amqp1]/ssl_key_password |
| #ssl_key_password = <None> |
| |
| # Accept clients using either SSL or plain TCP (boolean value) |
| # Deprecated group/name - [amqp1]/allow_insecure_clients |
| #allow_insecure_clients = false |
| |
| # Space separated list of acceptable SASL mechanisms (string value) |
| # Deprecated group/name - [amqp1]/sasl_mechanisms |
| #sasl_mechanisms = |
| |
| # Path to directory that contains the SASL configuration (string value) |
| # Deprecated group/name - [amqp1]/sasl_config_dir |
| #sasl_config_dir = |
| |
| # Name of configuration file (without .conf suffix) (string value) |
| # Deprecated group/name - [amqp1]/sasl_config_name |
| #sasl_config_name = |
| |
| # User name for message broker authentication (string value) |
| # Deprecated group/name - [amqp1]/username |
| #username = |
| |
| # Password for message broker authentication (string value) |
| # Deprecated group/name - [amqp1]/password |
| #password = |
| |
| # Seconds to pause before attempting to re-connect. (integer value) |
| # Minimum value: 1 |
| #connection_retry_interval = 1 |
| |
| # Increase the connection_retry_interval by this many seconds after each |
| # unsuccessful failover attempt. (integer value) |
| # Minimum value: 0 |
| #connection_retry_backoff = 2 |
| |
| # Maximum limit for connection_retry_interval + connection_retry_backoff |
| # (integer value) |
| # Minimum value: 1 |
| #connection_retry_interval_max = 30 |
| |
| # Time to pause between re-connecting an AMQP 1.0 link that failed due to a |
| # recoverable error. (integer value) |
| # Minimum value: 1 |
| #link_retry_delay = 10 |
| |
| # The deadline for an rpc reply message delivery. Only used when caller does |
| # not provide a timeout expiry. (integer value) |
| # Minimum value: 5 |
| #default_reply_timeout = 30 |
| |
| # The deadline for an rpc cast or call message delivery. Only used when caller |
| # does not provide a timeout expiry. (integer value) |
| # Minimum value: 5 |
| #default_send_timeout = 30 |
| |
| # The deadline for a sent notification message delivery. Only used when caller |
| # does not provide a timeout expiry. (integer value) |
| # Minimum value: 5 |
| #default_notify_timeout = 30 |
| |
| # Indicates the addressing mode used by the driver. |
| # Permitted values: |
| # 'legacy' - use legacy non-routable addressing |
| # 'routable' - use routable addresses |
| # 'dynamic' - use legacy addresses if the message bus does not support routing |
| # otherwise use routable addressing (string value) |
| #addressing_mode = dynamic |
| |
| # address prefix used when sending to a specific server (string value) |
| # Deprecated group/name - [amqp1]/server_request_prefix |
| #server_request_prefix = exclusive |
| |
| # address prefix used when broadcasting to all servers (string value) |
| # Deprecated group/name - [amqp1]/broadcast_prefix |
| #broadcast_prefix = broadcast |
| |
| # address prefix when sending to any server in group (string value) |
| # Deprecated group/name - [amqp1]/group_request_prefix |
| #group_request_prefix = unicast |
| |
| # Address prefix for all generated RPC addresses (string value) |
| #rpc_address_prefix = openstack.org/om/rpc |
| |
| # Address prefix for all generated Notification addresses (string value) |
| #notify_address_prefix = openstack.org/om/notify |
| |
| # Appended to the address prefix when sending a fanout message. Used by the |
| # message bus to identify fanout messages. (string value) |
| #multicast_address = multicast |
| |
| # Appended to the address prefix when sending to a particular RPC/Notification |
| # server. Used by the message bus to identify messages sent to a single |
| # destination. (string value) |
| #unicast_address = unicast |
| |
| # Appended to the address prefix when sending to a group of consumers. Used by |
| # the message bus to identify messages that should be delivered in a round- |
| # robin fashion across consumers. (string value) |
| #anycast_address = anycast |
| |
| # Exchange name used in notification addresses. |
| # Exchange name resolution precedence: |
| # Target.exchange if set |
| # else default_notification_exchange if set |
| # else control_exchange if set |
| # else 'notify' (string value) |
| #default_notification_exchange = <None> |
| |
| # Exchange name used in RPC addresses. |
| # Exchange name resolution precedence: |
| # Target.exchange if set |
| # else default_rpc_exchange if set |
| # else control_exchange if set |
| # else 'rpc' (string value) |
| #default_rpc_exchange = <None> |
| |
| # Window size for incoming RPC Reply messages. (integer value) |
| # Minimum value: 1 |
| #reply_link_credit = 200 |
| |
| # Window size for incoming RPC Request messages (integer value) |
| # Minimum value: 1 |
| #rpc_server_credit = 100 |
| |
| # Window size for incoming Notification messages (integer value) |
| # Minimum value: 1 |
| #notify_server_credit = 100 |
| |
| |
| [oslo_messaging_notifications] |
| |
| # |
| # From oslo.messaging |
| # |
| |
| # The Drivers(s) to handle sending notifications. Possible values are |
| # messaging, messagingv2, routing, log, test, noop (multi valued) |
| # Deprecated group/name - [DEFAULT]/notification_driver |
| #driver = |
| {%- if server.notification is mapping %} |
| driver = {{ server.notification.get('driver', 'messagingv2') }} |
| {%- if server.notification.topics is defined %} |
| topics = {{ server.notification.topics }} |
| {%- endif %} |
| {%- elif server.notification %} |
| driver=messagingv2 |
| {%- endif %} |
| |
| # A URL representing the messaging driver to use for notifications. If not set, |
| # we fall back to the same configuration used for RPC. (string value) |
| # Deprecated group/name - [DEFAULT]/notification_transport_url |
| #transport_url = <None> |
| |
| # AMQP topic used for OpenStack notifications. (list value) |
| # Deprecated group/name - [rpc_notifier2]/topics |
| # Deprecated group/name - [DEFAULT]/notification_topics |
| #topics = notifications |
| |
| |
| [oslo_messaging_rabbit] |
| |
| # |
| # From oslo.messaging |
| # |
| |
| {%- if server.notification %} |
| |
| {%- if server.message_queue.get('ssl',{}).get('enabled', False) %} |
| rabbit_use_ssl=true |
| |
| {%- if server.message_queue.ssl.version is defined %} |
| kombu_ssl_version = {{ server.message_queue.ssl.version }} |
| {%- elif salt['grains.get']('pythonversion') > [2,7,8] %} |
| kombu_ssl_version = TLSv1_2 |
| {%- endif %} |
| |
| kombu_ssl_ca_certs = {{ server.message_queue.ssl.get('cacert_file', server.cacert_file) }} |
| {%- endif %} |
| |
| {%- endif %} |
| |
| # Use durable queues in AMQP. (boolean value) |
| # Deprecated group/name - [DEFAULT]/amqp_durable_queues |
| # Deprecated group/name - [DEFAULT]/rabbit_durable_queues |
| #amqp_durable_queues = false |
| |
| # Auto-delete queues in AMQP. (boolean value) |
| # Deprecated group/name - [DEFAULT]/amqp_auto_delete |
| #amqp_auto_delete = false |
| |
| # SSL version to use (valid only if SSL enabled). Valid values are TLSv1 and |
| # SSLv23. SSLv2, SSLv3, TLSv1_1, and TLSv1_2 may be available on some |
| # distributions. (string value) |
| # Deprecated group/name - [DEFAULT]/kombu_ssl_version |
| #kombu_ssl_version = |
| |
| # SSL key file (valid only if SSL enabled). (string value) |
| # Deprecated group/name - [DEFAULT]/kombu_ssl_keyfile |
| #kombu_ssl_keyfile = |
| |
| # SSL cert file (valid only if SSL enabled). (string value) |
| # Deprecated group/name - [DEFAULT]/kombu_ssl_certfile |
| #kombu_ssl_certfile = |
| |
| # SSL certification authority file (valid only if SSL enabled). (string value) |
| # Deprecated group/name - [DEFAULT]/kombu_ssl_ca_certs |
| #kombu_ssl_ca_certs = |
| |
| # How long to wait before reconnecting in response to an AMQP consumer cancel |
| # notification. (floating point value) |
| # Deprecated group/name - [DEFAULT]/kombu_reconnect_delay |
| #kombu_reconnect_delay = 1.0 |
| |
| # EXPERIMENTAL: Possible values are: gzip, bz2. If not set compression will not |
| # be used. This option may not be available in future versions. (string value) |
| #kombu_compression = <None> |
| |
| # How long to wait a missing client before abandoning to send it its replies. |
| # This value should not be longer than rpc_response_timeout. (integer value) |
| # Deprecated group/name - [oslo_messaging_rabbit]/kombu_reconnect_timeout |
| #kombu_missing_consumer_retry_timeout = 60 |
| |
| # Determines how the next RabbitMQ node is chosen in case the one we are |
| # currently connected to becomes unavailable. Takes effect only if more than |
| # one RabbitMQ node is provided in config. (string value) |
| # Allowed values: round-robin, shuffle |
| #kombu_failover_strategy = round-robin |
| |
| # DEPRECATED: The RabbitMQ broker address where a single node is used. (string |
| # value) |
| # Deprecated group/name - [DEFAULT]/rabbit_host |
| # This option is deprecated for removal. |
| # Its value may be silently ignored in the future. |
| # Reason: Replaced by [DEFAULT]/transport_url |
| #rabbit_host = localhost |
| |
| # DEPRECATED: The RabbitMQ broker port where a single node is used. (port |
| # value) |
| # Minimum value: 0 |
| # Maximum value: 65535 |
| # Deprecated group/name - [DEFAULT]/rabbit_port |
| # This option is deprecated for removal. |
| # Its value may be silently ignored in the future. |
| # Reason: Replaced by [DEFAULT]/transport_url |
| #rabbit_port = 5672 |
| |
| # DEPRECATED: RabbitMQ HA cluster host:port pairs. (list value) |
| # Deprecated group/name - [DEFAULT]/rabbit_hosts |
| # This option is deprecated for removal. |
| # Its value may be silently ignored in the future. |
| # Reason: Replaced by [DEFAULT]/transport_url |
| #rabbit_hosts = $rabbit_host:$rabbit_port |
| |
| # Connect over SSL for RabbitMQ. (boolean value) |
| # Deprecated group/name - [DEFAULT]/rabbit_use_ssl |
| #rabbit_use_ssl = false |
| |
| # DEPRECATED: The RabbitMQ userid. (string value) |
| # Deprecated group/name - [DEFAULT]/rabbit_userid |
| # This option is deprecated for removal. |
| # Its value may be silently ignored in the future. |
| # Reason: Replaced by [DEFAULT]/transport_url |
| #rabbit_userid = guest |
| |
| # DEPRECATED: The RabbitMQ password. (string value) |
| # Deprecated group/name - [DEFAULT]/rabbit_password |
| # This option is deprecated for removal. |
| # Its value may be silently ignored in the future. |
| # Reason: Replaced by [DEFAULT]/transport_url |
| #rabbit_password = guest |
| |
| # The RabbitMQ login method. (string value) |
| # Deprecated group/name - [DEFAULT]/rabbit_login_method |
| #rabbit_login_method = AMQPLAIN |
| |
| # DEPRECATED: The RabbitMQ virtual host. (string value) |
| # Deprecated group/name - [DEFAULT]/rabbit_virtual_host |
| # This option is deprecated for removal. |
| # Its value may be silently ignored in the future. |
| # Reason: Replaced by [DEFAULT]/transport_url |
| #rabbit_virtual_host = / |
| |
| # How frequently to retry connecting with RabbitMQ. (integer value) |
| #rabbit_retry_interval = 1 |
| |
| # How long to backoff for between retries when connecting to RabbitMQ. (integer |
| # value) |
| # Deprecated group/name - [DEFAULT]/rabbit_retry_backoff |
| #rabbit_retry_backoff = 2 |
| |
| # Maximum interval of RabbitMQ connection retries. Default is 30 seconds. |
| # (integer value) |
| #rabbit_interval_max = 30 |
| |
| # DEPRECATED: Maximum number of RabbitMQ connection retries. Default is 0 |
| # (infinite retry count). (integer value) |
| # Deprecated group/name - [DEFAULT]/rabbit_max_retries |
| # This option is deprecated for removal. |
| # Its value may be silently ignored in the future. |
| #rabbit_max_retries = 0 |
| |
| # Try to use HA queues in RabbitMQ (x-ha-policy: all). If you change this |
| # option, you must wipe the RabbitMQ database. In RabbitMQ 3.0, queue mirroring |
| # is no longer controlled by the x-ha-policy argument when declaring a queue. |
| # If you just want to make sure that all queues (except those with auto- |
| # generated names) are mirrored across all nodes, run: "rabbitmqctl set_policy |
| # HA '^(?!amq\.).*' '{"ha-mode": "all"}' " (boolean value) |
| # Deprecated group/name - [DEFAULT]/rabbit_ha_queues |
| #rabbit_ha_queues = false |
| |
| # Positive integer representing duration in seconds for queue TTL (x-expires). |
| # Queues which are unused for the duration of the TTL are automatically |
| # deleted. The parameter affects only reply and fanout queues. (integer value) |
| # Minimum value: 1 |
| #rabbit_transient_queues_ttl = 1800 |
| |
| # Specifies the number of messages to prefetch. Setting to zero allows |
| # unlimited messages. (integer value) |
| #rabbit_qos_prefetch_count = 0 |
| |
| # Number of seconds after which the Rabbit broker is considered down if |
| # heartbeat's keep-alive fails (0 disable the heartbeat). EXPERIMENTAL (integer |
| # value) |
| #heartbeat_timeout_threshold = 60 |
| heartbeat_timeout_threshold = 0 |
| |
| # How often times during the heartbeat_timeout_threshold we check the |
| # heartbeat. (integer value) |
| #heartbeat_rate = 2 |
| heartbeat_rate = 2 |
| |
| # Deprecated, use rpc_backend=kombu+memory or rpc_backend=fake (boolean value) |
| # Deprecated group/name - [DEFAULT]/fake_rabbit |
| #fake_rabbit = false |
| |
| # Maximum number of channels to allow (integer value) |
| #channel_max = <None> |
| |
| # The maximum byte size for an AMQP frame (integer value) |
| #frame_max = <None> |
| |
| # How often to send heartbeats for consumer's connections (integer value) |
| #heartbeat_interval = 3 |
| |
| # Enable SSL (boolean value) |
| #ssl = <None> |
| |
| # Arguments passed to ssl.wrap_socket (dict value) |
| #ssl_options = <None> |
| |
| # Set socket timeout in seconds for connection's socket (floating point value) |
| #socket_timeout = 0.25 |
| |
| # Set TCP_USER_TIMEOUT in seconds for connection's socket (floating point |
| # value) |
| #tcp_user_timeout = 0.25 |
| |
| # Set delay for reconnection to some host which has connection error (floating |
| # point value) |
| #host_connection_reconnect_delay = 0.25 |
| |
| # Connection factory implementation (string value) |
| # Allowed values: new, single, read_write |
| #connection_factory = single |
| |
| # Maximum number of connections to keep queued. (integer value) |
| #pool_max_size = 30 |
| |
| # Maximum number of connections to create above `pool_max_size`. (integer |
| # value) |
| #pool_max_overflow = 0 |
| |
| # Default number of seconds to wait for a connections to available (integer |
| # value) |
| #pool_timeout = 30 |
| |
| # Lifetime of a connection (since creation) in seconds or None for no |
| # recycling. Expired connections are closed on acquire. (integer value) |
| #pool_recycle = 600 |
| |
| # Threshold at which inactive (since release) connections are considered stale |
| # in seconds or None for no staleness. Stale connections are closed on acquire. |
| # (integer value) |
| #pool_stale = 60 |
| |
| # Persist notification messages. (boolean value) |
| #notification_persistence = false |
| |
| # Exchange name for sending notifications (string value) |
| #default_notification_exchange = ${control_exchange}_notification |
| |
| # Max number of not acknowledged message which RabbitMQ can send to |
| # notification listener. (integer value) |
| #notification_listener_prefetch_count = 100 |
| |
| # Reconnecting retry count in case of connectivity problem during sending |
| # notification, -1 means infinite retry. (integer value) |
| #default_notification_retry_attempts = -1 |
| |
| # Reconnecting retry delay in case of connectivity problem during sending |
| # notification message (floating point value) |
| #notification_retry_delay = 0.25 |
| |
| # Time to live for rpc queues without consumers in seconds. (integer value) |
| #rpc_queue_expiration = 60 |
| |
| # Exchange name for sending RPC messages (string value) |
| #default_rpc_exchange = ${control_exchange}_rpc |
| |
| # Exchange name for receiving RPC replies (string value) |
| #rpc_reply_exchange = ${control_exchange}_rpc_reply |
| |
| # Max number of not acknowledged message which RabbitMQ can send to rpc |
| # listener. (integer value) |
| #rpc_listener_prefetch_count = 100 |
| |
| # Max number of not acknowledged message which RabbitMQ can send to rpc reply |
| # listener. (integer value) |
| #rpc_reply_listener_prefetch_count = 100 |
| |
| # Reconnecting retry count in case of connectivity problem during sending |
| # reply. -1 means infinite retry during rpc_timeout (integer value) |
| #rpc_reply_retry_attempts = -1 |
| |
| # Reconnecting retry delay in case of connectivity problem during sending |
| # reply. (floating point value) |
| #rpc_reply_retry_delay = 0.25 |
| |
| # Reconnecting retry count in case of connectivity problem during sending RPC |
| # message, -1 means infinite retry. If actual retry attempts in not 0 the rpc |
| # request could be processed more then one time (integer value) |
| #default_rpc_retry_attempts = -1 |
| |
| # Reconnecting retry delay in case of connectivity problem during sending RPC |
| # message (floating point value) |
| #rpc_retry_delay = 0.25 |
| |
| [oslo_messaging_zmq] |
| |
| # |
| # From oslo.messaging |
| # |
| |
| # ZeroMQ bind address. Should be a wildcard (*), an ethernet interface, or IP. |
| # The "host" option should point or resolve to this address. (string value) |
| # Deprecated group/name - [DEFAULT]/rpc_zmq_bind_address |
| #rpc_zmq_bind_address = * |
| |
| # MatchMaker driver. (string value) |
| # Allowed values: redis, dummy |
| # Deprecated group/name - [DEFAULT]/rpc_zmq_matchmaker |
| #rpc_zmq_matchmaker = redis |
| |
| # Number of ZeroMQ contexts, defaults to 1. (integer value) |
| # Deprecated group/name - [DEFAULT]/rpc_zmq_contexts |
| #rpc_zmq_contexts = 1 |
| |
| # Maximum number of ingress messages to locally buffer per topic. Default is |
| # unlimited. (integer value) |
| # Deprecated group/name - [DEFAULT]/rpc_zmq_topic_backlog |
| #rpc_zmq_topic_backlog = <None> |
| |
| # Directory for holding IPC sockets. (string value) |
| # Deprecated group/name - [DEFAULT]/rpc_zmq_ipc_dir |
| #rpc_zmq_ipc_dir = /var/run/openstack |
| |
| # Name of this node. Must be a valid hostname, FQDN, or IP address. Must match |
| # "host" option, if running Nova. (string value) |
| # Deprecated group/name - [DEFAULT]/rpc_zmq_host |
| #rpc_zmq_host = localhost |
| |
| # Seconds to wait before a cast expires (TTL). The default value of -1 |
| # specifies an infinite linger period. The value of 0 specifies no linger |
| # period. Pending messages shall be discarded immediately when the socket is |
| # closed. Only supported by impl_zmq. (integer value) |
| # Deprecated group/name - [DEFAULT]/rpc_cast_timeout |
| #rpc_cast_timeout = -1 |
| |
| # The default number of seconds that poll should wait. Poll raises timeout |
| # exception when timeout expired. (integer value) |
| # Deprecated group/name - [DEFAULT]/rpc_poll_timeout |
| #rpc_poll_timeout = 1 |
| |
| # Expiration timeout in seconds of a name service record about existing target |
| # ( < 0 means no timeout). (integer value) |
| # Deprecated group/name - [DEFAULT]/zmq_target_expire |
| #zmq_target_expire = 300 |
| |
| # Update period in seconds of a name service record about existing target. |
| # (integer value) |
| # Deprecated group/name - [DEFAULT]/zmq_target_update |
| #zmq_target_update = 180 |
| |
| # Use PUB/SUB pattern for fanout methods. PUB/SUB always uses proxy. (boolean |
| # value) |
| # Deprecated group/name - [DEFAULT]/use_pub_sub |
| #use_pub_sub = true |
| |
| # Use ROUTER remote proxy. (boolean value) |
| # Deprecated group/name - [DEFAULT]/use_router_proxy |
| #use_router_proxy = true |
| |
| # Minimal port number for random ports range. (port value) |
| # Minimum value: 0 |
| # Maximum value: 65535 |
| # Deprecated group/name - [DEFAULT]/rpc_zmq_min_port |
| #rpc_zmq_min_port = 49153 |
| |
| # Maximal port number for random ports range. (integer value) |
| # Minimum value: 1 |
| # Maximum value: 65536 |
| # Deprecated group/name - [DEFAULT]/rpc_zmq_max_port |
| #rpc_zmq_max_port = 65536 |
| |
| # Number of retries to find free port number before fail with ZMQBindError. |
| # (integer value) |
| # Deprecated group/name - [DEFAULT]/rpc_zmq_bind_port_retries |
| #rpc_zmq_bind_port_retries = 100 |
| |
| # Default serialization mechanism for serializing/deserializing |
| # outgoing/incoming messages (string value) |
| # Allowed values: json, msgpack |
| # Deprecated group/name - [DEFAULT]/rpc_zmq_serialization |
| #rpc_zmq_serialization = json |
| |
| # This option configures round-robin mode in zmq socket. True means not keeping |
| # a queue when server side disconnects. False means to keep queue and messages |
| # even if server is disconnected, when the server appears we send all |
| # accumulated messages to it. (boolean value) |
| #zmq_immediate = false |
| |
| |
| [oslo_middleware] |
| |
| # |
| # From oslo.middleware |
| # |
| |
| # The maximum body size for each request, in bytes. (integer value) |
| # Deprecated group/name - [DEFAULT]/osapi_max_request_body_size |
| # Deprecated group/name - [DEFAULT]/max_request_body_size |
| max_request_body_size= {{ server.max_request_body_size }} |
| |
| # DEPRECATED: The HTTP Header that will be used to determine what the original |
| # request protocol scheme was, even if it was hidden by a SSL termination |
| # proxy. (string value) |
| # This option is deprecated for removal. |
| # Its value may be silently ignored in the future. |
| #secure_proxy_ssl_header = X-Forwarded-Proto |
| |
| # Whether the application is behind a proxy or not. This determines if the |
| # middleware should parse the headers or not. (boolean value) |
| #enable_proxy_headers_parsing = false |
| {%- if server.enable_proxy_headers_parsing is defined %} |
| enable_proxy_headers_parsing = {{ server.enable_proxy_headers_parsing }} |
| {%- endif %} |
| |
| |
| [oslo_policy] |
| |
| # |
| # From oslo.policy |
| # |
| |
| # The JSON file that defines policies. (string value) |
| # Deprecated group/name - [DEFAULT]/policy_file |
| #policy_file = policy.json |
| |
| # Default rule. Enforced when a requested rule is not found. (string value) |
| # Deprecated group/name - [DEFAULT]/policy_default_rule |
| #policy_default_rule = default |
| |
| # Directories where policy configuration files are stored. They can be relative |
| # to any directory in the search path defined by the config_dir option, or |
| # absolute paths. The file defined by policy_file must exist for these |
| # directories to be searched. Missing or empty directories are ignored. (multi |
| # valued) |
| # Deprecated group/name - [DEFAULT]/policy_dirs |
| #policy_dirs = policy.d |
| |
| |
| [paste_deploy] |
| |
| # |
| # From keystone |
| # |
| |
| # Name of (or absolute path to) the Paste Deploy configuration file that |
| # composes middleware and the keystone application itself into actual WSGI |
| # entry points. See http://pythonpaste.org/deploy/ for additional documentation |
| # on the file's format. (string value) |
| #config_file = keystone-paste.ini |
| |
| |
| [policy] |
| |
| # |
| # From keystone |
| # |
| |
| # Entry point for the policy backend driver in the `keystone.policy` namespace. |
| # Supplied drivers are `rules` (which does not support any CRUD operations for |
| # the v3 policy API) and `sql`. Typically, there is no reason to set this |
| # option unless you are providing a custom entry point. (string value) |
| #driver = sql |
| driver = keystone.policy.backends.sql.Policy |
| |
| # Maximum number of entities that will be returned in a policy collection. |
| # (integer value) |
| #list_limit = <None> |
| |
| |
| [profiler] |
| |
| # |
| # From osprofiler |
| # |
| |
| # |
| # Enables the profiling for all services on this node. Default value is False |
| # (fully disable the profiling feature). |
| # |
| # Possible values: |
| # |
| # * True: Enables the feature |
| # * False: Disables the feature. The profiling cannot be started via this |
| # project |
| # operations. If the profiling is triggered by another project, this project |
| # part |
| # will be empty. |
| # (boolean value) |
| # Deprecated group/name - [profiler]/profiler_enabled |
| #enabled = false |
| |
| # |
| # Enables SQL requests profiling in services. Default value is False (SQL |
| # requests won't be traced). |
| # |
| # Possible values: |
| # |
| # * True: Enables SQL requests profiling. Each SQL query will be part of the |
| # trace and can the be analyzed by how much time was spent for that. |
| # * False: Disables SQL requests profiling. The spent time is only shown on a |
| # higher level of operations. Single SQL queries cannot be analyzed this |
| # way. |
| # (boolean value) |
| #trace_sqlalchemy = false |
| |
| # |
| # Secret key(s) to use for encrypting context data for performance profiling. |
| # This string value should have the following format: |
| # <key1>[,<key2>,...<keyn>], |
| # where each key is some random string. A user who triggers the profiling via |
| # the REST API has to set one of these keys in the headers of the REST API call |
| # to include profiling results of this node for this particular project. |
| # |
| # Both "enabled" flag and "hmac_keys" config options should be set to enable |
| # profiling. Also, to generate correct profiling information across all |
| # services |
| # at least one key needs to be consistent between OpenStack projects. This |
| # ensures it can be used from client side to generate the trace, containing |
| # information from all possible resources. (string value) |
| #hmac_keys = SECRET_KEY |
| |
| # |
| # Connection string for a notifier backend. Default value is messaging:// which |
| # sets the notifier to oslo_messaging. |
| # |
| # Examples of possible values: |
| # |
| # * messaging://: use oslo_messaging driver for sending notifications. |
| # (string value) |
| #connection_string = messaging:// |
| |
| |
| [resource] |
| |
| # |
| # From keystone |
| # |
| |
| # Entry point for the resource driver in the `keystone.resource` namespace. |
| # Only a `sql` driver is supplied by keystone. If a resource driver is not |
| # specified, the assignment driver will choose the resource driver to maintain |
| # backwards compatibility with older configuration files. (string value) |
| #driver = <None> |
| |
| # Toggle for resource caching. This has no effect unless global caching is |
| # enabled. (boolean value) |
| # Deprecated group/name - [assignment]/caching |
| #caching = true |
| |
| # Time to cache resource data in seconds. This has no effect unless global |
| # caching is enabled. (integer value) |
| # Deprecated group/name - [assignment]/cache_time |
| #cache_time = <None> |
| |
| # Maximum number of entities that will be returned in a resource collection. |
| # (integer value) |
| # Deprecated group/name - [assignment]/list_limit |
| #list_limit = <None> |
| |
| # Name of the domain that owns the `admin_project_name`. If left unset, then |
| # there is no admin project. `[resource] admin_project_name` must also be set |
| # to use this option. (string value) |
| #admin_project_domain_name = <None> |
| |
| # This is a special project which represents cloud-level administrator |
| # privileges across services. Tokens scoped to this project will contain a true |
| # `is_admin_project` attribute to indicate to policy systems that the role |
| # assignments on that specific project should apply equally across every |
| # project. If left unset, then there is no admin project, and thus no explicit |
| # means of cross-project role assignments. `[resource] |
| # admin_project_domain_name` must also be set to use this option. (string |
| # value) |
| #admin_project_name = <None> |
| |
| # This controls whether the names of projects are restricted from containing |
| # URL-reserved characters. If set to `new`, attempts to create or update a |
| # project with a URL-unsafe name will fail. If set to `strict`, attempts to |
| # scope a token with a URL-unsafe project name will fail, thereby forcing all |
| # project names to be updated to be URL-safe. (string value) |
| # Allowed values: off, new, strict |
| #project_name_url_safe = off |
| |
| # This controls whether the names of domains are restricted from containing |
| # URL-reserved characters. If set to `new`, attempts to create or update a |
| # domain with a URL-unsafe name will fail. If set to `strict`, attempts to |
| # scope a token with a URL-unsafe domain name will fail, thereby forcing all |
| # domain names to be updated to be URL-safe. (string value) |
| # Allowed values: off, new, strict |
| #domain_name_url_safe = off |
| |
| |
| [revoke] |
| |
| # |
| # From keystone |
| # |
| |
| # Entry point for the token revocation backend driver in the `keystone.revoke` |
| # namespace. Keystone only provides a `sql` driver, so there is no reason to |
| # set this option unless you are providing a custom entry point. (string value) |
| #driver = sql |
| |
| # The number of seconds after a token has expired before a corresponding |
| # revocation event may be purged from the backend. (integer value) |
| # Minimum value: 0 |
| #expiration_buffer = 1800 |
| |
| # Toggle for revocation event caching. This has no effect unless global caching |
| # is enabled. (boolean value) |
| #caching = true |
| |
| # Time to cache the revocation list and the revocation events (in seconds). |
| # This has no effect unless global and `[revoke] caching` are both enabled. |
| # (integer value) |
| # Deprecated group/name - [token]/revocation_cache_time |
| #cache_time = 3600 |
| |
| |
| [role] |
| |
| # |
| # From keystone |
| # |
| |
| # Entry point for the role backend driver in the `keystone.role` namespace. |
| # Keystone only provides a `sql` driver, so there's no reason to change this |
| # unless you are providing a custom entry point. (string value) |
| #driver = <None> |
| |
| # Toggle for role caching. This has no effect unless global caching is enabled. |
| # In a typical deployment, there is no reason to disable this. (boolean value) |
| #caching = true |
| |
| # Time to cache role data, in seconds. This has no effect unless both global |
| # caching and `[role] caching` are enabled. (integer value) |
| #cache_time = <None> |
| |
| # Maximum number of entities that will be returned in a role collection. This |
| # may be useful to tune if you have a large number of discrete roles in your |
| # deployment. (integer value) |
| #list_limit = <None> |
| |
| |
| [saml] |
| |
| # |
| # From keystone |
| # |
| |
| # Determines the lifetime for any SAML assertions generated by keystone, using |
| # `NotOnOrAfter` attributes. (integer value) |
| #assertion_expiration_time = 3600 |
| |
| # Name of, or absolute path to, the binary to be used for XML signing. Although |
| # only the XML Security Library (`xmlsec1`) is supported, it may have a non- |
| # standard name or path on your system. If keystone cannot find the binary |
| # itself, you may need to install the appropriate package, use this option to |
| # specify an absolute path, or adjust keystone's PATH environment variable. |
| # (string value) |
| #xmlsec1_binary = xmlsec1 |
| |
| # Absolute path to the public certificate file to use for SAML signing. The |
| # value cannot contain a comma (`,`). (string value) |
| #certfile = /etc/keystone/ssl/certs/signing_cert.pem |
| |
| # Absolute path to the private key file to use for SAML signing. The value |
| # cannot contain a comma (`,`). (string value) |
| #keyfile = /etc/keystone/ssl/private/signing_key.pem |
| |
| # This is the unique entity identifier of the identity provider (keystone) to |
| # use when generating SAML assertions. This value is required to generate |
| # identity provider metadata and must be a URI (a URL is recommended). For |
| # example: `https://keystone.example.com/v3/OS-FEDERATION/saml2/idp`. (uri |
| # value) |
| #idp_entity_id = <None> |
| |
| # This is the single sign-on (SSO) service location of the identity provider |
| # which accepts HTTP POST requests. A value is required to generate identity |
| # provider metadata. For example: `https://keystone.example.com/v3/OS- |
| # FEDERATION/saml2/sso`. (uri value) |
| #idp_sso_endpoint = <None> |
| |
| # This is the language used by the identity provider's organization. (string |
| # value) |
| #idp_lang = en |
| |
| # This is the name of the identity provider's organization. (string value) |
| #idp_organization_name = SAML Identity Provider |
| |
| # This is the name of the identity provider's organization to be displayed. |
| # (string value) |
| #idp_organization_display_name = OpenStack SAML Identity Provider |
| |
| # This is the URL of the identity provider's organization. The URL referenced |
| # here should be useful to humans. (uri value) |
| #idp_organization_url = https://example.com/ |
| |
| # This is the company name of the identity provider's contact person. (string |
| # value) |
| #idp_contact_company = Example, Inc. |
| |
| # This is the given name of the identity provider's contact person. (string |
| # value) |
| #idp_contact_name = SAML Identity Provider Support |
| |
| # This is the surname of the identity provider's contact person. (string value) |
| #idp_contact_surname = Support |
| |
| # This is the email address of the identity provider's contact person. (string |
| # value) |
| #idp_contact_email = support@example.com |
| |
| # This is the telephone number of the identity provider's contact person. |
| # (string value) |
| #idp_contact_telephone = +1 800 555 0100 |
| |
| # This is the type of contact that best describes the identity provider's |
| # contact person. (string value) |
| # Allowed values: technical, support, administrative, billing, other |
| #idp_contact_type = other |
| |
| # Absolute path to the identity provider metadata file. This file should be |
| # generated with the `keystone-manage saml_idp_metadata` command. There is |
| # typically no reason to change this value. (string value) |
| #idp_metadata_path = /etc/keystone/saml2_idp_metadata.xml |
| |
| # The prefix of the RelayState SAML attribute to use when generating enhanced |
| # client and proxy (ECP) assertions. In a typical deployment, there is no |
| # reason to change this value. (string value) |
| #relay_state_prefix = ss:mem: |
| |
| |
| [security_compliance] |
| |
| # |
| # From keystone |
| # |
| |
| # The maximum number of days a user can go without authenticating before being |
| # considered "inactive" and automatically disabled (locked). This feature is |
| # disabled by default; set any value to enable it. This feature depends on the |
| # `sql` backend for the `[identity] driver`. When a user exceeds this threshold |
| # and is considered "inactive", the user's `enabled` attribute in the HTTP API |
| # may not match the value of the user's `enabled` column in the user table. |
| # (integer value) |
| # Minimum value: 1 |
| #disable_user_account_days_inactive = <None> |
| {%- if server.security_compliance.disable_user_account_days_inactive is defined and server.get('backend', 'sql') == 'sql' %} |
| disable_user_account_days_inactive = {{ server.security_compliance.disable_user_account_days_inactive }} |
| {%- endif %} |
| |
| # The maximum number of times that a user can fail to authenticate before the |
| # user account is locked for the number of seconds specified by |
| # `[security_compliance] lockout_duration`. This feature is disabled by |
| # default. If this feature is enabled and `[security_compliance] |
| # lockout_duration` is not set, then users may be locked out indefinitely until |
| # the user is explicitly enabled via the API. This feature depends on the `sql` |
| # backend for the `[identity] driver`. (integer value) |
| # Minimum value: 1 |
| #lockout_failure_attempts = <None> |
| {%- if server.security_compliance.lockout_failure_attempts is defined and server.get('backend', 'sql') == 'sql' %} |
| lockout_failure_attempts = {{ server.security_compliance.lockout_failure_attempts }} |
| {%- endif %} |
| |
| # The number of seconds a user account will be locked when the maximum number |
| # of failed authentication attempts (as specified by `[security_compliance] |
| # lockout_failure_attempts`) is exceeded. Setting this option will have no |
| # effect unless you also set `[security_compliance] lockout_failure_attempts` |
| # to a non-zero value. This feature depends on the `sql` backend for the |
| # `[identity] driver`. (integer value) |
| # Minimum value: 1 |
| #lockout_duration = 1800 |
| {%- if server.security_compliance.lockout_duration is defined and server.get('backend', 'sql') == 'sql' %} |
| lockout_duration = {{ server.security_compliance.lockout_duration }} |
| {%- endif %} |
| |
| # The number of days for which a password will be considered valid before |
| # requiring it to be changed. This feature is disabled by default. If enabled, |
| # new password changes will have an expiration date, however existing passwords |
| # would not be impacted. This feature depends on the `sql` backend for the |
| # `[identity] driver`. (integer value) |
| # Minimum value: 1 |
| #password_expires_days = <None> |
| {%- if server.security_compliance.password_expires_days is defined and server.get('backend', 'sql') == 'sql' %} |
| password_expires_days = {{ server.security_compliance.password_expires_days }} |
| {%- endif %} |
| |
| # Comma separated list of user IDs to be ignored when checking if a password is |
| # expired. Passwords for users in this list will not expire. This feature will |
| # only be enabled if `[security_compliance] password_expires_days` is set. |
| # (list value) |
| #password_expires_ignore_user_ids = |
| {%- if server.password_expires_ignore_user_ids is defined and server.password_expires_days is defined and server.get('backend', 'sql') == 'sql' %} |
| password_expires_ignore_user_ids = {{ server.password_expires_ignore_user_ids }} |
| {%- endif %} |
| |
| # This controls the number of previous user password iterations to keep in |
| # history, in order to enforce that newly created passwords are unique. Setting |
| # the value to one (the default) disables this feature. Thus, to enable this |
| # feature, values must be greater than 1. This feature depends on the `sql` |
| # backend for the `[identity] driver`. (integer value) |
| # Minimum value: 1 |
| #unique_last_password_count = 1 |
| {%- if server.security_compliance.unique_last_password_count is defined and server.get('backend', 'sql') == 'sql' %} |
| unique_last_password_count = {{ server.security_compliance.unique_last_password_count }} |
| {%- endif %} |
| |
| # The number of days that a password must be used before the user can change |
| # it. This prevents users from changing their passwords immediately in order to |
| # wipe out their password history and reuse an old password. This feature does |
| # not prevent administrators from manually resetting passwords. It is disabled |
| # by default and allows for immediate password changes. This feature depends on |
| # the `sql` backend for the `[identity] driver`. Note: If |
| # `[security_compliance] password_expires_days` is set, then the value for this |
| # option should be less than the `password_expires_days`. (integer value) |
| # Minimum value: 0 |
| #minimum_password_age = 0 |
| {%- if server.security_compliance.minimum_password_age is defined and server.get('backend', 'sql') == 'sql' %} |
| minimum_password_age = {{ server.security_compliance.minimum_password_age }} |
| {%- endif %} |
| |
| # The regular expression used to validate password strength requirements. By |
| # default, the regular expression will match any password. The following is an |
| # example of a pattern which requires at least 1 letter, 1 digit, and have a |
| # minimum length of 7 characters: ^(?=.*\d)(?=.*[a-zA-Z]).{7,}$ This feature |
| # depends on the `sql` backend for the `[identity] driver`. (string value) |
| #password_regex = <None> |
| {%- if server.security_compliance.password_regex is defined and server.get('backend', 'sql') == 'sql' %} |
| password_regex = {{ server.security_compliance.password_regex }} |
| {%- endif %} |
| |
| # Describe your password regular expression here in language for humans. If a |
| # password fails to match the regular expression, the contents of this |
| # configuration variable will be returned to users to explain why their |
| # requested password was insufficient. (string value) |
| #password_regex_description = <None> |
| {%- if server.security_compliance.password_regex_description is defined %} |
| password_regex_description = {{ server.security_compliance.password_regex_description }} |
| {%- endif %} |
| |
| [shadow_users] |
| |
| # |
| # From keystone |
| # |
| |
| # Entry point for the shadow users backend driver in the |
| # `keystone.identity.shadow_users` namespace. This driver is used for |
| # persisting local user references to externally-managed identities (via |
| # federation, LDAP, etc). Keystone only provides a `sql` driver, so there is no |
| # reason to change this option unless you are providing a custom entry point. |
| # (string value) |
| #driver = sql |
| |
| |
| [signing] |
| |
| # |
| # From keystone |
| # |
| |
| # DEPRECATED: Absolute path to the public certificate file to use for signing |
| # PKI and PKIZ tokens. Set this together with `[signing] keyfile`. For non- |
| # production environments, you may be interested in using `keystone-manage |
| # pki_setup` to generate self-signed certificates. There is no reason to set |
| # this option unless you are using either a `pki` or `pkiz` `[token] provider`. |
| # (string value) |
| # This option is deprecated for removal since M. |
| # Its value may be silently ignored in the future. |
| # Reason: PKI token support has been deprecated in the M release and will be |
| # removed in the O release. Fernet or UUID tokens are recommended. |
| #certfile = /etc/keystone/ssl/certs/signing_cert.pem |
| |
| # DEPRECATED: Absolute path to the private key file to use for signing PKI and |
| # PKIZ tokens. Set this together with `[signing] certfile`. There is no reason |
| # to set this option unless you are using either a `pki` or `pkiz` `[token] |
| # provider`. (string value) |
| # This option is deprecated for removal since M. |
| # Its value may be silently ignored in the future. |
| # Reason: PKI token support has been deprecated in the M release and will be |
| # removed in the O release. Fernet or UUID tokens are recommended. |
| #keyfile = /etc/keystone/ssl/private/signing_key.pem |
| |
| # DEPRECATED: Absolute path to the public certificate authority (CA) file to |
| # use when creating self-signed certificates with `keystone-manage pki_setup`. |
| # Set this together with `[signing] ca_key`. There is no reason to set this |
| # option unless you are using a `pki` or `pkiz` `[token] provider` value in a |
| # non-production environment. Use a `[signing] certfile` issued from a trusted |
| # certificate authority instead. (string value) |
| # This option is deprecated for removal since M. |
| # Its value may be silently ignored in the future. |
| # Reason: PKI token support has been deprecated in the M release and will be |
| # removed in the O release. Fernet or UUID tokens are recommended. |
| #ca_certs = /etc/keystone/ssl/certs/ca.pem |
| |
| # DEPRECATED: Absolute path to the private certificate authority (CA) key file |
| # to use when creating self-signed certificates with `keystone-manage |
| # pki_setup`. Set this together with `[signing] ca_certs`. There is no reason |
| # to set this option unless you are using a `pki` or `pkiz` `[token] provider` |
| # value in a non-production environment. Use a `[signing] certfile` issued from |
| # a trusted certificate authority instead. (string value) |
| # This option is deprecated for removal since M. |
| # Its value may be silently ignored in the future. |
| # Reason: PKI token support has been deprecated in the M release and will be |
| # removed in the O release. Fernet or UUID tokens are recommended. |
| #ca_key = /etc/keystone/ssl/private/cakey.pem |
| |
| # DEPRECATED: Key size (in bits) to use when generating a self-signed token |
| # signing certificate. There is no reason to set this option unless you are |
| # using a `pki` or `pkiz` `[token] provider` value in a non-production |
| # environment. Use a `[signing] certfile` issued from a trusted certificate |
| # authority instead. (integer value) |
| # Minimum value: 1024 |
| # This option is deprecated for removal since M. |
| # Its value may be silently ignored in the future. |
| # Reason: PKI token support has been deprecated in the M release and will be |
| # removed in the O release. Fernet or UUID tokens are recommended. |
| #key_size = 2048 |
| |
| # DEPRECATED: The validity period (in days) to use when generating a self- |
| # signed token signing certificate. There is no reason to set this option |
| # unless you are using a `pki` or `pkiz` `[token] provider` value in a non- |
| # production environment. Use a `[signing] certfile` issued from a trusted |
| # certificate authority instead. (integer value) |
| # This option is deprecated for removal since M. |
| # Its value may be silently ignored in the future. |
| # Reason: PKI token support has been deprecated in the M release and will be |
| # removed in the O release. Fernet or UUID tokens are recommended. |
| #valid_days = 3650 |
| |
| # DEPRECATED: The certificate subject to use when generating a self-signed |
| # token signing certificate. There is no reason to set this option unless you |
| # are using a `pki` or `pkiz` `[token] provider` value in a non-production |
| # environment. Use a `[signing] certfile` issued from a trusted certificate |
| # authority instead. (string value) |
| # This option is deprecated for removal since M. |
| # Its value may be silently ignored in the future. |
| # Reason: PKI token support has been deprecated in the M release and will be |
| # removed in the O release. Fernet or UUID tokens are recommended. |
| #cert_subject = /C=US/ST=Unset/L=Unset/O=Unset/CN=www.example.com |
| |
| |
| [token] |
| |
| # |
| # From keystone |
| # |
| |
| # This is a list of external authentication mechanisms which should add token |
| # binding metadata to tokens, such as `kerberos` or `x509`. Binding metadata is |
| # enforced according to the `[token] enforce_token_bind` option. (list value) |
| #bind = |
| |
| # This controls the token binding enforcement policy on tokens presented to |
| # keystone with token binding metadata (as specified by the `[token] bind` |
| # option). `disabled` completely bypasses token binding validation. |
| # `permissive` and `strict` do not require tokens to have binding metadata (but |
| # will validate it if present), whereas `required` will always demand tokens to |
| # having binding metadata. `permissive` will allow unsupported binding metadata |
| # to pass through without validation (usually to be validated at another time |
| # by another component), whereas `strict` and `required` will demand that the |
| # included binding metadata be supported by keystone. (string value) |
| # Allowed values: disabled, permissive, strict, required |
| #enforce_token_bind = permissive |
| |
| # The amount of time that a token should remain valid (in seconds). Drastically |
| # reducing this value may break "long-running" operations that involve multiple |
| # services to coordinate together, and will force users to authenticate with |
| # keystone more frequently. Drastically increasing this value will increase |
| # load on the `[token] driver`, as more tokens will be simultaneously valid. |
| # Keystone tokens are also bearer tokens, so a shorter duration will also |
| # reduce the potential security impact of a compromised token. (integer value) |
| # Minimum value: 0 |
| # Maximum value: 9223372036854775807 |
| #expiration = 3600 |
| expiration = {{ server.tokens.expiration }} |
| |
| # Entry point for the token provider in the `keystone.token.provider` |
| # namespace. The token provider controls the token construction, validation, |
| # and revocation operations. Keystone includes `fernet`, `pkiz`, `pki`, and |
| # `uuid` token providers. `uuid` tokens must be persisted (using the backend |
| # specified in the `[token] driver` option), but do not require any extra |
| # configuration or setup. `fernet` tokens do not need to be persisted at all, |
| # but require that you run `keystone-manage fernet_setup` (also see the |
| # `keystone-manage fernet_rotate` command). `pki` and `pkiz` tokens can be |
| # validated offline, without making HTTP calls to keystone, but require that |
| # certificates be installed and distributed to facilitate signing tokens and |
| # later validating those signatures. (string value) |
| #provider = uuid |
| {% if server.tokens.engine == 'fernet' %} |
| provider = keystone.token.providers.fernet.Provider |
| {% endif %} |
| |
| # Entry point for the token persistence backend driver in the |
| # `keystone.token.persistence` namespace. Keystone provides `kvs`, `memcache`, |
| # `memcache_pool`, and `sql` drivers. The `kvs` backend depends on the |
| # configuration in the `[kvs]` section. The `memcache` and `memcache_pool` |
| # options depend on the configuration in the `[memcache]` section. The `sql` |
| # option (default) depends on the options in your `[database]` section. If |
| # you're using the `fernet` `[token] provider`, this backend will not be |
| # utilized to persist tokens at all. (string value) |
| #driver = sql |
| driver = keystone.token.persistence.backends.memcache_pool.Token |
| |
| # Toggle for caching token creation and validation data. This has no effect |
| # unless global caching is enabled. (boolean value) |
| #caching = true |
| caching = false |
| |
| # The number of seconds to cache token creation and validation data. This has |
| # no effect unless both global and `[token] caching` are enabled. (integer |
| # value) |
| # Minimum value: 0 |
| # Maximum value: 9223372036854775807 |
| #cache_time = <None> |
| |
| # This toggles support for revoking individual tokens by the token identifier |
| # and thus various token enumeration operations (such as listing all tokens |
| # issued to a specific user). These operations are used to determine the list |
| # of tokens to consider revoked. Do not disable this option if you're using the |
| # `kvs` `[revoke] driver`. (boolean value) |
| #revoke_by_id = true |
| revoke_by_id = False |
| |
| # This toggles whether scoped tokens may be be re-scoped to a new project or |
| # domain, thereby preventing users from exchanging a scoped token (including |
| # those with a default project scope) for any other token. This forces users to |
| # either authenticate for unscoped tokens (and later exchange that unscoped |
| # token for tokens with a more specific scope) or to provide their credentials |
| # in every request for a scoped token to avoid re-scoping altogether. (boolean |
| # value) |
| #allow_rescope_scoped_token = true |
| |
| # DEPRECATED: This controls the hash algorithm to use to uniquely identify PKI |
| # tokens without having to transmit the entire token to keystone (which may be |
| # several kilobytes). This can be set to any algorithm that hashlib supports. |
| # WARNING: Before changing this value, the `auth_token` middleware protecting |
| # all other services must be configured with the set of hash algorithms to |
| # expect from keystone (both your old and new value for this option), otherwise |
| # token revocation will not be processed correctly. (string value) |
| # Allowed values: md5, sha1, sha224, sha256, sha384, sha512 |
| # This option is deprecated for removal since M. |
| # Its value may be silently ignored in the future. |
| # Reason: PKI token support has been deprecated in the M release and will be |
| # removed in the O release. Fernet or UUID tokens are recommended. |
| #hash_algorithm = md5 |
| hash_algorithm = {{ server.hash_algorithm }} |
| |
| # This controls whether roles should be included with tokens that are not |
| # directly assigned to the token's scope, but are instead linked implicitly to |
| # other role assignments. (boolean value) |
| #infer_roles = true |
| |
| # Enable storing issued token data to token validation cache so that first |
| # token validation doesn't actually cause full validation cycle. (boolean |
| # value) |
| #cache_on_issue = false |
| |
| |
| [tokenless_auth] |
| |
| # |
| # From keystone |
| # |
| |
| # The list of distinguished names which identify trusted issuers of client |
| # certificates allowed to use X.509 tokenless authorization. If the option is |
| # absent then no certificates will be allowed. The format for the values of a |
| # distinguished name (DN) must be separated by a comma and contain no spaces. |
| # Furthermore, because an individual DN may contain commas, this configuration |
| # option may be repeated multiple times to represent multiple values. For |
| # example, keystone.conf would include two consecutive lines in order to trust |
| # two different DNs, such as `trusted_issuer = CN=john,OU=keystone,O=openstack` |
| # and `trusted_issuer = CN=mary,OU=eng,O=abc`. (multi valued) |
| #trusted_issuer = |
| |
| # The federated protocol ID used to represent X.509 tokenless authorization. |
| # This is used in combination with the value of `[tokenless_auth] |
| # issuer_attribute` to find a corresponding federated mapping. In a typical |
| # deployment, there is no reason to change this value. (string value) |
| #protocol = x509 |
| |
| # The name of the WSGI environment variable used to pass the issuer of the |
| # client certificate to keystone. This attribute is used as an identity |
| # provider ID for the X.509 tokenless authorization along with the protocol to |
| # look up its corresponding mapping. In a typical deployment, there is no |
| # reason to change this value. (string value) |
| #issuer_attribute = SSL_CLIENT_I_DN |
| |
| |
| [trust] |
| |
| # |
| # From keystone |
| # |
| |
| # Delegation and impersonation features using trusts can be optionally |
| # disabled. (boolean value) |
| #enabled = true |
| |
| # Allows authorization to be redelegated from one user to another, effectively |
| # chaining trusts together. When disabled, the `remaining_uses` attribute of a |
| # trust is constrained to be zero. (boolean value) |
| #allow_redelegation = false |
| |
| # Maximum number of times that authorization can be redelegated from one user |
| # to another in a chain of trusts. This number may be reduced further for a |
| # specific trust. (integer value) |
| #max_redelegation_count = 3 |
| |
| # Entry point for the trust backend driver in the `keystone.trust` namespace. |
| # Keystone only provides a `sql` driver, so there is no reason to change this |
| # unless you are providing a custom entry point. (string value) |
| #driver = sql |
| [extra_headers] |
| Distribution = Ubuntu |
| |
| {% if server.extra_config is defined %} |
| {%- for section, params in server.extra_config.items() %} |
| [{{ section }}] |
| {%- for param, value in params.items() %} |
| {{ param }} = {{ value }} |
| {%- endfor %} |
| {%- endfor %} |
| {%- endif %} |