Create or update application privileges API

Create or update application privileges API

New API reference

For the most up-to-date API details, refer to Security APIs.

Adds or updates application privileges.

Request

POST /_security/privilege

PUT /_security/privilege

Prerequisites

To use this API, you must have either:

  • the manage_security cluster privilege (or a greater privilege such as all); or
  • the “Manage Application Privileges” global privilege for the application being referenced in the request

Description

This API creates or updates privileges. To remove privileges, use the delete application privilege API.

For more information, see Application privileges.

To check a user’s application privileges, use the has privileges API.

Request body

The body is a JSON object where the names of the fields are the application names and the value of each field is an object. The fields in this inner object are the names of the privileges and each value is a JSON object that includes the following fields:

actions

(array-of-string) A list of action names that are granted by this privilege. This field must exist and cannot be an empty array.

metadata

(object) Optional meta-data. Within the metadata object, keys that begin with _ are reserved for system usage.

Validation

Application names

Application names are formed from a prefix, with an optional suffix that conform to the following rules:

  • The prefix must begin with a lowercase ASCII letter
  • The prefix must contain only ASCII letters or digits
  • The prefix must be at least 3 characters long
  • If the suffix exists, it must begin with either - or _
  • The suffix cannot contain any of the following characters: \, /, *, ?, ", <, >, |, ,, *
  • No part of the name can contain whitespace.

Privilege names

Privilege names must begin with a lowercase ASCII letter and must contain only ASCII letters and digits along with the characters _, - and .

Action names

Action names can contain any number of printable ASCII characters and must contain at least one of the following characters: / *, :

Response body

A successful call returns a JSON structure that shows whether the privilege has been created or updated.

Examples

To add a single privilege, submit a PUT or POST request to the /_security/privilege/ endpoint. For example:

  1. resp = client.security.put_privileges(
  2. privileges={
  3. "myapp": {
  4. "read": {
  5. "actions": [
  6. "data:read/*",
  7. "action:login"
  8. ],
  9. "metadata": {
  10. "description": "Read access to myapp"
  11. }
  12. }
  13. }
  14. },
  15. )
  16. print(resp)
  1. const response = await client.security.putPrivileges({
  2. privileges: {
  3. myapp: {
  4. read: {
  5. actions: ["data:read/*", "action:login"],
  6. metadata: {
  7. description: "Read access to myapp",
  8. },
  9. },
  10. },
  11. },
  12. });
  13. console.log(response);
  1. PUT /_security/privilege
  2. {
  3. "myapp": {
  4. "read": {
  5. "actions": [
  6. "data:read/*" ,
  7. "action:login" ],
  8. "metadata": {
  9. "description": "Read access to myapp"
  10. }
  11. }
  12. }
  13. }

These strings have significance within the “myapp” application. Elasticsearch does not assign any meaning to them.

The use of a wildcard here (*) means that this privilege grants access to all actions that start with data:read/. Elasticsearch does not assign any meaning to these actions. However, if the request includes an application privilege such as data:read/users or data:read/settings, the has privileges API respects the use of a wildcard and returns true.

The metadata object is optional.

  1. {
  2. "myapp": {
  3. "read": {
  4. "created": true
  5. }
  6. }
  7. }

When an existing privilege is updated, created is set to false.

To add multiple privileges, submit a POST request to the /_security/privilege/ endpoint. For example:

  1. resp = client.security.put_privileges(
  2. privileges={
  3. "app01": {
  4. "read": {
  5. "actions": [
  6. "action:login",
  7. "data:read/*"
  8. ]
  9. },
  10. "write": {
  11. "actions": [
  12. "action:login",
  13. "data:write/*"
  14. ]
  15. }
  16. },
  17. "app02": {
  18. "all": {
  19. "actions": [
  20. "*"
  21. ]
  22. }
  23. }
  24. },
  25. )
  26. print(resp)
  1. const response = await client.security.putPrivileges({
  2. privileges: {
  3. app01: {
  4. read: {
  5. actions: ["action:login", "data:read/*"],
  6. },
  7. write: {
  8. actions: ["action:login", "data:write/*"],
  9. },
  10. },
  11. app02: {
  12. all: {
  13. actions: ["*"],
  14. },
  15. },
  16. },
  17. });
  18. console.log(response);
  1. PUT /_security/privilege
  2. {
  3. "app01": {
  4. "read": {
  5. "actions": [ "action:login", "data:read/*" ]
  6. },
  7. "write": {
  8. "actions": [ "action:login", "data:write/*" ]
  9. }
  10. },
  11. "app02": {
  12. "all": {
  13. "actions": [ "*" ]
  14. }
  15. }
  16. }

A successful call returns a JSON structure that shows whether the privileges have been created or updated.

  1. {
  2. "app02": {
  3. "all": {
  4. "created": true
  5. }
  6. },
  7. "app01": {
  8. "read": {
  9. "created": true
  10. },
  11. "write": {
  12. "created": true
  13. }
  14. }
  15. }