Найти пользователей
Ищет пользователей по заданным критериям.
Запрос
Параметры тела запроса
Этот запрос может фильтровать пользователей по любому полю пользователя. Подробная информация о модели доступна в статье Пользователь.
Фильтры могут использовать Операторы запроса MongoDB.
Тело запроса
Тело запроса содержит запрос MongoDB который фильтрует пользователей.
Запрос с пустым фильтром возвращает всех пользователей в системе. |
{
"status": 2,
"language": "en",
"permissions": {
"$regex": "delete",
"$options": "i"
}
}
Вы можете искать либо по полному 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
}
]