#Добавить позицию в корзину

POST /v1/basket-items

Добавляет новую товарную позицию в существующий заказ. Тело запроса плоское — без обёртки fields.

#Поля запроса (body)

Параметр Тип Обяз. Описание
orderId number да Идентификатор заказа. Источник: `GET /v1/orders`
productId number да Идентификатор товара в каталоге. Источник: `GET /v1/catalog-products`. Передайте 0, чтобы создать виртуальный товар без привязки к каталогу
name string да Название позиции. Если передан productId > 0 — название лучше скопировать из карточки товара
price number да Цена за единицу (итоговая, с учётом скидки)
currency string да Валюта позиции. Список: `GET /v1/currencies`
quantity number да Количество
basePrice number нет Базовая цена до скидки. По умолчанию равна price
discountPrice number нет Размер скидки за единицу. По умолчанию 0
vatRate number нет Ставка НДС в долях единицы (0.20 = 20%, 0.10 = 10%, 0 — без НДС)
vatIncluded boolean нет Включён ли НДС в цену. По умолчанию true
customPrice boolean нет Защита цены от автопересчёта при изменении товара в каталоге. По умолчанию false
weight number нет Вес в граммах
measureCode number нет Код единицы измерения (796 = шт, 163 = г, 006 = м)
xmlId string нет Внешний идентификатор позиции

#Примеры

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

Terminal
curl -X POST "https://vibecode.bitrix24.tech/v1/basket-items" \
  -H "X-Api-Key: YOUR_API_KEY" \
  -H "Content-Type: application/json" \
  -d '{
    "orderId": 33,
    "productId": 119,
    "name": "Домашние Тапочки Любимый Спорт",
    "quantity": 2,
    "price": 470,
    "currency": "RUB",
    "vatRate": 0.20,
    "vatIncluded": true
  }'

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

Terminal
curl -X POST "https://vibecode.bitrix24.tech/v1/basket-items" \
  -H "X-Api-Key: YOUR_APP_KEY" \
  -H "Authorization: Bearer USER_SESSION_TOKEN" \
  -H "Content-Type: application/json" \
  -d '{
    "orderId": 33,
    "productId": 119,
    "name": "Домашние Тапочки Любимый Спорт",
    "quantity": 2,
    "price": 470,
    "currency": "RUB",
    "vatRate": 0.20,
    "vatIncluded": true
  }'

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

javascript
const res = await fetch('https://vibecode.bitrix24.tech/v1/basket-items', {
  method: 'POST',
  headers: {
    'X-Api-Key': 'YOUR_API_KEY',
    'Content-Type': 'application/json',
  },
  body: JSON.stringify({
    orderId: 33,
    productId: 119,
    name: 'Домашние Тапочки Любимый Спорт',
    quantity: 2,
    price: 470,
    currency: 'RUB',
    vatRate: 0.20,
    vatIncluded: true,
  }),
})

const { success, data } = await res.json()
console.log('Basket item ID:', data.id)

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

javascript
const res = await fetch('https://vibecode.bitrix24.tech/v1/basket-items', {
  method: 'POST',
  headers: {
    'X-Api-Key': 'YOUR_APP_KEY',
    'Authorization': 'Bearer USER_SESSION_TOKEN',
    'Content-Type': 'application/json',
  },
  body: JSON.stringify({
    orderId: 33,
    productId: 119,
    name: 'Домашние Тапочки Любимый Спорт',
    quantity: 2,
    price: 470,
    currency: 'RUB',
    vatRate: 0.20,
    vatIncluded: true,
  }),
})

const { success, data } = await res.json()

#Поля ответа

Возвращается полный объект созданной позиции корзины.

Поле Тип Описание
id number Идентификатор созданной позиции
name string Название товара (заполнено из карточки productId, если не передано)
productXmlId / catalogXmlId string Внешние идентификаторы товара и каталога (заполняются автоматически)
dateInsert datetime Дата создания

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

JSON
{
  "success": true,
  "data": {
    "id": 201,
    "orderId": 33,
    "productId": 119,
    "name": "Домашние Тапочки Любимый Спорт",
    "price": 470,
    "basePrice": 470,
    "discountPrice": 0,
    "currency": "RUB",
    "quantity": 2,
    "vatRate": 0.20,
    "vatIncluded": true,
    "customPrice": false,
    "canBuy": true,
    "weight": 0,
    "measureCode": 796,
    "measureName": "шт",
    "productXmlId": "1000000475",
    "catalogXmlId": "FUTURE-1C-CATALOG",
    "xmlId": "bx_61a23456789ab",
    "dateInsert": "2026-05-13T11:55:42.000Z",
    "dateUpdate": "2026-05-13T11:55:42.000Z"
  }
}

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

400 — не передан обязательный orderId:

JSON
{
  "success": false,
  "error": {
    "code": "BITRIX_ERROR",
    "message": "Required fields: orderId"
  }
}

#Ошибки

HTTP Код Описание
400 BITRIX_ERROR Не переданы обязательные поля — сообщение содержит их список
400 BITRIX_ERROR Несуществующий orderId или productId
403 SCOPE_DENIED API-ключ не имеет скоупа sale
401 TOKEN_MISSING API-ключ не имеет настроенных токенов

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

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

Поля товара заполняются из каталога. Если передать productId, Битрикс24 берёт name, productXmlId, catalogXmlId, measureCode и measureName из карточки товара. Чтобы переопределить название — передавайте его явно в name.

Несколько позиций для одного товара. Можно добавить одну и ту же productId в заказ несколькими позициями — Битрикс24 не схлопывает их. Чтобы увеличить количество существующей позиции, используйте `PATCH /v1/basket-items/:id` с quantity.

Цена не пересчитывается автоматически. Передавайте согласованные price / basePrice / discountPrice — Вайбкод и Битрикс24 не пересчитывают их между собой. Если нужна защита цены от обновлений каталога — передавайте customPrice: true.

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