Получить данные голосования с информацией о проголосовавших vote.AttachedVote.getWithVoted
Если вы разрабатываете интеграции для Битрикс24 с помощью AI-инструментов (Codex, Claude Code, Cursor), подключите MCP-сервер, чтобы ассистент использовал официальную REST-документацию.
Scope:
voteКто может выполнять метод: любой пользователь с правами чтения голосования
Метод vote.AttachedVote.getWithVoted возвращает данные прикрепленного голосования вместе с информацией о проголосовавших пользователях.
Параметры метода
Доступно три варианта вызова метода.
1. Через идентификатор прикрепленного опроса
Обязательные параметры отмечены *
|
Название |
Описание |
|
attachId* |
Идентификатор прикрепленного голосования, получить можно методами vote.AttachedVote.get или vote.AttachedVote.getMany |
|
pageSize |
Количество записей на странице для списка проголосовавших. |
|
userForMobileFormat |
Формат данных пользователей для мобильных устройств. |
2. Через элемент с опросом
Обязательные параметры отмечены *
|
Название |
Описание |
|
moduleId* |
Идентификатор модуля, возможные значения:
|
|
entityType* |
Тип объекта, возможные значения:
|
|
entityId* |
Идентификатор элемента, возможные значения:
|
|
pageSize |
Количество записей на странице для списка проголосовавших. |
|
userForMobileFormat |
Формат данных пользователей для мобильных устройств. |
3. Через подписанный идентификатор
Обязательные параметры отмечены *
|
Название |
Описание |
|
signedAttachId* |
Подписанный идентификатор прикрепления, получить можно методом vote.AttachedVote.get, параметр ответа |
|
pageSize |
Количество записей на странице для списка проголосовавших. |
|
userForMobileFormat |
Формат данных пользователей для мобильных устройств. |
Примеры кода
Как использовать примеры в документации
curl -X POST \
-H "Content-Type: application/json" \
-H "Accept: application/json" \
-d '{"attachId":**put_attach_id**,"pageSize":**put_page_size**,"userForMobileFormat":false}' \
https://**put_your_bitrix24_address**/rest/**put_your_user_id_here**/**put_your_webhook_here**/vote.AttachedVote.getWithVoted
curl -X POST \
-H "Content-Type: application/json" \
-H "Accept: application/json" \
-d '{"attachId":**put_attach_id**,"pageSize":**put_page_size**,"userForMobileFormat":false,"auth":"**put_access_token_here**"}' \
https://**put_your_bitrix24_address**/rest/vote.AttachedVote.getWithVoted
try
{
const response = await $b24.callMethod(
'vote.AttachedVote.getWithVoted',
{
attachId: **put_attach_id**,
pageSize: **put_page_size**,
userForMobileFormat: false
}
);
const result = response.getData().result;
console.log('Dat a:', result);
processResult(result);
}
catch( error )
{
console.error('Error:', error);
}
try {
$response = $b24Service
->core
->call(
'vote.AttachedVote.getWithVoted',
[
'attachId' => **put_attach_id**,
'pageSize' => **put_page_size**,
'userForMobileFormat' => false
]
);
$result = $response
->getResponseData()
->getResult();
echo 'Success: ' . print_r($result, true);
processData($result);
} catch (Throwable $e) {
error_log($e->getMessage());
echo 'Error: ' . $e->getMessage();
}
BX24.callMethod(
"vote.AttachedVote.getWithVoted",
{
"attachId": **put_attach_id**,
"pageSize": **put_page_size**,
"userForMobileFormat": false
},
function(result)
{
if(result.error())
{
console.error(result.error());
}
else
{
console.dir(result.data());
}
}
);
require_once('crest.php');
$result = CRest::call(
'vote.AttachedVote.getWithVoted',
[
'attachId' => **put_attach_id**,
'pageSize' => **put_page_size**,
'userForMobileFormat' => false
]
);
echo '<PRE>';
print_r($result);
echo '</PRE>';
Обработка ответа
HTTP-статус: 200
{
"result": {
"attach": {
"ID": 1,
"VOTE_ID": 1,
"COUNTER": 1,
"QUESTIONS": {
"1": {
"ID": "1",
"ACTIVE": "Y",
"TIMESTAMP_X": "2025-08-12T11:47:50+03:00",
"VOTE_ID": "1",
"C_SORT": "10",
"COUNTER": "1",
"QUESTION": "Первое рест голосование",
"QUESTION_TYPE": "text",
"IMAGE_ID": null,
"DIAGRAM": "Y",
"DIAGRAM_TYPE": "histogram",
"REQUIRED": "N",
"FIELD_TYPE": "0",
"FIELD_NAME": "bx_vote_event[1][BALLOT][1]",
"IMAGE": null,
"ANSWERS": {
"1": {
"ID": "1",
"ACTIVE": "Y",
"TIMESTAMP_X": "2025-08-12T11:47:50+03:00",
"QUESTION_ID": "1",
"C_SORT": "10",
"IMAGE_ID": null,
"MESSAGE": "первый вариант",
"MESSAGE_TYPE": "html",
"COUNTER": "0",
"FIELD_TYPE": "0",
"FIELD_WIDTH": "0",
"FIELD_HEIGHT": "0",
"FIELD_PARAM": null,
"COLOR": "",
"REACTION": "",
"~FIELD_NAME": "bx_vote_event[1][BALLOT][1]",
"FIELD_NAME": "bx_vote_event[1][BALLOT][1]",
"MESSAGE_FIELD_NAME": "bx_vote_event[1][MESSAGE][1][1]",
"~PERCENT": 0,
"PERCENT": 0
},
"3": {
"ID": "3",
"ACTIVE": "Y",
"TIMESTAMP_X": "2025-08-12T11:47:50+03:00",
"QUESTION_ID": "1",
"C_SORT": "20",
"IMAGE_ID": null,
"MESSAGE": "Второй вариант",
"MESSAGE_TYPE": "html",
"COUNTER": "1",
"FIELD_TYPE": "0",
"FIELD_WIDTH": "0",
"FIELD_HEIGHT": "0",
"FIELD_PARAM": null,
"COLOR": "",
"REACTION": "",
"~FIELD_NAME": "bx_vote_event[1][BALLOT][1]",
"FIELD_NAME": "bx_vote_event[1][BALLOT][1]",
"MESSAGE_FIELD_NAME": "bx_vote_event[1][MESSAGE][1][3]",
"~PERCENT": 100,
"PERCENT": 100
},
"5": {
"ID": "5",
"ACTIVE": "Y",
"TIMESTAMP_X": "2025-08-12T11:47:50+03:00",
"QUESTION_ID": "1",
"C_SORT": "30",
"IMAGE_ID": null,
"MESSAGE": "Третий вариант",
"MESSAGE_TYPE": "html",
"COUNTER": "0",
"FIELD_TYPE": "0",
"FIELD_WIDTH": "0",
"FIELD_HEIGHT": "0",
"FIELD_PARAM": null,
"COLOR": "",
"REACTION": "",
"~FIELD_NAME": "bx_vote_event[1][BALLOT][1]",
"FIELD_NAME": "bx_vote_event[1][BALLOT][1]",
"MESSAGE_FIELD_NAME": "bx_vote_event[1][MESSAGE][1][5]",
"~PERCENT": 0,
"PERCENT": 0
}
}
}
},
"ANONYMITY": 0,
"OPTIONS": 0,
"userAnswerMap": {
"1": {
"3": {
"EVENT_ID": "1",
"EVENT_QUESTION_ID": "1",
"ANSWER_ID": "3",
"ID": "1",
"MESSAGE": ""
}
}
},
"canEdit": true,
"canVote": false,
"canRevote": false,
"isVoted": true,
"signedAttachId": "1.d6db75c1a03fe2313547841960f1d4e95906721cf211763be19855fc6aeec45b",
"resultUrl": "\/vote-result\/qgp3r31sg4vj5vas",
"downloadUrl": "\/bitrix\/services\/main\/ajax.php?action=vote.AttachedVote.download\u0026SITE_ID=s1\u0026signedAttachId=1.d6db75c1a03fe2313547841960f106721cf211763be19855fc6aeec45b",
"entityId": 32219,
"isFinished": false
},
"voted": {
"3": [
{
"ID": 1,
"NAME": "Саша",
"IMAGE": "https:\/\/your-domain.bitrix24.ru\/b13743910\/resize_cache\/2267\/cec8d72046af30148f6f5b573a3a0aa8\/main\/c7b\/c7bd44b1bab25dd97d038ce1b\/d5fb56b94dc2c3cd8c006a2c595a4895.jpg",
"WORK_POSITION": ""
}
]
}
},
"time": {
"start": 1755077476.824466,
"finish": 1755077476.928421,
"duration": 0.10395503044128418,
"processing": 0.10184097290039062,
"date_start": "2025-08-13T12:31:16+03:00",
"date_finish": "2025-08-13T12:31:16+03:00",
"operating_reset_at": 1755078076,
"operating": 0
}
}
Возвращаемые данные
|
Название |
Описание |
|
result |
Корневой элемент ответа. Содержит информацию о голосовании и проголосовавших, структура описана ниже |
|
time |
Информация о времени выполнения запроса |
Элемент ответа result
|
Название |
Описание |
|
attach |
Данные прикрепленного голосования, структура описана ниже |
|
voted |
Информация о проголосовавших пользователях, структура описана ниже |
Элемент ответа attach
|
Название |
Описание |
|
ID |
Идентификатор прикрепленного голосования |
|
VOTE_ID |
Идентификатор самого голосования |
|
COUNTER |
Счетчик голосов |
|
QUESTIONS |
Массив с вопросами опроса |
|
ANONYMITY |
Уровень анонимности опроса |
|
OPTIONS |
Доступность переголосования |
|
userAnswerMap |
Карта ответов текущего пользователя |
|
canEdit |
Может ли текущий пользователь редактировать опрос |
|
canVote |
Может ли текущий пользователь проголосовать |
|
canRevote |
Может ли текущий пользователь переголосовать |
|
isVoted |
Проголосовал ли уже текущий пользователь |
|
signedAttachId |
Подписанный идентификатор |
|
resultUrl |
URL-адрес для просмотра результатов опроса |
|
downloadUrl |
URL-адрес для скачивания результатов опроса |
|
entityId |
Идентификатор элемента, к которому прикреплен опрос |
|
isFinished |
Завершен ли опрос |
Элемент ответа voted
|
Название |
Описание |
|
ID |
Идентификатор пользователя |
|
NAME |
Имя пользователя |
|
IMAGE |
Ссылка на изображение пользователя |
|
WORK_POSITION |
Должность пользователя |
Обработка ошибок
HTTP-статус: 4xx
{
"error": "ATTACH_NOT_FOUND",
"error_description": "Attach not found"
}
|
Название |
Описание |
|
error |
Строковый код ошибки. Может состоять из цифр, латинских букв и знака подчеркивания |
|
error_description |
Текстовое описание ошибки. Описание не предназначено для показа конечному пользователю в необработанном виде |
Возможные коды ошибок
|
Код |
Описание |
|
|
Голосование не найдено |
|
|
Нет прав для участия в голосовании |
Статусы и коды системных ошибок
HTTP-статус: 20x, 40x, 50x
Описанные ниже ошибки могут возникнуть при вызове любого метода
|
Статус |
Код |
Описание |
|
|
|
Возникла внутренняя ошибка сервера, обратитесь к администратору сервера или в техническую поддержку Битрикс24 |
|
|
|
Возникла внутренняя ошибка сервера, обратитесь к администратору сервера или в техническую поддержку Битрикс24 |
|
|
|
Превышен лимит на интенсивность запросов |
|
|
|
Текущий метод не разрешен для вызова с помощью batch |
|
|
|
Превышена максимальная длина параметров, переданных в метод batch |
|
|
|
Неверный access-токен или код вебхука |
|
|
|
Для вызовов методов требуется использовать протокол HTTPS |
|
|
|
REST API заблокирован из-за перегрузки. Это ручная индивидуальная блокировка, для снятия необходимо обращаться в техническую поддержку Битрикс24 |
|
|
|
REST API доступен только на коммерческих планах |
|
|
|
У пользователя, с чьим access-токеном или вебхуком был вызван метод, не хватает прав |
|
|
|
Манифест недоступен |
|
|
|
Запрос требует более высоких привилегий, чем предоставляет токен вебхука |
|
|
|
Предоставленный access-токен доступа истек |
|
|
|
Пользователь не имеет доступа к приложению. Это означает, что приложение установлено, но администратор портала разрешил доступ к этому приложению только конкретным пользователям |
|
|
|
Публичная часть сайта закрыта. Чтобы открыть публичную часть сайта на коробочной установке отключите опцию «Временное закрытие публичной части сайта». Путь к настройке: Рабочий стол > Настройки > Настройки продукта > Настройки модулей > Главный модуль > Временное закрытие публичной части сайта |
Продолжите изучение
- Опросы, голосования: обзор методов
- Скачать отчет по голосованию vote.AttachedVote.download
- Получить данные прикрепленного голосования vote.AttachedVote.get
- Получить список проголосовавших за ответ vote.AttachedVote.getAnswerVoted
- Получить несколько голосований vote.AttachedVote.getMany
- Отозвать свой голос vote.AttachedVote.recall
- Возобновить голосование vote.AttachedVote.resume
- Остановить голосование vote.AttachedVote.stop
- Проголосовать в прикрепленном голосовании vote.AttachedVote.vote
- Создать и отправить голосование в чат vote.Integration.Im.send