Invalidate token API

Invalidate token API

New API reference

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

Invalidates one or more access tokens or refresh tokens.

Request

DELETE /_security/oauth2/token

Description

The access tokens returned by the get token API have a finite period of time for which they are valid and after that time period, they can no longer be used. That time period is defined by the xpack.security.authc.token.timeout setting. For more information, see Token service settings.

The refresh tokens returned by the get token API are only valid for 24 hours. They can also be used exactly once.

If you want to invalidate one or more access or refresh tokens immediately, use this invalidate token API.

Request body

The following parameters can be specified in the body of a DELETE request and pertain to invalidating tokens:

token

(Optional, string) An access token. This parameter cannot be used any of refresh_token, realm_name or username are used.

refresh_token

(Optional, string) A refresh token. This parameter cannot be used any of refresh_token, realm_name or username are used.

realm_name

(Optional, string) The name of an authentication realm. This parameter cannot be used with either refresh_token or token.

username

(Optional, string) The username of a user. This parameter cannot be used with either refresh_token or token

While all parameters are optional, at least one of them is required. More specifically, either one of token or refresh_token parameters is required. If none of these two are specified, then realm_name and/or username need to be specified.

Response body

A successful call returns a JSON structure that contains the number of tokens that were invalidated, the number of tokens that had already been invalidated, and potentially a list of errors encountered while invalidating specific tokens.

Examples

For example, if you create a token using the client_credentials grant type as follows:

  1. resp = client.security.get_token(
  2. grant_type="client_credentials",
  3. )
  4. print(resp)
  1. const response = await client.security.getToken({
  2. grant_type: "client_credentials",
  3. });
  4. console.log(response);
  1. POST /_security/oauth2/token
  2. {
  3. "grant_type" : "client_credentials"
  4. }

The get token API returns the following information about the access token:

  1. {
  2. "access_token" : "dGhpcyBpcyBub3QgYSByZWFsIHRva2VuIGJ1dCBpdCBpcyBvbmx5IHRlc3QgZGF0YS4gZG8gbm90IHRyeSB0byByZWFkIHRva2VuIQ==",
  3. "type" : "Bearer",
  4. "expires_in" : 1200,
  5. "authentication" : {
  6. "username" : "test_admin",
  7. "roles" : [
  8. "superuser"
  9. ],
  10. "full_name" : null,
  11. "email" : null,
  12. "metadata" : { },
  13. "enabled" : true,
  14. "authentication_realm" : {
  15. "name" : "file",
  16. "type" : "file"
  17. },
  18. "lookup_realm" : {
  19. "name" : "file",
  20. "type" : "file"
  21. },
  22. "authentication_type" : "realm"
  23. }
  24. }

This access token can now be immediately invalidated, as shown in the following example:

  1. resp = client.security.invalidate_token(
  2. token="dGhpcyBpcyBub3QgYSByZWFsIHRva2VuIGJ1dCBpdCBpcyBvbmx5IHRlc3QgZGF0YS4gZG8gbm90IHRyeSB0byByZWFkIHRva2VuIQ==",
  3. )
  4. print(resp)
  1. const response = await client.security.invalidateToken({
  2. token:
  3. "dGhpcyBpcyBub3QgYSByZWFsIHRva2VuIGJ1dCBpdCBpcyBvbmx5IHRlc3QgZGF0YS4gZG8gbm90IHRyeSB0byByZWFkIHRva2VuIQ==",
  4. });
  5. console.log(response);
  1. DELETE /_security/oauth2/token
  2. {
  3. "token" : "dGhpcyBpcyBub3QgYSByZWFsIHRva2VuIGJ1dCBpdCBpcyBvbmx5IHRlc3QgZGF0YS4gZG8gbm90IHRyeSB0byByZWFkIHRva2VuIQ=="
  4. }

If you used the password grant type to obtain a token for a user, the response might also contain a refresh token. For example:

  1. resp = client.security.get_token(
  2. grant_type="password",
  3. username="test_admin",
  4. password="x-pack-test-password",
  5. )
  6. print(resp)
  1. const response = await client.security.getToken({
  2. grant_type: "password",
  3. username: "test_admin",
  4. password: "x-pack-test-password",
  5. });
  6. console.log(response);
  1. POST /_security/oauth2/token
  2. {
  3. "grant_type" : "password",
  4. "username" : "test_admin",
  5. "password" : "x-pack-test-password"
  6. }

The get token API returns the following information:

  1. {
  2. "access_token" : "dGhpcyBpcyBub3QgYSByZWFsIHRva2VuIGJ1dCBpdCBpcyBvbmx5IHRlc3QgZGF0YS4gZG8gbm90IHRyeSB0byByZWFkIHRva2VuIQ==",
  3. "type" : "Bearer",
  4. "expires_in" : 1200,
  5. "refresh_token": "vLBPvmAB6KvwvJZr27cS",
  6. "authentication" : {
  7. "username" : "test_admin",
  8. "roles" : [
  9. "superuser"
  10. ],
  11. "full_name" : null,
  12. "email" : null,
  13. "metadata" : { },
  14. "enabled" : true,
  15. "authentication_realm" : {
  16. "name" : "file",
  17. "type" : "file"
  18. },
  19. "lookup_realm" : {
  20. "name" : "file",
  21. "type" : "file"
  22. },
  23. "authentication_type" : "realm"
  24. }
  25. }

The refresh token can now also be immediately invalidated as shown in the following example:

  1. resp = client.security.invalidate_token(
  2. refresh_token="vLBPvmAB6KvwvJZr27cS",
  3. )
  4. print(resp)
  1. const response = await client.security.invalidateToken({
  2. refresh_token: "vLBPvmAB6KvwvJZr27cS",
  3. });
  4. console.log(response);
  1. DELETE /_security/oauth2/token
  2. {
  3. "refresh_token" : "vLBPvmAB6KvwvJZr27cS"
  4. }

The following example invalidates all access tokens and refresh tokens for the saml1 realm immediately:

  1. resp = client.security.invalidate_token(
  2. realm_name="saml1",
  3. )
  4. print(resp)
  1. const response = await client.security.invalidateToken({
  2. realm_name: "saml1",
  3. });
  4. console.log(response);
  1. DELETE /_security/oauth2/token
  2. {
  3. "realm_name" : "saml1"
  4. }

The following example invalidates all access tokens and refresh tokens for the user myuser in all realms immediately:

  1. resp = client.security.invalidate_token(
  2. username="myuser",
  3. )
  4. print(resp)
  1. const response = await client.security.invalidateToken({
  2. username: "myuser",
  3. });
  4. console.log(response);
  1. DELETE /_security/oauth2/token
  2. {
  3. "username" : "myuser"
  4. }

Finally, the following example invalidates all access tokens and refresh tokens for the user myuser in the saml1 realm immediately:

  1. resp = client.security.invalidate_token(
  2. username="myuser",
  3. realm_name="saml1",
  4. )
  5. print(resp)
  1. const response = await client.security.invalidateToken({
  2. username: "myuser",
  3. realm_name: "saml1",
  4. });
  5. console.log(response);
  1. DELETE /_security/oauth2/token
  2. {
  3. "username" : "myuser",
  4. "realm_name" : "saml1"
  5. }
  1. {
  2. "invalidated_tokens":9,
  3. "previously_invalidated_tokens":15,
  4. "error_count":2,
  5. "error_details":[
  6. {
  7. "type":"exception",
  8. "reason":"Elasticsearch exception [type=exception, reason=foo]",
  9. "caused_by":{
  10. "type":"exception",
  11. "reason":"Elasticsearch exception [type=illegal_argument_exception, reason=bar]"
  12. }
  13. },
  14. {
  15. "type":"exception",
  16. "reason":"Elasticsearch exception [type=exception, reason=boo]",
  17. "caused_by":{
  18. "type":"exception",
  19. "reason":"Elasticsearch exception [type=illegal_argument_exception, reason=far]"
  20. }
  21. }
  22. ]
  23. }

The number of the tokens that were invalidated as part of this request.

The number of tokens that were already invalidated.

The number of errors that were encountered when invalidating the tokens.

Details about these errors. This field is not present in the response when error_count is 0.