#Список постов

GET /v1/posts

Возвращает посты Ленты новостей Битрикс24, доступные текущему API-ключу, в нормализованном виде: ключи в camelCase, флаги булевыми, числовые поля числами.

#Параметры

Параметр Тип Обяз. По умолч. Описание
limit (query) number нет 50 Количество постов в ответе. Допустимый диапазон 1..50. Значение больше 50 возвращает 400 INVALID_LIMIT. Значение в диапазоне обрезает выдачу до указанного числа
offset (query) number нет 0 Смещение для пагинации. Целое неотрицательное число

Пагинация. Страница содержит до 50 постов. Чтобы получить следующую порцию, передайте в offset значение meta.nextOffset из ответа предыдущего запроса. Поле meta.nextOffset присутствует, только когда есть следующая страница. Если его нет, посты закончились.

#Примеры

#curl — личный ключ

Terminal
curl "https://vibecode.bitrix24.tech/v1/posts?limit=3" \
  -H "X-Api-Key: YOUR_API_KEY"

#curl — OAuth-приложение

Terminal
curl "https://vibecode.bitrix24.tech/v1/posts?limit=3" \
  -H "X-Api-Key: YOUR_APP_KEY" \
  -H "Authorization: Bearer USER_SESSION_TOKEN"

#JavaScript — личный ключ

javascript
const res = await fetch('https://vibecode.bitrix24.tech/v1/posts?limit=3', {
  headers: { 'X-Api-Key': 'YOUR_API_KEY' },
})
const { data, meta } = await res.json()
console.log(`Постов: ${data.length} из ${meta.total}`)

#JavaScript — OAuth-приложение

javascript
const res = await fetch('https://vibecode.bitrix24.tech/v1/posts?limit=3', {
  headers: {
    'X-Api-Key': 'YOUR_APP_KEY',
    'Authorization': 'Bearer USER_SESSION_TOKEN',
  },
})
const { data, meta } = await res.json()

#Поля ответа

Поле Тип Описание
success boolean Всегда true при успехе
data array Массив постов
data[].id number ID поста. Используется в пути PATCH /v1/posts/:id и в URL поста
data[].blogId number ID блога, к которому относится пост
data[].publishStatus string Статус публикации (P — опубликован)
data[].title string Заголовок поста
data[].detailText string Текст поста
data[].authorId number ID автора. Список: GET /v1/users
data[].enableComments boolean Разрешены ли комментарии к посту
data[].numComments string Количество комментариев строкой (например, "2")
data[].code string | null Символьный код поста
data[].micro boolean Микропост (без заголовка)
data[].datePublish string Дата публикации (ISO 8601 с часовым поясом)
data[].categoryId number | null ID категории поста
data[].hasSocnetAll boolean Пост адресован всем сотрудникам
data[].hasTags boolean | null В посте есть теги
data[].hasImages boolean | null В посте есть изображения
data[].hasProps boolean | null В посте есть свойства
meta.total number Общее количество постов, доступных ключу
meta.pageSize number Размер страницы — всегда 50
meta.requestedLimit number Значение переданного limit. Присутствует, только если параметр был передан
meta.nextOffset number Смещение следующей страницы. Присутствует, только если есть следующая страница — передайте его в offset следующего запроса

#Пример ответа

Показаны основные поля.

JSON
{
  "success": true,
  "data": [
    {
      "id": 293,
      "blogId": 1,
      "publishStatus": "P",
      "title": "Объявление",
      "detailText": "Текст объявления для сотрудников",
      "authorId": 1,
      "enableComments": true,
      "numComments": "0",
      "code": null,
      "micro": true,
      "datePublish": "2026-05-29T11:47:37+03:00",
      "categoryId": null,
      "hasSocnetAll": false,
      "hasTags": false,
      "hasImages": false,
      "hasProps": false
    },
    {
      "id": 215,
      "blogId": 1,
      "publishStatus": "P",
      "title": "Опрос",
      "detailText": "Текст опроса",
      "authorId": 1,
      "enableComments": true,
      "numComments": "3",
      "code": null,
      "micro": true,
      "datePublish": "2025-08-13T10:46:10+03:00",
      "categoryId": null,
      "hasSocnetAll": true,
      "hasTags": false,
      "hasImages": false,
      "hasProps": true
    }
  ],
  "meta": {
    "total": 89,
    "pageSize": 50,
    "requestedLimit": 3,
    "nextOffset": 50
  }
}

#Пример ответа при ошибке

400 — limit вне диапазона 1..50:

JSON
{
  "success": false,
  "error": {
    "code": "INVALID_LIMIT",
    "message": "The page size is fixed at 50 records — a larger `limit` cannot be honoured. Omit `limit` (or pass any value ≤ 50) and paginate via the returned `meta.nextOffset`."
  }
}

#Ошибки

HTTP Код Описание
400 INVALID_LIMIT limit не положительное целое или больше 50
400 INVALID_OFFSET offset отрицательный или не целое число
401 TOKEN_MISSING У API-ключа не настроены токены доступа
403 SCOPE_DENIED У API-ключа нет скоупа log
422 BITRIX_ERROR Битрикс24 вернул ошибку при выборке постов
502 BITRIX_UNAVAILABLE Битрикс24 недоступен

Полный список общих ошибок API — Ошибки.

#Известные особенности

  • numComments приходит строкой. Количество комментариев представлено строкой ("2"), а не числом — приведите его к числу на стороне клиента, если нужны вычисления.

#Смотрите также