2019-02-04 22:21:57 -05:00
|
|
|
[role="xpack"]
|
|
|
|
[[security-api-invalidate-api-key]]
|
2019-03-19 14:00:42 -04:00
|
|
|
=== Invalidate API key API
|
2019-02-04 22:21:57 -05:00
|
|
|
++++
|
|
|
|
<titleabbrev>Invalidate API key</titleabbrev>
|
|
|
|
++++
|
|
|
|
|
|
|
|
Invalidates one or more API keys.
|
|
|
|
|
2019-08-02 13:56:05 -04:00
|
|
|
[[security-api-invalidate-api-key-request]]
|
|
|
|
==== {api-request-title}
|
2019-02-04 22:21:57 -05:00
|
|
|
|
|
|
|
`DELETE /_security/api_key`
|
|
|
|
|
2019-08-02 13:56:05 -04:00
|
|
|
[[security-api-invalidate-api-key-prereqs]]
|
|
|
|
==== {api-prereq-title}
|
|
|
|
|
|
|
|
* To use this API, you must have at least the `manage_api_key` cluster privilege.
|
|
|
|
|
|
|
|
[[security-api-invalidate-api-key-desc]]
|
|
|
|
==== {api-description-title}
|
2019-02-04 22:21:57 -05:00
|
|
|
|
2019-03-19 14:00:42 -04:00
|
|
|
The API keys created by <<security-api-create-api-key,create API Key>> can be
|
|
|
|
invalidated using this API.
|
2019-02-04 22:21:57 -05:00
|
|
|
|
2019-08-02 13:56:05 -04:00
|
|
|
|
|
|
|
[[security-api-invalidate-api-key-request-body]]
|
|
|
|
==== {api-request-body-title}
|
2019-02-04 22:21:57 -05:00
|
|
|
|
|
|
|
The following parameters can be specified in the body of a DELETE request and
|
|
|
|
pertain to invalidating api keys:
|
|
|
|
|
2019-08-02 13:56:05 -04:00
|
|
|
`id`::
|
|
|
|
(Optional, string) An API key id. This parameter cannot be used with any of
|
|
|
|
`name`, `realm_name` or `username` are used.
|
2019-02-04 22:21:57 -05:00
|
|
|
|
2019-08-02 13:56:05 -04:00
|
|
|
`name`::
|
|
|
|
(Optional, string) An API key name. This parameter cannot be used with any of
|
|
|
|
`id`, `realm_name` or `username` are used.
|
2019-02-04 22:21:57 -05:00
|
|
|
|
2019-08-02 13:56:05 -04:00
|
|
|
`realm_name`::
|
|
|
|
(Optional, string) The name of an authentication realm. This parameter cannot be
|
2019-08-27 10:44:23 -04:00
|
|
|
used with either `id` or `name` or when `owner` flag is set to `true`.
|
2019-02-04 22:21:57 -05:00
|
|
|
|
2019-08-02 13:56:05 -04:00
|
|
|
`username`::
|
|
|
|
(Optional, string) The username of a user. This parameter cannot be used with
|
2019-08-27 10:44:23 -04:00
|
|
|
either `id` or `name` or when `owner` flag is set to `true`.
|
2019-02-04 22:21:57 -05:00
|
|
|
|
2019-08-27 10:44:23 -04:00
|
|
|
`owner`::
|
|
|
|
(Optional, boolean) A boolean flag that can be used to query API keys owned
|
|
|
|
by the currently authenticated user. Defaults to false.
|
|
|
|
The 'realm_name' or 'username' parameters cannot be specified when this
|
|
|
|
parameter is set to 'true' as they are assumed to be the currently authenticated ones.
|
|
|
|
|
|
|
|
NOTE: At least one of "id", "name", "username" and "realm_name" must be specified
|
|
|
|
if "owner" is "false" (default).
|
2019-02-04 22:21:57 -05:00
|
|
|
|
2019-08-02 13:56:05 -04:00
|
|
|
[[security-api-invalidate-api-key-response-body]]
|
|
|
|
==== {api-response-body-title}
|
2019-07-02 23:51:44 -04:00
|
|
|
|
2019-08-02 13:56:05 -04:00
|
|
|
A successful call returns a JSON structure that contains the ids of the API keys
|
|
|
|
that were invalidated, the ids of the API keys that had already been invalidated,
|
|
|
|
and potentially a list of errors encountered while invalidating specific api
|
|
|
|
keys.
|
2019-07-02 23:51:44 -04:00
|
|
|
|
2019-08-02 13:56:05 -04:00
|
|
|
[[security-api-invalidate-api-key-example]]
|
|
|
|
==== {api-examples-title}
|
2019-02-04 22:21:57 -05:00
|
|
|
|
2019-03-19 14:00:42 -04:00
|
|
|
If you create an API key as follows:
|
|
|
|
|
|
|
|
[source, js]
|
|
|
|
------------------------------------------------------------
|
|
|
|
POST /_security/api_key
|
|
|
|
{
|
2019-06-26 00:30:51 -04:00
|
|
|
"name": "my-api-key"
|
2019-03-19 14:00:42 -04:00
|
|
|
}
|
|
|
|
------------------------------------------------------------
|
|
|
|
// CONSOLE
|
|
|
|
// TEST
|
|
|
|
|
|
|
|
A successful call returns a JSON structure that provides
|
|
|
|
API key information. For example:
|
|
|
|
|
|
|
|
[source,js]
|
|
|
|
--------------------------------------------------
|
|
|
|
{
|
|
|
|
"id":"VuaCfGcBCdbkQm-e5aOx",
|
|
|
|
"name":"my-api-key",
|
|
|
|
"api_key":"ui2lp2axTNmsyakw9tvNnw"
|
|
|
|
}
|
|
|
|
--------------------------------------------------
|
|
|
|
// TESTRESPONSE[s/VuaCfGcBCdbkQm-e5aOx/$body.id/]
|
|
|
|
// TESTRESPONSE[s/ui2lp2axTNmsyakw9tvNnw/$body.api_key/]
|
|
|
|
|
2019-08-02 13:56:05 -04:00
|
|
|
The following example invalidates the API key identified by specified `id`
|
|
|
|
immediately:
|
2019-02-04 22:21:57 -05:00
|
|
|
|
|
|
|
[source,js]
|
|
|
|
--------------------------------------------------
|
|
|
|
DELETE /_security/api_key
|
|
|
|
{
|
2019-03-19 14:00:42 -04:00
|
|
|
"id" : "VuaCfGcBCdbkQm-e5aOx"
|
2019-02-04 22:21:57 -05:00
|
|
|
}
|
|
|
|
--------------------------------------------------
|
2019-03-19 14:00:42 -04:00
|
|
|
// CONSOLE
|
|
|
|
// TEST[s/VuaCfGcBCdbkQm-e5aOx/$body.id/]
|
|
|
|
// TEST[continued]
|
2019-02-04 22:21:57 -05:00
|
|
|
|
2019-08-02 13:56:05 -04:00
|
|
|
The following example invalidates the API key identified by specified `name`
|
|
|
|
immediately:
|
2019-02-04 22:21:57 -05:00
|
|
|
|
|
|
|
[source,js]
|
|
|
|
--------------------------------------------------
|
|
|
|
DELETE /_security/api_key
|
|
|
|
{
|
2019-03-19 14:00:42 -04:00
|
|
|
"name" : "my-api-key"
|
2019-02-04 22:21:57 -05:00
|
|
|
}
|
|
|
|
--------------------------------------------------
|
2019-03-19 14:00:42 -04:00
|
|
|
// CONSOLE
|
|
|
|
// TEST
|
2019-02-04 22:21:57 -05:00
|
|
|
|
2019-03-19 14:00:42 -04:00
|
|
|
The following example invalidates all API keys for the `native1` realm
|
|
|
|
immediately:
|
2019-02-04 22:21:57 -05:00
|
|
|
|
|
|
|
[source,js]
|
|
|
|
--------------------------------------------------
|
2019-02-28 14:08:39 -05:00
|
|
|
DELETE /_security/api_key
|
2019-02-04 22:21:57 -05:00
|
|
|
{
|
|
|
|
"realm_name" : "native1"
|
|
|
|
}
|
|
|
|
--------------------------------------------------
|
2019-03-19 14:00:42 -04:00
|
|
|
// CONSOLE
|
|
|
|
// TEST
|
2019-02-04 22:21:57 -05:00
|
|
|
|
2019-03-19 14:00:42 -04:00
|
|
|
The following example invalidates all API keys for the user `myuser` in all
|
|
|
|
realms immediately:
|
2019-02-04 22:21:57 -05:00
|
|
|
|
|
|
|
[source,js]
|
|
|
|
--------------------------------------------------
|
2019-02-28 14:08:39 -05:00
|
|
|
DELETE /_security/api_key
|
2019-02-04 22:21:57 -05:00
|
|
|
{
|
|
|
|
"username" : "myuser"
|
|
|
|
}
|
|
|
|
--------------------------------------------------
|
2019-03-19 14:00:42 -04:00
|
|
|
// CONSOLE
|
|
|
|
// TEST
|
2019-02-04 22:21:57 -05:00
|
|
|
|
2019-08-27 10:44:23 -04:00
|
|
|
The following example invalidates the API key identified by the specified `id` if
|
|
|
|
it is owned by the currently authenticated user immediately:
|
|
|
|
|
|
|
|
[source,js]
|
|
|
|
--------------------------------------------------
|
|
|
|
DELETE /_security/api_key
|
|
|
|
{
|
|
|
|
"id" : "VuaCfGcBCdbkQm-e5aOx",
|
|
|
|
"owner" : "true"
|
|
|
|
}
|
|
|
|
--------------------------------------------------
|
|
|
|
// CONSOLE
|
|
|
|
|
|
|
|
The following example invalidates all API keys owned by the currently authenticated
|
|
|
|
user immediately:
|
|
|
|
|
|
|
|
[source,js]
|
|
|
|
--------------------------------------------------
|
|
|
|
DELETE /_security/api_key
|
|
|
|
{
|
|
|
|
"owner" : "true"
|
|
|
|
}
|
|
|
|
--------------------------------------------------
|
|
|
|
// CONSOLE
|
|
|
|
// TEST
|
|
|
|
|
2019-02-04 22:21:57 -05:00
|
|
|
Finally, the following example invalidates all API keys for the user `myuser` in
|
|
|
|
the `native1` realm immediately:
|
|
|
|
|
|
|
|
[source,js]
|
|
|
|
--------------------------------------------------
|
2019-02-28 14:08:39 -05:00
|
|
|
DELETE /_security/api_key
|
2019-02-04 22:21:57 -05:00
|
|
|
{
|
|
|
|
"username" : "myuser",
|
|
|
|
"realm_name" : "native1"
|
|
|
|
}
|
|
|
|
--------------------------------------------------
|
2019-03-19 14:00:42 -04:00
|
|
|
// CONSOLE
|
|
|
|
// TEST
|
2019-02-04 22:21:57 -05:00
|
|
|
|
|
|
|
[source,js]
|
|
|
|
--------------------------------------------------
|
|
|
|
{
|
|
|
|
"invalidated_api_keys": [ <1>
|
|
|
|
"api-key-id-1"
|
|
|
|
],
|
|
|
|
"previously_invalidated_api_keys": [ <2>
|
|
|
|
"api-key-id-2",
|
|
|
|
"api-key-id-3"
|
|
|
|
],
|
|
|
|
"error_count": 2, <3>
|
|
|
|
"error_details": [ <4>
|
|
|
|
{
|
|
|
|
"type": "exception",
|
|
|
|
"reason": "error occurred while invalidating api keys",
|
|
|
|
"caused_by": {
|
|
|
|
"type": "illegal_argument_exception",
|
|
|
|
"reason": "invalid api key id"
|
|
|
|
}
|
|
|
|
},
|
|
|
|
{
|
|
|
|
"type": "exception",
|
|
|
|
"reason": "error occurred while invalidating api keys",
|
|
|
|
"caused_by": {
|
|
|
|
"type": "illegal_argument_exception",
|
|
|
|
"reason": "invalid api key id"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
]
|
|
|
|
}
|
|
|
|
--------------------------------------------------
|
|
|
|
// NOTCONSOLE
|
|
|
|
|
2019-08-02 13:56:05 -04:00
|
|
|
<1> The IDs of the API keys that were invalidated as part of this request.
|
|
|
|
<2> The IDs of the API keys that were already invalidated.
|
2019-02-04 22:21:57 -05:00
|
|
|
<3> The number of errors that were encountered when invalidating the API keys.
|
|
|
|
<4> Details about these errors. This field is not present in the response when
|
|
|
|
`error_count` is 0.
|