Инициализация оплаты по QR-коду (C2B2_V2)
Данный сценарий описывает инициализацию проведения оплаты за товар/услугу посредством сканирования QR-кода в POS-терминале или посредством статического QR-кода.
В рамках данного сценария клиенту предоставляется возможность QR-оплаты из приложения одного банка (банка отправителя денег) через POS-терминал или статический QR-код другого банка (банка бенефициара).
Важно! Если отсканированный QR-код выпущен самим Банком отправителя денег, то оплата производится внутри Банка отправителя денег без взаимодействия с Платформой. Т.е. если счет бенефициара, указанный в QR-коде, также обслуживается в данном банке, то производится внутрибанковская операция.
Методы API (endpoint), которые необходимо реализовать
При реализации участниками информационного взаимодействия данные API должны быть идемпотентны (получив повторный запрос с теми же параметрами, должен выдаваться в ответе результат исходного запроса).
Схему успешного сценария процесса «Инициализация оплаты по QR-коду (C2B2_V2)» отображает рисунок ниже.
Примечание: На схеме темно-зелеными квадратами отображены методы (endpoint), которые должны быть реализованы на стороне соответствующего участника для реализации данного сценария. Описание методов приведено в электронном формате в https://transfers-openapi.npck.kz/.
Методы API (endpoint), которые необходимо реализовать каждому участнику на своей стороне в рамках процесса «Инициализация оплаты по QR-коду (C2B2_V2)», приведены в таблице ниже.
Запрос данных по QR-коду для оплаты
(POST /v1/transfers/iso20022/admi.009.001.02)
+
Данные для оплаты
(POST /v1/transfers/iso20022/admi.010.001.02)
+
+
Запрос на перевод денег
(POST /v1/transfers/iso20022/pacs.008.001.11)
+
Статус обработки запроса перевода денег
(POST /v1/transfers/iso20022/pacs.002.001.13)
+
+
Взаимосвязь идентификаторов сообщений
Процесс «Инициализация оплаты по QR-коду (C2B2_V2)» построен на обмене сообщениями, основанными на стандарте ISO20022, которые логически связаны между собой.

Описание процесса
Описание успешного сценария процесса «Инициализация оплаты по QR-коду (C2B2_V2)»:
Генерация и считывание QR-кода для оплаты
POS-терминал направляет данные о платеже в Банк бенефициара
Для статического QR-кода данный шаг не применяется
Банк бенефициара формирует данные для QR-кода для оплаты
Отправитель денег в приложении Банка отправителя денег сканирует QR-код в POS-терминале или статический QR-код
Важно! Если отсканированный QR-код выпущен самим Банком отправителя денег, то оплата производится внутри Банка отправителя денег без взаимодействия с Платформой. Т.е. если счет бенефициара, указанный в QR-коде, также обслуживается в данном банке, то производится внутрибанковская операция.
Банк отправителя денег направляет Платформе запрос данных для оплаты (сообщение admi.009), на основе данных из QR-кода, подписав его своим ЭЦП
Возможные неуспешные сценарии
Платформа не отвечает:
Банк отправителя денег завершает процесс, не получив ответ в срок в соответствии с установленным регламентом (см. Тайм-ауты и логика повторных запросов).
Процесс завершается неуспешно.
Валидация сообщения не прошла успешно:
Валидация сообщения не проходит успешно, Платформа направляет Банку отправителя денег ответ с соответствующим ошибке HTTP статусом.
Процесс завершается неуспешно.
4.1. Платформа, получив запрос, проводит его валидацию, в том числе:
проверяет подпись Банка отправителя денег
проверяет корректность заполнения полей
Если валидация запроса проходит успешно, Платформа направляет ответ с HTTP статусом 200.
Платформа направляет в Банк бенефициара запрос данных для оплаты (сообщение admi.009), подписав его ЭЦП Платформы
Возможные неуспешные сценарии
Банк бенефициара не отвечает:
Если Банк бенефициара не направляет ответ, то Платформа должна считать, что запрос не доставлен.
Платформа завершает процесс, не получив ответ в срок в соответствии с установленным регламентом (см. Тайм-ауты и логика повторных запросов).
Платформа направляет в Банк отправителя сообщение admi.010 с ошибкой.
Банк отправителя денег завершает процесс, получив сообщение с информацией об ошибке.
Процесс завершается неуспешно.
Валидация сообщения не прошла успешно:
Валидация сообщения не проходит успешно, Банк бенефициара направляет ответ Платформе с соответствующим ошибке HTTP статусом.
Платформа завершает процесс, получив сообщение с информацией об ошибке.
Платформа направляет в Банк отправителя сообщение admi.010 с ошибкой.
Банк отправителя денег завершает процесс, получив сообщение с информацией об ошибке.
Процесс завершается неуспешно.
5.1. Банк бенефициара, получив запрос, проводит его обработку, в том числе:
проверяет подпись Платформы
проверяет корректность заполнения полей
выполняет поиск данных по идентификатору QR-кода
Если валидация запроса проходит успешно, Банк бенефициара направляет ответ с HTTP статусом 200.
Банк бенефициара направляет данные для оплаты Платформе (сообщение admi.010), подписав его своим ЭЦП
Возможные неуспешные сценарии
Платформа не отвечает:
Если Платформа не направляет ответ, то Банк бенефициара должен считать, что запрос не доставлен.
Банк бенефициара выполняет попытку повторной отправки запроса в соответствии с установленным регламентом (см. Тайм-ауты и логика повторных запросов).
Валидация сообщения не прошла успешно:
Валидация сообщения не проходит успешно, Платформа направляет Банку бенефициара ответ с соответствующим ошибке HTTP статусом.
Банк бенефициара завершается процесс с ошибкой.
Банк отправителя денег завершает процесс по тайм-ауту (см. Тайм-ауты и логика повторных запросов).
Процесс завершается неуспешно.
6.1. Платформа, получив ответ, проводит его валидацию, в том числе:
проверяет подпись Банка бенефициара
проверяет корректность заполнения полей
Если валидация запроса проходит успешно, Платформа направляет ответ с HTTP статусом 200.
Платформа направляет данные для оплаты в Банк отправителя денег (сообщение admi.010), подписав его ЭЦП Платформы
Возможные неуспешные сценарии
Банк отправителя денег не отвечает:
Если Банк отправителя денег не направляет ответ, то Платформа должна считать, что запрос не доставлен.
Платформа выполняет попытку повторной отправки запроса в соответствии с установленным регламентом (см. Тайм-ауты и логика повторных запросов).
7.1. Банк отправителя денег, получив ответ, проводит его валидацию, в том числе:
проверяет подпись Платформы
проверяет корректность заполнения полей
Если валидация запроса проходит успешно, Платформа направляет ответ с HTTP статусом 200.
Отправителю денег в приложении Банка отправителя денег отображается информация о платеже, он выбирает счет для оплаты и подтверждает проведение оплаты.
Возможные неуспешные сценарии
Клиент отменил операцию или операция отменена по иной причине на стороне Банка отправителя денег:
Банк отправителя денег направляет Платформе уведомление об отмене операции (сообщение admi.010), подписав его своим ЭЦП.
1.1. Платформа, получив запрос, проводит его валидацию, в том числе
проверяет подпись Банка отправителя денег
проверяет корректность заполнения полей
Если валидация запроса проходит успешно, Платформа направляет ответ с HTTP статусом 200.
• Возможные неуспешные сценарии
• Платформа не отвечает
Если Платформа не направляет ответ, то Банк отправителя денег должен считать, что запрос не доставлен.
Банк отправителя денег выполняет попытку повторной отправки запроса в соответствии с установленным регламентом (см.
• Валидация сообщения не прошла успешно:
Валидация сообщения не проходит успешно, Платформа направляет Банку отправителя денег ответ с соответствующим ошибке HTTP статусом.
Банк отправителя денег завершается процесс с ошибкой.
Банк бенефициара завершает процесс по тайм-ауту (см. Тайм-ау ты и логика повторных запросов).
Процесс завершается неуспешно
1.2. Платформа направляет в Банк бенефициара уведомление об отмене операции (сообщение admi.010), подписав его ЭЦП Платформы.
• Возможные неуспешные сценарии
• Банк бенефициара не отвечает
Если Банк бенефициара не направляет ответ, то Платформа должна считать, что запрос не доставлен.
Платформа завершает процесс, не получив ответ в срок в соответствии с установленным регламентом (см. Тайм-ауты и логика повторных запросов).
• Валидация сообщения не прошла успешно:
Валидация сообщения не проходит успешно, Банк бенефициара направляет ответ Платформе с соответствующим ошибке HTTP статусом.
Платформа завершает процесс, получив сообщение с информацией об ошибке.
Процесс завершается неуспешно.
1.3. Банк бенефициара, получив запрос, проводит его обработку, в том числе:
проверяет подпись Платформы
проверяет корректность заполнения полей
Если валидация запроса проходит успешно, Банк бенефициара направляет ответ с HTTP статусом 200.
1.4. На POS-терминале выводится информация о том, что операция отменена клиентом, и процесс завершается.
Транзакция по проведению платежа
Банк отправителя денег проводит проверку счета клиента на:
валидность статуса для его дебетования
отсутствие наложенного ПТП/ РПРО/ ареста и т.п.
достаточности средств для списания суммы операции
Возможные неуспешные сценарии
Проверка счета не прошла успешно:
Банк отправителя денег уведомляет клиента о невозможности проведения операции.
Процесс завершается неуспешно
Банк отправителя денег проверяет возможность транзакции по счету клиента и формирует платежное поручение (pacs.008).
Банк отправителя денег направляет Платформе запрос на проведение оплаты (сообщение pacs.008), подписав его своим ЭЦП.
Возможные неуспешные сценарии
Платформа не отвечает:
Если Платформа не направляет ответ, то Банк отправителя денег должен считать, что запрос не доставлен.
Банк отправителя денег выполняет попытку повторной отправки корректного запроса в соответствии с установленным регламентом (см. Тайм-ауты и логика повторных запросов).
Валидация сообщения не прошла успешно:
Валидация сообщения не проходит успешно, Платформа направляет Банку отправителя денег ответ с соответствующим ошибке HTTP статусом.
Процесс завершается неуспешно.
11.1. Платформа, получив запрос, проводит его валидацию, в том числе:
проверяет подпись Банка отправителя денег
проверяет корректность заполнения полей
Если валидация запроса проходит успешно, Платформа направляет ответ с HTTP статусом 200.
Платформа обрабатывает запрос на проведение оплаты (сообщение pacs.008), в том числе:
выполняет проверку лимитов;
выполняет блокирование средств для проведения транзакции;
осуществляет проверку чистой позиции - при достижении лимита чистой позиции направляет в Банк отправителя и Банк бенефициара сообщение pacs.002 со статусом RJCT и кодом ошибки
PACS_002_NET_POSITION_LIMIT_REACHED.
Возможные неуспешные сценарии
Обработка запроса на перевод денег pacs.008 Платформой не проходит успешно:
Платформа направляет статус обработки запроса на проведение оплаты в Банк отправителя денег (сообщение pacs.002), подписав его ЭЦП Платформы, со статусом транзакции RJCT (отклонена).
Процесс завершается неуспешно.
Платформа направляет в Банк бенефициара запрос на проведение оплаты (сообщение pacs.008), подписав его ЭЦП Платформы.
Возможные неуспешные сценарии
Банк бенефициара не отвечает:
Если Банк бенефициара не направляет ответ, то Платформа должна считать, что запрос не доставлен.
Платформа выполняет попытку повторной отправки запроса в соответствии с установленным регламентом (см. Тайм-ауты и логика повторных запросов).
Платформа завершает процесс, не получив ответ в срок в соответствии с установленным регламентом (см. Тайм-ауты и логика повторных запросов).
Платформа направляет в Банк отправителя сообщение pacs.002 с ошибкой.
Банк отправителя денег завершает процесс, получив сообщение с информацией об ошибке.
Процесс завершается неуспешно.
Валидация сообщения не прошла успешно:
Валидация сообщения не проходит успешно, Банк бенефициара направляет ответ Платформе с соответствующим ошибке HTTP статусом.
Платформа устанавливает статус транзакции RJCT (отклонена).
Платформа направляет в Банк отправителя сообщение pacs.002 с ошибкой.
Банк отправителя денег завершает процесс, получив сообщение с информацией об ошибке, устанавливает статус транзакции RJCT (отклонена).
Процесс завершается неуспешно.
13.1. Банк бенефициара, получив запрос, проводит его обработку, в том числе:
проверяет подпись Платформы;
проверяет корректность заполнения полей.
Если валидация запроса проходит успешно, Банк бенефициара направляет ответ с HTTP статусом 200.
Банк бенефициара проверяет счет бенефициара на возможность зачисления денег.
Банк бенефициара направляет статус обработки запроса проведения оплаты Платформе (сообщение pacs.002), подписав его своим ЭЦП.
Возможные неуспешные сценарии
Платформа не отвечает:
Если Платформа не направляет ответ, то Банк бенефициара должен считать, что запрос не доставлен.
Банк бенефициара выполняет попытку повторной отправки запроса в соответствии с установленным регламентом (см. Тайм-ауты и логика повторных запросов).
Валидация сообщения не прошла успешно:
Валидация сообщения не проходит успешно, Платформа направляет ответ Банку бенефициара с соответствующим ошибке HTTP статусом. Банк бенефициара устанавливает статус транзакции RJCT (отклонена).
Платформа устанавливает статус транзакции RJCT (отклонена).
Банк отправителя денег, не получив ответ в срок в соответствии с установленным регламентом (см. Тайм-ауты и логика повторных запросов), устанавливает статус транзакции RJCT (отклонена).
Процесс завершается неуспешно.
Транзакция отклонена (статус транзакции RJCT):
Банк бенефициара направляет Платформе статус обработки запроса проведения оплаты (сообщение pacs.002) - RJCT (отклонена).
Платформа направляет статус обработки запроса проведения оплаты в Банк отправителя денег (сообщение pacs.002), подписав его ЭЦП Платформы, со статусом транзакции RJCT (отклонена).
Процесс завершается неуспешно.
15.1. Платформа, получив запрос, проводит его валидацию, в том числе:
проверяет подпись Банка бенефициара;
проверяет корректность заполнения полей.
Если валидация запроса проходит успешно, Платформа направляет ответ с HTTP статусом 200.
Платформа направляет статус обработки запроса проведения оплаты в Банк отправителя денег (сообщение pacs.002), подписав его ЭЦП Платформы.
Возможные неуспешные сценарии
Банк отправителя денег не отвечает:
Если Банк отправителя денег не направляет ответ, то Платформа должна считать, что запрос не доставлен.
Платформа выполняет попытку повторной отправки запроса в соответствии с установленным регламентом (см. Тайм-ауты и логика повторных запросов).
16.1. Банк отправителя денег, получив запрос, проводит его валидацию, в том числе:
проверяет подпись Платформы;
проверяет корректность заполнения полей.
Если валидация запроса проходит успешно, Банк отправителя денег направляет ответ с HTTP статусом 200.
16.2.Банк отправителя денег снимает/блокирует сумму операции по счету клиента.
Банк отправителя денег направляет в качестве уведомления об успешной транзакции в Платформу сообщение pacs.002 со статусом транзакции ACSC, подписав его своим ЭЦП.
Возможные неуспешные сценарии
Платформа не отвечает:
При отсутствии ответа от Платформы, Банк отправителя денег осуществляет повторную отправку запроса с интервалом 3 секунды до тех пор, пока не будет получен ответ HTTP 200.
17.1. Платформа, получив запрос, проводит его валидацию, в том числе:
проверяет подпись Банка отправителя денег;
проверяет корректность заполнения полей.
Если валидация запроса проходит успешно, Платформа направляет ответ с HTTP статусом 200.
Возможные неуспешные сценарии
Не получен pacs.002 ACSC от Банка отправителя денег:
Если Платформа в течение 30 секунд не получает сообщение pacs.002 (ACSC) от Банка отправителя денег, то транзакция завершается со статусом RJCT и при получении pacs.002 ACSC от Банка отправителя денег будет возвращен HTTP 408.
Платформа направляет в качестве уведомления сообщение pacs.002 со статусом ACSC в Банк бенефициара, подписав его ЭЦП Платформы.
Возможные неуспешные сценарии
Банк бенефициара не отвечает:
Платформа выполняет попытку повторной отправки запроса в соответствии с установленным регламентом (см. Тайм-ауты и логика повторных запросов).
Если Банк бенефициара не направляет ответ, то Платформа считает запрос не доставленным, при этом транзакция не отклоняется и остается в состоянии ожидания сообщения pacs.002 с финальным статусом от Банка бенефициара.
Банк бенефициара не получив ответ от платформы в соответствии с установленным регламентом (см. Тайм-ауты и логика повторных запросов), завершает транзакцию с ошибкой и направляет в Платформу pacs.002 со статусом RJCT с интервалом 3 секунды до тех пор, пока не будет получен ответ HTTP 200.
18.1. Банк бенефициара, получив сообщение pacs.002 со статусом транзакции, проводит его валидацию, в том числе:
проверяет подпись Платформы;
проверяет корректность заполнения полей.
Если валидация запроса проходит успешно, Банк бенефициара направляет ответ с HTTP статусом 200.
Банк бенефициара производит зачисление денег на счет бенефициара и направляет информацию об этом на POS-терминал.
Банк бенефициара направляет в качестве уведомления об успешной транзакции в Платформу сообщение pacs.002 со статусом транзакции ACSC, подписав его своим ЭЦП.
Возможные неуспешные сценарии
Платформа не отвечает:
При отсутствии ответа от Платформы, Банк отправителя денег осуществляет повторную отправку запроса с интервалом 3 секунды до тех пор, пока не будет получен ответ HTTP 200.
20.1. Платформа, получив запрос, проводит его валидацию, в том числе:
проверяет подпись Банка бенефициара
проверяет корректность заполнения полей.
Если валидация запроса проходит успешно, Платформа направляет ответ с HTTP статусом 200.
Платформа успешно завершает транзакцию (commit transaction).
Платформа направляет уведомление pacs.002 со статусом ACSC до Банка отправителя денег с информацией о дате обработки транзакции (Processing Date) и информацией о размерах комиссий, подписав его ЭЦП Платформы.
Банк отправителя завершает транзакцию и уведомляет клиента о завершении операции.
Возможные неуспешные сценарии
Банк отправителя денег не получил финальное уведомление от платформы pacs.002 со статусом ACSC с информацией о дате обработки транзакции (Processing Date) и информацией о размерах комиссий.
Банк отправителя денег отправляет запрос на получение статуса обработки транзакции (pacs.028) в соответствии с установленным регламентом (см. Тайм-ауты и логика повторных запросов).
Рекомендуется: Банку отправителя денег начинать направлять запрос статуса обработки транзакции (pacs.028) через 5 секунд после успешной отправки pacs.002.
Last updated