Перейти к содержимому

Введение

  • Version: 2.0.0
  • Servers: https://store.xsolla.com/api
  • Contact Us by Email
  • Contact URL: https://xsolla.com/
  • Required TLS version: 1.2

API каталога позволяет настраивать каталог внутриигровых товаров на стороне Xsolla и отображать каталог пользователям в вашем игровом магазине.

API позволяет вам управлять такими сущностями каталога, как:

  • Виртуальные предметы — внутриигровые предметы, например оружие, скины, бустеры.
  • Виртуальная валюта — виртуальные деньги, которые используются для приобретения виртуальных товаров. Пакеты виртуальной валюты — предустановленные наборы виртуальной валюты.
  • Бандлы — комбинированные наборы виртуальных предметов, валюты или игровых ключей, продаваемые как единый артикул.
  • Игровые ключи — ключи для игр и DLC, распространяемые через такие платформы, как Steam, или других DRM-провайдеров.
  • Группы — логические группировки для организации и сортировки товаров в каталоге.

Методы API

Методы API делятся на следующие группы:

  • Admin — методы для создания, обновления, удаления и настройки товаров и групп каталога. Для вызова требуется базовая HTTP-аутентификация с использованием учетных данных Личного кабинета. Не предназначены для построения витрин для конечных пользователей.
  • Catalog — методы для получения товаров и построения витрин для конечных пользователей. Поддерживают опциональную аутентификацию с использованием JWT пользователя для возврата персонализированных данных, таких как пользовательские лимиты и активные промоакции.

Аутентификация

Методы API требуют аутентификации либо от имени пользователя, либо от имени проекта. Тип используемой схемы аутентификации указан в блоке Безопасность в описании каждого метода.

Аутентификация с помощью JWT пользователя

Аутентификация с помощью JWT пользователя применяется, когда запрос выполняется из браузера, мобильного приложения или игры. По умолчанию используется XsollaLoginUserJWT. Подробная информация о создании токена приведена в документации Xsolla Login API.

The token is passed in the Authorization header in the following format: Authorization: Bearer <user_JWT>, where <user_JWT> is the user token. The token identifies the user and provides access to personalized data.

В качестве альтернативы вы можете использовать токен для открытия платежного интерфейса.

Базовая HTTP-аутентификация

Базовая HTTP-аутентификация применяется при взаимодействии server-to-server, когда вызов API отправляется напрямую с вашего сервера, а не из браузера пользователя или мобильного приложения. Обычно применяется базовая HTTP-аутентификация с использованием ключа API.

Примечание

Ключ API является конфиденциальным и не должен храниться или использоваться в клиентских приложениях.

При базовой серверной аутентификации все запросы к API должны содержать заголовок:

  • для basicAuthAuthorization: Basic <your_authorization_basic_key>, где your_authorization_basic_key — это пара project_id:api_key, закодированная по стандарту Base64;
  • для basicMerchantAuthAuthorization: Basic <your_authorization_basic_key>, где your_authorization_basic_key — это пара merchant_id:api_key, закодированная по стандарту Base64.

Значения параметров вы можете найти в Личном кабинете:

  • merchant_id отображается:
    • В разделе Настройки компании > Компания.
    • В адресной строке браузера на любой странице Личного кабинета. URL-адрес имеет вид: https://publisher.xsolla.com/<merchant_id>.
  • project_id отображается:
    • В Личном кабинете рядом с названием проекта.
    • В адресной строке браузера при работе с проектом в Личном кабинете. URL-адрес имеет вид: https://publisher.xsolla.com/<merchant_id>/projects/<project_id>.
  • api_key отображается в Личном кабинете только при создании и должен храниться на вашей стороне. Создать ключ можно в разделах:
Внимание

Если необходимый метод API не включает в себя path-параметр project_id, используйте для авторизации ключ API, который действует во всех проектах.

Подробная информация о работе с ключами API приведена в справочнике API.

Аутентификация с поддержкой гостевого доступа

Для продажи корзины используется схема аутентификации AuthForCart, которая поддерживает два режима:

  1. Аутентификация с помощью JWT пользователя. Токен передается в заголовке Authorization в следующем формате: Authorization: Bearer <user_JWT>, где <user_JWT> — токен пользователя. Токен идентифицирует пользователя и обеспечивает доступ к персонализированным данным. В качестве альтернативы вы можете использовать токен для открытия платежного интерфейса.

  2. Упрощенный режим без заголовка. Он применяется только для неавторизованных пользователей и может быть использована только для продажи игровых ключей. Вместо токена в запрос передаются заголовки:

    • x-unauthorized-id с ID запроса;
    • x-user с email пользователя, закодированным в формате Base64.

Базовая структура товара

Товары всех типов (виртуальные предметы, бандлы, виртуальная валюта, ключи) используют схожую структуру данных. Понимание базовой структуры упрощает работу с API и позволяет быстрее ориентироваться в документации.

Примечание

В некоторых методах могут использоваться дополнительные поля, но они не изменяют базовую структуру.

Идентификация

  • merchant_id — ID компании в Личном кабинете;
  • project_id — ID проекта в Личном кабинете;
  • sku — артикул товара, уникальный в рамках проекта.

Отображение в каталоге

  • name — название;
  • description — описание;
  • image_url — ссылка на изображение;
  • is_enabled — доступность товара;
  • is_show_in_store — отображение в каталоге.

Подробнее об управлении доступностью товаров в каталоге – в документации.

Организация

  • type — тип товара, например, виртуальный предмет (virtual_item) или бандл (bundle);
  • groups — группы, к которым относится товар;
  • order — порядок отображения в каталоге.

Условия продажи

  • prices — цены в реальной или виртуальной валюте;
  • limits — ограничения на покупку;
  • periods — период доступности;
  • regions — региональные ограничения.

Пример базовой структуры:

{
  "attributes": [],
  "bundle_type": "virtual_currency_package",
  "content": [
    {
      "description": {
        "en": "Main in-game currency"
      },
      "image_url": "https://.../image.png",
      "name": {
        "en": "Crystals",
        "de": "Kristalle"
      },
      "quantity": 500,
      "sku": "com.xsolla.crystal_2",
      "type": "virtual_currency"
    }
  ],
  "description": {
    "en": "Crystals x500"
  },
  "groups": [],
  "image_url": "https://.../image.png",
  "is_enabled": true,
  "is_free": false,
  "is_show_in_store": true,
  "limits": {
    "per_item": null,
    "per_user": null,
    "recurrent_schedule": null
  },
  "long_description": null,
  "media_list": [],
  "name": {
    "en": "Medium crystal pack"
  },
  "order": 1,
  "periods": [
    {
      "date_from": null,
      "date_until": "2020-08-11T20:00:00+03:00"
    }
  ],
  "prices": [
    {
      "amount": 20,
      "country_iso": "US",
      "currency": "USD",
      "is_default": true,
      "is_enabled": true
    }
  ],
  "regions": [],
  "sku": "com.xsolla.crystal_pack_2",
  "type": "bundle",
  "vc_prices": []
}

Настройка продажи товаров

Xsolla API позволяет реализовать логику магазина внутриигровых товаров,  включая получение каталога, управление корзиной, создание заказов и отслеживание их статусов. В зависимости от сценария интеграции методы API делятся на подразделы Admin и Catalog, которые используют разные схемы аутентификации.

Ниже приведен пример базового сценария настройки и работы магазина — от создания товаров до их продажи пользователю.

Создание товаров и групп (Admin)

Создайте каталог товаров для вашего магазина, например, виртуальные предметы, бандлы или виртуальную валюту.

Примеры методов:

Настройка акций, цепочек, ограничений (Admin)

Настройте инструменты привлечения пользователей и монетизации, например скидки, бонусы, ежедневные награды или цепочки предложений.

Примеры методов:

Получение информации о товарах (Client)

Настройте отображение товаров магазина в вашем приложении.

Внимание

Не используйте методы подраздела Admin для построения каталога пользователям — у таких методов заданы ограничения по частоте запросов, которые не рассчитаны на пользовательский трафик.

Примеры методов:

Примечание

По умолчанию в методах получения каталога возвращаются товары, которые отображаются в магазине на момент запроса. Чтобы получить информацию о товарах, период отображения которых еще не наступил или уже истек, передайте параметр "show_inactive_time_limited_items": 1 при запросе каталога.

Продажа товаров

Вы можете продавать товары за реальную валюту следующими способами:

  • Быстрая покупка — продажа одного товара, но в любом количестве.
  • Покупка корзины — пользователь наполняет корзину, добавляет и удаляет товары, изменяет количество в одном заказе.

Если товар оплачивается внутриигровой валютой, а не реальными деньгами, используйте метод Создание заказа с указанным товаром, приобретенным за виртуальную валюту. Платежный интерфейс открывать не нужно — списание происходит в момент вызова метода.

Если товар бесплатный, используйте метод Создание заказа с указанным бесплатным товаром или метод Создание заказа с помощью бесплатной корзины. Платежный интерфейс открывать не нужно — заказ сразу переходит в статус done.

Быстрая покупка

Используйте клиентский метод создания заказа с указанным товаром – в ответе вы получите токен, который используется для открытия платежного интерфейса.

Примечание

Информация о скидке доступна пользователю только в платежном интерфейсе. Использование промокодов не предусмотрено.

Покупка корзины

Наполнение и покупка корзины может осуществляться на клиенте или на сервере.

Наполнение и покупка корзины на клиенте

Самостоятельно реализуйте логику добавления и удаления товаров. Также необходимо учитывать, что до вызова метода наполнения корзины у вас не будет информации о том, какие акции будут применены при покупке. Это означает, что итоговая стоимость и сведения о добавленных бонусных предметах будут неизвестны.

Реализуйте следующую логику работы с корзиной:

  1. После наполнения корзины игроком используйте метод Наполнение корзины товарами для наполнения корзины. В ответе вернется текущая информация о выбранных товарах — цены до и после применения скидок, бонусные товары.
  2. Обновите содержимое корзины в соответствии с действиями пользователя:
Примечание

Если вы хотите получить актуальное состояние корзины, используйте метод Получение корзины текущего пользователя.
  1. Используйте метод покупки корзины Создание заказа со всеми товарами из текущей корзины. В ответе вернутся ID заказа и платежный токен. Заказу будет присвоен статус new.

Наполнение и покупка корзины на сервере

Этот вариант наполнения корзины может занимать значительное время на настройку, поскольку каждое изменение корзины может сопровождаться вызовом большего количества методов API.

Реализуйте следующую логику работы с корзиной:

  1. После наполнения корзины игроком используйте методс Наполнение корзины товарамидля наполнения корзины. В ответе вернется текущая информация о выбранных товарах — цены до и после применения скидок, бонусные товары.
  2. Используйте метод покупки корзины Создание заказа со всеми товарами из текущей корзины. В ответе вернутся ID заказа и платежный токен. Заказу будет присвоен статус new.

Открытие платежного интерфейса

Используйте полученный токен для открытия платежного интерфейса в новом окне. Другие способы открытия платежного интерфейса описаны в документации.

ДействиеЭндпоинт
Открыть в боевом окружении.https://secure.xsolla.com/paystation4/?token={token}
Открыть в тестовом окружении.https://sandbox-secure.xsolla.com/paystation4/?token={token}
Примечание

Используйте тестовый режим (sandbox-режим) при разработке и тестировании — при совершении тестовой покупки с реальных счетов не списываются деньги. Для тестирования вы можете использовать тестовые банковские карты.

После проведения первого реального платежа в силу вступает строгая политика платежей в тестовом окружении. Проведение платежа в нем будет доступно только для пользователей, которые указаны в Личном кабинете в разделе Настройки компании > Пользователи.

Покупка виртуальной валюты и виртуальных предметов за реальную валюту возможна после подписания лицензионного договора с Xsolla. Для этого в Личном кабинете перейдите в Договоры и налоги > Договоры, заполните договор и дождитесь подтверждения согласования. Согласование может занять до 3 рабочих дней.

Для включения или отключения тестового режима вам необходимо изменить значение параметра sandbox в теле запроса методов быстрой покупки и покупки корзины. По умолчанию тестовый режим выключен.

Возможные статусы заказа: - new — заказ создан; - paid — оплата получена; - done — товар начислен; - canceled — заказ отменен; - expired — истек срок оплаты.

Отслеживайте статус одним из следующих способов:

Пагинация

Методы API для запроса большого количества записей (например, для построения каталога) возвращают данные постранично. Пагинация — это механизм ограничения количества элементов, возвращаемых в одном ответе API, с возможностью последовательного получения следующих страниц.

Для управления количеством возвращаемых элементов используйте следующие параметры:

  • limit — количество элементов на странице;
  • offset — номер элемента, с которого выполняется вывод на странице (нумерация ведется с 0);
  • has_more — есть ли следующая страница;
  • total_items_count — общее количество элементов.

Пример запроса:

GET /items?limit=20&offset=40

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

{
  "items": [...],
  "has_more": true,
  "total_items_count": 135
}

Рекомендуется выполнять последовательные запросы до тех пор, пока в ответе не вернется has_more = false.

Формат даты и времени

Дата и время передаются в формате ISO 8601.

Поддерживаются:

  • смещение относительно UTC;
  • значение null, когда нет ограничения времени отображения предмета;
  • в отдельных полях используется Unix timestamp (в секундах).

Формат: YYYY-MM-DDTHH:MM:SS±HH:MM

Пример: 2026-03-16T10:00:00+03:00

Локализация

Xsolla поддерживает локализацию пользовательских полей, таких как название и описание товаров. Локализованные значения передаются в виде объекта, в котором ключом является код языка. Полный список поддерживаемых языков приведен в документации.

Поддерживаемые поля

Локализация может быть задана для следующих параметров:

  • name
  • description
  • long_description

Формат локали

Ключ локали может быть указан в одном из следующих форматов:

  • двухбуквенный код языка: en, ru
  • формат язык–страна: en-US, ru-RU, de-DE

Примеры

Пример с двухбуквенным кодом языка:

{
  "name": {
    "en": "Starter Pack",
    "ru": "Стартовый набор"
  }
}

Пример с форматом язык–страна:

{
  "description": {
    "en-US": "Premium bundle",
    "de-DE": "Premium-Paket"
  }
}

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

При возникновении ошибки API возвращает HTTP-статус и тело ответа в формате JSON. Полный список ошибок в работе магазина приведен в документации.

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

{
  "errorCode": 1102,
  "errorMessage": "Validation error",
  "statusCode": 422,
  "transactionId": "c9e1a..."
}
  • errorCode — код ошибки.
  • errorMessage — краткое описание ошибки.
  • statusCode — HTTP статус ответа.
  • transactionId — ID запроса. Возвращается не во всех случаях.
  • errorMessageExtended — дополнительные данные об ошибке, например параметры запроса. Возвращаются не во всех случаях.

Пример расширенного ответа:

{
  "errorCode": 7001,
  "errorMessage": "Chain not found",
  "errorMessageExtended": {
    "chain_id": "test_chain_id",
    "project_id": "test_project_id",
    "step_number": 2
  },
  "statusCode": 404
}

Частые HTTP-статусы

  • 400 — некорректный запрос
  • 401 — ошибка аутентификации
  • 403 — недостаточно прав доступа
  • 404 — ресурс не найден
  • 422 — ошибка валидации данных
  • 429 — превышено ограничение частоты запросов

Рекомендации

  • Обрабатывайте HTTP-статус и тело ответа совместно.
  • Используйте errorCode для обработки ошибок, связанных с логикой работы приложения.
  • Используйте transactionId, чтобы быстрее идентифицировать запросы при анализе ошибок.
Скачать описание OpenAPI
Языки
Серверы
https://store.xsolla.com/api/
Mock server
https://xsolla.redocly.app/_mock/ru/api/catalog/

Основная информация

С помощью виртуальных предметов и валюты вы можете построить внутриигровой магазин и настроить его отображение пользователям. Доступны следующие типы товаров:

  • Виртуальные предметы — внутриигровые товары, например оружие, скины или бустеры. Продаются за реальные деньги или виртуальную валюту.
  • Виртуальная валюта — внутриигровая валюта для покупки виртуальных предметов. Продается за реальные деньги или виртуальную валюту.
  • Пакеты виртуальной валюты — фиксированное количество виртуальной валюты. Продается за реальные деньги или виртуальную валюту.

Для организации товаров в каталоге используются группы. Они позволяют логически объединять товары и управлять их отображением.

Используйте методы подраздела Admin для создания, обновления и удаления товаров.

Используйте методы подраздела Catalog для получения списков товаров и их отображения пользователям.

Уведомление

Не используйте методы подраздела Admin для построения каталога пользователям.

Примечание

Метод Получение списка виртуальных предметов возвращает подробные данные о предметах, включая цены и атрибуты, и поддерживает пагинацию — используйте его для отображения страниц каталога в витрине магазина.

Метод Получение списка всех виртуальных предметов возвращает артикул, название и описание предмета, а также ID и название группы без пагинации — используйте его для поиска или индексирования на стороне клиента.

Для реализации покупок за виртуальную валюту используйте метод Создание заказа с указанным товаром, приобретенным за виртуальную валюту. Открывать платежный интерфейс не нужно — списание происходит в момент вызова метода.

Пример сценария покупки товара за виртуальную валюту:

Purchase flow with virtual currency example

Операции
Операции
Операции

Основная информация

Game keys are single-use unique alphanumeric codes that grant users access to a game or DLC on gaming platforms. You can sell game keys via a direct link, through the store UI, or via a widget. You can also configure regional restrictions to sell game keys in specific countries. For detailed information, refer to the Game keys packages section.

User authentication is not required to sell game keys — the keys are sent to the email the user specified at checkout. You can configure authentication to enable additional scenarios: personalization, purchase limits, or an entitlement system. For detailed information, refer to the How to set up authentication when selling game keys section.

Game key sales flow:

  1. Create a game using the Create game API call.
  2. Configure regional restrictions.
  3. Upload keys to a game key package using the Upload codes API call to make them available for purchase.
  4. Display the game catalog with prices for the user's region using the Get games list API call.
  5. Create an order. For a fast purchase, you can use the Create order with all items from current cart API call, passing the game key SKU. The response returns a token for opening the payment UI.
  6. Implement the opening of the payment UI to pay for the order.

To receive timely notifications about successful payments and deliver items to the user, set up order status tracking, for example, using webhooks. The keys are sent to the email the user specified at checkout, and the order moves to the done status.

Game keys

Операции
Операции
Операции

Основная информация

Bundles are sets of items sold as a single unit. A bundle can include virtual items, virtual currency, virtual currency packages, game keys, and other bundles. Use bundles to create starter packs, seasonal offers, and special deals.

Use the following API call groups to work with bundles:

  • Use API calls from the Admin subsection to create, update, delete bundles, and manage their visibility.
  • Use API calls from the Catalog subsection to retrieve bundles.

Purchase limits are configured via the limits object when creating or updating a bundle. For more information, refer to the Limits overview. You can also configure regional restrictions to sell items in specific countries.

Note

For detailed information on configuring bundles, refer to the Bundles section.

Bundle management scenario:

  1. Create a bundle using the Create bundle API call. To verify the created bundle, use the Get bundle API call. To retrieve all bundles in the project, use the Get list of bundles API call.
  2. If needed, use the Update bundle API call to modify the bundle content or settings.
  3. Implement bundle display logic in your storefront using the Get list of bundles, Get specified bundle, or Get list of bundles by specified group API call.
  4. Create an order using the Cart and payment section. For example, for a fast purchase you can use the Create order with specified item API call, passing the bundle SKU. The response contains a token for opening the payment UI.
  5. Implement opening the payment UI to pay for the order.
  6. Set up order status tracking, for example using webhooks, to promptly receive data on successfully paid items and grant them to the user.

Bundle management scenario

Операции

Получение списка бандловServer-sideAdmin

Запрос

Получает список бандлов в рамках проекта для администрирования.

Примечание

Не используйте данный метод для построения каталога магазина.
Безопасность
basicAuth
Путь
project_idintegerобязательный

ID проекта. Вы можете найти этот параметр в Личном кабинете рядом с названием проекта, а также в адресной строке браузера при работе с проектом. URL-адрес имеет следующий формат: https://publisher.xsolla.com/<merchant_id>/projects/<project_id>.

Пример: 44056
Запрос
limitinteger>= 1

Лимит количества элементов на странице.

Пример: limit=50
offsetinteger>= 0

Номер элемента, с которого выполняется вывод на странице (нумерация ведется с 0).

Пример: offset=0
curl -i -X GET \
  -u <username>:<password> \
  'https://store.xsolla.com/api/v2/project/44056/admin/items/bundle?limit=50&offset=0'

Ответы

Список бандлов успешно получен.

Телоapplication/json
itemsArray of objects(Bundles_admin_bundle_response)
items[].​item_idinteger(Bundles_item_id)[ 1 .. 255 ] characters

Внутренний уникальный ID виртуального предмета или валюты.

items[].​skustring(Bundles_sku)[ 1 .. 255 ] characters^[a-zA-Z0-9_\-–.]*$

Уникальный ID товара. Артикул может содержать только строчные и заглавные латинские буквы, цифры, точки, тире и подчеркивания.

items[].​name(two-letter (object or null)) or (five-letter (object or null))(name-localization-object)

Объект с локализованными названиями товара. Принимает значения в одном из двух форматов: двухбуквенный код языка в нижнем регистре (например, en) или код языка из пяти символов (например, en-US). Оба формата допустимы при отправке запроса, но в ответе всегда используется двухбуквенный код языка. Если для одного языка указаны оба варианта (например, en и en-US), будет сохранено последнее переданное значение. Полный список поддерживаемых языков приведен в документации.

Any of:

Двухбуквенные строчные языковые коды.

items[].​name.​enstring or null

Английский

items[].​name.​arstring or null

Арабский

items[].​name.​bgstring or null

Болгарский

items[].​name.​cnstring or null

Китайский упрощенный

items[].​name.​csstring or null

Чешский

items[].​name.​destring or null

Немецкий

items[].​name.​esstring or null

Испанский

items[].​name.​frstring or null

Французский

items[].​name.​hestring or null

Иврит

items[].​name.​itstring or null

Итальянский

items[].​name.​jastring or null

Японский

items[].​name.​kostring or null

Корейский

items[].​name.​plstring or null

Польский

items[].​name.​ptstring or null

Португальский

items[].​name.​rostring or null

Румынский

items[].​name.​rustring or null

Русский

items[].​name.​thstring or null

Тайский

items[].​name.​trstring or null

Турецкий

items[].​name.​twstring or null

Китайский традиционный

items[].​name.​vistring or null

Вьетнамский

items[].​name.​kmstring or null

Кхмерский

items[].​name.​idstring or null

Индонезийский

items[].​name.​lostring or null

Лаосский

items[].​name.​mystring or null

Бирманский

items[].​name.​phstring or null

Филиппинский

items[].​name.​nestring or null

Непальский

items[].​attributesArray of objects(Bundles_admin-attributes)

Список атрибутов.

Пример: [{"external_id":"attribute_external_id","name":{"en":"Attribute name","de":"Attributname"},"values":[{"external_id":"value_1","name":{"en":"value 1","de":"wert 1"}},{"external_id":"value_2","name":{"en":"value 2","de":"wert 2"}}]}]
items[].​attributes[].​external_idstring(admin-attribute-external_id)[ 1 .. 255 ] characters^[a-zA-Z0-9-_]+$обязательный

Уникальный ID атрибута. external_id может содержать только строчные и заглавные латинские буквы, цифры, тире и подчеркивания.

Пример: "attribute_external_id"
items[].​attributes[].​nameobject(admin-attribute-name)

Объект с локализациями для названия атрибута. Ключи для обозначения стран указаны в стандарте ISO 3166-1.

Пример: {"en":"Attribute name","de":"Attributname"}
items[].​attributes[].​name.​property name*stringдополнительное свойство
items[].​attributes[].​valuesArray of objects(attribute-value)обязательный
Пример: [{"external_id":"value_1","name":{"en":"value 1","de":"wert 1"}},{"external_id":"value_2","name":{"en":"value 2","de":"wert 2"}}]
items[].​attributes[].​values[].​external_idstring(value-external_id)[ 1 .. 255 ] characters^[-_.\d\w]+$обязательный

Уникальный ID значения атрибута. external_id может содержать только строчные латинские буквы, цифры, тире и подчеркивания.

Пример: "value_external_id"
items[].​attributes[].​values[].​valueobject(value-name)обязательный

Объект с локализациями для названия значения. Ключи для обозначения стран указаны в стандарте ISO 3166-1.

items[].​attributes[].​values[].​value.​property name*stringдополнительное свойство
items[].​typestring(Bundles_type)

Тип товара.

items[].​bundle_typestring(bundle_type)

Тип бандла. Возвращается, если тип элемента является бандлом.

Перечисление"standard""virtual_currency_package""partner_side_content"
items[].​description(two-letter (object or null)) or (five-letter (object or null))(description-localization-object)

Объект с локализованными описаниями товара. Принимает значения в одном из двух форматов: двухбуквенный код языка в нижнем регистре (например, en) или код локали из пяти символов (например, en-US). Оба формата допустимы при отправке запроса, но в ответе всегда используется код из двух символов. Если для одного языка указаны оба варианта (например, en и en-US), будет сохранено последнее переданное значение. Полный список поддерживаемых языков приведен в документации.

Any of:

Двухбуквенные строчные языковые коды.

items[].​description.​enstring or null

Английский

items[].​description.​arstring or null

Арабский

items[].​description.​bgstring or null

Болгарский

items[].​description.​cnstring or null

Китайский упрощенный

items[].​description.​csstring or null

Чешский

items[].​description.​destring or null

Немецкий

items[].​description.​esstring or null

Испанский

items[].​description.​frstring or null

Французский

items[].​description.​hestring or null

Иврит

items[].​description.​itstring or null

Итальянский

items[].​description.​jastring or null

Японский

items[].​description.​kostring or null

Корейский

items[].​description.​plstring or null

Польский

items[].​description.​ptstring or null

Португальский

items[].​description.​rostring or null

Румынский

items[].​description.​rustring or null

Русский

items[].​description.​thstring or null

Тайский

items[].​description.​trstring or null

Турецкий

items[].​description.​twstring or null

Китайский традиционный

items[].​description.​vistring or null

Вьетнамский

items[].​description.​kmstring or null

Кхмерский

items[].​description.​idstring or null

Индонезийский

items[].​description.​lostring or null

Лаосский

items[].​description.​mystring or null

Бирманский

items[].​description.​phstring or null

Филиппинский

items[].​description.​nestring or null

Непальский

items[].​long_description(two-letter (object or null)) or (five-letter (object or null))(long-description-localization-object)

Объект с локализованными длинными описаниями товара. Принимает значения в одном из двух форматов: двухбуквенный код языка в нижнем регистре (например, en) или код локали из пяти символов (например, en-US). Оба формата допустимы при отправке запроса, но в ответе всегда используется код из двух символов. Если для одного языка указаны оба варианта (например, en и en-US), будет сохранено последнее переданное значение. Полный список поддерживаемых языков приведен в документации.

Any of:

Двухбуквенные строчные языковые коды.

items[].​long_description.​enstring or null

Английский

items[].​long_description.​arstring or null

Арабский

items[].​long_description.​bgstring or null

Болгарский

items[].​long_description.​cnstring or null

Китайский упрощенный

items[].​long_description.​csstring or null

Чешский

items[].​long_description.​destring or null

Немецкий

items[].​long_description.​esstring or null

Испанский

items[].​long_description.​frstring or null

Французский

items[].​long_description.​hestring or null

Иврит

items[].​long_description.​itstring or null

Итальянский

items[].​long_description.​jastring or null

Японский

items[].​long_description.​kostring or null

Корейский

items[].​long_description.​plstring or null

Польский

items[].​long_description.​ptstring or null

Португальский

items[].​long_description.​rostring or null

Румынский

items[].​long_description.​rustring or null

Русский

items[].​long_description.​thstring or null

Тайский

items[].​long_description.​trstring or null

Турецкий

items[].​long_description.​twstring or null

Китайский традиционный

items[].​long_description.​vistring or null

Вьетнамский

items[].​long_description.​kmstring or null

Кхмерский

items[].​long_description.​idstring or null

Индонезийский

items[].​long_description.​lostring or null

Лаосский

items[].​long_description.​mystring or null

Бирманский

items[].​long_description.​phstring or null

Филиппинский

items[].​long_description.​nestring or null

Непальский

items[].​image_urlstring or null(Bundles_image_url)

URL-адрес изображения. Для корректного отображения и быстрой загрузки изображения в платежном интерфейсе проверьте требования к файлу и ссылке:

  • Поддерживаемые форматы: WebP (рекомендуется), PNG, JPG.
  • Размер файла: ≤ 50 КБ (для WebP) или ≤ 150 КБ (для PNG и JPG).
  • Размер изображения: 280 x 280 px.
  • Цветовое пространство: sRGB.
  • Протокол передачи данных: HTTPS с долгосрочным кэшированием версионированных URL-адресов.

items[].​is_freeboolean(value-is_free)

Является ли товар бесплатным.

items[].​is_paid_randomized_rewardboolean(value-is_paid_randomized_reward)

Является ли товар случайной платной наградой, например лутбоксом.

items[].​groupsArray of objects(Bundles_groups_response)

Группы, к которым принадлежит товар.

items[].​groups[].​external_idstring
Пример: "horror"
items[].​groups[].​nameobject

Название элемента. Должно содержать пары ключ/значение, где ключ — это языковой стандарт в {2}формате "^[a-z]", значение — строка.

По умолчанию {"en":"Horror"}
Пример: {"en":"Horror","de":"Horror"}
items[].​groups[].​name.​property name*stringдополнительное свойство
items[].​pricesArray of objects(Bundles_prices)

Цены в реальных валютах.

items[].​prices[].​amountstring(Bundles_amount_without_discount)^\d*\.?\d*$обязательный

Цена товара.

items[].​prices[].​currencystring(Bundles_currency)обязательный

Валюта, в которой указана цена товара. Трехбуквенный код в соответствии со стандартом ISO 4217.

items[].​prices[].​is_defaultbooleanобязательный

Цена по умолчанию используется для построения каталога, если цена в валюте пользователя не указана.

items[].​prices[].​is_enabledbooleanобязательный

Цена включена.

items[].​prices[].​country_isostring or null

Страна, где доступна эта цена. Двухбуквенный код в соответствии с ISO 3166-1 alpha 2.

Пример: "US"
items[].​virtual_pricesArray of objects(Bundles_admin-response-virtual_price)
items[].​virtual_prices[].​skustring(Bundles_sku)[ 1 .. 255 ] characters^[a-zA-Z0-9_\-–.]*$

Уникальный ID товара. Артикул может содержать только строчные и заглавные латинские буквы, цифры, точки, тире и подчеркивания.

items[].​virtual_prices[].​name(two-letter (object or null)) or (five-letter (object or null))(name-localization-object)

Объект с локализованными названиями товара. Принимает значения в одном из двух форматов: двухбуквенный код языка в нижнем регистре (например, en) или код языка из пяти символов (например, en-US). Оба формата допустимы при отправке запроса, но в ответе всегда используется двухбуквенный код языка. Если для одного языка указаны оба варианта (например, en и en-US), будет сохранено последнее переданное значение. Полный список поддерживаемых языков приведен в документации.

Any of:

Двухбуквенные строчные языковые коды.

items[].​virtual_prices[].​name.​enstring or null

Английский

items[].​virtual_prices[].​name.​arstring or null

Арабский

items[].​virtual_prices[].​name.​bgstring or null

Болгарский

items[].​virtual_prices[].​name.​cnstring or null

Китайский упрощенный

items[].​virtual_prices[].​name.​csstring or null

Чешский

items[].​virtual_prices[].​name.​destring or null

Немецкий

items[].​virtual_prices[].​name.​esstring or null

Испанский

items[].​virtual_prices[].​name.​frstring or null

Французский

items[].​virtual_prices[].​name.​hestring or null

Иврит

items[].​virtual_prices[].​name.​itstring or null

Итальянский

items[].​virtual_prices[].​name.​jastring or null

Японский

items[].​virtual_prices[].​name.​kostring or null

Корейский

items[].​virtual_prices[].​name.​plstring or null

Польский

items[].​virtual_prices[].​name.​ptstring or null

Португальский

items[].​virtual_prices[].​name.​rostring or null

Румынский

items[].​virtual_prices[].​name.​rustring or null

Русский

items[].​virtual_prices[].​name.​thstring or null

Тайский

items[].​virtual_prices[].​name.​trstring or null

Турецкий

items[].​virtual_prices[].​name.​twstring or null

Китайский традиционный

items[].​virtual_prices[].​name.​vistring or null

Вьетнамский

items[].​virtual_prices[].​name.​kmstring or null

Кхмерский

items[].​virtual_prices[].​name.​idstring or null

Индонезийский

items[].​virtual_prices[].​name.​lostring or null

Лаосский

items[].​virtual_prices[].​name.​mystring or null

Бирманский

items[].​virtual_prices[].​name.​phstring or null

Филиппинский

items[].​virtual_prices[].​name.​nestring or null

Непальский

items[].​virtual_prices[].​typestring(Bundles_vc-type)

Тип виртуальной валюты.

items[].​virtual_prices[].​description(two-letter (object or null)) or (five-letter (object or null))(description-localization-object)

Объект с локализованными описаниями товара. Принимает значения в одном из двух форматов: двухбуквенный код языка в нижнем регистре (например, en) или код локали из пяти символов (например, en-US). Оба формата допустимы при отправке запроса, но в ответе всегда используется код из двух символов. Если для одного языка указаны оба варианта (например, en и en-US), будет сохранено последнее переданное значение. Полный список поддерживаемых языков приведен в документации.

Any of:

Двухбуквенные строчные языковые коды.

items[].​virtual_prices[].​description.​enstring or null

Английский

items[].​virtual_prices[].​description.​arstring or null

Арабский

items[].​virtual_prices[].​description.​bgstring or null

Болгарский

items[].​virtual_prices[].​description.​cnstring or null

Китайский упрощенный

items[].​virtual_prices[].​description.​csstring or null

Чешский

items[].​virtual_prices[].​description.​destring or null

Немецкий

items[].​virtual_prices[].​description.​esstring or null

Испанский

items[].​virtual_prices[].​description.​frstring or null

Французский

items[].​virtual_prices[].​description.​hestring or null

Иврит

items[].​virtual_prices[].​description.​itstring or null

Итальянский

items[].​virtual_prices[].​description.​jastring or null

Японский

items[].​virtual_prices[].​description.​kostring or null

Корейский

items[].​virtual_prices[].​description.​plstring or null

Польский

items[].​virtual_prices[].​description.​ptstring or null

Португальский

items[].​virtual_prices[].​description.​rostring or null

Румынский

items[].​virtual_prices[].​description.​rustring or null

Русский

items[].​virtual_prices[].​description.​thstring or null

Тайский

items[].​virtual_prices[].​description.​trstring or null

Турецкий

items[].​virtual_prices[].​description.​twstring or null

Китайский традиционный

items[].​virtual_prices[].​description.​vistring or null

Вьетнамский

items[].​virtual_prices[].​description.​kmstring or null

Кхмерский

items[].​virtual_prices[].​description.​idstring or null

Индонезийский

items[].​virtual_prices[].​description.​lostring or null

Лаосский

items[].​virtual_prices[].​description.​mystring or null

Бирманский

items[].​virtual_prices[].​description.​phstring or null

Филиппинский

items[].​virtual_prices[].​description.​nestring or null

Непальский

items[].​virtual_prices[].​image_urlstring or null(Bundles_image_url)

URL-адрес изображения. Для корректного отображения и быстрой загрузки изображения в платежном интерфейсе проверьте требования к файлу и ссылке:

  • Поддерживаемые форматы: WebP (рекомендуется), PNG, JPG.
  • Размер файла: ≤ 50 КБ (для WebP) или ≤ 150 КБ (для PNG и JPG).
  • Размер изображения: 280 x 280 px.
  • Цветовое пространство: sRGB.
  • Протокол передачи данных: HTTPS с долгосрочным кэшированием версионированных URL-адресов.

items[].​virtual_prices[].​amountstring(Bundles_amount)^\d*\.?\d*$

Цена товара со скидкой.

items[].​virtual_prices[].​is_defaultboolean(Bundles_currency-is_default)

Является ли данная цена товара ценой по умолчанию.

items[].​media_listArray of Bundles_media_list (objects) or null
Any of:

Дополнительные ассеты бандла.

items[].​media_list[].​typestring

Тип медиа: image/video.

Перечисление"image""video"
Пример: "image"
items[].​media_list[].​urlstring

Ссылка на файл.

Пример: "https://cdn3.xsolla.com/img/misc/images/71ab1e12126f2103e1868076f0acb21a.jpg"
items[].​orderinteger(Bundles_order)

Приоритет заказа бандла в списке.

items[].​is_enabledboolean(Bundles_is_enabled)

Если этот параметр отключен, товар не может быть найден и приобретен.

items[].​is_show_in_storeboolean(Bundles_is_show_in_store)

Товар доступен для покупки.

items[].​regionsArray of objects(Bundles_admin-regions)
items[].​regions[].​idinteger>= 1
Пример: 1
items[].​contentArray of objects(Bundles_admin_content_response)
items[].​content[].​skustring(Bundles_sku)[ 1 .. 255 ] characters^[a-zA-Z0-9_\-–.]*$

Уникальный ID товара. Артикул может содержать только строчные и заглавные латинские буквы, цифры, точки, тире и подчеркивания.

items[].​content[].​name(two-letter (object or null)) or (five-letter (object or null))(name-localization-object)

Объект с локализованными названиями товара. Принимает значения в одном из двух форматов: двухбуквенный код языка в нижнем регистре (например, en) или код языка из пяти символов (например, en-US). Оба формата допустимы при отправке запроса, но в ответе всегда используется двухбуквенный код языка. Если для одного языка указаны оба варианта (например, en и en-US), будет сохранено последнее переданное значение. Полный список поддерживаемых языков приведен в документации.

Any of:

Двухбуквенные строчные языковые коды.

items[].​content[].​name.​enstring or null

Английский

items[].​content[].​name.​arstring or null

Арабский

items[].​content[].​name.​bgstring or null

Болгарский

items[].​content[].​name.​cnstring or null

Китайский упрощенный

items[].​content[].​name.​csstring or null

Чешский

items[].​content[].​name.​destring or null

Немецкий

items[].​content[].​name.​esstring or null

Испанский

items[].​content[].​name.​frstring or null

Французский

items[].​content[].​name.​hestring or null

Иврит

items[].​content[].​name.​itstring or null

Итальянский

items[].​content[].​name.​jastring or null

Японский

items[].​content[].​name.​kostring or null

Корейский

items[].​content[].​name.​plstring or null

Польский

items[].​content[].​name.​ptstring or null

Португальский

items[].​content[].​name.​rostring or null

Румынский

items[].​content[].​name.​rustring or null

Русский

items[].​content[].​name.​thstring or null

Тайский

items[].​content[].​name.​trstring or null

Турецкий

items[].​content[].​name.​twstring or null

Китайский традиционный

items[].​content[].​name.​vistring or null

Вьетнамский

items[].​content[].​name.​kmstring or null

Кхмерский

items[].​content[].​name.​idstring or null

Индонезийский

items[].​content[].​name.​lostring or null

Лаосский

items[].​content[].​name.​mystring or null

Бирманский

items[].​content[].​name.​phstring or null

Филиппинский

items[].​content[].​name.​nestring or null

Непальский

items[].​content[].​typestring(Bundles_type)

Тип товара.

items[].​content[].​description(two-letter (object or null)) or (five-letter (object or null))(description-localization-object)

Объект с локализованными описаниями товара. Принимает значения в одном из двух форматов: двухбуквенный код языка в нижнем регистре (например, en) или код локали из пяти символов (например, en-US). Оба формата допустимы при отправке запроса, но в ответе всегда используется код из двух символов. Если для одного языка указаны оба варианта (например, en и en-US), будет сохранено последнее переданное значение. Полный список поддерживаемых языков приведен в документации.

Any of:

Двухбуквенные строчные языковые коды.

items[].​content[].​description.​enstring or null

Английский

items[].​content[].​description.​arstring or null

Арабский

items[].​content[].​description.​bgstring or null

Болгарский

items[].​content[].​description.​cnstring or null

Китайский упрощенный

items[].​content[].​description.​csstring or null

Чешский

items[].​content[].​description.​destring or null

Немецкий

items[].​content[].​description.​esstring or null

Испанский

items[].​content[].​description.​frstring or null

Французский

items[].​content[].​description.​hestring or null

Иврит

items[].​content[].​description.​itstring or null

Итальянский

items[].​content[].​description.​jastring or null

Японский

items[].​content[].​description.​kostring or null

Корейский

items[].​content[].​description.​plstring or null

Польский

items[].​content[].​description.​ptstring or null

Португальский

items[].​content[].​description.​rostring or null

Румынский

items[].​content[].​description.​rustring or null

Русский

items[].​content[].​description.​thstring or null

Тайский

items[].​content[].​description.​trstring or null

Турецкий

items[].​content[].​description.​twstring or null

Китайский традиционный

items[].​content[].​description.​vistring or null

Вьетнамский

items[].​content[].​description.​kmstring or null

Кхмерский

items[].​content[].​description.​idstring or null

Индонезийский

items[].​content[].​description.​lostring or null

Лаосский

items[].​content[].​description.​mystring or null

Бирманский

items[].​content[].​description.​phstring or null

Филиппинский

items[].​content[].​description.​nestring or null

Непальский

items[].​content[].​image_urlstring or null(Bundles_image_url)

URL-адрес изображения. Для корректного отображения и быстрой загрузки изображения в платежном интерфейсе проверьте требования к файлу и ссылке:

  • Поддерживаемые форматы: WebP (рекомендуется), PNG, JPG.
  • Размер файла: ≤ 50 КБ (для WebP) или ≤ 150 КБ (для PNG и JPG).
  • Размер изображения: 280 x 280 px.
  • Цветовое пространство: sRGB.
  • Протокол передачи данных: HTTPS с долгосрочным кэшированием версионированных URL-адресов.

items[].​content[].​quantityinteger>= 1

Количество единиц товара данного типа в бандле.

По умолчанию 1
items[].​limitsobject or null(admin-item-limit-response)

Ограничения на продажу товара.

items[].​limits.​per_userobject or null

Ограничение количества товара для отдельного пользователя.

items[].​limits.​per_user.​totalinteger

Максимальное количество товара, которое может приобрести один пользователь.

items[].​limits.​per_user.​limit_exceeded_visibilitystring(limit_exceeded_visibility)

Определяет видимость товара в каталоге после достижения лимита покупок до момента следующего обновления лимитов.

Применяется к товарам, для которых задано регулярное обновление лимитов в массиве recurrent_schedule.

Если обновление лимитов не задано, товар не отображается в каталоге после достижения лимита независимо от значения limit_exceeded_visibility.

Возможные значения:

  • show — Товар возвращается в методах получения каталога товаров после достижения лимита покупок. В клиентских методах получения каталога после достижения лимита товар возвращается с флагом can_be_bought: false. Дата следующего сброса возвращается в reset_next_date.
  • hide — Товар не возвращается в методах получения каталога товаров после достижения лимита покупок до момента сброса лимитов.
Перечисление"show""hide"
items[].​limits.​per_itemobject or null

Глобальное ограничение товара.

items[].​limits.​per_item.​totalinteger

Максимальное количество товара, которое могут приобрести все пользователи.

items[].​limits.​per_item.​availableinteger

Оставшееся количество товара, которое могут приобрести все пользователи.

items[].​limits.​per_item.​reservedinteger
items[].​limits.​per_item.​soldinteger
items[].​limits.​recurrent_scheduleobject or null(admin_recurrent_schedule_response)

Период обновления установленный ограничений.

items[].​limits.​recurrent_schedule.​per_userinterval_type = daily (object) or interval_type = weekly (object) or interval_type = monthly (object) or interval_type = hourly (object)

Период обновления установленный ограничений для пользователя.

One of:

Ежедневное обновления пользовательских ограничений.

items[].​limits.​recurrent_schedule.​per_user.​interval_typestring

Recurrent refresh period type.

Значение"daily"
items[].​limits.​recurrent_schedule.​per_user.​timestring(full-time)

Время обновления ограничений в желаемом часовом поясе (округление до часов).

Пример: "11:00:00+03:00"
items[].​limits.​recurrent_schedule.​per_user.​reset_next_dateinteger

Date and time when limits refresh (Unix Timestamp).

Пример: 1677553200
items[].​limits.​recurrent_schedule.​per_user.​displayable_reset_start_datestring(date-time)

Date and time of the first limit refresh (ISO 8601).

Пример: "2023-02-28T11:00:00+08:00"
items[].​limits.​recurrent_schedule.​per_user.​displayable_reset_next_datestring(date-time)

Date and time when limits should reset (ISO 8601).

Пример: "2023-02-28T11:00:00+08:00"
items[].​periodsArray of objects(item-periods-response)

Период продажи товара.

items[].​periods[].​date_fromstring or null(date-time)

Дата, когда указанный товар будет доступен для продажи.

Пример: "2020-08-11T10:00:00+03:00"
items[].​periods[].​date_untilstring or null(date-time)

Дата, когда указанный товар станет недоступен для продажи. Может быть null.

Пример: "2020-08-11T20:00:00+03:00"
items[].​custom_attributesobject(json)(item-custom-attributes-response)

JSON-объект, содержащий атрибуты товара и их значения.

items[].​total_content_priceobject or null(Bundles_total_content_price)

Сумма цен содержимого бандла.

items[].​total_content_price.​amountstring

Сумма цен содержимого бандла со скидкой.

Пример: "100.99"
items[].​total_content_price.​amount_without_discountstring

Сумма цен содержимого бандла.

Пример: "100.99"
items[].​total_content_price.​currencystring(Bundles_currency)

Валюта, в которой указана цена товара. Трехбуквенный код в соответствии со стандартом ISO 4217.

Ответ
application/json
{ "items": [ {}, {} ] }

Создание бандлаServer-sideAdmin

Запрос

Creates a bundle — a set of items sold as a single unit. A bundle can contain virtual items, virtual currency packages, game keys, and other bundles. For more information, refer to the Bundles section.

Notice

All items in the content array must be created in your project in advance. The system returns an error if the specified SKU doesn't exist.
Безопасность
basicAuth
Путь
project_idintegerобязательный

ID проекта. Вы можете найти этот параметр в Личном кабинете рядом с названием проекта, а также в адресной строке браузера при работе с проектом. URL-адрес имеет следующий формат: https://publisher.xsolla.com/<merchant_id>/projects/<project_id>.

Пример: 44056
Телоapplication/jsonобязательный

Объект с данными бандла.

skustring(Bundles_sku)[ 1 .. 255 ] characters^[a-zA-Z0-9_\-–.]*$обязательный

Уникальный ID товара. Артикул может содержать только строчные и заглавные латинские буквы, цифры, точки, тире и подчеркивания.

name(two-letter (object or null)) or (five-letter (object or null))(name-localization-object)обязательный

Объект с локализованными названиями товара. Принимает значения в одном из двух форматов: двухбуквенный код языка в нижнем регистре (например, en) или код языка из пяти символов (например, en-US). Оба формата допустимы при отправке запроса, но в ответе всегда используется двухбуквенный код языка. Если для одного языка указаны оба варианта (например, en и en-US), будет сохранено последнее переданное значение. Полный список поддерживаемых языков приведен в документации.

Any of:

Двухбуквенные строчные языковые коды.

name.​enstring or null

Английский

name.​arstring or null

Арабский

name.​bgstring or null

Болгарский

name.​cnstring or null

Китайский упрощенный

name.​csstring or null

Чешский

name.​destring or null

Немецкий

name.​esstring or null

Испанский

name.​frstring or null

Французский

name.​hestring or null

Иврит

name.​itstring or null

Итальянский

name.​jastring or null

Японский

name.​kostring or null

Корейский

name.​plstring or null

Польский

name.​ptstring or null

Португальский

name.​rostring or null

Румынский

name.​rustring or null

Русский

name.​thstring or null

Тайский

name.​trstring or null

Турецкий

name.​twstring or null

Китайский традиционный

name.​vistring or null

Вьетнамский

name.​kmstring or null

Кхмерский

name.​idstring or null

Индонезийский

name.​lostring or null

Лаосский

name.​mystring or null

Бирманский

name.​phstring or null

Филиппинский

name.​nestring or null

Непальский

groupsArray of strings(Bundles_groups_request)

Группы, к которым принадлежит товар.

Примечание. Строковое значение относится к группе `external_id`.
attributesArray of objects(Bundles_admin-post-put-attributes)<= 20 items

Список атрибутов.

Внимание. Для товара невозможно указать более 20 атрибутов. Любые попытки превысить данное ограничение вызовут ошибку.
attributes[].​external_idstring(admin-attribute-external_id)[ 1 .. 255 ] characters^[a-zA-Z0-9-_]+$обязательный

Уникальный ID атрибута. external_id может содержать только строчные и заглавные латинские буквы, цифры, тире и подчеркивания.

attributes[].​nameobject(admin-attribute-name)

Объект с локализациями для названия атрибута. Ключи для обозначения стран указаны в стандарте ISO 3166-1.

attributes[].​name.​property name*stringдополнительное свойство
attributes[].​valuesArray of objects(attribute-value)обязательный
Внимание.Невозможно создать более 6 значений для каждого атрибута. Любые попытки превысить данное ограничение вызовут ошибку.
Пример: [{"external_id":"strategy","value":{"en":"Strategy","de":"Strategie"}},{"external_id":"action","value":{"en":"Action","de":"Aktion"}}]
attributes[].​values[].​external_idstring(value-external_id)[ 1 .. 255 ] characters^[-_.\d\w]+$обязательный

Уникальный ID значения атрибута. external_id может содержать только строчные латинские буквы, цифры, тире и подчеркивания.

Пример: "value_external_id"
attributes[].​values[].​valueobject(value-name)обязательный

Объект с локализациями для названия значения. Ключи для обозначения стран указаны в стандарте ISO 3166-1.

attributes[].​values[].​value.​property name*stringдополнительное свойство
description(two-letter (object or null)) or (five-letter (object or null))(description-localization-object)обязательный

Объект с локализованными описаниями товара. Принимает значения в одном из двух форматов: двухбуквенный код языка в нижнем регистре (например, en) или код локали из пяти символов (например, en-US). Оба формата допустимы при отправке запроса, но в ответе всегда используется код из двух символов. Если для одного языка указаны оба варианта (например, en и en-US), будет сохранено последнее переданное значение. Полный список поддерживаемых языков приведен в документации.

Any of:

Двухбуквенные строчные языковые коды.

description.​enstring or null

Английский

description.​arstring or null

Арабский

description.​bgstring or null

Болгарский

description.​cnstring or null

Китайский упрощенный

description.​csstring or null

Чешский

description.​destring or null

Немецкий

description.​esstring or null

Испанский

description.​frstring or null

Французский

description.​hestring or null

Иврит

description.​itstring or null

Итальянский

description.​jastring or null

Японский

description.​kostring or null

Корейский

description.​plstring or null

Польский

description.​ptstring or null

Португальский

description.​rostring or null

Румынский

description.​rustring or null

Русский

description.​thstring or null

Тайский

description.​trstring or null

Турецкий

description.​twstring or null

Китайский традиционный

description.​vistring or null

Вьетнамский

description.​kmstring or null

Кхмерский

description.​idstring or null

Индонезийский

description.​lostring or null

Лаосский

description.​mystring or null

Бирманский

description.​phstring or null

Филиппинский

description.​nestring or null

Непальский

long_description(two-letter (object or null)) or (five-letter (object or null))(long-description-localization-object)

Объект с локализованными длинными описаниями товара. Принимает значения в одном из двух форматов: двухбуквенный код языка в нижнем регистре (например, en) или код локали из пяти символов (например, en-US). Оба формата допустимы при отправке запроса, но в ответе всегда используется код из двух символов. Если для одного языка указаны оба варианта (например, en и en-US), будет сохранено последнее переданное значение. Полный список поддерживаемых языков приведен в документации.

Any of:

Двухбуквенные строчные языковые коды.

long_description.​enstring or null

Английский

long_description.​arstring or null

Арабский

long_description.​bgstring or null

Болгарский

long_description.​cnstring or null

Китайский упрощенный

long_description.​csstring or null

Чешский

long_description.​destring or null

Немецкий

long_description.​esstring or null

Испанский

long_description.​frstring or null

Французский

long_description.​hestring or null

Иврит

long_description.​itstring or null

Итальянский

long_description.​jastring or null

Японский

long_description.​kostring or null

Корейский

long_description.​plstring or null

Польский

long_description.​ptstring or null

Португальский

long_description.​rostring or null

Румынский

long_description.​rustring or null

Русский

long_description.​thstring or null

Тайский

long_description.​trstring or null

Турецкий

long_description.​twstring or null

Китайский традиционный

long_description.​vistring or null

Вьетнамский

long_description.​kmstring or null

Кхмерский

long_description.​idstring or null

Индонезийский

long_description.​lostring or null

Лаосский

long_description.​mystring or null

Бирманский

long_description.​phstring or null

Филиппинский

long_description.​nestring or null

Непальский

image_urlstring or null(Bundles_image_url)

URL-адрес изображения. Для корректного отображения и быстрой загрузки изображения в платежном интерфейсе проверьте требования к файлу и ссылке:

  • Поддерживаемые форматы: WebP (рекомендуется), PNG, JPG.
  • Размер файла: ≤ 50 КБ (для WebP) или ≤ 150 КБ (для PNG и JPG).
  • Размер изображения: 280 x 280 px.
  • Цветовое пространство: sRGB.
  • Протокол передачи данных: HTTPS с долгосрочным кэшированием версионированных URL-адресов.

pricesArray of objects(Bundles_prices)

Цены в реальных валютах.

prices[].​amountstring(Bundles_amount_without_discount)^\d*\.?\d*$обязательный

Цена товара.

prices[].​currencystring(Bundles_currency)обязательный

Валюта, в которой указана цена товара. Трехбуквенный код в соответствии со стандартом ISO 4217.

prices[].​is_defaultbooleanобязательный

Цена по умолчанию используется для построения каталога, если цена в валюте пользователя не указана.

prices[].​is_enabledbooleanобязательный

Цена включена.

prices[].​country_isostring or null

Страна, где доступна эта цена. Двухбуквенный код в соответствии с ISO 3166-1 alpha 2.

Пример: "US"
vc_pricesArray of Bundles_vc_prices (objects) or null
Any of:
vc_prices[].​skustring

Уникальный ID товара. Артикул может содержать только строчные и заглавные латинские буквы, цифры, точки, тире и подчеркивания.

Пример: "gold"
vc_prices[].​amountintegerобязательный
vc_prices[].​is_defaultbooleanобязательный
vc_prices[].​is_enabledbooleanобязательный
bundle_typestring(Bundles_bundle_type)

Тип бандла. Используйте standard, чтобы создать бандл с товарами и указать артикулы товаров, которые содержатся в бандле. Используйте partner_side_content, чтобы создать пустой бандл и добавить в него товары на своей стороне с помощью вебхука. Используется только для персонализации каталога товаров на стороне партнера.

Перечисление"standard""partner_side_content"
contentArray of objects(Bundles_admin_content_request)non-empty

Array of items included in the bundle. Each entry specifies the item SKU and quantity. All items must be created in your project in advance. The system returns an error if the specified SKU doesn't exist.

Пример: [{"sku":"com.xsolla.kg_1","quantity":1}]
content[].​skustring[ 1 .. 255 ] characters^[a-zA-Z0-9_\-–.]*$обязательный

SKU of an item to include in the bundle. The item must be created in your project in advance. The system returns an error if the specified SKU doesn't exist. Allowed characters: a–z, A–Z, 0–9, period (.), hyphen (-), underscore (_).

Пример: "com.xsolla.kg_1"
content[].​quantityinteger>= 1

Количество выбранных товаров в бандле.

По умолчанию 1
Пример: 1
is_freeboolean(value-is_free)

Является ли товар бесплатным.

is_paid_randomized_rewardboolean(value-is_paid_randomized_reward)

Является ли товар случайной платной наградой, например лутбоксом.

is_enabledboolean(Bundles_is_enabled)

Если этот параметр отключен, товар не может быть найден и приобретен.

is_show_in_storeboolean(Bundles_is_show_in_store)

Товар доступен для покупки.

media_listArray of Bundles_media_list (objects) or null
Any of:

Дополнительные ассеты бандла.

media_list[].​typestring

Тип медиа: image/video.

Перечисление"image""video"
Пример: "image"
media_list[].​urlstring

Ссылка на файл.

Пример: "https://cdn3.xsolla.com/img/misc/images/71ab1e12126f2103e1868076f0acb21a.jpg"
orderinteger(Bundles_order)

Приоритет заказа бандла в списке.

regionsArray of objects(Bundles_admin-regions)
regions[].​idinteger>= 1
Пример: 1
limitsobject(bundle-item-limit)

Ограничения на продажу товара.

limits.​per_userlimit_per_user (null) or limit_per_user (integer) or limit_per_user (object)(limit_per_user)

Ограничение количества товара для отдельного пользователя.

Any of:

Ограничение количества товара для отдельного пользователя.

null(limit_per_user)
limits.​per_iteminteger or null(limit_per_item)

Глобальное ограничение товара.

limits.​recurrent_scheduleobject or null(bundle_recurrent_schedule)

Период обновления установленный ограничений.

limits.​recurrent_schedule.​per_userinterval_type = daily (object) or interval_type = weekly (object) or interval_type = monthly (object) or interval_type = hourly (object)

Сброс лимитов на покупку товара, выполняемый через временной интервал, заданный в часах.

One of:

Сброс лимитов на покупку товара, выполняемый через временной интервал, заданный в часах.

limits.​recurrent_schedule.​per_user.​interval_typestringобязательный

Период обновления ограничений.

Значение"daily"
limits.​recurrent_schedule.​per_user.​timestring((0[0-9]|1[0-9]|2[0-3]):00:00)(\+|-)(0[0-9]|1...обязательный

Время обновления ограничений в желаемом часовом поясе (округление до часов).

Пример: "02:00:00+03:00"
periodsArray of objects or null(item-periods)

Период продажи товара.

periods[].​date_fromstring(date-time)

Дата, когда указанный товар будет доступен для продажи.

Пример: "2020-08-11T10:00:00+03:00"
periods[].​date_untilstring or null(date-time)

Дата, когда указанный товар станет недоступен для продажи. Может быть null.

Пример: "2020-08-11T20:00:00+03:00"
custom_attributesobject(json)(item-custom-attributes)<= 500 characters

JSON-объект, содержащий атрибуты товара и их значения. Атрибуты позволяют добавить дополнительную информацию к товарам. Например, указать уровень игрока, на котором ему станет доступен этот товар. Атрибуты дополняют внутреннюю логику игры и могут быть получены через GET-методы и вебхуки.

curl -i -X POST \
  -u <username>:<password> \
  https://store.xsolla.com/api/v2/project/44056/admin/items/bundle \
  -H 'Content-Type: application/json' \
  -d '{
    "sku": "com.xsolla.armour_chest_1",
    "name": {
      "en": "Chest of armour",
      "de": "Brustpanzer"
    },
    "is_enabled": true,
    "is_free": true,
    "is_paid_randomized_reward": true,
    "order": 1,
    "long_description": {
      "en": "Chest of armour for soldiers",
      "de": "Brustpanzer für Soldaten"
    },
    "description": {
      "en": "Chest of armour for soldiers",
      "de": "Brustpanzer für Soldaten"
    },
    "image_url": "https://picture.bundle-with-many-stuff.png",
    "media_list": [
      {
        "type": "image",
        "url": "https://test.com/image0"
      },
      {
        "type": "image",
        "url": "https://test.com/image1"
      }
    ],
    "groups": [
      "chests"
    ],
    "attributes": [
      {
        "external_id": "class",
        "name": {
          "en": "Class"
        },
        "values": [
          {
            "external_id": "soldier",
            "value": {
              "en": "Soldier"
            }
          },
          {
            "external_id": "officer",
            "value": {
              "en": "Officer"
            }
          }
        ]
      }
    ],
    "prices": [
      {
        "currency": "USD",
        "amount": "9.99",
        "is_default": true,
        "is_enabled": true
      },
      {
        "currency": "EUR",
        "amount": "9.99",
        "is_default": false,
        "is_enabled": true
      }
    ],
    "vc_prices": [],
    "content": [
      {
        "sku": "com.xsolla.iron_gloves_1",
        "quantity": 1
      },
      {
        "sku": "com.xsolla.iron_boots_1",
        "quantity": 1
      },
      {
        "sku": "com.xsolla.iron_shield_1",
        "quantity": 1
      },
      {
        "sku": "com.xsolla.iron_armour_1",
        "quantity": 1
      },
      {
        "sku": "com.xsolla.iron_helmet_1",
        "quantity": 1
      }
    ],
    "limits": {
      "per_user": null,
      "per_item": null
    },
    "periods": [
      {
        "date_from": "2020-08-11T10:00:00+03:00",
        "date_until": "2020-08-11T20:00:00+03:00"
      }
    ],
    "custom_attributes": {
      "type": "lootbox",
      "purchased": 0
    }
  }'

Ответы

Бандл успешно создан.

Телоapplication/json
skustring(Bundles_sku)[ 1 .. 255 ] characters^[a-zA-Z0-9_\-–.]*$

Уникальный ID товара. Артикул может содержать только строчные и заглавные латинские буквы, цифры, точки, тире и подчеркивания.

Ответ
application/json
{ "sku": "com.xsolla.kg_1" }

Получение списка бандлов по указанному ID группыServer-sideAdmin

Запрос

Получает список бандлов в рамках группы для администрирования.

Примечание

Не используйте данный метод для построения каталога магазина.
Безопасность
basicAuth
Путь
project_idintegerобязательный

ID проекта. Вы можете найти этот параметр в Личном кабинете рядом с названием проекта, а также в адресной строке браузера при работе с проектом. URL-адрес имеет следующий формат: https://publisher.xsolla.com/<merchant_id>/projects/<project_id>.

Пример: 44056
group_idintegerобязательный

ID группы.

Пример: 10
Запрос
limitinteger>= 1

Лимит количества элементов на странице.

Пример: limit=50
offsetinteger>= 0

Номер элемента, с которого выполняется вывод на странице (нумерация ведется с 0).

Пример: offset=0
curl -i -X GET \
  -u <username>:<password> \
  'https://store.xsolla.com/api/v2/project/44056/admin/items/bundle/group/id/10?limit=50&offset=0'

Ответы

Список бандлов успешно получен.

Телоapplication/json
itemsArray of objects(Bundles_admin_bundle_response)
items[].​item_idinteger(Bundles_item_id)[ 1 .. 255 ] characters

Внутренний уникальный ID виртуального предмета или валюты.

items[].​skustring(Bundles_sku)[ 1 .. 255 ] characters^[a-zA-Z0-9_\-–.]*$

Уникальный ID товара. Артикул может содержать только строчные и заглавные латинские буквы, цифры, точки, тире и подчеркивания.

items[].​name(two-letter (object or null)) or (five-letter (object or null))(name-localization-object)

Объект с локализованными названиями товара. Принимает значения в одном из двух форматов: двухбуквенный код языка в нижнем регистре (например, en) или код языка из пяти символов (например, en-US). Оба формата допустимы при отправке запроса, но в ответе всегда используется двухбуквенный код языка. Если для одного языка указаны оба варианта (например, en и en-US), будет сохранено последнее переданное значение. Полный список поддерживаемых языков приведен в документации.

Any of:

Двухбуквенные строчные языковые коды.

items[].​name.​enstring or null

Английский

items[].​name.​arstring or null

Арабский

items[].​name.​bgstring or null

Болгарский

items[].​name.​cnstring or null

Китайский упрощенный

items[].​name.​csstring or null

Чешский

items[].​name.​destring or null

Немецкий

items[].​name.​esstring or null

Испанский

items[].​name.​frstring or null

Французский

items[].​name.​hestring or null

Иврит

items[].​name.​itstring or null

Итальянский

items[].​name.​jastring or null

Японский

items[].​name.​kostring or null

Корейский

items[].​name.​plstring or null

Польский

items[].​name.​ptstring or null

Португальский

items[].​name.​rostring or null

Румынский

items[].​name.​rustring or null

Русский

items[].​name.​thstring or null

Тайский

items[].​name.​trstring or null

Турецкий

items[].​name.​twstring or null

Китайский традиционный

items[].​name.​vistring or null

Вьетнамский

items[].​name.​kmstring or null

Кхмерский

items[].​name.​idstring or null

Индонезийский

items[].​name.​lostring or null

Лаосский

items[].​name.​mystring or null

Бирманский

items[].​name.​phstring or null

Филиппинский

items[].​name.​nestring or null

Непальский

items[].​attributesArray of objects(Bundles_admin-attributes)

Список атрибутов.

Пример: [{"external_id":"attribute_external_id","name":{"en":"Attribute name","de":"Attributname"},"values":[{"external_id":"value_1","name":{"en":"value 1","de":"wert 1"}},{"external_id":"value_2","name":{"en":"value 2","de":"wert 2"}}]}]
items[].​attributes[].​external_idstring(admin-attribute-external_id)[ 1 .. 255 ] characters^[a-zA-Z0-9-_]+$обязательный

Уникальный ID атрибута. external_id может содержать только строчные и заглавные латинские буквы, цифры, тире и подчеркивания.

Пример: "attribute_external_id"
items[].​attributes[].​nameobject(admin-attribute-name)

Объект с локализациями для названия атрибута. Ключи для обозначения стран указаны в стандарте ISO 3166-1.

Пример: {"en":"Attribute name","de":"Attributname"}
items[].​attributes[].​name.​property name*stringдополнительное свойство
items[].​attributes[].​valuesArray of objects(attribute-value)обязательный
Пример: [{"external_id":"value_1","name":{"en":"value 1","de":"wert 1"}},{"external_id":"value_2","name":{"en":"value 2","de":"wert 2"}}]
items[].​attributes[].​values[].​external_idstring(value-external_id)[ 1 .. 255 ] characters^[-_.\d\w]+$обязательный

Уникальный ID значения атрибута. external_id может содержать только строчные латинские буквы, цифры, тире и подчеркивания.

Пример: "value_external_id"
items[].​attributes[].​values[].​valueobject(value-name)обязательный

Объект с локализациями для названия значения. Ключи для обозначения стран указаны в стандарте ISO 3166-1.

items[].​attributes[].​values[].​value.​property name*stringдополнительное свойство
items[].​typestring(Bundles_type)

Тип товара.

items[].​bundle_typestring(bundle_type)

Тип бандла. Возвращается, если тип элемента является бандлом.

Перечисление"standard""virtual_currency_package""partner_side_content"
items[].​description(two-letter (object or null)) or (five-letter (object or null))(description-localization-object)

Объект с локализованными описаниями товара. Принимает значения в одном из двух форматов: двухбуквенный код языка в нижнем регистре (например, en) или код локали из пяти символов (например, en-US). Оба формата допустимы при отправке запроса, но в ответе всегда используется код из двух символов. Если для одного языка указаны оба варианта (например, en и en-US), будет сохранено последнее переданное значение. Полный список поддерживаемых языков приведен в документации.

Any of:

Двухбуквенные строчные языковые коды.

items[].​description.​enstring or null

Английский

items[].​description.​arstring or null

Арабский

items[].​description.​bgstring or null

Болгарский

items[].​description.​cnstring or null

Китайский упрощенный

items[].​description.​csstring or null

Чешский

items[].​description.​destring or null

Немецкий

items[].​description.​esstring or null

Испанский

items[].​description.​frstring or null

Французский

items[].​description.​hestring or null

Иврит

items[].​description.​itstring or null

Итальянский

items[].​description.​jastring or null

Японский

items[].​description.​kostring or null

Корейский

items[].​description.​plstring or null

Польский

items[].​description.​ptstring or null

Португальский

items[].​description.​rostring or null

Румынский

items[].​description.​rustring or null

Русский

items[].​description.​thstring or null

Тайский

items[].​description.​trstring or null

Турецкий

items[].​description.​twstring or null

Китайский традиционный

items[].​description.​vistring or null

Вьетнамский

items[].​description.​kmstring or null

Кхмерский

items[].​description.​idstring or null

Индонезийский

items[].​description.​lostring or null

Лаосский

items[].​description.​mystring or null

Бирманский

items[].​description.​phstring or null

Филиппинский

items[].​description.​nestring or null

Непальский

items[].​long_description(two-letter (object or null)) or (five-letter (object or null))(long-description-localization-object)

Объект с локализованными длинными описаниями товара. Принимает значения в одном из двух форматов: двухбуквенный код языка в нижнем регистре (например, en) или код локали из пяти символов (например, en-US). Оба формата допустимы при отправке запроса, но в ответе всегда используется код из двух символов. Если для одного языка указаны оба варианта (например, en и en-US), будет сохранено последнее переданное значение. Полный список поддерживаемых языков приведен в документации.

Any of:

Двухбуквенные строчные языковые коды.

items[].​long_description.​enstring or null

Английский

items[].​long_description.​arstring or null

Арабский

items[].​long_description.​bgstring or null

Болгарский

items[].​long_description.​cnstring or null

Китайский упрощенный

items[].​long_description.​csstring or null

Чешский

items[].​long_description.​destring or null

Немецкий

items[].​long_description.​esstring or null

Испанский

items[].​long_description.​frstring or null

Французский

items[].​long_description.​hestring or null

Иврит

items[].​long_description.​itstring or null

Итальянский

items[].​long_description.​jastring or null

Японский

items[].​long_description.​kostring or null

Корейский

items[].​long_description.​plstring or null

Польский

items[].​long_description.​ptstring or null

Португальский

items[].​long_description.​rostring or null

Румынский

items[].​long_description.​rustring or null

Русский

items[].​long_description.​thstring or null

Тайский

items[].​long_description.​trstring or null

Турецкий

items[].​long_description.​twstring or null

Китайский традиционный

items[].​long_description.​vistring or null

Вьетнамский

items[].​long_description.​kmstring or null

Кхмерский

items[].​long_description.​idstring or null

Индонезийский

items[].​long_description.​lostring or null

Лаосский

items[].​long_description.​mystring or null

Бирманский

items[].​long_description.​phstring or null

Филиппинский

items[].​long_description.​nestring or null

Непальский

items[].​image_urlstring or null(Bundles_image_url)

URL-адрес изображения. Для корректного отображения и быстрой загрузки изображения в платежном интерфейсе проверьте требования к файлу и ссылке:

  • Поддерживаемые форматы: WebP (рекомендуется), PNG, JPG.
  • Размер файла: ≤ 50 КБ (для WebP) или ≤ 150 КБ (для PNG и JPG).
  • Размер изображения: 280 x 280 px.
  • Цветовое пространство: sRGB.
  • Протокол передачи данных: HTTPS с долгосрочным кэшированием версионированных URL-адресов.

items[].​is_freeboolean(value-is_free)

Является ли товар бесплатным.

items[].​is_paid_randomized_rewardboolean(value-is_paid_randomized_reward)

Является ли товар случайной платной наградой, например лутбоксом.

items[].​groupsArray of objects(Bundles_groups_response)

Группы, к которым принадлежит товар.

items[].​groups[].​external_idstring
Пример: "horror"
items[].​groups[].​nameobject

Название элемента. Должно содержать пары ключ/значение, где ключ — это языковой стандарт в {2}формате "^[a-z]", значение — строка.

По умолчанию {"en":"Horror"}
Пример: {"en":"Horror","de":"Horror"}
items[].​groups[].​name.​property name*stringдополнительное свойство
items[].​pricesArray of objects(Bundles_prices)

Цены в реальных валютах.

items[].​prices[].​amountstring(Bundles_amount_without_discount)^\d*\.?\d*$обязательный

Цена товара.

items[].​prices[].​currencystring(Bundles_currency)обязательный

Валюта, в которой указана цена товара. Трехбуквенный код в соответствии со стандартом ISO 4217.

items[].​prices[].​is_defaultbooleanобязательный

Цена по умолчанию используется для построения каталога, если цена в валюте пользователя не указана.

items[].​prices[].​is_enabledbooleanобязательный

Цена включена.

items[].​prices[].​country_isostring or null

Страна, где доступна эта цена. Двухбуквенный код в соответствии с ISO 3166-1 alpha 2.

Пример: "US"
items[].​virtual_pricesArray of objects(Bundles_admin-response-virtual_price)
items[].​virtual_prices[].​skustring(Bundles_sku)[ 1 .. 255 ] characters^[a-zA-Z0-9_\-–.]*$

Уникальный ID товара. Артикул может содержать только строчные и заглавные латинские буквы, цифры, точки, тире и подчеркивания.

items[].​virtual_prices[].​name(two-letter (object or null)) or (five-letter (object or null))(name-localization-object)

Объект с локализованными названиями товара. Принимает значения в одном из двух форматов: двухбуквенный код языка в нижнем регистре (например, en) или код языка из пяти символов (например, en-US). Оба формата допустимы при отправке запроса, но в ответе всегда используется двухбуквенный код языка. Если для одного языка указаны оба варианта (например, en и en-US), будет сохранено последнее переданное значение. Полный список поддерживаемых языков приведен в документации.

Any of:

Двухбуквенные строчные языковые коды.

items[].​virtual_prices[].​name.​enstring or null

Английский

items[].​virtual_prices[].​name.​arstring or null

Арабский

items[].​virtual_prices[].​name.​bgstring or null

Болгарский

items[].​virtual_prices[].​name.​cnstring or null

Китайский упрощенный

items[].​virtual_prices[].​name.​csstring or null

Чешский

items[].​virtual_prices[].​name.​destring or null

Немецкий

items[].​virtual_prices[].​name.​esstring or null

Испанский

items[].​virtual_prices[].​name.​frstring or null

Французский

items[].​virtual_prices[].​name.​hestring or null

Иврит

items[].​virtual_prices[].​name.​itstring or null

Итальянский

items[].​virtual_prices[].​name.​jastring or null

Японский

items[].​virtual_prices[].​name.​kostring or null

Корейский

items[].​virtual_prices[].​name.​plstring or null

Польский

items[].​virtual_prices[].​name.​ptstring or null

Португальский

items[].​virtual_prices[].​name.​rostring or null

Румынский

items[].​virtual_prices[].​name.​rustring or null

Русский

items[].​virtual_prices[].​name.​thstring or null

Тайский

items[].​virtual_prices[].​name.​trstring or null

Турецкий

items[].​virtual_prices[].​name.​twstring or null

Китайский традиционный

items[].​virtual_prices[].​name.​vistring or null

Вьетнамский

items[].​virtual_prices[].​name.​kmstring or null

Кхмерский

items[].​virtual_prices[].​name.​idstring or null

Индонезийский

items[].​virtual_prices[].​name.​lostring or null

Лаосский

items[].​virtual_prices[].​name.​mystring or null

Бирманский

items[].​virtual_prices[].​name.​phstring or null

Филиппинский

items[].​virtual_prices[].​name.​nestring or null

Непальский

items[].​virtual_prices[].​typestring(Bundles_vc-type)

Тип виртуальной валюты.

items[].​virtual_prices[].​description(two-letter (object or null)) or (five-letter (object or null))(description-localization-object)

Объект с локализованными описаниями товара. Принимает значения в одном из двух форматов: двухбуквенный код языка в нижнем регистре (например, en) или код локали из пяти символов (например, en-US). Оба формата допустимы при отправке запроса, но в ответе всегда используется код из двух символов. Если для одного языка указаны оба варианта (например, en и en-US), будет сохранено последнее переданное значение. Полный список поддерживаемых языков приведен в документации.

Any of:

Двухбуквенные строчные языковые коды.

items[].​virtual_prices[].​description.​enstring or null

Английский

items[].​virtual_prices[].​description.​arstring or null

Арабский

items[].​virtual_prices[].​description.​bgstring or null

Болгарский

items[].​virtual_prices[].​description.​cnstring or null

Китайский упрощенный

items[].​virtual_prices[].​description.​csstring or null

Чешский

items[].​virtual_prices[].​description.​destring or null

Немецкий

items[].​virtual_prices[].​description.​esstring or null

Испанский

items[].​virtual_prices[].​description.​frstring or null

Французский

items[].​virtual_prices[].​description.​hestring or null

Иврит

items[].​virtual_prices[].​description.​itstring or null

Итальянский

items[].​virtual_prices[].​description.​jastring or null

Японский

items[].​virtual_prices[].​description.​kostring or null

Корейский

items[].​virtual_prices[].​description.​plstring or null

Польский

items[].​virtual_prices[].​description.​ptstring or null

Португальский

items[].​virtual_prices[].​description.​rostring or null

Румынский

items[].​virtual_prices[].​description.​rustring or null

Русский

items[].​virtual_prices[].​description.​thstring or null

Тайский

items[].​virtual_prices[].​description.​trstring or null

Турецкий

items[].​virtual_prices[].​description.​twstring or null

Китайский традиционный

items[].​virtual_prices[].​description.​vistring or null

Вьетнамский

items[].​virtual_prices[].​description.​kmstring or null

Кхмерский

items[].​virtual_prices[].​description.​idstring or null

Индонезийский

items[].​virtual_prices[].​description.​lostring or null

Лаосский

items[].​virtual_prices[].​description.​mystring or null

Бирманский

items[].​virtual_prices[].​description.​phstring or null

Филиппинский

items[].​virtual_prices[].​description.​nestring or null

Непальский

items[].​virtual_prices[].​image_urlstring or null(Bundles_image_url)

URL-адрес изображения. Для корректного отображения и быстрой загрузки изображения в платежном интерфейсе проверьте требования к файлу и ссылке:

  • Поддерживаемые форматы: WebP (рекомендуется), PNG, JPG.
  • Размер файла: ≤ 50 КБ (для WebP) или ≤ 150 КБ (для PNG и JPG).
  • Размер изображения: 280 x 280 px.
  • Цветовое пространство: sRGB.
  • Протокол передачи данных: HTTPS с долгосрочным кэшированием версионированных URL-адресов.

items[].​virtual_prices[].​amountstring(Bundles_amount)^\d*\.?\d*$

Цена товара со скидкой.

items[].​virtual_prices[].​is_defaultboolean(Bundles_currency-is_default)

Является ли данная цена товара ценой по умолчанию.

items[].​media_listArray of Bundles_media_list (objects) or null
Any of:

Дополнительные ассеты бандла.

items[].​media_list[].​typestring

Тип медиа: image/video.

Перечисление"image""video"
Пример: "image"
items[].​media_list[].​urlstring

Ссылка на файл.

Пример: "https://cdn3.xsolla.com/img/misc/images/71ab1e12126f2103e1868076f0acb21a.jpg"
items[].​orderinteger(Bundles_order)

Приоритет заказа бандла в списке.

items[].​is_enabledboolean(Bundles_is_enabled)

Если этот параметр отключен, товар не может быть найден и приобретен.

items[].​is_show_in_storeboolean(Bundles_is_show_in_store)

Товар доступен для покупки.

items[].​regionsArray of objects(Bundles_admin-regions)
items[].​regions[].​idinteger>= 1
Пример: 1
items[].​contentArray of objects(Bundles_admin_content_response)
items[].​content[].​skustring(Bundles_sku)[ 1 .. 255 ] characters^[a-zA-Z0-9_\-–.]*$

Уникальный ID товара. Артикул может содержать только строчные и заглавные латинские буквы, цифры, точки, тире и подчеркивания.

items[].​content[].​name(two-letter (object or null)) or (five-letter (object or null))(name-localization-object)

Объект с локализованными названиями товара. Принимает значения в одном из двух форматов: двухбуквенный код языка в нижнем регистре (например, en) или код языка из пяти символов (например, en-US). Оба формата допустимы при отправке запроса, но в ответе всегда используется двухбуквенный код языка. Если для одного языка указаны оба варианта (например, en и en-US), будет сохранено последнее переданное значение. Полный список поддерживаемых языков приведен в документации.

Any of:

Двухбуквенные строчные языковые коды.

items[].​content[].​name.​enstring or null

Английский

items[].​content[].​name.​arstring or null

Арабский

items[].​content[].​name.​bgstring or null

Болгарский

items[].​content[].​name.​cnstring or null

Китайский упрощенный

items[].​content[].​name.​csstring or null

Чешский

items[].​content[].​name.​destring or null

Немецкий

items[].​content[].​name.​esstring or null

Испанский

items[].​content[].​name.​frstring or null

Французский

items[].​content[].​name.​hestring or null

Иврит

items[].​content[].​name.​itstring or null

Итальянский

items[].​content[].​name.​jastring or null

Японский

items[].​content[].​name.​kostring or null

Корейский

items[].​content[].​name.​plstring or null

Польский

items[].​content[].​name.​ptstring or null

Португальский

items[].​content[].​name.​rostring or null

Румынский

items[].​content[].​name.​rustring or null

Русский

items[].​content[].​name.​thstring or null

Тайский

items[].​content[].​name.​trstring or null

Турецкий

items[].​content[].​name.​twstring or null

Китайский традиционный

items[].​content[].​name.​vistring or null

Вьетнамский

items[].​content[].​name.​kmstring or null

Кхмерский

items[].​content[].​name.​idstring or null

Индонезийский

items[].​content[].​name.​lostring or null

Лаосский

items[].​content[].​name.​mystring or null

Бирманский

items[].​content[].​name.​phstring or null

Филиппинский

items[].​content[].​name.​nestring or null

Непальский

items[].​content[].​typestring(Bundles_type)

Тип товара.

items[].​content[].​description(two-letter (object or null)) or (five-letter (object or null))(description-localization-object)

Объект с локализованными описаниями товара. Принимает значения в одном из двух форматов: двухбуквенный код языка в нижнем регистре (например, en) или код локали из пяти символов (например, en-US). Оба формата допустимы при отправке запроса, но в ответе всегда используется код из двух символов. Если для одного языка указаны оба варианта (например, en и en-US), будет сохранено последнее переданное значение. Полный список поддерживаемых языков приведен в документации.

Any of:

Двухбуквенные строчные языковые коды.

items[].​content[].​description.​enstring or null

Английский

items[].​content[].​description.​arstring or null

Арабский

items[].​content[].​description.​bgstring or null

Болгарский

items[].​content[].​description.​cnstring or null

Китайский упрощенный

items[].​content[].​description.​csstring or null

Чешский

items[].​content[].​description.​destring or null

Немецкий

items[].​content[].​description.​esstring or null

Испанский

items[].​content[].​description.​frstring or null

Французский

items[].​content[].​description.​hestring or null

Иврит

items[].​content[].​description.​itstring or null

Итальянский

items[].​content[].​description.​jastring or null

Японский

items[].​content[].​description.​kostring or null

Корейский

items[].​content[].​description.​plstring or null

Польский

items[].​content[].​description.​ptstring or null

Португальский

items[].​content[].​description.​rostring or null

Румынский

items[].​content[].​description.​rustring or null

Русский

items[].​content[].​description.​thstring or null

Тайский

items[].​content[].​description.​trstring or null

Турецкий

items[].​content[].​description.​twstring or null

Китайский традиционный

items[].​content[].​description.​vistring or null

Вьетнамский

items[].​content[].​description.​kmstring or null

Кхмерский

items[].​content[].​description.​idstring or null

Индонезийский

items[].​content[].​description.​lostring or null

Лаосский

items[].​content[].​description.​mystring or null

Бирманский

items[].​content[].​description.​phstring or null

Филиппинский

items[].​content[].​description.​nestring or null

Непальский

items[].​content[].​image_urlstring or null(Bundles_image_url)

URL-адрес изображения. Для корректного отображения и быстрой загрузки изображения в платежном интерфейсе проверьте требования к файлу и ссылке:

  • Поддерживаемые форматы: WebP (рекомендуется), PNG, JPG.
  • Размер файла: ≤ 50 КБ (для WebP) или ≤ 150 КБ (для PNG и JPG).
  • Размер изображения: 280 x 280 px.
  • Цветовое пространство: sRGB.
  • Протокол передачи данных: HTTPS с долгосрочным кэшированием версионированных URL-адресов.

items[].​content[].​quantityinteger>= 1

Количество единиц товара данного типа в бандле.

По умолчанию 1
items[].​limitsobject or null(admin-item-limit-response)

Ограничения на продажу товара.

items[].​limits.​per_userobject or null

Ограничение количества товара для отдельного пользователя.

items[].​limits.​per_user.​totalinteger

Максимальное количество товара, которое может приобрести один пользователь.

items[].​limits.​per_user.​limit_exceeded_visibilitystring(limit_exceeded_visibility)

Определяет видимость товара в каталоге после достижения лимита покупок до момента следующего обновления лимитов.

Применяется к товарам, для которых задано регулярное обновление лимитов в массиве recurrent_schedule.

Если обновление лимитов не задано, товар не отображается в каталоге после достижения лимита независимо от значения limit_exceeded_visibility.

Возможные значения:

  • show — Товар возвращается в методах получения каталога товаров после достижения лимита покупок. В клиентских методах получения каталога после достижения лимита товар возвращается с флагом can_be_bought: false. Дата следующего сброса возвращается в reset_next_date.
  • hide — Товар не возвращается в методах получения каталога товаров после достижения лимита покупок до момента сброса лимитов.
Перечисление"show""hide"
items[].​limits.​per_itemobject or null

Глобальное ограничение товара.

items[].​limits.​per_item.​totalinteger

Максимальное количество товара, которое могут приобрести все пользователи.

items[].​limits.​per_item.​availableinteger

Оставшееся количество товара, которое могут приобрести все пользователи.

items[].​limits.​per_item.​reservedinteger
items[].​limits.​per_item.​soldinteger
items[].​limits.​recurrent_scheduleobject or null(admin_recurrent_schedule_response)

Период обновления установленный ограничений.

items[].​limits.​recurrent_schedule.​per_userinterval_type = daily (object) or interval_type = weekly (object) or interval_type = monthly (object) or interval_type = hourly (object)

Период обновления установленный ограничений для пользователя.

One of:

Ежедневное обновления пользовательских ограничений.

items[].​limits.​recurrent_schedule.​per_user.​interval_typestring

Recurrent refresh period type.

Значение"daily"
items[].​limits.​recurrent_schedule.​per_user.​timestring(full-time)

Время обновления ограничений в желаемом часовом поясе (округление до часов).

Пример: "11:00:00+03:00"
items[].​limits.​recurrent_schedule.​per_user.​reset_next_dateinteger

Date and time when limits refresh (Unix Timestamp).

Пример: 1677553200
items[].​limits.​recurrent_schedule.​per_user.​displayable_reset_start_datestring(date-time)

Date and time of the first limit refresh (ISO 8601).

Пример: "2023-02-28T11:00:00+08:00"
items[].​limits.​recurrent_schedule.​per_user.​displayable_reset_next_datestring(date-time)

Date and time when limits should reset (ISO 8601).

Пример: "2023-02-28T11:00:00+08:00"
items[].​periodsArray of objects(item-periods-response)

Период продажи товара.

items[].​periods[].​date_fromstring or null(date-time)

Дата, когда указанный товар будет доступен для продажи.

Пример: "2020-08-11T10:00:00+03:00"
items[].​periods[].​date_untilstring or null(date-time)

Дата, когда указанный товар станет недоступен для продажи. Может быть null.

Пример: "2020-08-11T20:00:00+03:00"
items[].​custom_attributesobject(json)(item-custom-attributes-response)

JSON-объект, содержащий атрибуты товара и их значения.

items[].​total_content_priceobject or null(Bundles_total_content_price)

Сумма цен содержимого бандла.

items[].​total_content_price.​amountstring

Сумма цен содержимого бандла со скидкой.

Пример: "100.99"
items[].​total_content_price.​amount_without_discountstring

Сумма цен содержимого бандла.

Пример: "100.99"
items[].​total_content_price.​currencystring(Bundles_currency)

Валюта, в которой указана цена товара. Трехбуквенный код в соответствии со стандартом ISO 4217.

Ответ
application/json
{ "items": [ {}, {} ] }
Операции

Основная информация

Корзина — это механизм покупки, который позволяет объединять несколько товаров в одном заказе. Пользователь может купить товары любого типа в любом количестве за реальную валюту, а также использовать промокоды.

Корзина привязана к конкретному пользователю и хранится на стороне Xsolla. Вы можете идентифицировать корзину двумя способами: автоматически по JWT пользователя или по ID корзины (cart_id).

Управление корзиной доступно как на стороне клиента, так и на стороне сервера.

На стороне сервера вы можете наполнить корзину товарами, например при восстановлении сессии пользователя. На стороне клиента доступны следующие действия:

  • получить корзину текущего пользователя или по ID корзины;
  • наполнить корзину;
  • обновить товары в корзине;
  • удалить товары из корзины.

Для оплаты товаров из корзины используются клиентские и серверные методы создания заказа.

Сценарий использования корзины:

  1. Реализуйте интерфейс магазина, в котором пользователь будет выбирать товары.
  2. Когда пользователь выбирает товары в магазине, добавьте их в корзину, например с помощью метода Наполнение корзины товарами. В массиве items необходимо передать артикулы и количество необходимых товаров.
  3. Реализуйте интерфейс просмотра корзины. При переходе пользователя в корзину отобразите ее содержимое с помощью метода Получение корзины текущего пользователя. В ответе отобразится информация об итоговой цене товаров с учетом скидок, а также примененных акциях.
  4. Реализуйте открытие платежного интерфейса для оплаты заказа. Например, вы можете вызвать метод Создание заказа со всеми товарами из определенной корзины. В ответе вы получите токен для открытия платежного интерфейса.
  5. Настройте отслеживание статуса заказа, например с помощью вебхуков, чтобы своевременно получать данные об успешно оплаченных товарах и начислять их пользователю.

Примечание

Подробная информация о настройке продажи товаров в игре и онлайн приведена в руководстве по интеграции.

Сценарий использования корзины

Жизненный цикл заказа

Понимание жизненного цикла заказа поможет вам при настройке его отслеживания, например, чтобы начислить товары пользователю после успешной оплаты.

Заказ переходит по следующим статусам:

СтатусОписаниеПримечание
newЗаказ создан. Система ожидает подтверждение оплаты.Описания статусов транзакций приведены в документации Pay Station API.
paidЗаказ оплачен (транзакция перешла в статус done), и товар может быть начислен пользователю. Пока заказ не оплачен, он находится в статусе new.
doneТовар из заказа начислен пользователю.
canceledПользователь оформил возврат платежа. Заказ переходит в этот статус, когда статус транзакции меняется на refunded.
expired Если новый заказ включает в себя товар, промокод или акцию, на которые настроены ограничения, предыдущий неоплаченный заказ с этим же товаром переходит в статус expired. Пользователь может оплатить только последний созданный заказ. Если пользователь пытается оплатить заказ, который находится в этом статусе, в платежном интерфейсе он увидит ошибку 2002 и не сможет совершить платеж.

Жизненный цикл заказа

Примечание

Если в процессе оплаты заказ перешел в статус expired, но пользователь успешно завершил платеж, заказ переходит из статуса expired в paid. Это возможно только если при оплате такого заказа не будет превышен лимит на покупку товара.

Корзина (на стороне клиента)

Используйте методы из этого подраздела для управления корзиной на стороне клиента.

Операции

Корзина (на стороне сервера)

Используйте методы из этого подраздела для управления корзиной на стороне сервера.

Операции

Оплата (на стороне клиента)

Используйте методы из этого подраздела для формирования платежного токена на стороне клиента.

Операции

Оплата (на стороне сервера)

Используйте методы из этого подраздела для формирования платежного токена на стороне сервера.

Операции

Заказ

Используйте методы из этого раздела для получения информации о заказах.

Операции

Бесплатные товары

Используйте методы из этого подраздела для начисления бесплатных товаров пользователям.

Операции

Основная информация

Лимиты на покупку ограничивают количество товаров, доступных одному пользователю или всем пользователям. Вы также можете задавать периоды автоматического обновления лимитов.

Лимиты хранятся на стороне Xsolla и задаются на уровне конкретного товара в Личном кабинете или через объект limits в следующих методах API:

Информация о лимитах возвращается в объекте items.limits в методах получения каталога товаров:

Методы подраздела Управление из группы методов Лимиты позволяют получать информацию о текущем состоянии лимитов и изменять их для конкретного пользователя — например, сбрасывать счетчик после выполнения квеста или корректировать остаток вручную.

Примечание

Подробная информация по настройке лимитов в каталоге приведена в разделе Лимиты на покупку товаров.
Операции
Операции
Операции
Операции

Catalog

Данный API позволяет получать продаваемые товары любого вида или конкретный товар.

Операции
Операции
Операции
Операции
Операции