2019-02-04 22:21:57 -05:00
|
|
|
[role="xpack"]
|
|
|
|
[[security-api-get-api-key]]
|
2019-03-19 14:00:42 -04:00
|
|
|
=== Get API key information API
|
2019-02-04 22:21:57 -05:00
|
|
|
++++
|
|
|
|
<titleabbrev>Get API key information</titleabbrev>
|
|
|
|
++++
|
|
|
|
|
|
|
|
Retrieves information for one or more API keys.
|
|
|
|
|
|
|
|
==== Request
|
|
|
|
|
|
|
|
`GET /_security/api_key`
|
|
|
|
|
|
|
|
==== Description
|
|
|
|
|
|
|
|
The information for the API keys created by <<security-api-create-api-key,create API Key>> can be retrieved
|
|
|
|
using this API.
|
|
|
|
|
|
|
|
==== Request Body
|
|
|
|
|
|
|
|
The following parameters can be specified in the query parameters of a GET request and
|
|
|
|
pertain to retrieving api keys:
|
|
|
|
|
|
|
|
`id` (optional)::
|
2019-03-19 14:00:42 -04:00
|
|
|
(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
|
|
|
|
|
|
|
`name` (optional)::
|
2019-03-19 14:00:42 -04:00
|
|
|
(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
|
|
|
|
|
|
|
`realm_name` (optional)::
|
2019-03-19 14:00:42 -04:00
|
|
|
(string) The name of an authentication realm. This parameter cannot be used with
|
|
|
|
either `id` or `name`.
|
2019-02-04 22:21:57 -05:00
|
|
|
|
|
|
|
`username` (optional)::
|
2019-03-19 14:00:42 -04:00
|
|
|
(string) The username of a user. This parameter cannot be used with either `id`
|
|
|
|
or `name`.
|
2019-02-04 22:21:57 -05:00
|
|
|
|
|
|
|
NOTE: While all parameters are optional, at least one of them is required.
|
|
|
|
|
|
|
|
==== Examples
|
|
|
|
|
2019-03-19 14:00:42 -04:00
|
|
|
If you create an API key as follows:
|
|
|
|
|
|
|
|
[source, js]
|
|
|
|
------------------------------------------------------------
|
|
|
|
POST /_security/api_key
|
|
|
|
{
|
|
|
|
"name": "my-api-key",
|
|
|
|
"role_descriptors": {}
|
|
|
|
}
|
|
|
|
------------------------------------------------------------
|
|
|
|
// CONSOLE
|
|
|
|
// TEST
|
|
|
|
|
|
|
|
A successful call returns a JSON structure that provides
|
|
|
|
API key information. For example:
|
2019-02-04 22:21:57 -05:00
|
|
|
|
|
|
|
[source,js]
|
|
|
|
--------------------------------------------------
|
2019-03-19 14:00:42 -04:00
|
|
|
{
|
|
|
|
"id":"VuaCfGcBCdbkQm-e5aOx",
|
|
|
|
"name":"my-api-key",
|
|
|
|
"api_key":"ui2lp2axTNmsyakw9tvNnw"
|
|
|
|
}
|
2019-02-04 22:21:57 -05:00
|
|
|
--------------------------------------------------
|
2019-03-19 14:00:42 -04:00
|
|
|
// TESTRESPONSE[s/VuaCfGcBCdbkQm-e5aOx/$body.id/]
|
|
|
|
// TESTRESPONSE[s/ui2lp2axTNmsyakw9tvNnw/$body.api_key/]
|
2019-02-04 22:21:57 -05:00
|
|
|
|
2019-03-19 14:00:42 -04:00
|
|
|
You can use the following example to retrieve the API key by ID:
|
2019-02-04 22:21:57 -05:00
|
|
|
|
|
|
|
[source,js]
|
|
|
|
--------------------------------------------------
|
2019-03-19 14:00:42 -04:00
|
|
|
GET /_security/api_key?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]
|
|
|
|
|
|
|
|
You can use the following example to retrieve the API key by name:
|
|
|
|
|
|
|
|
[source,js]
|
|
|
|
--------------------------------------------------
|
|
|
|
GET /_security/api_key?name=my-api-key
|
|
|
|
--------------------------------------------------
|
|
|
|
// CONSOLE
|
|
|
|
// TEST[continued]
|
2019-02-04 22:21:57 -05:00
|
|
|
|
|
|
|
The following example retrieves all API keys for the `native1` realm:
|
|
|
|
|
|
|
|
[source,js]
|
|
|
|
--------------------------------------------------
|
2019-02-28 14:08:39 -05:00
|
|
|
GET /_security/api_key?realm_name=native1
|
2019-02-04 22:21:57 -05:00
|
|
|
--------------------------------------------------
|
2019-03-19 14:00:42 -04:00
|
|
|
// CONSOLE
|
|
|
|
// TEST[continued]
|
2019-02-04 22:21:57 -05:00
|
|
|
|
|
|
|
The following example retrieves all API keys for the user `myuser` in all realms:
|
|
|
|
|
|
|
|
[source,js]
|
|
|
|
--------------------------------------------------
|
2019-02-28 14:08:39 -05:00
|
|
|
GET /_security/api_key?username=myuser
|
2019-02-04 22:21:57 -05:00
|
|
|
--------------------------------------------------
|
2019-03-19 14:00:42 -04:00
|
|
|
// CONSOLE
|
|
|
|
// TEST[continued]
|
2019-02-04 22:21:57 -05:00
|
|
|
|
|
|
|
Finally, the following example retrieves all API keys for the user `myuser` in
|
|
|
|
the `native1` realm immediately:
|
|
|
|
|
|
|
|
[source,js]
|
|
|
|
--------------------------------------------------
|
2019-02-28 14:08:39 -05:00
|
|
|
GET /_security/api_key?username=myuser&realm_name=native1
|
2019-02-04 22:21:57 -05:00
|
|
|
--------------------------------------------------
|
2019-03-19 14:00:42 -04:00
|
|
|
// CONSOLE
|
|
|
|
// TEST[continued]
|
2019-02-04 22:21:57 -05:00
|
|
|
|
|
|
|
A successful call returns a JSON structure that contains the information of one or more API keys that were retrieved.
|
|
|
|
|
|
|
|
[source,js]
|
|
|
|
--------------------------------------------------
|
|
|
|
{
|
|
|
|
"api_keys": [ <1>
|
|
|
|
{
|
|
|
|
"id": "dGhpcyBpcyBub3QgYSByZWFsIHRva2VuIGJ1dCBpdCBpcyBvbmx5IHRlc3QgZGF0YS4gZG8gbm90IHRyeSB0byByZWFkIHRva2VuIQ==", <2>
|
|
|
|
"name": "hadoop_myuser_key", <3>
|
|
|
|
"creation": 1548550550158, <4>
|
|
|
|
"expiration": 1548551550158, <5>
|
|
|
|
"invalidated": false, <6>
|
|
|
|
"username": "myuser", <7>
|
|
|
|
"realm": "native1" <8>
|
|
|
|
},
|
|
|
|
{
|
|
|
|
"id": "api-key-id-2",
|
|
|
|
"name": "api-key-name-2",
|
|
|
|
"creation": 1548550550158,
|
|
|
|
"invalidated": false,
|
|
|
|
"username": "user-y",
|
|
|
|
"realm": "realm-2"
|
|
|
|
}
|
|
|
|
]
|
|
|
|
}
|
|
|
|
--------------------------------------------------
|
|
|
|
// NOTCONSOLE
|
|
|
|
|
|
|
|
<1> The list of API keys that were retrieved for this request.
|
|
|
|
<2> Id for the API key
|
|
|
|
<3> Name of the API key
|
|
|
|
<4> Creation time for the API key in milliseconds
|
2019-03-19 14:00:42 -04:00
|
|
|
<5> Optional expiration time for the API key in milliseconds
|
|
|
|
<6> Invalidation status for the API key. If the key has been invalidated, it has
|
|
|
|
a value of `true`. Otherwise, it is `false`.
|
|
|
|
<7> Principal for which this API key was created
|
|
|
|
<8> Realm name of the principal for which this API key was created
|