Query Role API

Query Role API

New API reference

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

Retrieves roles with Query DSL in a paginated fashion.

Request

GET /_security/_query/role

POST /_security/_query/role

Prerequisites

  • To use this API, you must have at least the read_security cluster privilege.

Description

The role management APIs are generally the preferred way to manage roles, rather than using file-based role management. The query roles API does not retrieve roles that are defined in roles files, nor built-in ones. You can optionally filter the results with a query. Also, the results can be paginated and sorted.

Request body

You can specify the following parameters in the request body:

query

(Optional, string) A query to filter which roles to return. The query supports a subset of query types, including match_all, bool, term, terms, match, ids, prefix, wildcard, exists, range, and simple query string.

You can query the following values associated with a role.

Valid values for query

  • name

    (keyword) The name of the role.

    description

    (text) The description of the role.

    metadata

    (flattened) Metadata field associated with the role, such as metadata.app_tag. Note that metadata is internally indexed as a flattened field type. This means that all sub-fields act like keyword fields when querying and sorting. It also implies that it is not possible to refer to a subset of metadata fields using wildcard patterns, e.g. metadata.field*, even for query types that support field name patterns. Lastly, all the metadata fields can be searched together when simply mentioning the metadata field (i.e. not followed by any dot and sub-field name).

    applications

    The list of application privileges that the role grants.

    • application

      (keyword) The name of the application associated to the privileges and resources.

      privileges

      (keyword) The names of the privileges that the role grants.

      resources

      (keyword) The resources to which the privileges apply.

from

(Optional, integer) Starting document offset. Needs to be non-negative and defaults to 0.

By default, you cannot page through more than 10,000 hits using the from and size parameters. To page through more hits, use the search_after parameter.

size

(Optional, integer) The number of hits to return. Must not be negative and defaults to 10.

By default, you cannot page through more than 10,000 hits using the from and size parameters. To page through more hits, use the search_after parameter.

sort

(Optional, object) Sort definition. You can sort on username, roles or enabled. In addition, sort can also be applied to the _doc field to sort by index order.

search_after

(Optional, array) Search after definition.

Response body

This API returns the following top level fields:

total

The total number of roles found.

count

The number of roles returned in the response.

roles

A list of roles that match the query. The returned role format is an extension of the role definition format. It adds the transient_metadata.enabled and the _sort fields. transient_metadata.enabled is set to false in case the role is automatically disabled, for example when the role grants privileges that are not allowed by the installed license. _sort is present when the search query sorts on some field. It contains the array of values that have been used for sorting.

Examples

The following request lists all roles, sorted by the role name:

  1. resp = client.security.query_role(
  2. sort=[
  3. "name"
  4. ],
  5. )
  6. print(resp)
  1. const response = await client.security.queryRole({
  2. sort: ["name"],
  3. });
  4. console.log(response);
  1. POST /_security/_query/role
  2. {
  3. "sort": ["name"]
  4. }

A successful call returns a JSON structure that contains the information retrieved for one or more roles:

  1. {
  2. "total": 2,
  3. "count": 2,
  4. "roles": [
  5. {
  6. "name" : "my_admin_role",
  7. "cluster" : [
  8. "all"
  9. ],
  10. "indices" : [
  11. {
  12. "names" : [
  13. "index1",
  14. "index2"
  15. ],
  16. "privileges" : [
  17. "all"
  18. ],
  19. "field_security" : {
  20. "grant" : [
  21. "title",
  22. "body"
  23. ]
  24. },
  25. "allow_restricted_indices" : false
  26. }
  27. ],
  28. "applications" : [ ],
  29. "run_as" : [
  30. "other_user"
  31. ],
  32. "metadata" : {
  33. "version" : 1
  34. },
  35. "transient_metadata" : {
  36. "enabled" : true
  37. },
  38. "description" : "Grants full access to all management features within the cluster.",
  39. "_sort" : [
  40. "my_admin_role"
  41. ]
  42. },
  43. {
  44. "name" : "my_user_role",
  45. "cluster" : [ ],
  46. "indices" : [
  47. {
  48. "names" : [
  49. "index1",
  50. "index2"
  51. ],
  52. "privileges" : [
  53. "all"
  54. ],
  55. "field_security" : {
  56. "grant" : [
  57. "title",
  58. "body"
  59. ]
  60. },
  61. "allow_restricted_indices" : false
  62. }
  63. ],
  64. "applications" : [ ],
  65. "run_as" : [ ],
  66. "metadata" : {
  67. "version" : 1
  68. },
  69. "transient_metadata" : {
  70. "enabled" : true
  71. },
  72. "description" : "Grants user access to some indicies.",
  73. "_sort" : [
  74. "my_user_role"
  75. ]
  76. }
  77. ]
  78. }

The list of roles that were retrieved for this request

Similarly, the following request can be used to query only the user access role, given its description:

  1. resp = client.security.query_role(
  2. query={
  3. "match": {
  4. "description": {
  5. "query": "user access"
  6. }
  7. }
  8. },
  9. size=1,
  10. )
  11. print(resp)
  1. const response = await client.security.queryRole({
  2. query: {
  3. match: {
  4. description: {
  5. query: "user access",
  6. },
  7. },
  8. },
  9. size: 1,
  10. });
  11. console.log(response);
  1. POST /_security/_query/role
  2. {
  3. "query": {
  4. "match": {
  5. "description": {
  6. "query": "user access"
  7. }
  8. }
  9. },
  10. "size": 1
  11. }

Return only the best matching role

  1. {
  2. "total": 2,
  3. "count": 1,
  4. "roles": [
  5. {
  6. "name" : "my_user_role",
  7. "cluster" : [ ],
  8. "indices" : [
  9. {
  10. "names" : [
  11. "index1",
  12. "index2"
  13. ],
  14. "privileges" : [
  15. "all"
  16. ],
  17. "field_security" : {
  18. "grant" : [
  19. "title",
  20. "body"
  21. ]
  22. },
  23. "allow_restricted_indices" : false
  24. }
  25. ],
  26. "applications" : [ ],
  27. "run_as" : [ ],
  28. "metadata" : {
  29. "version" : 1
  30. },
  31. "transient_metadata" : {
  32. "enabled" : true
  33. },
  34. "description" : "Grants user access to some indicies."
  35. }
  36. ]
  37. }