Найти пользователей

Ищет пользователей по заданным критериям.

Запрос

HTTP Запрос

POST /node/api/users/search

Права

manage-users

Параметры пути

Параметры не требуются.

Параметры тела запроса

Этот запрос может фильтровать пользователей по любому полю пользователя. Подробная информация о модели доступна в статье Пользователь.

Фильтры могут использовать Операторы запроса MongoDB.

Тело запроса

Тело запроса содержит запрос MongoDB который фильтрует пользователей.

Запрос с пустым фильтром возвращает всех пользователей в системе.
{
    "status": 2,
    "language": "en",
    "permissions": {
        "$regex": "delete",
        "$options": "i"
    }
}

Email

Вы можете искать либо по полному email, либо по его части. Этот фильтр недоступен для других полей.

  • Полный email

  • Часть email

{
    "email": "email@example.com",
}
{
    "email": { "contains": "@example.com" }
}
Оба фильтра email чувствительны к регистру.

Вложенные объекты

Для фильтрации нельзя использовать вложенные объекты.

Например, нельзя искать пользователя по полю include объекта objectPermissions. В фильтре нужно указать весь объект.

{
    "objectPermissions": {
        "include": [
            1,
            "6151bf7bc6efdc7ac9d86fe2"
        ]
    }
}

Фильтр выше включит в ответ первого пользователя, но не второго:

{
    "id": "55e59fbe7d0ce76f660607b8""login": "user 1",
    ...
    "objectPermissions": {
        "include": [
            1,
            "6151bf7bc6efdc7ac9d86fe2"
        ]
    }
},
{
    "id": "55e59fbe7d0ce76f660607b9""login": "user 2",
    ...
    "objectPermissions": {
        "include": [
            1,
            "6151bf7bc6efdc7ac9d86fe2"
        ],
        "exclude": [] // This user wouldn't match the filter because of this empty array
    }
}

Ответ

Этот запрос возвращает массив пользователей, которые подходят под заданный критерий.

Пример

Запрос

  • Bash

  • JavaScript

  • NodeJS

  • Python

login=<...>
password=<...>
saymon_hostname=<...>
url=https://$saymon_hostname/node/api/users/search

curl -X POST $url -u $login:$password \
    -H "Content-Type: application/json" \
    -d @- <<EOF
{
  'status': 2,
  'email': { 'contains': 'gmail' },
    'permissions': { '$regex': 'delete', '$options': 'i' }
}
EOF
let login = <...>
let password = <...>
let saymonHostname = <...>
let path = "/node/api/users/search";
let auth = "Basic " + btoa(login + ":" + password);

let headers = new Headers();
headers.append("Content-Type", "application/json");
headers.append("Authorization", auth);

let data = JSON.stringify({
  'status': 2,
  'email': { 'contains': 'gmail' },
    'permissions': { '$regex': 'delete', '$options': 'i' }
});

let requestOptions = {
    method: "POST",
    headers: headers,
    body: data
};

fetch(saymonHostname + path, requestOptions)
    .then(response => response.text())
    .then(result => console.log(result))
    .catch(error => console.log("error", error));
const http = require("http");

let login = <...>
let password = <...>
let saymonHostname = <...>
let path = "/node/api/users/search";
let auth = "Basic " + Buffer.from(login + ":" + password).toString("base64");

let options = {
    "method": "POST",
    "hostname": saymonHostname,
    "headers": {
        "Authorization": auth,
        "Content-Type": "application/json"
    },
    "path": path
};

let req = http.request(options, function (res) {
    let chunks = [];

    res.on("data", function (chunk) {
        chunks.push(chunk);
    });

    res.on("end", function (chunk) {
        let body = Buffer.concat(chunks);
        console.log(body.toString());
    });

    res.on("error", function (error) {
        console.error(error);
    });
});

let data = JSON.stringify({
  'status': 2,
  'email': { 'contains': 'gmail' },
    'permissions': { '$regex': 'delete', '$options': 'i' }
});

req.write(data);
req.end();
import requests

login = <...>
password = <...>
saymon_hostname = <...>
url = "https://" + saymon_hostname + "/node/api/users/search"

body = {
    'status': 2,
    'email': { 'contains': 'gmail' },
    'permissions': { '$regex': 'delete', '$options': 'i' }
}

response = requests.request("POST", url, json=body, auth=(login, password))
print(response.text)

Ответ

[
    {
        "contacts": [],
        "email": "user_email@example.com",
        "eventFilter": [],
        "id": "5ac7ac5c6402b51c27548e5b",
        "login": "user_login",
        "objectPermissions": {
            "exclude": [
                "5e84d212866ec23538893061"
            ],
            "include": [
                "817",
                "5e84d165866ec23538892f7d",
                "5ec7aab16402b70c27448e64"
            ]
        },
        "permissions": [
            "manage-objects",
            'delete-objects',
            "manage-links",
            "manage-service-properties",
            "view-section-stat",
            "view-section-monitoring",
            "view-section-history-graph"
        ],
        "status": 2
    }
]