2017-06-27 12:14:35 -04:00
[role="xpack"]
2017-04-06 20:34:23 -04:00
[[security-settings]]
2017-08-11 13:00:35 -04:00
=== Security Settings in Elasticsearch
++++
<titleabbrev>Security Settings</titleabbrev>
++++
2017-04-06 20:34:23 -04:00
2017-06-27 12:14:35 -04:00
You configure `xpack.security` settings to
2017-06-26 15:50:12 -04:00
<<anonymous-access-settings, enable anonymous access>>
2017-04-06 20:34:23 -04:00
and perform message authentication,
2017-06-27 12:14:35 -04:00
<<field-document-security-settings, set up document and field
level security>>, <<realm-settings, configure realms>>,
2017-06-26 13:35:25 -04:00
and <<ssl-tls-settings, encrypt communications with SSL>>.
2017-04-06 20:34:23 -04:00
[float]
[[general-security-settings]]
2017-06-27 12:14:35 -04:00
==== General Security Settings
2017-04-06 20:34:23 -04:00
`xpack.security.enabled`::
2017-08-04 11:59:50 -04:00
Set to `true` (default) to enable {security}. +
+
If set to `false` in `elasticsearch.yml`, {security} is disabled. It also
affects all {kib} instances that connect to this {es} instance; you do not
need to disable {security} in those `kibana.yml` files. For more information
about disabling {security} in specific {kib} instances, see
{kibana-ref}/security-settings-kb.html[{kib} Security Settings].
2017-04-06 20:34:23 -04:00
[float]
[[password-security-settings]]
2017-06-27 12:14:35 -04:00
==== Default Password Security Settings
2017-04-06 20:34:23 -04:00
`xpack.security.authc.accept_default_password`::
In `elasticsearch.yml`, set this to `false` to disable support for the default "changeme" password.
[float]
[[anonymous-access-settings]]
2017-06-27 12:14:35 -04:00
==== Anonymous Access Settings
You can configure the following anonymous access settings in
2017-06-26 13:35:25 -04:00
`elasticsearch.yml`. For more information, see {xpack-ref}/anonymous-access.html[
Enabling Anonymous Access].
2017-04-06 20:34:23 -04:00
`xpack.security.authc.anonymous.username`::
2017-06-27 12:14:35 -04:00
The username (principal) of the anonymous user. Defaults to `_es_anonymous_user`.
2017-04-06 20:34:23 -04:00
`xpack.security.authc.anonymous.roles`::
The roles to associate with the anonymous user. Required.
`xpack.security.authc.anonymous.authz_exception`::
When `true`, an HTTP 403 response is returned if the anonymous user
does not have the appropriate permissions for the requested action. The
user is not prompted to provide credentials to access the requested
2017-06-27 12:14:35 -04:00
resource. When set to `false`, a HTTP 401 is returned and the user
can provide credentials with the appropriate permissions to gain
2017-04-06 20:34:23 -04:00
access. Defaults to `true`.
[float]
[[field-document-security-settings]]
2017-06-27 12:14:35 -04:00
==== Document and Field Level Security Settings
2017-04-06 20:34:23 -04:00
You can set the following document and field level security
2017-06-27 12:14:35 -04:00
settings in `elasticsearch.yml`. For more information, see
2017-06-26 13:35:25 -04:00
{xpack-ref}/field-and-document-access-control.html[Setting Up Document and Field
Level Security].
2017-04-06 20:34:23 -04:00
`xpack.security.dls_fls.enabled`::
2017-06-27 12:14:35 -04:00
Set to `false` to prevent document and field level security
2017-04-06 20:34:23 -04:00
from being configured. Defaults to `true`.
2017-06-22 10:45:14 -04:00
[float]
[[token-service-settings]]
2017-06-27 12:14:35 -04:00
==== Token Service Settings
2017-06-22 10:45:14 -04:00
You can set the following token service settings in
`elasticsearch.yml`.
`xpack.security.authc.token.enabled`::
2017-08-23 06:21:30 -04:00
Set to `false` to disable the built-in token service. Defaults to `true` unless
`xpack.security.http.ssl.enabled` is `false` and `http.enabled` is `true`.
This prevents sniffing the token from a connection over plain http.
2017-06-22 10:45:14 -04:00
`xpack.security.authc.token.timeout`::
The length of time that a token is valid for. By default this value is `20m` or
20 minutes. The maximum value is 1 hour.
2017-04-06 20:34:23 -04:00
[float]
[[realm-settings]]
2017-06-27 12:14:35 -04:00
==== Realm Settings
You configure realm settings in the `xpack.security.authc.realms`
2017-04-06 20:34:23 -04:00
namespace in `elasticsearch.yml`. For example:
[source,yaml]
----------------------------------------
xpack.security.authc.realms:
realm1:
type: native
order: 0
...
realm2:
type: ldap
order: 1
...
realm3:
type: active_directory
order: 2
...
...
----------------------------------------
2017-06-27 12:14:35 -04:00
The valid settings vary depending on the realm type. For more
2017-06-26 13:35:25 -04:00
information, see {xpack-ref}/setting-up-authentication.html[Setting Up Authentication].
2017-04-06 20:34:23 -04:00
[float]
2017-06-27 12:14:35 -04:00
===== Settings Valid for All Realms
2017-04-06 20:34:23 -04:00
2017-06-27 12:14:35 -04:00
`type`::
2017-04-06 20:34:23 -04:00
The type of the realm: `native, `ldap`, `active_directory`, `pki`, or `file`. Required.
2017-06-27 12:14:35 -04:00
`order`::
The priority of the realm within the realm chain. Defaults to `Integer.MAX_VALUE`.
2017-04-06 20:34:23 -04:00
2017-06-27 12:14:35 -04:00
`enabled`::
2017-04-06 20:34:23 -04:00
Enable/disable the realm. Defaults to `true`.
[[ref-users-settings]]
[float]
2017-06-27 12:14:35 -04:00
===== File Realm Settings
2017-04-06 20:34:23 -04:00
2017-06-27 12:14:35 -04:00
`cache.ttl`::
The time-to-live for cached user entries--user credentials are cached for
2017-04-06 20:34:23 -04:00
this configured period of time. Defaults to `20m`. Specify values using the
2017-06-27 12:14:35 -04:00
standard Elasticsearch {ref}/common-options.html#time-units[time units].
2017-04-06 20:34:23 -04:00
Defaults to `20m`.
2017-06-27 12:14:35 -04:00
`cache.max_users`::
The maximum number of user entries that can live in the cache at a given time.
2017-04-06 20:34:23 -04:00
Defaults to 100,000.
2017-06-27 12:14:35 -04:00
`cache.hash_algo`::
(Expert Setting) The hashing algorithm that is used for the in-memory cached
2017-06-26 13:35:25 -04:00
user credentials. See the {xpack-ref}/controlling-user-cache.html#controlling-user-cache[Cache hash algorithms] table for
all possible values. Defaults to `ssha256`.
2017-04-06 20:34:23 -04:00
[[ref-ldap-settings]]
[float]
2017-06-27 12:14:35 -04:00
===== LDAP Realm Settings
`url`::
2017-04-06 20:34:23 -04:00
An LDAP URL in the format `ldap[s]://<server>:<port>`. Required.
2017-06-27 12:14:35 -04:00
`load_balance.type`::
The behavior to use when there are multiple LDAP URLs defined. For supported
2017-06-26 13:35:25 -04:00
values see {xpack-ref}/ldap-realm.html#ldap-load-balancing[LDAP load balancing and failover types].
2017-04-06 20:34:23 -04:00
Defaults to `failover`.
2017-06-27 12:14:35 -04:00
`load_balance.cache_ttl`::
When using `dns_failover` or `dns_round_robin` as the load balancing type,
this setting controls the amount of time to cache DNS lookups. Defaults
2017-04-06 20:34:23 -04:00
to `1h`.
2017-06-27 12:14:35 -04:00
`bind_dn`::
The DN of the user that will be used to bind to the LDAP and perform searches.
2017-07-13 00:23:23 -04:00
Only applicable in {xpack-ref}/ldap-realm.html#ldap-user-search[user search mode].
2017-06-27 12:14:35 -04:00
If this is not specified, an anonymous bind will be attempted.
2017-04-06 20:34:23 -04:00
Defaults to Empty.
2017-06-27 12:14:35 -04:00
`bind_password`::
The password for the user that will be used to bind to the LDAP.
2017-04-06 20:34:23 -04:00
Defaults to Empty.
2017-06-27 12:14:35 -04:00
`user_dn_templates`::
The DN template that replaces the user name with the string `{0}`.
This element is multivalued; you can specify multiple user contexts.
2017-04-06 20:34:23 -04:00
Required to operate in user template mode. Not valid
if `user_search.base_dn` is specified. For more information on
2017-06-27 12:14:35 -04:00
the different modes, see {xpack-ref}/ldap-realm.html[LDAP realms].
2017-04-06 20:34:23 -04:00
2017-06-27 12:14:35 -04:00
`user_group_attribute`::
Specifies the attribute to examine on the user for group membership.
The default is `memberOf`. This setting will be ignored if any
2017-04-06 20:34:23 -04:00
`group_search` settings are specified. Defaults to `memberOf`.
2017-06-27 12:14:35 -04:00
`user_search.base_dn`::
Specifies a container DN to search for users. Required
to operated in user search mode. Not valid if
2017-04-06 20:34:23 -04:00
`user_dn_templates is specified. For more information on
2017-06-26 13:35:25 -04:00
the different modes, see {xpack-ref}/ldap-realm.html[LDAP realms].
2017-04-06 20:34:23 -04:00
2017-06-27 12:14:35 -04:00
`user_search.scope`::
The scope of the user search. Valid values are `sub_tree`, `one_level` or
`base`. `one_level` only searches objects directly contained within the
`base_dn`. `sub_tree` searches all objects contained under `base_dn`.
`base` specifies that the `base_dn` is the user object, and that it is
2017-04-06 20:34:23 -04:00
the only user considered. Defaults to `sub_tree`.
2017-07-11 11:27:24 -04:00
`user_search.filter`::
Specifies the filter used to search the directory in attempt to match
an entry with the username provided by the user. Defaults to `(uid={0})`.
`{0}` is substituted with the username provided when searching.
2017-06-27 12:14:35 -04:00
`user_search.attribute`::
2017-07-11 11:27:24 -04:00
This setting is deprecated; use `user_search.filter` instead.
2017-04-06 20:34:23 -04:00
The attribute to match with the username presented to. Defaults to `uid`.
`user_search.pool.enabled`::
Enables or disables connection pooling for user search. When
disabled a new connection is created for every search. The
2017-07-12 16:01:39 -04:00
default is `true` when `bind_dn` is provided.
2017-04-06 20:34:23 -04:00
2017-06-27 12:14:35 -04:00
`user_search.pool.size`::
The maximum number of connections to the LDAP server to allow in the
2017-04-06 20:34:23 -04:00
connection pool. Defaults to `20`.
2017-06-27 12:14:35 -04:00
`user_search.pool.initial_size`::
2017-04-06 20:34:23 -04:00
The initial number of connections to create to the LDAP server on startup.
2017-07-12 16:01:39 -04:00
Defaults to `0`.
2017-04-06 20:34:23 -04:00
2017-06-27 12:14:35 -04:00
`user_search.pool.health_check.enabled`::
Flag to enable or disable a health check on LDAP connections in the connection
2017-04-06 20:34:23 -04:00
pool. Connections are checked in the background at the specified interval.
Defaults to `true`.
2017-06-27 12:14:35 -04:00
`user_search.pool.health_check.dn`::
The distinguished name to be retrieved as part of the health check.
2017-07-12 16:01:39 -04:00
Defaults to the value of `bind_dn` if present, and if
not falls back to `user_search.base_dn`.
2017-04-06 20:34:23 -04:00
2017-06-27 12:14:35 -04:00
`user_search.pool.health_check.interval`::
2017-04-06 20:34:23 -04:00
The interval to perform background checks of connections in the pool.
Defaults to `60s`.
2017-07-12 16:01:39 -04:00
2017-06-27 12:14:35 -04:00
`group_search.base_dn`::
The container DN to search for groups in which the user has membership. When
this element is absent, Security searches for the attribute specified by
2017-04-06 20:34:23 -04:00
`user_group_attribute` set on the user in order to determine group membership.
2017-06-27 12:14:35 -04:00
`group_search.scope`::
Specifies whether the group search should be `sub_tree`, `one_level` or
`base`. `one_level` only searches objects directly contained within the
`base_dn`. `sub_tree` searches all objects contained under `base_dn`.
`base` specifies that the `base_dn` is a group object, and that it is the
2017-04-06 20:34:23 -04:00
only group considered. Defaults to `sub_tree`.
2017-06-27 12:14:35 -04:00
`group_search.filter`::
2017-04-06 20:34:23 -04:00
When not set, the realm searches for `group`, `groupOfNames`, `groupOfUniqueNames`,
or `posixGroup` with the attributes `member`, `memberOf`, or `memberUid`. Any
instance of `{0}` in the filter is replaced by the user attribute defined in
`group_search.user_attribute`.
2017-06-27 12:14:35 -04:00
`group_search.user_attribute`::
Specifies the user attribute that will be fetched and provided as a parameter to
2017-04-06 20:34:23 -04:00
the filter. If not set, the user DN is passed into the filter. Defaults to Empty.
2017-06-27 12:14:35 -04:00
`unmapped_groups_as_roles`::
Takes a boolean variable. When this element is set to `true`, the names of any
2017-06-06 00:12:31 -04:00
LDAP groups that are not referenced in a role-mapping _file_ are used as role
names and assigned to the user. Defaults to `false`.
2017-04-06 20:34:23 -04:00
2017-06-27 12:14:35 -04:00
`files.role_mapping`::
The {xpack-ref}/security-files.html[location] for the {xpack-ref}/mapping-roles.html#mapping-roles[
YAML role mapping configuration file]. Defaults to
2017-04-06 20:34:23 -04:00
`CONFIG_DIR/x-pack/role_mapping.yml`.
2017-06-27 12:14:35 -04:00
`follow_referrals`::
Boolean value that specifies whether Securityshould follow referrals returned
by the LDAP server. Referrals are URLs returned by the server that are to be
2017-04-06 20:34:23 -04:00
used to continue the LDAP operation (e.g. search). Defaults to `true`.
2017-06-06 00:12:31 -04:00
`metadata`::
A list of additional LDAP attributes that should be loaded from the
LDAP server and stored in the authenticated user's metadata field.
2017-04-06 20:34:23 -04:00
`timeout.tcp_connect`::
The TCP connect timeout period for establishing an LDAP connection.
An `s` at the end indicates seconds, or `ms` indicates milliseconds.
Defaults to `5s` (5 seconds ).
`timeout.tcp_read`::
The TCP read timeout period after establishing an LDAP connection.
An `s` at the end indicates seconds, or `ms` indicates milliseconds.
Defaults to `5s` (5 seconds ).
`timeout.ldap_search`::
The LDAP Server enforced timeout period for an LDAP search.
An `s` at the end indicates seconds, or `ms` indicates milliseconds.
Defaults to `5s` (5 seconds ).
`ssl.key`::
Path to a PEM encoded file containing the private key.
`ssl.key_passphrase`::
The passphrase that will be used to decrypt the private key. This value is
optional as the key may not be encrypted.
`ssl.certificate`::
Path to a PEM encoded file containing the certificate (or certificate chain)
that will be presented to clients when they connect.
`ssl.certificate_authorities`::
List of paths to PEM encoded certificate files that should be trusted.
`ssl.keystore.path`::
The path to the Java Keystore file that contains a private key and certificate.
`ssl.key` and `ssl.keystore.path` may not be used at the same time.
2017-07-25 03:31:37 -04:00
`ssl.keystore.type`::
The format of the keystore file. Should be either `jks` to use the Java
Keystore format, or `PKCS12` to use PKCS#12 files. The default is `jks`.
2017-04-06 20:34:23 -04:00
`ssl.keystore.password`::
The password to the keystore.
`ssl.keystore.key_password`::
The password for the key in the keystore. Defaults to the keystore password.
`ssl.truststore.path`::
The path to the Java Keystore file that contains the certificates to trust.
2017-07-24 23:03:07 -04:00
`ssl.certificate_authorities` and `ssl.truststore.path` may not be used at the same time.
2017-04-06 20:34:23 -04:00
2017-07-25 03:31:37 -04:00
`ssl.truststore.type`::
The format of the keystore file. Should be either `jks` to use the Java
Keystore format, or `PKCS12` to use PKCS#12 files. The default is `jks`.
2017-04-06 20:34:23 -04:00
`ssl.truststore.password`::
The password to the truststore.
`ssl.verification_mode`::
Indicates the type of verification when using `ldaps` to protect against man
in the middle attacks and certificate forgery. Values are `none`, `certificate`,
and `full`. Defaults to the value of `xpack.ssl.verification_mode`.
`ssl.supported_protocols`::
Supported protocols with versions. Defaults to the value of
`xpack.ssl.supported_protocols`.
`ssl.cipher_suites`
Supported cipher suites can be found in Oracle's http://docs.oracle.com/javase/8/docs/technotes/guides/security/SunProviders.html[
Java Cryptography Architecture documentation]. Defaults to the value of
`xpack.ssl.cipher_suites`.
2017-06-27 12:14:35 -04:00
`cache.ttl`::
Specifies the time-to-live for cached user entries (a user and its credentials
are cached for this period of time). Use the standard Elasticsearch
2017-04-06 20:34:23 -04:00
{ref}/common-options.html#time-units[time units]). Defaults to `20m`.
2017-06-27 12:14:35 -04:00
`cache.max_users`::
Specifies the maximum number of user entries that the cache can contain.
2017-04-06 20:34:23 -04:00
Defaults to `100000`.
2017-06-27 12:14:35 -04:00
`cache.hash_algo`::
(Expert Setting) Specifies the hashing algorithm that is used for the
in-memory cached user credentials (see {xpack-ref}/controlling-user-cache.html#controlling-user-cache[Cache hash algorithms]
2017-04-06 20:34:23 -04:00
table for all possible values). Defaults to `ssha256`.
[[ref-ad-settings]]
[float]
2017-06-27 12:14:35 -04:00
===== Active Directory Realm Settings
2017-04-06 20:34:23 -04:00
2017-06-27 12:14:35 -04:00
`url`::
A URL in the format `ldap[s]://<server>:<port>`. Defaults to `ldap://<domain_name>:389`.
2017-04-06 20:34:23 -04:00
2017-06-27 12:14:35 -04:00
`load_balance.type`::
The behavior to use when there are multiple LDAP URLs defined. For supported
2017-06-26 13:35:25 -04:00
values see {xpack-ref}/active-directory-realm.html#ad-load-balancing[load balancing and failover types].
2017-04-06 20:34:23 -04:00
Defaults to `failover`.
2017-06-27 12:14:35 -04:00
`load_balance.cache_ttl`::
When using `dns_failover` or `dns_round_robin` as the load balancing type,
2017-04-06 20:34:23 -04:00
this setting controls the amount of time to cache DNS lookups. Defaults
to `1h`.
2017-06-27 12:14:35 -04:00
`domain_name`::
The domain name of Active Directory. The cluster can derive the URL and
`user_search_dn` fields from values in this element if those fields are not
2017-04-06 20:34:23 -04:00
otherwise specified. Required.
2017-07-12 16:01:39 -04:00
`bind_dn`::
The DN of the user that will be used to bind to Active Directory and perform searches.
Defaults to Empty.
`bind_password`::
The password for the user that will be used to bind to Active Directory.
Defaults to Empty.
2017-06-27 12:14:35 -04:00
`unmapped_groups_as_roles`::
2017-06-06 00:12:31 -04:00
Takes a boolean variable. When this element is set to `true`, the names of any
LDAP groups that are not referenced in a role-mapping _file_ are used as role
names and assigned to the user. Defaults to `false`.
2017-04-06 20:34:23 -04:00
2017-06-27 12:14:35 -04:00
`files.role_mapping`::
2017-06-26 13:35:25 -04:00
The {xpack-ref}/security-files.html[location] for the YAML
2017-06-27 12:14:35 -04:00
role mapping configuration file. Defaults to `CONFIG_DIR/x-pack/role_mapping.yml`.
2017-04-06 20:34:23 -04:00
2017-06-27 12:14:35 -04:00
`user_search.base_dn`::
The context to search for a user. Defaults to the root
of the Active Directory domain.
2017-04-06 20:34:23 -04:00
2017-06-27 12:14:35 -04:00
`user_search.scope`::
Specifies whether the user search should be `sub_tree`, `one_level` or `base`.
`one_level` only searches users directly contained within the `base_dn`.
`sub_tree` searches all objects contained under `base_dn`. `base`
specifies that the `base_dn` is a user object, and that it is the
2017-04-06 20:34:23 -04:00
only user considered. Defaults to `sub_tree`.
2017-06-27 12:14:35 -04:00
`user_search.filter`::
Specifies a filter to use to lookup a user given a username. The default
filter looks up `user` objects with either `sAMAccountName` or
2017-04-06 20:34:23 -04:00
`userPrincipalName`.
2017-04-27 10:20:59 -04:00
`user_search.upn_filter`::
Specifies a filter to use to lookup a user given a user principal name.
2017-07-13 12:08:22 -04:00
The default filter looks up `user` objects with
a matching `userPrincipalName`. If specified, this
2017-04-27 10:20:59 -04:00
must be a valid LDAP user search filter, for example
2017-07-13 12:08:22 -04:00
`(&(objectClass=user)(userPrincipalName={1}))`. `{1}` is the full user principal name
2017-04-27 10:20:59 -04:00
provided by the user.
`user_search.down_level_filter`::
Specifies a filter to use to lookup a user given a down level logon name
(DOMAIN\user). The default filter looks up `user` objects with a matching
`sAMAccountName` in the domain provided. If specified, this
must be a valid LDAP user search filter, for example
`(&(objectClass=user)(sAMAccountName={0}))`.
2017-07-12 16:01:39 -04:00
`user_search.pool.enabled`::
Enables or disables connection pooling for user search. When
disabled a new connection is created for every search. The
default is `true` when `bind_dn` is provided.
`user_search.pool.size`::
The maximum number of connections to the Active Directory server to allow in the
connection pool. Defaults to `20`.
`user_search.pool.initial_size`::
The initial number of connections to create to the Active Directory server on startup.
Defaults to `0`.
`user_search.pool.health_check.enabled`::
Flag to enable or disable a health check on Active Directory connections in the connection
pool. Connections are checked in the background at the specified interval.
Defaults to `true`.
`user_search.pool.health_check.dn`::
The distinguished name to be retrieved as part of the health check.
Defaults to the value of `bind_dn` if it is a distinguished name.
`user_search.pool.health_check.interval`::
The interval to perform background checks of connections in the pool.
Defaults to `60s`.
2017-06-27 12:14:35 -04:00
`group_search.base_dn`::
The context to search for groups in which the user has membership. Defaults
2017-04-06 20:34:23 -04:00
to the root of the Active Directory domain.
2017-06-27 12:14:35 -04:00
`group_search.scope`::
Specifies whether the group search should be `sub_tree`, `one_level` or
`base`. `one_level` searches for groups directly contained within the
`base_dn`. `sub_tree` searches all objects contained under `base_dn`.
`base` specifies that the `base_dn` is a group object, and that it is
2017-04-06 20:34:23 -04:00
the only group considered. Defaults to `sub_tree`.
2017-06-06 00:12:31 -04:00
`metadata`::
A list of additional LDAP attributes that should be loaded from the
LDAP server and stored in the authenticated user's metadata field.
`timeout.tcp_connect`::
2017-06-27 12:14:35 -04:00
The TCP connect timeout period for establishing an LDAP connection.
2017-04-06 20:34:23 -04:00
An `s` at the end indicates seconds, or `ms` indicates milliseconds.
Defaults to `5s` (5 seconds ).
2017-06-27 12:14:35 -04:00
`timeout.tcp_read`::
The TCP read timeout period after establishing an LDAP connection.
2017-04-06 20:34:23 -04:00
An `s` at the end indicates seconds, or `ms` indicates milliseconds.
Defaults to `5s` (5 seconds ).
2017-06-27 12:14:35 -04:00
`timeout.ldap_search`::
The LDAP Server enforced timeout period for an LDAP search.
2017-04-06 20:34:23 -04:00
An `s` at the end indicates seconds, or `ms` indicates milliseconds.
Defaults to `5s` (5 seconds ).
`ssl.key`::
Path to the PEM encoded file containing the private key.
`ssl.key_passphrase`::
The passphrase that will be used to decrypt the private key. This value is
optional as the key may not be encrypted.
`ssl.certificate`::
Path to a PEM encoded file containing the certificate (or certificate chain)
that will be presented to clients when they connect.
`ssl.certificate_authorities`::
List of paths to PEM encoded certificate files that should be trusted.
`ssl.keystore.path`::
The path to the Java Keystore file that contains a private key and certificate.
2017-07-25 03:31:37 -04:00
`ssl.keystore.type`::
The format of the keystore file. Should be either `jks` to use the Java
Keystore format, or `PKCS12` to use PKCS#12 files. The default is `jks`.
2017-04-06 20:34:23 -04:00
`ssl.keystore.password`::
The password to the keystore.
`ssl.keystore.key_password`::
The password for the key in the keystore. Defaults to the keystore password.
`ssl.truststore.path`::
The path to the Java Keystore file that contains the certificates to trust.
2017-07-25 03:31:37 -04:00
`ssl.truststore.type`::
The format of the truststore file. Should be either `jks` to use the Java
Keystore format, or `PKCS12` to use PKCS#12 files. The default is `jks`.
2017-04-06 20:34:23 -04:00
`ssl.truststore.password`::
The password to the truststore.
`ssl.verification_mode`::
Indicates the type of verification when using `ldaps` to protect against man
in the middle attacks and certificate forgery. Values are `none`, `certificate`,
and `full`. Defaults to the value of `xpack.ssl.verification_mode`.
`ssl.supported_protocols`::
Supported protocols with versions. Defaults to the value of
`xpack.ssl.supported_protocols`.
`ssl.cipher_suites`
Supported cipher suites can be found in Oracle's http://docs.oracle.com/javase/8/docs/technotes/guides/security/SunProviders.html[
Java Cryptography Architecture documentation]. Defaults to the value of
`xpack.ssl.cipher_suites`.
2017-06-27 12:14:35 -04:00
`cache.ttl`::
2017-04-06 20:34:23 -04:00
Specifies the time-to-live for cached user entries (user
2017-06-27 12:14:35 -04:00
credentials are cached for this configured period of time). Use the
2017-04-06 20:34:23 -04:00
standard Elasticsearch {ref}/common-options.html#time-units[time units]).
Defaults to `20m`.
2017-06-27 12:14:35 -04:00
`cache.max_users`::
Specifies the maximum number of user entries that the cache can contain.
2017-04-06 20:34:23 -04:00
Defaults to `100000`.
2017-06-27 12:14:35 -04:00
`cache.hash_algo`::
(Expert Setting) Specifies the hashing algorithm that will be used for
2017-06-26 13:35:25 -04:00
the in-memory cached user credentials (see {xpack-ref}/controlling-user-cache.html#controlling-user-cache[Cache hash algorithms] table for all possible values). Defaults to `ssha256`.
2017-04-06 20:34:23 -04:00
[[ref-pki-settings]]
[float]
2017-06-27 12:14:35 -04:00
===== PKI Realm Settings
2017-04-06 20:34:23 -04:00
2017-06-27 12:14:35 -04:00
`username_pattern`::
The regular expression pattern used to extract the username from the
certificate DN. The first match group is the used as the username.
2017-04-06 20:34:23 -04:00
Defaults to `CN=(.*?)(?:,\|$)`
`certificate_authorities`::
List of PEM certificate files that should be used to authenticate a
user's certificate as trusted. Defaults to the trusted certificates configured for SSL.
2017-07-06 23:33:35 -04:00
See the {xpack-ref}/pki-realm.html#pki-ssl-config[SSL settings] section of the PKI realm documentation for more information.
2017-04-06 20:34:23 -04:00
This setting may not be used with `truststore.path`.
2017-06-27 12:14:35 -04:00
`truststore.path`::
2017-04-06 20:34:23 -04:00
The path of a truststore to use. Defaults to the trusted certificates configured for SSL.
2017-07-06 23:33:35 -04:00
See the {xpack-ref}/pki-realm.html#pki-ssl-config[SSL settings] section of the PKI realm documentation for more information.
2017-04-06 20:34:23 -04:00
This setting may not be used with `certificate_authorities`.
2017-06-27 12:14:35 -04:00
`truststore.password`::
2017-04-06 20:34:23 -04:00
The password for the truststore. Must be provided if `truststore.path` is set.
2017-06-27 12:14:35 -04:00
`truststore.algorithm`::
2017-07-24 23:03:07 -04:00
Algorithm for the truststore. Defaults to `SunX509`.
2017-04-06 20:34:23 -04:00
2017-06-27 12:14:35 -04:00
`files.role_mapping`::
Specifies the {xpack-ref}/security-files.html[location] of the
2017-06-26 13:35:25 -04:00
{xpack-ref}/mapping-roles.html[YAML role mapping configuration file].
2017-04-06 20:34:23 -04:00
Defaults to `CONFIG_DIR/x-pack/role_mapping.yml`.
[float]
[[ssl-tls-settings]]
2017-06-27 12:14:35 -04:00
==== Default TLS/SSL Settings
You can configure the following TLS/SSL settings in
2017-04-06 20:34:23 -04:00
`elasticsearch.yml`. For more information, see
2017-06-26 13:35:25 -04:00
{xpack-ref}/encrypting-communications.html[Encrypting Communications]. These settings will be used
2017-04-06 20:34:23 -04:00
for all of {xpack} unless they have been overridden by more specific
settings such as those for HTTP or Transport.
`xpack.ssl.supported_protocols`::
Supported protocols with versions. Valid protocols: `SSLv2Hello`,
`SSLv3`, `TLSv1`, `TLSv1.1`, `TLSv1.2`. Defaults to `TLSv1.2`, `TLSv1.1`,
`TLSv1`.
`xpack.ssl.client_authentication`::
Controls the server's behavior in regard to requesting a certificate
from client connections. Valid values are `required`, `optional`, and `none`.
`required` forces a client to present a certificate, while `optional`
requests a client certificate but the client is not required to present one.
Defaults to `required`.
`xpack.ssl.verification_mode`::
Controls the verification of certificates. Valid values are `none`,
`certificate`, and `full`. Defaults to `full`.
`xpack.ssl.cipher_suites`
Supported cipher suites can be found in Oracle's http://docs.oracle.com/javase/8/docs/technotes/guides/security/SunProviders.html[
Java Cryptography Architecture documentation]. Defaults to `TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA256`,
`TLS_ECDHE_ECDSA_WITH_AES_128_CBC_SHA256`, `TLS_ECDHE_ECDSA_WITH_AES_128_CBC_SHA`, `TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA`,
2017-08-01 09:36:35 -04:00
`TLS_RSA_WITH_AES_128_CBC_SHA256`, `TLS_RSA_WITH_AES_128_CBC_SHA`. If the _Java Cryptography Extension (JCE) Unlimited Strength
Jurisdiction Policy Files_ has been installed, the default value also includes `TLS_ECDHE_RSA_WITH_AES_256_CBC_SHA384`,
`TLS_ECDHE_ECDSA_WITH_AES_256_CBC_SHA384`, `TLS_ECDHE_ECDSA_WITH_AES_256_CBC_SHA`, `TLS_ECDHE_RSA_WITH_AES_256_CBC_SHA`,
`TLS_RSA_WITH_AES_256_CBC_SHA256`, `TLS_RSA_WITH_AES_256_CBC_SHA`.
2017-04-06 20:34:23 -04:00
[float]
[[tls-ssl-key-settings]]
2017-06-27 12:14:35 -04:00
===== Default TLS/SSL Key and Trusted Certificate Settings
2017-04-06 20:34:23 -04:00
The following settings are used to specify a private key, certificate, and the
trusted certificates that should be used when communicating over an SSL/TLS connection.
If none of the settings below are specified, this will default to the <<ssl-tls-settings, {xpack}
defaults>>. If no trusted certificates are configured, the default certificates that are trusted by the JVM will be
trusted along with the certificate(s) from the <<tls-ssl-key-settings, key settings>>. The key and certificate must be in place
for connections that require client authentication or when acting as a SSL enabled server.
[float]
===== PEM Encoded Files
When using PEM encoded files, use the following settings:
`xpack.ssl.key`::
Path to the PEM encoded file containing the private key.
`xpack.ssl.key_passphrase`::
The passphrase that will be used to decrypt the private key. This value is
optional as the key may not be encrypted.
`xpack.ssl.certificate`::
Path to a PEM encoded file containing the certificate (or certificate chain)
that will be presented to clients when they connect.
`xpack.ssl.certificate_authorities`::
List of paths to the PEM encoded certificate files that should be trusted.
[float]
===== Java Keystore Files
When using Java keystore files (JKS), which contain the private key, certificate
and certificates that should be trusted, use the following settings:
`xpack.ssl.keystore.path`::
Path to the keystore that holds the private key and certificate.
`xpack.ssl.keystore.password`::
Password to the keystore.
`xpack.ssl.keystore.key_password`::
Password for the private key in the keystore. Defaults to the
same value as `xpack.ssl.keystore.password`.
`xpack.ssl.truststore.path`::
Path to the truststore file.
`xpack.ssl.truststore.password`::
Password to the truststore.
2017-07-25 03:31:37 -04:00
[float]
===== PKCS#12 Files
When using PKCS#12 container files (`.p12` or `.pfx`), which contain the
private key, certificate, and certificates that should be trusted, use
the following settings:
`xpack.ssl.keystore.path`::
Path to the PKCS#12 file that holds the private key and certificate.
`xpack.ssl.keystore.type`::
Set this to `PKCS12`.
`xpack.ssl.keystore.password`::
Password to the PKCS#12 file.
`xpack.ssl.keystore.key_password`::
Password for the private key in the PKCS12 file.
Defaults to the same value as `xpack.ssl.keystore.password`.
`xpack.ssl.truststore.path`::
Path to the truststore file.
`xpack.ssl.truststore.type`::
Set this to `PKCS12`.
`xpack.ssl.truststore.password`::
Password to the truststore.
2017-04-06 20:34:23 -04:00
[[http-tls-ssl-settings]]
:ssl-prefix: xpack.security.http
:component: HTTP
:client-auth-default: none
:verifies!:
:server:
include::ssl-settings.asciidoc[]
[[transport-tls-ssl-settings]]
:ssl-prefix: xpack.security.transport
:component: Transport
:client-auth-default!:
:verifies:
:server:
include::ssl-settings.asciidoc[]
[[ssl-tls-profile-settings]]
[float]
2017-06-27 12:14:35 -04:00
===== Transport Profile TLS/SSL Settings
2017-04-06 20:34:23 -04:00
The same settings that are available for the <<transport-tls-ssl-settings, default transport>>
are also available for each transport profile. By default, the settings for a
transport profile will be the same as the default transport unless they
are specified.
As an example, lets look at the enabled setting. For the default transport
this is `xpack.security.transport.ssl.enabled`. In order to use this setting in a
transport profile, use the prefix `transport.profiles.$PROFILE.xpack.security.` and
append the portion of the setting after `xpack.security.transport.`. For the enabled
setting, this would be `transport.profiles.$PROFILE.xpack.security.ssl.enabled`.
[float]
[[ip-filtering-settings]]
2017-06-27 12:14:35 -04:00
==== IP Filtering Settings
2017-06-26 13:35:25 -04:00
You can configure the following settings for {xpack-ref}/ip-filtering.html[IP filtering].
2017-04-06 20:34:23 -04:00
`xpack.security.transport.filter.allow`::
List of IP addresses to allow.
`xpack.security.transport.filter.deny`::
List of IP addresses to deny.
`xpack.security.http.filter.allow`::
List of IP addresses to allow just for HTTP.
`xpack.security.http.filter.deny`::
List of IP addresses to deny just for HTTP.
`transport.profiles.$PROFILE.xpack.security.filter.allow`::
List of IP addresses to allow for this profile.
`transport.profiles.$PROFILE.xpack.security.filter.deny`::
List of IP addresses to deny for this profile.