Search Guard Main Concepts
Content
Search Guard can be used to secure your Elasticsearch cluster by working with different industry standard authentication techniques, like Kerberos, LDAP / Active Directory, JSON web tokens, TLS certificates and Proxy authentication / SSO.
Regardless of what authentication method you use, the basic flow is as follows:
- A user wants to access an Elasticsearch cluster, for example by issuing a simple query.
- Search Guard retrieves the user’s credentials from the request
- How the credentials are retrieved depends on the authentication method. For example, they can be extracted from HTTP Basic Authentication headers, from a JSON web token or from a Kerberos ticket.
- Search Guard authenticates the credentials against the configured authentication backend(s).
- Search Guard authorizes the user by retrieving a list of the user’s roles from the configured authorization backend
- Roles retrieved from authorization backends are called backend roles.
- For example, roles can be fetched from LDAP/AD, from a JSON web token or from the Search Guard internal user database.
- Search Guard maps the user and backend roles to Search Guard roles.
- Search Guard determines the permissions associated with the Search Guard role and decides whether the action the user wants to perform is allowed or not.
- If your are using Document- and Field-Level-Security, you can also apply more fine grained permissions based on documents and individual fields.
Authentication flow
Credentials
In order to identify the user who wants to interact with the cluster, Search Guard first needs the user’s credentials.
What the term credential means depends on the technology you use for user identification. For example, if you use HTTP basic auth, then the credentials are username and password.
If you use a JSON web token, the credentials are contained in the token itself.
If you use TLS certificates for identifying clients, the credentials are the DN of the certificate.
A credential provider can either be challenging or non-challenging. A challenging provider actively asks the user for his or her credentials if they are not already present in the request. A common way is to display an HTTP basic auth dialogue.
A non-challenging authenticator always assumes that the credentials are present in the request, and will not ask the user for it in case they are missing.
Authentication AKA Authc
Search Guard then authenticates the credentials against a backend authentication module, for example LDAP, Active Directory, Kerberos or JWT.
Search Guard supports chaining multiple authenticators. If more than one authenticator is configured, Search Guard will try to authenticate the user against all authenticators in the chain, until one authenticator succeeds.
A common use case is to combine the Search Guard internal user database with LDAP / Active Directory.
Additionally, Search Guard supports so-called user information backends which can enrich the data of an already authenticated user by additional roles or attributes. Thus, you can get authentication from JWT. This JWT might also already carry role information. Using an LDAP user information backend, you can retrieve additional roles for the authenticated user.
Search Guard also supports external authentication and Single Sign On (SSO) solutions. In most cases, these systems act as a proxy or store authentication information in HTTP header fields. Search Guard provides an HTTP proxy authenticator, which can read and interpret these fields.
Users and roles
After the user is verified and roles have been retrieved, Search Guard will map the user and any backend roles to Search Guard roles.
In some cases you want to map the backend roles 1:1 to Search Guard roles, but more often you want to map different backend roles and users to one Search Guard role.
Permissions
Each interaction with Elasticsearch means that a particular user wants to execute an action on an Elasticsearch cluster and one or more indices.
A permission defines:
- which role,
- can perform which action,
- against which cluster or index.
A definition of a permission that allows searching a particular index looks like:
indices:data/read/search*
Permissions are defined per role and can be applied on a cluster or index level.
Search Guard ships with built-in groups of permissions like SGS_READ
, SGS_WRITE
, SGS_SEARCH
etc.
Action groups
An action group is an alias for a set of permissions. Action groups can be nested.
For example, the following snippet shows two action groups, where the SGS_SUGGEST
action group is referenced by the SGS_SEARCH
action group:
SGS_SEARCH:
- "indices:data/read/search*"
- "indices:data/read/msearch*"
- SGS_SUGGEST
SGS_SUGGEST:
- "indices:data/read/suggest*"
Action groups can be used in the role configuration instead of or in combination with fine-grained permissions like indices:data/read/search*
.
Search Guard ships with a built-in set of useful action groups like SGS_READ
, SGS_WRITE
, SGS_SEARCH
etc. We always keep the action groups up to date, so the preferred way of configuring your roles is to use the built-in action groups.
The Search Guard index
All configuration settings for Search Guard, such as users, roles and permissions, are stored as documents in a special Search Guard index. This index is secured so that only an admin user with a special SSL certificate may write or read this index. You can define one or more of these certificates, called admin certificates, in elasticsearch.yml.
Keeping the configuration settings in an Elasticsearch index enables hot config reloading. This means that you can change any of the user, role and permission settings at runtime, without restarting your nodes. Configuration changes will take effect immediately.
Also the authenticator configuration is hot reloadable, so you can add, remove or change authenticators at runtime as well.
You can load and change the settings from any machine which has access to your Elasticsearch cluster. You do not need to keep any configuration files on the nodes themselves.
The core configuration consists of the following files:
sg_authc.yml
- configure authenticationsg_roles.yml
- define roles and the associated permissions.sg_internal_users.yml
- stores users, roles and hashed passwords (hash with hash.sh) in the internal user database.sg_action_groups.yml
- define named permission groups.
If you are running Kibana, you might also need the following configuration:
sg_frontend_authc.yml
- authentication for Kibanasg_frontend_multi_tenancy.yml
- basic multi-tenancy settings for Kibanasg_tenants.yml
- defines tenants for configuring Kibana access
For special features or configuration, you have also the following files:
sg_authz.yml
- authorization-specific settingssg_auth_token_service.yml
- for configuring the API auth token servicesg_blocks.yml
- defines blocked users and IP addresses
You can find sample templates for all files in the Search Guard download.
Configuration settings are applied by pushing the content of one or more configuration files to the Search Guard secured cluster by using the sgctl
tool. For details, refer to the chapter sgctl.
Additional resources