2017-04-04 16:33:22 +00:00
---
layout: api
2018-10-31 22:11:51 +00:00
page_title: Legacy ACLs - HTTP API
sidebar_current: api-acl-tokens-legacy
2017-04-04 16:33:22 +00:00
description: |-
2018-10-31 22:11:51 +00:00
The /acl endpoints create, update, destroy, and query Legacy ACL tokens in Consul.
2017-04-04 16:33:22 +00:00
---
2018-10-31 22:11:51 +00:00
-> **Consul 1.4.0 deprecates the legacy ACL system completely.** It's _strongly_
recommended you do not build anything using the legacy system and consider using
the new ACL [Token ](/api/acl/tokens.html ) and [Policy ](/api/acl/policies.html ) APIs instead.
2017-08-03 00:05:18 +00:00
2018-10-31 22:11:51 +00:00
# ACL HTTP API
2017-08-03 00:05:18 +00:00
2018-10-31 22:11:51 +00:00
The `/acl` endpoints create, update, destroy, and query ACL tokens in Consul. For more information about ACLs, please see the [ACL Guide ](/docs/guides/acl-legacy.html ).
2017-08-03 00:05:18 +00:00
2017-04-04 16:33:22 +00:00
## Create ACL Token
This endpoint makes a new ACL token.
| Method | Path | Produces |
| ------ | ---------------------------- | -------------------------- |
| `PUT` | `/acl/create` | `application/json` |
The table below shows this endpoint's support for
2019-04-30 17:20:51 +00:00
[blocking queries ](/api/features/blocking.html ),
[consistency modes ](/api/features/consistency.html ),
[agent caching ](/api/features/caching.html ), and
[required ACLs ](/api/index.html#authentication ).
2017-04-04 16:33:22 +00:00
2018-09-06 10:34:28 +00:00
| Blocking Queries | Consistency Modes | Agent Caching | ACL Required |
| ---------------- | ----------------- | ------------- | ------------ |
| `NO` | `none` | `none` | `management` |
2017-04-04 16:33:22 +00:00
### Parameters
- `ID` `(string: "")` - Specifies the ID of the ACL. If not provided, a UUID is
generated.
- `Name` `(string: "")` - Specifies a human-friendly name for the ACL token.
- `Type` `(string: "client")` - Specifies the type of ACL token. Valid values
are: `client` and `management` .
- `Rules` `(string: "")` - Specifies rules for this ACL token. The format of the
2018-10-31 22:11:51 +00:00
`Rules` property is documented in the [ACL Guide ](/docs/guides/acl-legacy.html ).
2017-04-04 16:33:22 +00:00
### Sample Payload
```json
{
"Name": "my-app-token",
"Type": "client",
"Rules": ""
}
```
### Sample Request
```text
$ curl \
--request PUT \
--data @payload .json \
2018-08-28 16:07:15 +00:00
http://127.0.0.1:8500/v1/acl/create
2017-04-04 16:33:22 +00:00
```
### Sample Response
```json
{
"ID": "adf4238a-882b-9ddc-4a9d-5b6758e4159e"
}
```
## Update ACL Token
This endpoint is used to modify the policy for a given ACL token. Instead of
generating a new token ID, the `ID` field must be provided.
| Method | Path | Produces |
| ------ | ---------------------------- | -------------------------- |
| `PUT` | `/acl/update` | `application/json` |
The table below shows this endpoint's support for
2019-04-30 17:20:51 +00:00
[blocking queries ](/api/features/blocking.html ),
[consistency modes ](/api/features/consistency.html ),
[agent caching ](/api/features/caching.html ), and
[required ACLs ](/api/index.html#authentication ).
2017-04-04 16:33:22 +00:00
2018-09-06 10:34:28 +00:00
| Blocking Queries | Consistency Modes | Agent Caching | ACL Required |
| ---------------- | ----------------- | ------------- | ------------ |
| `NO` | `none` | `none` | `management` |
2017-04-04 16:33:22 +00:00
### Parameters
The parameters are the same as the _create_ endpoint, except the `ID` field is
required.
### Sample Payload
```json
{
"ID": "adf4238a-882b-9ddc-4a9d-5b6758e4159e",
"Name": "my-app-token-updated",
"Type": "client",
"Rules": "# New Rules",
}
```
### Sample Request
```text
$ curl \
--request PUT \
--data @payload .json \
2018-08-28 16:07:15 +00:00
http://127.0.0.1:8500/v1/acl/update
2017-04-04 16:33:22 +00:00
```
2018-10-24 15:11:51 +00:00
### Sample Response
```json
{
"ID": "adf4238a-882b-9ddc-4a9d-5b6758e4159e"
}
```
2018-10-31 22:11:51 +00:00
2017-04-04 16:33:22 +00:00
## Delete ACL Token
This endpoint deletes an ACL token with the given ID.
| Method | Path | Produces |
| ------ | ---------------------------- | -------------------------- |
| `PUT` | `/acl/destroy/:uuid` | `application/json` |
2018-10-31 22:11:51 +00:00
Even though the return type is application/json, the value is either true or
false, indicating whether the delete succeeded.
2018-10-24 15:11:51 +00:00
2017-04-04 16:33:22 +00:00
The table below shows this endpoint's support for
2019-04-30 17:20:51 +00:00
[blocking queries ](/api/features/blocking.html ),
[consistency modes ](/api/features/consistency.html ),
[agent caching ](/api/features/caching.html ), and
[required ACLs ](/api/index.html#authentication ).
2017-04-04 16:33:22 +00:00
2018-09-06 10:34:28 +00:00
| Blocking Queries | Consistency Modes | Agent Caching | ACL Required |
| ---------------- | ----------------- | ------------- | ------------ |
| `NO` | `none` | `none` | `management` |
2017-04-04 16:33:22 +00:00
### Parameters
- `uuid` `(string: <required>)` - Specifies the UUID of the ACL token to
destroy. This is required and is specified as part of the URL path.
### Sample Request
```text
$ curl \
--request PUT \
2018-08-28 16:07:15 +00:00
http://127.0.0.1:8500/v1/acl/destroy/8f246b77-f3e1-ff88-5b48-8ec93abf3e05
2017-04-04 16:33:22 +00:00
```
2018-10-24 15:11:51 +00:00
### Sample Response
```json
true
```
2017-04-04 16:33:22 +00:00
## Read ACL Token
This endpoint reads an ACL token with the given ID.
| Method | Path | Produces |
| ------ | ---------------------------- | -------------------------- |
| `GET` | `/acl/info/:uuid` | `application/json` |
The table below shows this endpoint's support for
2019-04-30 17:20:51 +00:00
[blocking queries ](/api/features/blocking.html ),
[consistency modes ](/api/features/consistency.html ),
[agent caching ](/api/features/caching.html ), and
[required ACLs ](/api/index.html#authentication ).
2017-04-04 16:33:22 +00:00
2018-09-06 10:34:28 +00:00
| Blocking Queries | Consistency Modes | Agent Caching | ACL Required |
| ---------------- | ----------------- | ------------- | ------------ |
| `YES` | `all` | `none` | `none` |
2017-04-04 16:33:22 +00:00
Note: No ACL is required because the ACL is specified in the URL path.
### Parameters
- `uuid` `(string: <required>)` - Specifies the UUID of the ACL token to
2017-05-07 00:21:13 +00:00
read. This is required and is specified as part of the URL path.
2017-04-04 16:33:22 +00:00
### Sample Request
```text
$ curl \
2018-08-28 16:07:15 +00:00
http://127.0.0.1:8500/v1/acl/info/8f246b77-f3e1-ff88-5b48-8ec93abf3e05
2017-04-04 16:33:22 +00:00
```
### Sample Response
```json
[
{
"CreateIndex": 3,
"ModifyIndex": 3,
"ID": "8f246b77-f3e1-ff88-5b48-8ec93abf3e05",
"Name": "Client Token",
"Type": "client",
"Rules": "..."
}
]
```
## Clone ACL Token
This endpoint clones an ACL and returns a new token `ID` . This allows a token to
serve as a template for others, making it simple to generate new tokens without
complex rule management.
| Method | Path | Produces |
| ------ | ---------------------------- | -------------------------- |
| `PUT` | `/acl/clone/:uuid` | `application/json` |
The table below shows this endpoint's support for
2019-04-30 17:20:51 +00:00
[blocking queries ](/api/features/blocking.html ),
[consistency modes ](/api/features/consistency.html ),
[agent caching ](/api/features/caching.html ), and
[required ACLs ](/api/index.html#authentication ).
2017-04-04 16:33:22 +00:00
2018-09-06 10:34:28 +00:00
| Blocking Queries | Consistency Modes | Agent Caching | ACL Required |
| ---------------- | ----------------- | ------------- | ------------ |
| `NO` | `none` | `none` | `management` |
2017-04-04 16:33:22 +00:00
### Parameters
- `uuid` `(string: <required>)` - Specifies the UUID of the ACL token to
2017-06-10 21:46:25 +00:00
be cloned. This is required and is specified as part of the URL path.
2017-04-04 16:33:22 +00:00
### Sample Request
```text
$ curl \
--request PUT \
2018-08-28 16:07:15 +00:00
http://127.0.0.1:8500/v1/acl/clone/8f246b77-f3e1-ff88-5b48-8ec93abf3e05
2017-04-04 16:33:22 +00:00
```
### Sample Response
```json
{
"ID": "adf4238a-882b-9ddc-4a9d-5b6758e4159e"
}
```
## List ACLs
This endpoint lists all the active ACL tokens.
| Method | Path | Produces |
| ------ | ---------------------------- | -------------------------- |
| `GET` | `/acl/list` | `application/json` |
The table below shows this endpoint's support for
2019-04-30 17:20:51 +00:00
[blocking queries ](/api/features/blocking.html ),
[consistency modes ](/api/features/consistency.html ),
[agent caching ](/api/features/caching.html ), and
[required ACLs ](/api/index.html#authentication ).
2017-04-04 16:33:22 +00:00
2018-09-06 10:34:28 +00:00
| Blocking Queries | Consistency Modes | Agent Caching | ACL Required |
| ---------------- | ----------------- | ------------- | ------------ |
| `YES` | `all` | `none` | `management` |
2017-04-04 16:33:22 +00:00
### Sample Request
```text
$ curl \
2018-08-28 16:07:15 +00:00
http://127.0.0.1:8500/v1/acl/list
2017-04-04 16:33:22 +00:00
```
### Sample Response
```json
[
{
"CreateIndex": 3,
"ModifyIndex": 3,
"ID": "8f246b77-f3e1-ff88-5b48-8ec93abf3e05",
"Name": "Client Token",
"Type": "client",
"Rules": "..."
}
]
2018-10-31 22:11:51 +00:00
```