Рекуррентные платежи

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

Важно

Рекуррентные платежи не поддерживают способ оплаты Сплит.

Как это работает?

Примечание

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

Чтобы подключить и настроить рекуррентные платежи, обратитесь в поддержку.

Этап 1. Оформление подписки

Схема

image.png

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

    • период в единицах измерения времени и их количество;
    • сумма следующих списаний;
    • наличие пробного периода (триала): до конкретной даты или период с единицей измерения.
  2. Разместите кнопку оплаты Яндекс Пэй согласно общим рекомендациям. Нажатие на кнопку вызывает сallback на фронтенде партнера.

  3. Настройте фронтенд магазина так, чтобы после нажатия кнопки оплаты Яндекс Пэй он создавал заказ на бэкенде магазина.

  4. Настройте бэкенд магазина так, чтобы при выборе варианта подписки он передавал заказ в бэкенд Яндекс Пэй методом /subscriptions. В запросе должны быть параметры:

    Параметр и значение

    Описание

    is_binding: false

    Позволяет передавать данные о корзине и условиях подписки

    currencyCode: RUB

    Трехбуквенный код валюты заказа

    orderId

    Уникальный идентификатор заказа, будет использоваться в дальнейшем для списания средств

    redirectUrls

    Ссылки для переадресации пользователя с формы оплаты. Обязательно для онлайн-магазинов

    cart

    Данные корзины

    intervalCount

    Периодичность подписки

    intervalUnit

    Единица времени для периодичности подписки

    futureWriteOffAmount

    Сумма, которая будет списываться в будущем

    trialUnit и trialCount

    Пробный период, если есть (в единицах измерения времени и их количество)

    trialEndAt

    Дата окончания пробного периода, если есть

    Полный список параметров и значений см. в Документации бэкенда.

  5. В ответ бэкенд Яндекс Пэй вернет в поле paymentUrl ссылку на форму оплаты Яндекс Пэй. Настройте передачу этой ссылки на фронтенд магазина.

  6. Настройте фронтенд магазина так, чтобы он транслировал полученную ссылку на оплату в SDK Яндекс Пэй.

  7. SDK Яндекс Пэй загружает с бэкенда Яндекс Пэй информацию о корзине товаров и отображает покупателю форму оплаты с информацией о корзине товаров и условиями подписки.

    • для Web SDK: происходит перенаправление на полученную ссылку для оплаты;
    • для Mobile SDK: открывается формы для оплаты.
  8. Покупатель приступает к оплате:

    1. Открывает ссылку на оплату.

    2. Авторизуется с Яндекс ID, если не был авторизован ранее.

    3. Выбирает способ оплаты и нажимает кнопку оплаты (в случае полной оплаты с кешбэком выбирает сохраненную в Яндексе карту или СБП-привязку к счету).

    4. При покупке товара или услуги с пробным периодом проходит процедуру привязки карты и подтверждает списание тестовой суммы (11 рублей) для проверки 3ds. Сумма (11 рублей) будет возращена после прохождения проверки.

  9. Яндекс Пэй проводит платеж, списывая денежные средства с выбранной карты покупателя.

    Если оплата прошла успешно, заказ перейдет в статус CAPTURED. Отслеживать статус заказа можно через:

    Уведомления

    Для оповещения об изменениях статуса заказа или операции настройте обратный вызов (/webhook) от бэкенда Яндекс Пэй:

    1. Укажите публично доступный HTTPS URL-адрес бэкенда магазина в поле Callback URL в личном кабинете Яндекс Пэй в разделе Настройки.
    2. Настройте бэкенд магазина таким образом, чтобы он принимал запросы от бэкенда Яндекс Пэй. Подробнее о требованиях читайте в документации Merchant API.
    Поллинг статуса заказа

    Настройте регулярную отправку запросов о статусе заказа /orders/{order_id} к бэкенду Яндекс Пэй.

    Возможные статусы заказа при проведении оплаты:

    PENDING

    Оплата в процессе

    CAPTURED

    Оплачен

    FAILED

    Оплата не прошла. В этом случае в поле reason будет указана причина ошибки

  10. Деньги за покупку поступят на следующие сутки.

    Примечание

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

Этап 2. Списание средств продавцом

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

Для списания средств настройте бэкенд магазина так, чтобы после формирования корзины товаров он вызывал метод /subscriptions/recur и передавал в поле parentOrderId значение orderId, заданное ранее при привязке карты.

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

Отслеживать статус заказа можно через:

Уведомления

Для оповещения об изменениях статуса заказа или операции настройте обратный вызов (/webhook) от бэкенда Яндекс Пэй:

  1. Укажите публично доступный HTTPS URL-адрес бэкенда магазина в поле Callback URL в личном кабинете Яндекс Пэй в разделе Настройки.
  2. Настройте бэкенд магазина таким образом, чтобы он принимал запросы от бэкенда Яндекс Пэй. Подробнее о требованиях читайте в документации Merchant API.
Поллинг статуса заказа

Настройте регулярную отправку запросов о статусе заказа /orders/{order_id} к бэкенду Яндекс Пэй.

Возможные статусы заказа при проведении оплаты:

PENDING

Оплата в процессе

CAPTURED

Оплачен

FAILED

Оплата не прошла. В этом случае в поле reason будет указана причина ошибки

Проверка привязки карты

Чтобы проверить, привязана ли карта к аккаунту в магазине или сервису, используйте метод /subscriptions/{customer_subscription_id}. В запросе передайте параметры:

  • subscriptionId — идентификатор подписки, полученный при привязке карты в ответе на запрос /merchant_v1_subscriptions;
  • check_card_active: true — чтобы проверить привязку карты.

Если в ответе вернулся параметр is_card_active: null, то привязанных карт нет.

Возврат средств

Провести возврат можно двумя способами:

  • в личном кабинете в разделе Платежи;
  • при помощи запросов к API.

Статусы, которые мы высылаем в интеграции

Примечание

Статусы AUTHORIZED, VOIDED и CONFIRMED в текущей интеграции не используются.

Статусы при проведении оплаты:

PENDING

Оплата еще в процессе, нужно запросить статус платежа позже. Не отправляется в нотификации.

FAILED

Оплата завершилась неудачно. Терминальный неуспешный статус.

CAPTURED

Оплата совершена. Терминальный успешный статус.

Статусы при проведении возврата:

FAILED

Процедура возврата неуспешна. Терминальный неуспешный статус.

REFUNDED

Возврат совершен. Терминальный успешный статус.

PARTIALLY_REFUNDED

Частичный возврат совершен. Терминальный успешный статус.

Сценарии тестирования механики

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

Если вы настроили интеграцию по API Яндекс Пэй, в ходе тестирования рекомендуем использовать тестовые сценарии:

Сценарий

Действия

Ожидаемый результат

Среда

Успешная оплата подписки. Callback URL задан в ЛК

  1. Задайте Callback URL в ЛК.
  2. Проведите оплату через сервис Пэй.
  3. Проверьте изменение статуса в CRM на успешный на основании webhook.
  1. Получен webhook с статусом заказа CAPTURED.
  2. На основании полученного из Яндекс статуса на стороне продавца сформирован чек продажи и передан клиенту и в ФНС.

Test

Успешная оплата подписки. Callback URL не задан в ЛК

  1. Не задавайте Callback URL в ЛК.
  2. Проведите оплату через сервис Пэй.
  3. Проверьте изменение статуса в CRM на успешный на основании опроса статуса.
  1. В методе orders/{order_id} получен статус заказа CAPTURED. Webhook не отправляется.
  2. На основании полученного из Яндекс статуса на стороне продавца сформирован чек продажи и передан клиенту и в ФНС.

Test

Частичный возврат подписки через API

  1. Проведите оплату через сервис Пэй.
  2. В кассовом ПО или CRM выберите несколько товаров к возврату и осуществите его.

  3. В Яндекс вызовите метод v2/orders/{order_id}/refund.

  1. Частичный возврат осуществлен и получен статус заказа PARTIALLY_REFUNDED в webhook или на метод orders/{order_id}.
  2. На основании полученного из Яндекс статуса на стороне продавца сформирован чек возврата и передан клиенту и в ФНС.

Test, Prod

Полный возврат подписки через API

  1. Проведите оплату через сервис Пэй.
  2. В кассовом ПО или CRM выберите весь чек к возврату и осуществите его.

  3. В Яндекс вызовите метод v2/orders/{order_id}/refund.

  1. Полный возврат осуществлен и получен статус заказа REFUNDED в webhook или на метод orders/{order_id}.
  2. На основании полученного из Яндекс статуса на стороне продавца сформирован чек возврата и передан клиенту и в ФНС.

Test, Prod

Успешное продление подписки

  1. По ранее созданному заказу продлите подписку методом subscriptions/recur.
  2. Проверьте изменение статуса в CRM на успешный на основании webhook или опроса статуса orders/{order_id}.
  1. В методе orders/{order_id} или в webhook получен статус заказа CAPTURED.
  2. На основании полученного из Яндекс статуса на стороне продавца сформирован чек продажи и передан клиенту и в ФНС.

Test, Prod

Недостаточно средств при продлении подписки

  1. По ранее созданному заказу продлите подписку методом subscriptions/recur при этом сумма заказа должна быть 10 002 рубля и выбрана карта МИР.
  2. Проверить изменение статус в CRM на ошибку на основании webhook или опроса статуса orders/{order_id}.
  1. В методе orders/{order_id} или в webhook получен статус заказа FAILED.
  2. В поле reason отражен комментарий, что недостаточно денежных средств.

Test

Частичный возврат продления подписки через API

  1. По ранее созданному заказу сделать продление подписки методом subscriptions/recur.
  2. В кассовом ПО или CRM выберите несколько товаров к возврату и осуществите его.

  3. В Яндекс вызовите метод v2/orders/{order_id}/refund.

  1. Частичный возврат осуществлен и получен статус заказа PARTIALLY_REFUNDED в webhook или на метод orders/{order_id}.
  2. На основании полученного из Яндекс статуса на стороне продавца сформирован чек возврата и передан клиенту и в ФНС.

Test, Prod

Полный возврат продления подписки через API

  1. По ранее созданному заказу сделать продление подписки методом subscriptions/recur.
  2. В кассовом ПО или CRM выберите весь чек к возврату и осуществите его.

  3. В Яндекс вызовите метод v2/orders/{order_id}/refund.

  1. Полный возврат осуществлен и получен статус заказа REFUNDED в webhook или на метод orders/{order_id}.
  2. На основании полученного из Яндекс статуса на стороне продавца сформирован чек возврата и передан клиенту и в ФНС.

Prod

Частичный возврат любого способа оплаты через ЛК (опционально: если не используется API)

  1. Проведите оплату через сервис Пэй.
  2. В ЛК Яндекс Пэй найдите платеж и сделайте частичный возврат товаров.
  1. Частичный возврат осуществлен и получен статус заказа PARTIALLY_REFUNDED в webhook или на метод orders/{order_id}.
  2. На основании полученного из Яндекс статуса на стороне продавца сформирован чек возврата и передан клиенту и в ФНС.

Prod

Полный возврат любого способа оплаты через ЛК (опционально: если не используется API)

  1. Проведите оплату через сервис Пэй.
  2. В ЛК Яндекс Пэй найдите платеж и сделайте полный возврат товаров.
  1. Полный возврат осуществлен и получен статус заказа REFUNDED в webhook или на метод orders/{order_id}.
  2. На основании полученного из Яндекс статуса на стороне продавца сформирован чек возврата и передан клиенту и в ФНС.

Prod

Успешная оплата СБП

  1. Проведите оплату через сервис Пэй с использованием СБП.
  2. Проверьте изменение статуса в CRM на успешный на основании опроса статуса.
  1. По факту оплаты от Яндекс пришел webhook или на опрос статуса orders/{order_id} получен статус CAPTURED.
  2. На основании полученного из Яндекс статуса на стороне продавца сформирован чек продажи и передан клиенту и в ФНС.

Prod

Успешная оплата банковской картой

  1. Проведите оплату через сервис Пэй с использованием банковской карты.
  2. Проверьте изменение статуса в CRM на успешный на основании опроса статуса.
  1. По факту оплаты от Яндекс пришел webhook или на опрос статуса orders/{order_id} получен статус CAPTURED.
  2. На основании полученного из Яндекс статуса на стороне продавца сформирован чек продажи и передан клиенту и в ФНС.

Prod

Проверка ежедневного отчета о продажах

Оставьте без возврата успешные продажи на сумму не менее 500 рублей.

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

Prod