2018-08-17 12:18:08 -04:00
|
|
|
[role="xpack"]
|
|
|
|
[[security-api-get-role]]
|
|
|
|
=== Get roles API
|
2018-12-20 13:23:28 -05:00
|
|
|
++++
|
|
|
|
<titleabbrev>Get roles</titleabbrev>
|
|
|
|
++++
|
2018-08-17 12:18:08 -04:00
|
|
|
|
|
|
|
Retrieves roles in the native realm.
|
|
|
|
|
|
|
|
==== Request
|
|
|
|
|
2018-12-11 04:13:10 -05:00
|
|
|
`GET /_security/role` +
|
2018-08-17 12:18:08 -04:00
|
|
|
|
2018-12-11 04:13:10 -05:00
|
|
|
`GET /_security/role/<name>` +
|
2018-08-17 12:18:08 -04:00
|
|
|
|
|
|
|
==== Description
|
|
|
|
|
|
|
|
For more information about the native realm, see
|
|
|
|
{stack-ov}/realms.html[Realms] and <<configuring-native-realm>>.
|
|
|
|
|
|
|
|
==== Path Parameters
|
|
|
|
|
|
|
|
`name`::
|
|
|
|
(string) The name of the role. You can specify multiple roles as a
|
|
|
|
comma-separated list. If you do not specify this parameter, the API
|
|
|
|
returns information about all roles.
|
|
|
|
|
|
|
|
//==== Request Body
|
|
|
|
|
|
|
|
==== Authorization
|
|
|
|
|
|
|
|
To use this API, you must have at least the `manage_security` cluster
|
|
|
|
privilege.
|
|
|
|
|
|
|
|
|
|
|
|
==== Examples
|
|
|
|
|
|
|
|
The following example retrieves information about the `my_admin_role` role in
|
|
|
|
the native realm:
|
|
|
|
|
|
|
|
[source,js]
|
|
|
|
--------------------------------------------------
|
2018-12-11 04:13:10 -05:00
|
|
|
GET /_security/role/my_admin_role
|
2018-08-17 12:18:08 -04:00
|
|
|
--------------------------------------------------
|
|
|
|
// CONSOLE
|
|
|
|
// TEST[setup:admin_role]
|
|
|
|
|
|
|
|
A successful call returns an array of roles with the JSON representation of the
|
|
|
|
role. If the role is not defined in the native realm, the request returns 404.
|
|
|
|
|
|
|
|
[source,js]
|
|
|
|
--------------------------------------------------
|
|
|
|
{
|
|
|
|
"my_admin_role": {
|
|
|
|
"cluster" : [ "all" ],
|
|
|
|
"indices" : [
|
|
|
|
{
|
|
|
|
"names" : [ "index1", "index2" ],
|
|
|
|
"privileges" : [ "all" ],
|
|
|
|
"field_security" : {
|
|
|
|
"grant" : [ "title", "body" ]}
|
|
|
|
}
|
|
|
|
],
|
|
|
|
"applications" : [ ],
|
|
|
|
"run_as" : [ "other_user" ],
|
|
|
|
"metadata" : {
|
|
|
|
"version" : 1
|
|
|
|
},
|
|
|
|
"transient_metadata": {
|
|
|
|
"enabled": true
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
--------------------------------------------------
|
|
|
|
// TESTRESPONSE
|
|
|
|
|
|
|
|
To retrieve all roles, omit the role name:
|
|
|
|
|
|
|
|
[source,js]
|
|
|
|
--------------------------------------------------
|
2018-12-11 04:13:10 -05:00
|
|
|
GET /_security/role
|
2018-08-17 12:18:08 -04:00
|
|
|
--------------------------------------------------
|
|
|
|
// CONSOLE
|
|
|
|
// TEST[continued]
|
|
|
|
|
|
|
|
NOTE: If single role is requested, that role is returned as the response. When
|
|
|
|
requesting multiple roles, an object is returned holding the found roles, each
|
|
|
|
keyed by the relevant role name.
|