Query User API

Query User API

Retrieves native users with Query DSL in a paginated fashion.

As opposed to the get user api, built-in users are excluded from the result. This API is only for native users.

Request

GET /_security/_query/user

POST /_security/_query/user

Prerequisites

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

Description

Use this API to retrieve users managed by the native realm in a paginated manner. You can optionally filter the results with a query.

Request body

You can specify the following parameters in the request body:

query

(Optional, string) A query to filter which users 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 public values associated with a user.

Valid values for query

  • username

    An identifier for the user.

    roles

    An array of the role names of the roles that are assigned to the user.

    full_name

    Full name of the user.

    email

    The email of the user.

    enabled

    Specifies whether the user is enabled.

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.

Query parameters

with_profile_uid

(Optional, boolean) Determines whether to retrieve the user profile uid, if exists, for the users. Defaults to false.

Response body

This API returns the following top level fields:

total

The total number of users found.

count

The number of users returned in the response.

users

A list of users that match the query.

Examples

The following request lists all users, assuming you have the read_security privilege:

  1. resp = client.perform_request(
  2. "GET",
  3. "/_security/_query/user",
  4. )
  5. print(resp)
  1. const response = await client.security.queryUser();
  2. console.log(response);
  1. GET /_security/_query/user

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

  1. {
  2. "total": 2,
  3. "count": 2,
  4. "users": [
  5. {
  6. "username": "jacknich",
  7. "roles": [
  8. "admin",
  9. "other_role1"
  10. ],
  11. "full_name": "Jack Nicholson",
  12. "email": "jacknich@example.com",
  13. "metadata": {
  14. "intelligence": 7
  15. },
  16. "enabled": true
  17. },
  18. {
  19. "username": "sandrakn",
  20. "roles": [
  21. "admin",
  22. "other_role1"
  23. ],
  24. "full_name": "Sandra Knight",
  25. "email": "sandrakn@example.com",
  26. "metadata": {
  27. "intelligence": 7
  28. },
  29. "enabled": true
  30. }
  31. ]
  32. }

The list of users that were retrieved for this request

If you create a user with the following details:

  1. resp = client.security.put_user(
  2. username="jacknich",
  3. password="l0ng-r4nd0m-p@ssw0rd",
  4. roles=[
  5. "admin",
  6. "other_role1"
  7. ],
  8. full_name="Jack Nicholson",
  9. email="jacknich@example.com",
  10. metadata={
  11. "intelligence": 7
  12. },
  13. )
  14. print(resp)
  1. const response = await client.security.putUser({
  2. username: "jacknich",
  3. password: "l0ng-r4nd0m-p@ssw0rd",
  4. roles: ["admin", "other_role1"],
  5. full_name: "Jack Nicholson",
  6. email: "jacknich@example.com",
  7. metadata: {
  8. intelligence: 7,
  9. },
  10. });
  11. console.log(response);
  1. POST /_security/user/jacknich
  2. {
  3. "password" : "l0ng-r4nd0m-p@ssw0rd",
  4. "roles" : [ "admin", "other_role1" ],
  5. "full_name" : "Jack Nicholson",
  6. "email" : "jacknich@example.com",
  7. "metadata" : {
  8. "intelligence" : 7
  9. }
  10. }

A successful call returns a JSON structure:

  1. {
  2. "created": true
  3. }

Use the user information retrieve the user with a query:

  1. resp = client.perform_request(
  2. "POST",
  3. "/_security/_query/user",
  4. headers={"Content-Type": "application/json"},
  5. body={
  6. "query": {
  7. "prefix": {
  8. "roles": "other"
  9. }
  10. }
  11. },
  12. )
  13. print(resp)
  1. const response = await client.security.queryUser({
  2. query: {
  3. prefix: {
  4. roles: "other",
  5. },
  6. },
  7. });
  8. console.log(response);
  1. POST /_security/_query/user
  2. {
  3. "query": {
  4. "prefix": {
  5. "roles": "other"
  6. }
  7. }
  8. }

A successful call returns a JSON structure for a user:

  1. {
  2. "total": 1,
  3. "count": 1,
  4. "users": [
  5. {
  6. "username": "jacknich",
  7. "roles": [
  8. "admin",
  9. "other_role1"
  10. ],
  11. "full_name": "Jack Nicholson",
  12. "email": "jacknich@example.com",
  13. "metadata": {
  14. "intelligence": 7
  15. },
  16. "enabled": true
  17. }
  18. ]
  19. }

To retrieve the user profile_uid as part of the response:

  1. resp = client.perform_request(
  2. "POST",
  3. "/_security/_query/user",
  4. params={
  5. "with_profile_uid": "true"
  6. },
  7. headers={"Content-Type": "application/json"},
  8. body={
  9. "query": {
  10. "prefix": {
  11. "roles": "other"
  12. }
  13. }
  14. },
  15. )
  16. print(resp)
  1. const response = await client.security.queryUser({
  2. with_profile_uid: "true",
  3. query: {
  4. prefix: {
  5. roles: "other",
  6. },
  7. },
  8. });
  9. console.log(response);
  1. POST /_security/_query/user?with_profile_uid=true
  2. {
  3. "query": {
  4. "prefix": {
  5. "roles": "other"
  6. }
  7. }
  8. }
  1. {
  2. "total": 1,
  3. "count": 1,
  4. "users": [
  5. {
  6. "username": "jacknich",
  7. "roles": [
  8. "admin",
  9. "other_role1"
  10. ],
  11. "full_name": "Jack Nicholson",
  12. "email": "jacknich@example.com",
  13. "metadata": {
  14. "intelligence": 7
  15. },
  16. "enabled": true,
  17. "profile_uid": "u_79HkWkwmnBH5gqFKwoxggWPjEBOur1zLPXQPEl1VBW0_0"
  18. }
  19. ]
  20. }

Use a bool query to issue complex logical conditions and use from, size, sort to help paginate the result:

  1. POST /_security/_query/user
  2. {
  3. "query": {
  4. "bool": {
  5. "must": [
  6. {
  7. "wildcard": {
  8. "email": "*example.com"
  9. }
  10. },
  11. {
  12. "term": {
  13. "enabled": true
  14. }
  15. }
  16. ],
  17. "filter": [
  18. {
  19. "wildcard": {
  20. "roles": "*other*"
  21. }
  22. }
  23. ]
  24. }
  25. },
  26. "from": 1,
  27. "size": 2,
  28. "sort": [
  29. { "username": { "order": "desc"} }
  30. ]
  31. }

The email must end with example.com

The user must be enabled

The result will be filtered to only contain users with at least one role that contains the substring other

The offset to begin the search result is the 2nd (zero-based index) user

The page size of the response is 2 users

The result is sorted by username in descending order

The response contains a list of matched users along with their sort values:

  1. {
  2. "total": 5,
  3. "count": 2,
  4. "users": [
  5. {
  6. "username": "ray",
  7. "roles": [
  8. "other_role3"
  9. ],
  10. "full_name": "Ray Nicholson",
  11. "email": "rayn@example.com",
  12. "metadata": {
  13. "intelligence": 7
  14. },
  15. "enabled": true,
  16. "_sort": [
  17. "ray"
  18. ]
  19. },
  20. {
  21. "username": "lorraine",
  22. "roles": [
  23. "other_role3"
  24. ],
  25. "full_name": "Lorraine Nicholson",
  26. "email": "lorraine@example.com",
  27. "metadata": {
  28. "intelligence": 7
  29. },
  30. "enabled": true,
  31. "_sort": [
  32. "lorraine"
  33. ]
  34. }
  35. ]
  36. }

The sort value is username