2018-10-31 18:11:51 -04:00
---
layout: api
page_title: ACLs - HTTP API
2020-04-07 14:55:19 -04:00
description: The /acl endpoints manage the Consul's ACL system.
2018-10-31 18:11:51 -04:00
---
# ACL HTTP API
2020-10-14 10:23:05 -05:00
-> **1.4.0+:** This API documentation is for Consul versions 1.4.0 and later. The documentation for the legacy ACL API is [here](/api/acl/legacy).
2020-04-07 14:55:19 -04:00
2020-04-09 19:46:54 -04:00
The `/acl` endpoints are used to manage ACL tokens and policies in Consul, [bootstrap the ACL system](#bootstrap-acls), [check ACL replication status](#check-acl-replication), and [translate rules](#translate-rules). There are additional pages for managing [tokens](/api/acl/tokens) and [policies](/api/acl/policies) with the `/acl` endpoints.
2018-10-31 18:11:51 -04:00
2020-08-17 18:20:02 +02:00
For more information on how to setup ACLs, please check
the [ACL tutorial](https://learn.hashicorp.com/tutorials/consul/access-control-setup-production).
2018-10-31 18:11:51 -04:00
## Bootstrap ACLs
This endpoint does a special one-time bootstrap of the ACL system, making the first
2020-04-09 19:46:54 -04:00
management token if the [`acl.tokens.master`](/docs/agent/options#acl_tokens_master)
2018-10-31 18:11:51 -04:00
configuration entry is not specified in the Consul server configuration and if the
cluster has not been bootstrapped previously. This is available in Consul 0.9.1 and later,
and requires all Consul servers to be upgraded in order to operate.
This provides a mechanism to bootstrap ACLs without having any secrets present in Consul's
configuration files.
2020-04-06 16:27:35 -04:00
| Method | Path | Produces |
| ------ | ---------------- | ------------------ |
| `PUT` | `/acl/bootstrap` | `application/json` |
2018-10-31 18:11:51 -04:00
The table below shows this endpoint's support for
2020-04-09 19:46:54 -04:00
[blocking queries](/api/features/blocking),
[consistency modes](/api/features/consistency),
[agent caching](/api/features/caching), and
2020-04-09 19:20:00 -04:00
[required ACLs](/api#authentication).
2018-10-31 18:11:51 -04:00
| Blocking Queries | Consistency Modes | Agent Caching | ACL Required |
| ---------------- | ----------------- | ------------- | ------------ |
| `NO` | `none` | `none` | `none` |
### Sample Request
2020-05-19 14:32:38 -04:00
```shell-session
2018-10-31 18:11:51 -04:00
$ curl \
--request PUT \
http://127.0.0.1:8500/v1/acl/bootstrap
```
### Sample Response
-> **Deprecated** - The `ID` field in the response is for legacy compatibility and is a copy of the `SecretID` field. New
applications should ignore the `ID` field as it may be removed in a future major Consul version.
```json
{
2020-04-06 16:27:35 -04:00
"ID": "527347d3-9653-07dc-adc0-598b8f2b0f4d",
"AccessorID": "b5b1a918-50bc-fc46-dec2-d481359da4e3",
"SecretID": "527347d3-9653-07dc-adc0-598b8f2b0f4d",
"Description": "Bootstrap Token (Global Management)",
"Policies": [
{
"ID": "00000000-0000-0000-0000-000000000001",
"Name": "global-management"
}
],
"Local": false,
"CreateTime": "2018-10-24T10:34:20.843397-04:00",
"Hash": "oyrov6+GFLjo/KZAfqgxF/X4J/3LX0435DOBy9V22I0=",
"CreateIndex": 12,
"ModifyIndex": 12
2018-10-31 18:11:51 -04:00
}
```
You can detect if something has interfered with the ACL bootstrapping process by
checking the response code. A 200 response means that the bootstrap was a success, and
a 403 means that the cluster has already been bootstrapped, at which point you should
consider the cluster in a potentially compromised state.
The returned token will have unrestricted privileges to manage all details of the system.
2020-08-17 18:20:02 +02:00
It can then be used to further configure the ACL system. Please check the
[ACL tutorial](https://learn.hashicorp.com/tutorials/consul/access-control-setup-production) for more details.
2018-10-31 18:11:51 -04:00
## Check ACL Replication
This endpoint returns the status of the ACL replication processes in the
2020-04-06 16:27:35 -04:00
datacenter. This is intended to be used by operators or by automation checking
2018-10-31 18:11:51 -04:00
to discover the health of ACL replication.
2020-08-17 18:20:02 +02:00
Please check the [ACL Replication tutorial](https://learn.hashicorp.com/tutorials/consul/access-control-replication-multiple-datacenters)
2019-05-15 10:49:41 -05:00
for more details.
2018-10-31 18:11:51 -04:00
2020-04-06 16:27:35 -04:00
| Method | Path | Produces |
| ------ | ------------------ | ------------------ |
| `GET` | `/acl/replication` | `application/json` |
2018-10-31 18:11:51 -04:00
The table below shows this endpoint's support for
2020-04-09 19:46:54 -04:00
[blocking queries](/api/features/blocking),
[consistency modes](/api/features/consistency),
[agent caching](/api/features/caching), and
2020-04-09 19:20:00 -04:00
[required ACLs](/api#authentication).
2018-10-31 18:11:51 -04:00
| Blocking Queries | Consistency Modes | Agent Caching | ACL Required |
| ---------------- | ----------------- | ------------- | ------------ |
| `NO` | `consistent` | `none` | `none` |
### Parameters
- `dc` `(string: "")` - Specifies the datacenter to query. This will default to
the datacenter of the agent being queried. This is specified as part of the
URL as a query parameter.
### Sample Request
2020-05-19 14:32:38 -04:00
```shell-session
2018-10-31 18:11:51 -04:00
$ curl \
--request GET \
http://127.0.0.1:8500/v1/acl/replication
```
### Sample Response
```json
{
"Enabled": true,
"Running": true,
"SourceDatacenter": "dc1",
2020-04-06 16:27:35 -04:00
"ReplicationType": "tokens",
2018-10-31 18:11:51 -04:00
"ReplicatedIndex": 1976,
"ReplicatedTokenIndex": 2018,
"LastSuccess": "2018-11-03T06:28:58Z",
"LastError": "2016-11-03T06:28:28Z"
}
```
- `Enabled` - Reports whether ACL replication is enabled for the datacenter.
- `Running` - Reports whether the ACL replication process is running. The process
may take approximately 60 seconds to begin running after a leader election
occurs.
- `SourceDatacenter` - The authoritative ACL datacenter that ACLs are being
replicated from and will match the
2020-04-09 19:46:54 -04:00
[`primary_datacenter`](/docs/agent/options#primary_datacenter) configuration.
2018-10-31 18:11:51 -04:00
- `ReplicationType` - The type of replication that is currently in use.
2020-04-06 16:27:35 -04:00
- `legacy` - ACL replication is in legacy mode and is replicating legacy ACL tokens.
2018-10-31 18:11:51 -04:00
2020-04-06 16:27:35 -04:00
- `policies` - ACL replication is only replicating policies as token replication
is disabled.
2018-10-31 18:11:51 -04:00
2020-04-06 16:27:35 -04:00
- `tokens` - ACL replication is replicating both policies and tokens.
2018-10-31 18:11:51 -04:00
- `ReplicatedIndex` - The last index that was successfully replicated. Which data
the replicated index refers to depends on the replication type. For `legacy`
replication this can be compared with the value of the `X-Consul-Index` header
2020-04-13 17:24:10 -04:00
returned by the [`/v1/acl/list`](/api/acl/legacy#list-acls) endpoint to
2018-10-31 18:11:51 -04:00
determine if the replication process has gotten all available ACLs. When in either
`tokens` or `policies` mode, this index can be compared with the value of the
2020-04-09 19:46:54 -04:00
`X-Consul-Index` header returned by the [`/v1/acl/policies`](/api/acl/policies#list-policies)
2018-10-31 18:11:51 -04:00
endpoint to determine if the policy replication process has gotten all available
ACL policies. Note that ACL replication is rate limited so the indexes may lag behind
the primary datacenter.
- `ReplicatedTokenIndex` - The last token index that was successfully replicated.
2020-04-06 16:27:35 -04:00
This index can be compared with the value of the `X-Consul-Index` header returned
2020-09-01 10:14:13 -05:00
by the [`/v1/acl/tokens`](/api/acl/tokens#list-tokens) endpoint to determine
2020-04-06 16:27:35 -04:00
if the replication process has gotten all available ACL tokens. Note that ACL
replication is rate limited so the indexes may lag behind the primary
datacenter.
2018-10-31 18:11:51 -04:00
- `LastSuccess` - The UTC time of the last successful sync operation. Since ACL
replication is done with a blocking query, this may not update for up to 5
minutes if there have been no ACL changes to replicate. A zero value of
"0001-01-01T00:00:00Z" will be present if no sync has been successful.
- `LastError` - The UTC time of the last error encountered during a sync
operation. If this time is later than `LastSuccess`, you can assume the
replication process is not in a good state. A zero value of
"0001-01-01T00:00:00Z" will be present if no sync has resulted in an error.
## Translate Rules
-> **Deprecated** - This endpoint was introduced in Consul 1.4.0 for migration from the previous ACL system. It
will be removed in a future major Consul version when support for legacy ACLs is removed.
This endpoint translates the legacy rule syntax into the latest syntax. It is intended
to be used by operators managing Consul's ACLs and performing legacy token to new policy
migrations.
2020-04-06 16:27:35 -04:00
| Method | Path | Produces |
| ------ | ---------------------- | ------------ |
| `POST` | `/acl/rules/translate` | `text/plain` |
2018-10-31 18:11:51 -04:00
The table below shows this endpoint's support for
2020-04-09 19:46:54 -04:00
[blocking queries](/api/features/blocking),
[consistency modes](/api/features/consistency),
[agent caching](/api/features/caching), and
2020-04-09 19:20:00 -04:00
[required ACLs](/api#authentication).
2018-10-31 18:11:51 -04:00
| Blocking Queries | Consistency Modes | Agent Caching | ACL Required |
| ---------------- | ----------------- | ------------- | ------------ |
| `NO` | `none` | `none` | `acl:read` |
### Sample Payload
2021-07-30 18:37:33 -07:00
```hcl
2018-10-31 18:11:51 -04:00
agent "" {
policy = "read"
}
```
### Sample Request
2020-05-19 14:32:38 -04:00
```shell-session
2020-04-06 16:27:35 -04:00
$ curl -X POST -d @rules.hcl http://127.0.0.1:8500/v1/acl/rules/translate
2018-10-31 18:11:51 -04:00
```
### Sample Response
2021-07-30 18:37:33 -07:00
```hcl
2018-10-31 18:11:51 -04:00
agent_prefix "" {
policy = "read"
}
```
## Translate a Legacy Token's Rules
-> **Deprecated** - This endpoint was introduced in Consul 1.4.0 for migration from the previous ACL system.. It
will be removed in a future major Consul version when support for legacy ACLs is removed.
This endpoint translates the legacy rules embedded within a legacy ACL into the latest
syntax. It is intended to be used by operators managing Consul's ACLs and performing
legacy token to new policy migrations. Note that this API requires the auto-generated
Accessor ID of the legacy token. This ID can be retrieved using the
2020-04-13 19:11:41 -04:00
[`/v1/acl/token/self`](/api/acl/tokens#read-self-token) endpoint.
2018-10-31 18:11:51 -04:00
2020-04-06 16:27:35 -04:00
| Method | Path | Produces |
| ------ | ----------------------------------- | ------------ |
| `GET` | `/acl/rules/translate/:accessor_id` | `text/plain` |
2018-10-31 18:11:51 -04:00
The table below shows this endpoint's support for
2020-04-09 19:46:54 -04:00
[blocking queries](/api/features/blocking),
[consistency modes](/api/features/consistency),
[agent caching](/api/features/caching), and
2020-04-09 19:20:00 -04:00
[required ACLs](/api#authentication).
2018-10-31 18:11:51 -04:00
| Blocking Queries | Consistency Modes | Agent Caching | ACL Required |
| ---------------- | ----------------- | ------------- | ------------ |
| `NO` | `none` | `none` | `acl:read` |
### Sample Request
2020-05-19 14:32:38 -04:00
```shell-session
2018-10-31 18:11:51 -04:00
$ curl -X GET http://127.0.0.1:8500/v1/acl/rules/translate/4f48f7e6-9359-4890-8e67-6144a962b0a5
```
### Sample Response
2021-07-30 18:37:33 -07:00
```hcl
2018-10-31 18:11:51 -04:00
agent_prefix "" {
policy = "read"
}
```
2019-05-01 16:11:23 -05:00
## Login to Auth Method
This endpoint was added in Consul 1.5.0 and is used to exchange an [auth
2020-05-13 14:14:03 -05:00
method](/docs/acl/auth-methods) bearer token for a newly-created
2019-05-01 16:11:23 -05:00
Consul ACL token.
2020-04-06 16:27:35 -04:00
| Method | Path | Produces |
| ------ | ------------ | ------------------ |
| `POST` | `/acl/login` | `application/json` |
2019-05-01 16:11:23 -05:00
The table below shows this endpoint's support for
2020-04-09 19:46:54 -04:00
[blocking queries](/api/features/blocking),
[consistency modes](/api/features/consistency),
[agent caching](/api/features/caching), and
2020-04-09 19:20:00 -04:00
[required ACLs](/api#authentication).
2019-05-01 16:11:23 -05:00
| Blocking Queries | Consistency Modes | Agent Caching | ACL Required |
| ---------------- | ----------------- | ------------- | ------------ |
| `NO` | `none` | `none` | `none` |
2019-05-06 11:57:31 -05:00
-> **Note** - To use the login process to create tokens in any connected
secondary datacenter, [ACL
2020-04-09 19:46:54 -04:00
replication](/docs/agent/options#acl_enable_token_replication) must be
2019-05-06 11:57:31 -05:00
enabled. Login requires the ability to create local tokens which is restricted
to the primary datacenter and any secondary datacenters with ACL token
replication enabled.
2019-05-01 16:11:23 -05:00
### Parameters
- `AuthMethod` `(string: <required>)` - The name of the auth method to use for login.
- `BearerToken` `(string: <required>)` - The bearer token to present to the
auth method during login for authentication purposes. For the Kubernetes auth
method this is a [Service Account Token
(JWT)](https://kubernetes.io/docs/reference/access-authn-authz/authentication/#service-account-tokens).
- `Meta` `(map<string|string>: nil)` - Specifies arbitrary KV metadata
linked to the token. Can be useful to track origins.
2020-04-06 16:27:35 -04:00
2020-04-23 15:13:18 -07:00
- `Namespace` `(string: "")` <EnterpriseAlert inline /> - Specifies the namespace of
2019-12-06 11:14:56 -05:00
the Auth Method to use for Login. If not provided in the JSON body, the value of
2020-04-06 16:27:35 -04:00
the `ns` URL query parameter or in the `X-Consul-Namespace` header will be used.
2020-10-14 10:23:05 -05:00
If not provided, the namespace will be inherited from the request's ACL
2019-12-20 11:52:50 -05:00
token, or will default to the `default` namespace. Added in Consul 1.7.0.
2019-05-01 16:11:23 -05:00
### Sample Payload
```json
{
2020-04-06 16:27:35 -04:00
"AuthMethod": "minikube",
"BearerToken": "eyJhbGciOiJSUzI1NiIsImtpZCI6IiJ9..."
2019-05-01 16:11:23 -05:00
}
```
### Sample Request
2020-05-19 14:32:38 -04:00
```shell-session
2019-05-01 16:11:23 -05:00
$ curl \
--request POST \
--data @payload.json \
http://127.0.0.1:8500/v1/acl/login
```
### Sample Response
```json
{
2020-04-06 16:27:35 -04:00
"AccessorID": "926e2bd2-b344-d91b-0c83-ae89f372cd9b",
"SecretID": "b78d37c7-0ca7-5f4d-99ee-6d9975ce4586",
"Description": "token created via login",
"Roles": [
{
"ID": "3356c67c-5535-403a-ad79-c1d5f9df8fc7",
"Name": "demo"
}
],
"ServiceIdentities": [
{
"ServiceName": "example"
}
],
"Local": true,
"AuthMethod": "minikube",
"CreateTime": "2019-04-29T10:08:08.404370762-05:00",
"Hash": "nLimyD+7l6miiHEBmN/tvCelAmE/SbIXxcnTzG3pbGY=",
"CreateIndex": 36,
"ModifyIndex": 36
2019-05-01 16:11:23 -05:00
}
```
## Logout from Auth Method
This endpoint was added in Consul 1.5.0 and is used to destroy a token created
via the [login endpoint](#login-to-auth-method). The token deleted is specified
with the `X-Consul-Token` header or the `token` query parameter.
2020-04-06 16:27:35 -04:00
| Method | Path | Produces |
| ------ | ------------- | ------------------ |
| `POST` | `/acl/logout` | `application/json` |
2019-05-01 16:11:23 -05:00
The table below shows this endpoint's support for
2020-04-09 19:46:54 -04:00
[blocking queries](/api/features/blocking),
[consistency modes](/api/features/consistency),
[agent caching](/api/features/caching), and
2020-04-09 19:20:00 -04:00
[required ACLs](/api#authentication).
2019-05-01 16:11:23 -05:00
| Blocking Queries | Consistency Modes | Agent Caching | ACL Required |
| ---------------- | ----------------- | ------------- | ------------ |
| `NO` | `none` | `none` | `none` |
-> **Note** - This endpoint requires no specific privileges as it is just
deleting a token for which you already must possess its secret.
### Sample Request
2020-05-19 14:32:38 -04:00
```shell-session
2019-05-01 16:11:23 -05:00
$ curl \
-H "X-Consul-Token: b78d37c7-0ca7-5f4d-99ee-6d9975ce4586" \
--request POST \
http://127.0.0.1:8500/v1/acl/logout
```
2020-05-13 14:14:03 -05:00
## OIDC Authorization URL Request
2020-05-19 14:32:38 -04:00
<EnterpriseAlert>
{' '}
2020-12-17 16:11:36 -08:00
This is an enterprise only endpoint.
2020-05-19 14:32:38 -04:00
</EnterpriseAlert>
2020-05-13 14:14:03 -05:00
This endpoint was added in Consul 1.8.0 and is used to obtain an authorization
URL from Consul to start an [OIDC login flow](/docs/acl/auth-methods/oidc).
| Method | Path | Produces |
| ------ | -------------------- | ------------------ |
| `POST` | `/acl/oidc/auth-url` | `application/json` |
The table below shows this endpoint's support for
[blocking queries](/api/features/blocking),
[consistency modes](/api/features/consistency),
[agent caching](/api/features/caching), and
[required ACLs](/api#authentication).
| Blocking Queries | Consistency Modes | Agent Caching | ACL Required |
| ---------------- | ----------------- | ------------- | ------------ |
| `NO` | `none` | `none` | `none` |
-> **Note** - To use the login process to create tokens in any connected
secondary datacenter, [ACL
replication](/docs/agent/options#acl_enable_token_replication) must be
enabled. Login requires the ability to create local tokens which is restricted
to the primary datacenter and any secondary datacenters with ACL token
replication enabled.
### Parameters
- `AuthMethod` `(string: <required>)` - The name of the auth method to use for
2020-05-19 14:32:38 -04:00
login. This must be of type [`oidc`](/docs/acl/auth-methods/oidc).
2020-05-13 14:14:03 -05:00
2020-05-19 14:32:38 -04:00
- `RedirectURI` `(string: <required>)` - See [Redirect
2020-05-13 14:14:03 -05:00
URIs](/docs/acl/auth-methods/oidc#redirect-uris) for more information.
- `ClientNonce` `(string: "")` - Optional client-provided nonce that must match
during callback, if present.
- `Meta` `(map<string|string>: nil)` - Specifies arbitrary KV metadata
linked to the token. Can be useful to track origins.
- `Namespace` `(string: "")` <EnterpriseAlert inline /> - Specifies the namespace of
the Auth Method to use for Login. If not provided in the JSON body, the value of
the `ns` URL query parameter or in the `X-Consul-Namespace` header will be used.
2020-10-14 10:23:05 -05:00
If not provided, the namespace will be inherited from the request's ACL
2020-05-13 14:14:03 -05:00
token, or will default to the `default` namespace.
This must match the namespace provided on the [OIDC Callback](#oidc-callback).
### Sample Payload
```json
{
"AuthMethod": "auth0",
"RedirectURI": "http://localhost:8550/oidc/callback"
}
```
### Sample Request
2020-05-19 14:32:38 -04:00
```shell-session
2020-05-13 14:14:03 -05:00
$ curl \
--request POST \
--data @payload.json \
http://127.0.0.1:8500/v1/acl/oidc/auth-url
```
### Sample Response
```json
{
"AuthURL": "https://myprovider.com/authorize?client_id=..."
}
```
## OIDC Callback
2020-05-19 14:32:38 -04:00
<EnterpriseAlert>
{' '}
2020-12-17 16:11:36 -08:00
This is an enterprise only endpoint.
2020-05-19 14:32:38 -04:00
</EnterpriseAlert>
2020-05-13 14:14:03 -05:00
This endpoint was added in Consul 1.8.0 and is used to exchange an OIDC
authorization code for an OIDC ID Token. The ID token will in turn be exchanged
for a newly-created Consul ACL token.
| Method | Path | Produces |
| ------ | -------------------- | ------------------ |
| `POST` | `/acl/oidc/callback` | `application/json` |
The table below shows this endpoint's support for
[blocking queries](/api/features/blocking),
[consistency modes](/api/features/consistency),
[agent caching](/api/features/caching), and
[required ACLs](/api#authentication).
| Blocking Queries | Consistency Modes | Agent Caching | ACL Required |
| ---------------- | ----------------- | ------------- | ------------ |
| `NO` | `none` | `none` | `none` |
-> **Note** - To use the login process to create tokens in any connected
secondary datacenter, [ACL
replication](/docs/agent/options#acl_enable_token_replication) must be
enabled. Login requires the ability to create local tokens which is restricted
to the primary datacenter and any secondary datacenters with ACL token
replication enabled.
### Parameters
- `AuthMethod` `(string: <required>)` - The name of the auth method to use for
2020-05-19 14:32:38 -04:00
login. This must be of type [`oidc`](/docs/acl/auth-methods/oidc).
2020-05-13 14:14:03 -05:00
- `State` `(string: <required>)` - Opaque state ID that is part of the
Authorization URL and will be included in the the redirect following
successful authentication on the provider.
- `Code` `(string: <required>)` - Provider-generated authorization code that
Consul will exchange for an ID token.
- `ClientNonce` `(string: "")` - Optional client-provided nonce that must match
the one provided in the auth url request, if present.
- `Meta` `(map<string|string>: nil)` - Specifies arbitrary KV metadata
linked to the token. Can be useful to track origins.
- `Namespace` `(string: "")` <EnterpriseAlert inline /> - Specifies the namespace of
the Auth Method to use for Login. If not provided in the JSON body, the value of
the `ns` URL query parameter or in the `X-Consul-Namespace` header will be used.
2020-10-14 10:23:05 -05:00
If not provided, the namespace will be inherited from the request's ACL
2020-05-13 14:14:03 -05:00
token, or will default to the `default` namespace.
This must match the namespace provided on the [OIDC Callback](#oidc-callback).
### Sample Payload
```json
{
"AuthMethod": "auth0",
"State": "aa3f1903c2f5eac666e6f92e804cf7fc0ff1d15b",
"Code": "dn0u9oM9WegYBEnp"
}
```
### Sample Request
2020-05-19 14:32:38 -04:00
```shell-session
2020-05-13 14:14:03 -05:00
$ curl \
--request POST \
--data @payload.json \
http://127.0.0.1:8500/v1/acl/oidc/callback
```
### Sample Response
```json
{
"AccessorID": "926e2bd2-b344-d91b-0c83-ae89f372cd9b",
"SecretID": "b78d37c7-0ca7-5f4d-99ee-6d9975ce4586",
"Description": "token created via OIDC login",
"Roles": [
{
"ID": "3356c67c-5535-403a-ad79-c1d5f9df8fc7",
"Name": "demo"
}
],
"ServiceIdentities": [
{
"ServiceName": "example"
}
],
"Local": true,
"AuthMethod": "auth0",
"CreateTime": "2019-04-29T10:08:08.404370762-05:00",
"Hash": "nLimyD+7l6miiHEBmN/tvCelAmE/SbIXxcnTzG3pbGY=",
"CreateIndex": 36,
"ModifyIndex": 36
}
```