SDK
SDK Javascript v5.x
1

You are currently looking at the documentation of a previous version of Kuzzle. We strongly recommend that you use the latest version. You can also use the version selector in the top menu.

searchUsers #

Return users matching the given filter.


searchUsers(filters, [options], callback) #

ArgumentsTypeDescription
filtersJSON ObjectFilter in Elasticsearch's Query DSL format
optionsJSON ObjectOptional parameters
callbackfunctionCallback handling the response

Options #

OptionTypeDescriptionDefault
fromnumberStarting offset0
queuablebooleanMake this request queuable or nottrue
scrollstringStart a scroll session, with a time to live equals to this parameter's value following the Elastisearch time formatundefined
sizenumberNumber of hits to return per result page10
To get more information about scroll sessions, please refer to the [API reference documentation](/core/1/api/controllers/document/search).

Callback Response #

Return a JSON Object

Usage #

const filter = {
  bool: {
    must: [
      {
        terms: {
          profileIds: ['anonymous', 'default']
        }
      },
      {
        geo_distance: {
          distance: '10km',
          pos: {
            lat: 48.8566140,
            lon: 2.352222
          }
        }
      }
    ]
  }
};
// optional: result pagination configuration
const options = {
  from: 0,
  size: 10,
  scroll: '1m'
};
// Using callbacks (NodeJS or Web Browser)
kuzzle
  .security
  .searchUsers(filters, options, function(error, result) {
    // result is a JSON Object with the following properties:
    // {
    //   total: <number of found users>,
    //   users: [<User object>, <User object>, ...],
    //   scrollId: "<only if a 'scroll' parameter has been passed in the options>"
    // }
  });
// Using promises (NodeJS)
kuzzle
  .security
  .searchUsersPromise(filters, options)
  .then(result => {
    // result is a JSON Object with the following properties:
    // {
    //   total: <number of found users>,
    //   users: [<User object>, <User object>, ...],
    //   scrollId: "<only if a 'scroll' parameter has been passed in the options>"
    // }
  });

Callback response:

{
  "total": 124,
  "users": [
    // array of User objects
  ],
  // only if a scroll parameter has been provided
  "scrollId": "<scroll identifier>"
}