OIDC Auth Method
This feature requires Consul Enterprise.
This feature is available in version 1.8.0 and newer.
The auth method can be used to authenticate with Consul using OIDC. This method allows authentication via a configured OIDC provider using the user’s web browser. This method may be initiated from the Consul UI or the command line.
This page assumes general knowledge of and the concepts described in the main auth method documentation.
Both the and the oidc auth method types allow additional processing of the claims data in the JWT.
Since both the oidc
and jwt
auth methods ultimately operate on JWTs as bearer tokens, it may be confusing to know which is right for a given use case.
JWT: The user or application performing the Consul login must already be in possession of a valid JWT to begin. There is no browser interaction required. This is ideal for machine-oriented headless login where an operator may have already arranged for a valid JWT to be dropped on a VM or provided to a container.
OIDC: The user performing the Consul login does not have a JWT nor do they even need to know what that means. This is ideal for human-oriented interactive login where an operator or administrator may have deployed SSO widely and doesn’t want to have the burden of tracking and distributing Consul ACL tokens to any authorized coworker who may need to have access to a Consul instance. Browser interaction is required. This is only available in .
Config Parameters
The following auth method parameters are required to properly configure an auth method of type oidc
:
OIDCDiscoveryURL
(string: <required>)
- The OIDC Discovery URL, without any .well-known component (base path).(string: "")
- PEM encoded CA cert for use by the TLS client used to talk with the OIDC Discovery URL. NOTE: Every line must end with a newline (\n
). If not set, system certificates are used.OIDCClientID
(string: <required>)
- The OAuth Client ID configured with your OIDC provider.(string: <required>)
- The OAuth Client Secret configured with your OIDC provider.AllowedRedirectURIs
(array<string>)
- A list of allowed values forredirect_uri
. Must be non-empty.(map[string]string)
- Mappings of claims (key) that will be copied to a metadata field (value). Use this if the claim you are capturing is singular (such as an attribute).(map[string]string)
- Mappings of claims (key) will be copied to a metadata field (value). Use this if the claim you are capturing is list-like (such as groups).When mapped, the values in each list can be any of a number, string, or boolean and will all be stringified when returned.
(array<string>)
- A list of Authentication Context Class Reference values to use for the authentication request. See OIDC reference for more info on this parameter. Added in v1.11.0.(array<string>)
- JWTSupportedAlgs is a list of supported signing algorithms. Defaults to . (Available algorithms)(array<string>)
- List ofaud
claims that are valid for login; any match is sufficient.VerboseOIDCLogging
(bool: false)
- Log received OIDC tokens and claims when debug-level logging is active. Not recommended in production since sensitive information may be present in OIDC responses.
JWT signatures will be verified against public keys from the issuer via OIDC discovery. Keys will be fetched from the OIDC Discovery URL during authentication and OIDC validation criteria (e.g. iss
, aud
, etc.) will be applied.
OIDC Authentication
Consul includes two built-in OIDC login flows: the Consul UI, and the CLI using consul login.
An important part of OIDC auth method configuration is properly setting redirect URIs. This must be done both in Consul and with the OIDC provider, and these configurations must align. The redirect URIs are specified for an auth method with the parameter. There are different redirect URIs to configure the Consul UI and CLI flows, so one or both will need to be set up depending on the installation.
Consul UI
Logging in via the Consul UI requires a redirect URI of the form: http://localhost:8500/ui/oidc/callback
or https://{host:port}/ui/oidc/callback
The “host:port” must be correct for the Consul agent serving the Consul UI.
CLI
If you plan to support authentication via consul login -type=oidc -method=<name>
, a localhost redirect URI must be set (usually this is http://localhost:8550/oidc/callback
). Logins via the CLI may specify a different host and/or listening port if needed, and a URI with this host/port must match one of the configured redirected URIs. These same “localhost” URIs must be added to the provider as well.
Consul UI
- Click the “Log in” link at the top right of the menu bar.
- Click one of the “Continue with…” buttons for your OIDC auth method of choice.
- Complete the authentication with the configured provider.
CLI
The browser will open to the generated URL to complete the provider’s login. The URL may be entered manually if the browser cannot be automatically opened.
The callback listener may be customized with the following optional parameters. These are typically not required to be set:
The amount of configuration required for OIDC is relatively small, but it can be tricky to debug why things aren’t working. Some tips for setting up OIDC:
Monitor the log output for the Consul servers. Important information about OIDC validation failures will be emitted.
Ensure Redirect URIs are correct in Consul and on the provider. They need to match exactly. Check: http/https, 127.0.0.1/localhost, port numbers, whether trailing slashes are present.
BoundAudiences is optional and typically not required. OIDC providers will use the
client_id
as the audience and OIDC validation expects this.Check your provider for what scopes are required in order to receive all of the information you need. The scopes “profile” and “groups” often need to be requested, and can be added by setting
[OIDCScopes](#oidcscopes)="profile,groups"
on the auth method.The option is available which will log the received OIDC token if debug level logging is enabled. This can be helpful when debugging provider setup and verifying that the received claims are what you expect. Since claims data is logged verbatim and may contain sensitive information, this option should not be used in production.
Trusted Identity Attributes via Claim Mappings
Data from JWT claims can be returned from the authentication step as trusted identity attributes for use in binding rule selectors and bind name interpolation.
Control of which claims are mapped to which identity attributes is governed by the and ListClaimMappings. These are both maps of items to copy with elements of the form: "<JWT claim>":"<attribute suffix>"
.
The only difference between these two types of mappings is that is used to map singular values (such as a name, department, or team) while ListClaimMappings
is used to map lists of values.
The singular values mapped by ClaimMappings
can be interpolated in a binding rule, and the lists of values mapped by ListClaimMappings
cannot.
Assume this is your config snippet:
This specifies that the values in the JWT claims "givenName"
and "surname"
should be copied to attributes named "value.first_name"
and "value.last_name"
respectively. Additionally the list of values in the JWT claim "groups"
should be copied to an attribute named "list.groups"
.
The following table shows the resulting attributes that will be extracted, and the ways they may be used in Rule Bindings:
The and ListClaimMappings fields are used to point to data within the JWT. If the desired key is at the top of level of the JWT, the name can be provided directly. If it is nested at a lower level, a JSON Pointer may be used.
A parameter of "division"
will reference "North America"
, as this is a top level key. A parameter "/groups/primary"
uses JSON Pointer syntax to reference at a lower level. Any valid JSON Pointer can be used as a selector. Refer to the for a full description of the syntax