Grant API key API

Grant API key API

New API reference

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

Creates an API key on behalf of another user.

Request

POST /_security/api_key/grant

Prerequisites

  • To use this API, you must have the grant_api_key or the manage_api_key cluster privilege.

Description

This API is similar to Create API keys, however it creates the API key for a user that is different than the user that runs the API.

The caller must have authentication credentials for the user on whose behalf the API key will be created. It is not possible to use this API to create an API key without that user’s credentials. The supported user authentication credentials types are: * username and password * Elasticsearch access tokens * JWTs

The user, for whom the authentication credentials is provided, can optionally “run as” (impersonate) another user. In this case, the API key will be created on behalf of the impersonated user.

This API is intended be used by applications that need to create and manage API keys for end users, but cannot guarantee that those users have permission to create API keys on their own behalf (see Prerequisites). The API keys are created by the Elasticsearch API key service, which is automatically enabled.

A successful grant API key API call returns a JSON structure that contains the API key, its unique id, and its name. If applicable, it also returns expiration information for the API key in milliseconds.

By default, API keys never expire. You can specify expiration information when you create the API keys.

See API key service settings for configuration settings related to API key service.

Request body

The following parameters can be specified in the body of a POST request:

access_token

(Required*, string) The user’s Elasticsearch access token, or JWT. Both access and id JWT token types are supported, and they depend on the underlying JWT realm configuration. The created API key will have a point in time snapshot of permissions of the user authenticated with this token (or even more restricted permissions, see the role_descriptors parameter). If you specify the access_token grant type, this parameter is required. It is not valid with other grant types.

api_key

(Required, object) Defines the API key.

  • expiration

    (Optional, string) Expiration time for the API key. By default, API keys never expire.

    name

    (Required, string) Specifies the name for this API key.

    role_descriptors

    (Optional, object) The role descriptors for this API key. This parameter is optional. When it is not specified or is an empty array, the API key has a point in time snapshot of permissions of the specified user or access token. If you supply role descriptors, the resultant permissions are an intersection of API keys permissions and the permissions of the user or access token. The structure of a role descriptor is the same as the request for create API keys API.

    metadata

    (Optional, object) Arbitrary metadata that you want to associate with the API key. It supports nested data structure. Within the metadata object, keys beginning with _ are reserved for system usage.

client_authentication

(Optional, object) When using the access_token grant type, and when supplying a JWT, this specifies the client authentication for JWTs that need it (i.e. what’s normally specified by the ES-Client-Authentication request header).

  • scheme

    (Required, string) The scheme (case-sensitive) as it’s supplied in the ES-Client-Authentication request header. Currently, the only supported value is SharedSecret.

    value

    (Required, string) The value that follows the scheme for the client credentials as it’s supplied in the ES-Client-Authentication request header. For example, if the request header would be ES-Client-Authentication: SharedSecret myShar3dS3cret if the client were to authenticate directly with a JWT, then value here should be myShar3dS3cret.

grant_type

(Required, string) The type of grant. Supported grant types are: access_token,password.

  • access_token

    In this type of grant, you must supply either an access token, that was created by the Elasticsearch token service (see Get token and Encrypt HTTP client communications for Elasticsearch), or a JWT (either a JWT access_token or a JWT id_token).

    password

    In this type of grant, you must supply the user ID and password for which you want to create the API key.

password

(Required*, string) The user’s password. If you specify the password grant type, this parameter is required. It is not valid with other grant types.

username

(Required*, string) The user name that identifies the user. If you specify the password grant type, this parameter is required. It is not valid with other grant types.

run_as

(Optional, string) The name of the user to be impersonated.

*Indicates that the setting is required in some, but not all situations.

Examples

  1. resp = client.security.grant_api_key(
  2. grant_type="password",
  3. username="test_admin",
  4. password="x-pack-test-password",
  5. api_key={
  6. "name": "my-api-key",
  7. "expiration": "1d",
  8. "role_descriptors": {
  9. "role-a": {
  10. "cluster": [
  11. "all"
  12. ],
  13. "indices": [
  14. {
  15. "names": [
  16. "index-a*"
  17. ],
  18. "privileges": [
  19. "read"
  20. ]
  21. }
  22. ]
  23. },
  24. "role-b": {
  25. "cluster": [
  26. "all"
  27. ],
  28. "indices": [
  29. {
  30. "names": [
  31. "index-b*"
  32. ],
  33. "privileges": [
  34. "all"
  35. ]
  36. }
  37. ]
  38. }
  39. },
  40. "metadata": {
  41. "application": "my-application",
  42. "environment": {
  43. "level": 1,
  44. "trusted": True,
  45. "tags": [
  46. "dev",
  47. "staging"
  48. ]
  49. }
  50. }
  51. },
  52. )
  53. print(resp)
  1. const response = await client.security.grantApiKey({
  2. grant_type: "password",
  3. username: "test_admin",
  4. password: "x-pack-test-password",
  5. api_key: {
  6. name: "my-api-key",
  7. expiration: "1d",
  8. role_descriptors: {
  9. "role-a": {
  10. cluster: ["all"],
  11. indices: [
  12. {
  13. names: ["index-a*"],
  14. privileges: ["read"],
  15. },
  16. ],
  17. },
  18. "role-b": {
  19. cluster: ["all"],
  20. indices: [
  21. {
  22. names: ["index-b*"],
  23. privileges: ["all"],
  24. },
  25. ],
  26. },
  27. },
  28. metadata: {
  29. application: "my-application",
  30. environment: {
  31. level: 1,
  32. trusted: true,
  33. tags: ["dev", "staging"],
  34. },
  35. },
  36. },
  37. });
  38. console.log(response);
  1. POST /_security/api_key/grant
  2. {
  3. "grant_type": "password",
  4. "username" : "test_admin",
  5. "password" : "x-pack-test-password",
  6. "api_key" : {
  7. "name": "my-api-key",
  8. "expiration": "1d",
  9. "role_descriptors": {
  10. "role-a": {
  11. "cluster": ["all"],
  12. "indices": [
  13. {
  14. "names": ["index-a*"],
  15. "privileges": ["read"]
  16. }
  17. ]
  18. },
  19. "role-b": {
  20. "cluster": ["all"],
  21. "indices": [
  22. {
  23. "names": ["index-b*"],
  24. "privileges": ["all"]
  25. }
  26. ]
  27. }
  28. },
  29. "metadata": {
  30. "application": "my-application",
  31. "environment": {
  32. "level": 1,
  33. "trusted": true,
  34. "tags": ["dev", "staging"]
  35. }
  36. }
  37. }
  38. }

The user (test_admin) whose credentials are provided can “run as” another user (test_user). The API key will be granted to the impersonated user (test_user).

  1. resp = client.security.grant_api_key(
  2. grant_type="password",
  3. username="test_admin",
  4. password="x-pack-test-password",
  5. run_as="test_user",
  6. api_key={
  7. "name": "another-api-key"
  8. },
  9. )
  10. print(resp)
  1. const response = await client.security.grantApiKey({
  2. grant_type: "password",
  3. username: "test_admin",
  4. password: "x-pack-test-password",
  5. run_as: "test_user",
  6. api_key: {
  7. name: "another-api-key",
  8. },
  9. });
  10. console.log(response);
  1. POST /_security/api_key/grant
  2. {
  3. "grant_type": "password",
  4. "username" : "test_admin",
  5. "password" : "x-pack-test-password",
  6. "run_as": "test_user",
  7. "api_key" : {
  8. "name": "another-api-key"
  9. }
  10. }

The user for which the credential is provided and performs “run as”.

Credential for the above user

The impersonated user for whom the API key will be created for.