#Пригласить сотрудника
POST /v1/users/invite
Создаёт нового сотрудника или приглашает внешнего пользователя на портал. Принимает поля в camelCase и UPPER_SNAKE_CASE, проставляет разумные значения по умолчанию и проверяет email до вызова Битрикс24 — возвращая понятные коды ошибок (EMAIL_REQUIRED, EMAIL_INVALID, SONET_GROUP_ID_REQUIRED) вместо общего wrong_email.
#Поля запроса (body)
| Параметр | Тип | Обяз. | Описание |
|---|---|---|---|
email |
string | да | Email — должен быть уникальным среди всех сотрудников портала. Базовая синтаксическая проверка происходит на стороне Вайбкод |
name |
string | нет | Имя |
lastName |
string | нет | Фамилия |
secondName |
string | нет | Отчество |
workPosition |
string | нет | Должность |
workPhone |
string | нет | Рабочий телефон |
workCompany |
string | нет | Название компании |
personalPhone |
string | нет | Личный телефон |
personalMobile |
string | нет | Мобильный телефон |
personalBirthday |
string | нет | Дата рождения (ISO 8601) |
personalGender |
string | нет | Пол: M — мужской, F — женский |
personalCity |
string | нет | Город |
departmentId |
number[] | нет | Массив ID отделов. По умолчанию [1] (корневой отдел) для штатных сотрудников. Список: GET /v1/departments |
extranet |
string | нет | "Y" для приглашения внешнего пользователя. В этом случае departmentId игнорируется и обязателен sonetGroupId |
sonetGroupId |
number[] | условно | Массив ID рабочих групп — обязателен при extranet: "Y". Список: `GET /v1/workgroups` |
active |
boolean | нет | Признак активности (по умолчанию true) |
#Примеры
#curl — личный ключ
curl -X POST "https://vibecode.bitrix24.tech/v1/users/invite" \
-H "X-Api-Key: YOUR_API_KEY" \
-H "Content-Type: application/json" \
-d '{
"email": "ivan.petrov@example.com",
"name": "Иван",
"lastName": "Петров",
"workPosition": "Менеджер"
}'
#curl — OAuth-приложение
curl -X POST "https://vibecode.bitrix24.tech/v1/users/invite" \
-H "X-Api-Key: YOUR_APP_KEY" \
-H "Authorization: Bearer USER_SESSION_TOKEN" \
-H "Content-Type: application/json" \
-d '{
"email": "ivan.petrov@example.com",
"name": "Иван",
"lastName": "Петров",
"workPosition": "Менеджер"
}'
#JavaScript — личный ключ
const res = await fetch('https://vibecode.bitrix24.tech/v1/users/invite', {
method: 'POST',
headers: {
'X-Api-Key': 'YOUR_API_KEY',
'Content-Type': 'application/json',
},
body: JSON.stringify({
email: 'ivan.petrov@example.com',
name: 'Иван',
lastName: 'Петров',
workPosition: 'Менеджер',
}),
})
const { success, data } = await res.json()
console.log('Создан сотрудник ID:', data.id)
#JavaScript — OAuth-приложение
const res = await fetch('https://vibecode.bitrix24.tech/v1/users/invite', {
method: 'POST',
headers: {
'X-Api-Key': 'YOUR_APP_KEY',
'Authorization': 'Bearer USER_SESSION_TOKEN',
'Content-Type': 'application/json',
},
body: JSON.stringify({
email: 'ivan.petrov@example.com',
name: 'Иван',
lastName: 'Петров',
}),
})
const { success, data } = await res.json()
#Поля ответа
| Поле | Тип | Описание |
|---|---|---|
success |
boolean | Всегда true при успехе |
data.id |
number | ID созданного сотрудника |
data.user |
object | Полная запись только что созданного сотрудника — те же поля, что у `GET /v1/users/:id` |
#Пример ответа
{
"success": true,
"data": {
"id": 1331,
"user": {
"id": 1331,
"xmlId": "74668002",
"active": true,
"name": "Иван",
"lastName": "Петров",
"email": "ivan.petrov@example.com",
"lastLogin": null,
"dateRegister": "2026-05-06T00:00:00.000Z",
"isOnline": false,
"TIMESTAMP_X": {},
"personalGender": null,
"departmentId": [1],
"workPosition": "Менеджер",
"USER_TYPE": "employee"
}
}
}
HTTP-статус ответа — 201 Created.
#Пример ответа при ошибке
400 — email не передан:
{
"success": false,
"error": {
"code": "EMAIL_REQUIRED",
"message": "EMAIL (or `email`) is required to invite a user."
}
}
#Ошибки
| HTTP | Код | Описание |
|---|---|---|
| 400 | EMAIL_REQUIRED |
В теле запроса нет email (или EMAIL) |
| 400 | EMAIL_INVALID |
Email не прошёл синтаксическую проверку Вайбкод |
| 400 | SONET_GROUP_ID_REQUIRED |
При extranet: "Y" не передан sonetGroupId |
| 400 | BITRIX_ERROR (wrong_email) |
Битрикс24 отклонил создание: email уже занят, домен запрещён политикой портала, или другая ошибка email |
| 401 | TOKEN_MISSING |
API-ключ не имеет настроенных токенов |
| 403 | SCOPE_DENIED |
API-ключ не имеет скоупа user |
Полный список общих ошибок API — Ошибки.
#Известные особенности
Зачем дефолт departmentId: [1]. Без UF_DEPARTMENT Битрикс24 возвращает обобщённый wrong_email без указания причины — отсутствие отдела у штатного сотрудника одна из самых частых ловушек. Подстановка корневого отдела [1] устраняет её для типового случая «приглашаем сотрудника, конкретный отдел неизвестен». Если структура отделов важна — передавайте departmentId явно.
Уникальность email на портале. Email проверяется среди всех сотрудников включая ранее деактивированных — при дубле Битрикс24 отдаст BITRIX_ERROR: wrong_email. Перед приглашением — поиск через GET /v1/users?filter[EMAIL]=ivan.petrov@example.com. Если найден деактивированный, верните его в строй через `PATCH /v1/users/:id { active: true }` — это сохранит историю и связи, в отличие от создания дубля.
Best-effort повторное чтение. После успешного создания обёртка делает повторное чтение записи и кладёт её в data.user. Если вспомогательный вызов упал, data.id всё равно вернётся — сотрудник уже создан, повторное обращение `GET /v1/users/:id` подгрузит запись.
#Смотрите также
- Создать сотрудника — низкоуровневая форма без значений по умолчанию
- Список сотрудников — поиск дубликата email перед приглашением
- Обновить сотрудника — реактивация через
active: true - Отделы — источник
departmentId - Лимиты и оптимизация