ACL Auth Methods
An auth method is a component in Consul that performs authentication against a trusted external party to authorize the creation of an ACL tokens usable within the local datacenter.
Without an auth method a trusted operator is critically involved in the creation and secure introduction of each ACL token to every application that needs one, while ensuring that the policies assigned to these tokens follow the principle of least-privilege.
When running in environments such as a public cloud or when supervised by a cluster scheduler, applications may already have access to uniquely identifying credentials that were delivered securely by the platform. Consul auth method integrations allow for these credentials to be used to create ACL tokens with properly-scoped policies without additional operator intervention.
In Consul 1.5.0 the focus is around simplifying the creation of tokens with the privileges necessary to participate in a Connect service mesh with minimal operator intervention.
An operator needs to configure each auth method that is to be trusted by using the API or command line before they can be used by applications.
Authorization - One or more binding rules must be configured to define how to translate trusted identity attributes from each auth method into privileges assigned to the ACL token that is created. These can be managed with the
consul acl binding-rule
subcommands or the corresponding .
Note - To configure auth methods in any connected secondary datacenter, ACL token replication must be enabled. Auth methods require the ability to create local tokens which is restricted to the primary datacenter and any secondary datacenters with ACL token replication enabled.
Successful authentication with an auth method returns a set of trusted identity attributes corresponding to the authenticated identity. Those attributes are matched against all configured binding rules for that auth method to determine what privileges to grant the the Consul ACL token it will ultimately create.
Each binding rule is composed of two portions:
Selector - A logical query that must match the trusted identity attributes for the binding rule to be applicable to a given login attempt. The syntax uses github.com/hashicorp/go-bexpr which is shared with the . For example:
Bind Type and Name - A binding rule can bind a token to a role or to a by name. The name can be specified with a plain string or the bind name can be lightly templated using HIL syntax to interpolate the same values that are usable by the
Selector
syntax. For example:
When multiple binding rules match, then all roles and service identities are jointly linked to the token created by the login process.
Applications are responsible for exchanging their auth method specific secret bearer token for a Consul ACL token by using the login process:
Applications use the
consul login
subcommand or the to authenticate to a specific auth method using their local Consul client. Applications provide both the name of the auth method and a secret bearer token during login.Successful validation returns trusted identity attributes to the Consul leader.
The Consul leader consults the configured set of binding rules associated with the specified auth method and selects only those rules that match the trusted identity attributes.
The Consul leader uses the matching binding rules to generate a list of roles and service identities and assigns them to a token created exclusively in the local datacenter. If none are generated the login attempt fails.
The relevant and remaining details about the token are returned to the originating Consul client.
The Consul client returns the token details back to the application.
For more details about specific auth methods and how to configure them, click on the name of the auth method type in the sidebar.