QRIS
Обзор
QRIS — это платёжный метод для проведения оплат в Индонезии с помощью сканирования QR-кодов с использованием мобильных приложений и электронных кошельков. Для работы с этим методом могут использоваться различные приложения, поддерживающие работу со стандартом QRIS (Quick Response Code Indonesian Standard). Оплаты осуществляются через Payment Page и Gate.
Характеристика
Тип платёжного метода | платежи с помощью QR-кодов |
---|---|
Платёжные инструменты |
|
Регионы использования | ID |
Валюты платежей | IDR |
Конвертация валют | на стороне ecommpay |
Оплаты | + |
Выплаты | – |
Оплаты по сохранённым данным | – |
Полные возвраты | – |
Частичные возвраты | – |
Опротестования | + |
Особенности | При использовании валюты IDR не поддерживается обработка платежей, для которых сумма платежа указана с дробной частью. В запросе на оплату с указанием валюты IDR сумму оплаты необходимо округлять до целых чисел. Если в запросе указывается иная валюта, сумма платежа конвертируется на стороне ecommpay в эквивалентную сумму в валюте IDR и также округляется до целых чисел. Информацию об особенностях округления суммы следует уточнять у специалистов технической поддержки ecommpay. |
Организация и стоимость подключения | по согласованию с курирующим менеджером ecommpay |
Схема работы
В проведении отдельного платежа с использованием QRIS задействуются веб-сервис мерчанта, один из интерфейсов и платёжная платформа ecommpay, а также технические средства провайдера.
Основные операции
Интерфейсы | Суммы, IDR | Время* | ||||||
---|---|---|---|---|---|---|---|---|
Payment Page | CMS Plug-ins | Gate | Dashboard | минимум | максимум | базовое | предельное | |
Оплаты | + | – | + | – | 10 000,00 | 2 000 000,00 | – | – |
- Базовое время — среднее расчётное время проведения платежа от момента его инициирования на стороне платёжной платформы до момента отправки инициатору оповещения о результате. Это время, определяемое для условий штатной работы всех технических средств и каналов связи, а также типичных действий со стороны пользователя (там, где они необходимы). Базовое время рекомендуется использовать для реагирования на отсутствие оповещений о результате платежа и выполнения опроса состояния платежа.
- Предельное время — максимально допустимое время проведения платежа от момента его инициирования на стороне платёжной платформы до момента отправки инициатору оповещения о результате. Если платёж не был проведён или отклонён за это время, он автоматически переводится в статус
decline
. Для индивидуальной настройки предельного времени следует обращаться к специалистам технической поддержки ecommpay.
Сценарии использования
Проведение оплат с использованием метода QRIS выполняется с помощью сканирования QR-кодов с использованием мобильных приложений.
Рис.: Оплата через Payment Page
Рис.: Оплата через Gate
Детальные сведения о том, что необходимо делать со стороны мерчанта для проведения платежей, а также о том, что можно использовать для анализа информации о проведённых платежах и операциях, представлены далее.
Оплаты через Payment Page
Общая информация
Для оплаты через Payment Page с использованием метода QRIS со стороны веб-сервиса необходимо отправить запрос, содержащий требуемые параметры и подпись, на рабочий URL ecommpay и принять оповещение о результате оплаты. При этом метод QRIS можно сделать предварительно выбранным (подробнее — в разделе Предварительный выбор платёжных методов). Полная схема проведения оплаты представлена далее.
Рис.: Проведение оплаты через Payment Page
- Пользователь на стороне веб-сервиса инициирует оплату.
- От веб-сервиса на заданный URL ecommpay передаётся запрос на проведение оплаты через Payment Page.
- Запрос на проведение оплаты поступает в платёжную платформу.
- Выполняется начальная обработка запроса, в рамках которой обеспечивается проверка наличия обязательных параметров и корректной подписи.
- Осуществляется подготовка Payment Page согласно настройкам проекта и параметрам вызова.
- Пользователю отображается сформированная платёжная форма.
- Пользователь выбирает для оплаты метод QRIS.
- Запрос на проведение оплаты через провайдера поступает в платёжную платформу.
- Выполняется дальнейшая обработка запроса.
- Данные для отображения платёжной инструкции пользователю передаются к Payment Page.
- Пользователю отображается платёжная инструкция.
- Пользователь выполняет необходимые действия для оплаты.
- На стороне сервиса провайдера выполняется обработка платежа.
- От сервиса провайдера к платёжной платформе направляется информация о результате оплаты.
- От платёжной платформы к веб-сервису направляется оповещение о результате оплаты.
- От платёжной платформы к Payment Page отправляется информация о результате проведения оплаты.
- Информация о результате оплаты отображается пользователю на Payment Page.
Информация о формате запросов и параметрах вызова Payment Page при работе с QRIS, а также о формате оповещений о результатах оплат приведена далее; общая информация о работе с API см. в разделе Описание Payment Page API.
Формат запросов
При формировании запросов на открытие платёжной формы с применением метода QRIS необходимо учитывать следующее:
- Должен использоваться базовый минимум параметров — параметры, обязательные для любого платёжного метода:
- project_id — идентификатор проекта, полученный от ecommpay при интеграции;
- payment_id — идентификатор платежа, уникальный в рамках проекта;
- payment_currency — код валюты платежа в формате ISO-4217 alpha-3;
- payment_amount — сумма платежа, указанная в дробных единицах валюты. При использовании валюты IDR в запросе на оплату сумму платежа необходимо округлять до целых чисел. Если в запросе указывается иная валюта, то сумма платежа конвертируется на стороне ecommpay в эквивалентную сумму в валюте IDR и также округляется до целых чисел. Информацию об особенностях округления суммы следует уточнять у специалистов технической поддержки ecommpay.
- customer_id — идентификатор пользователя, уникальный в рамках проекта.
- Для предварительного выбора метода QRIS необходимо указывать код платёжного метода в параметре force_payment_method —
indonesia-qr
. - Дополнительно могут использоваться любые другие параметры из числа доступных для работы с Payment Page. Детальная информация обо всех параметрах приведена в разделе Параметры вызова платёжной формы.
- После определения всех параметров необходимо составить подпись (подробнее).
Таким образом, корректный запрос на открытие платёжной формы с применением метода QRIS должен содержать идентификаторы проекта, пользователя и платежа, валюту и сумму платежа, а также подпись:
{ payment_id: 'X03936', payment_amount: 1000000, payment_currency: 'IDR', project_id: 123, customer_id: 'customer1', signature: "kUi2x9dKHAVNU0FYldJrxh4yo+5...ZzUCwX6R\/ekpZhkIQg==" }
Формат оповещений
Для оповещений о результатах оплат с применением метода QRIS используется стандартный формат, описание которого представлено в разделе Оповещения.
В следующем примере оповещение свидетельствует о том, что в рамках проекта 1234
для пользователя customer1
была успешно проведена оплата в размере 100 000,00 IDR
.
Рис.: Пример оповещения о проведенной оплаты
{ "project_id": 1234, "payment": { "id": "ABC12345", "type": "purchase", "status": "success", "date": "2021-06-03T09:18:49+0000", "method": "indonesia-qr", "sum": { "amount": 10000000, "currency": "IDR" }, "description": "" }, "customer": { "id": "customer1" }, "operation": { "id": 66524010061681, "type": "sale", "status": "success", "date": "2021-06-03T09:18:49+0000", "created_date": "2021-06-03T09:04:56+0000", "request_id": "312be99ad68be48100c724ce274e...066525", "sum_initial": { "amount": 10000000, "currency": "IDR" }, "sum_converted": { "amount": 10000000, "currency": "IDR" }, "code": "0", "message": "Success", "provider": { "id": 5861, "payment_id": "32376801d1f6b6b6406...a02b4e45c", "auth_code": "", "date": "2021-06-03T09:18:39+0000" } }, "signature": "LaWvR4EPqYRvsuU7Hl0H09l6uYR0dCIvFYSK...eiLtrjaJxLAhCBsxA==" } }
В следующем примере оплата была отклонена.
Рис.: Пример оповещения об отказе в проведении оплаты
{ "id": "7890", "type": "purchase", "status": "decline", "date": "2021-06-04T06:19:47+0000", "method": "indonesia-qr", "sum": { "amount": 1000000, "currency": "IDR" }, "description": "" }, "customer": { "id": "1" }, "operation": { "id": 79864010068961, "type": "sale", "status": "decline", "date": "2021-06-04T06:19:47+0000", "created_date": "2021-06-03T06:19:31+0000", "request_id": "1504560d8c125cb12199c320ac41c...079865", "sum_initial": { "amount": 1000000, "currency": "IDR" }, "sum_converted": { "amount": 1000000, "currency": "IDR" }, "code": "20000", "message": "General decline", "provider": { "id": 5861, "payment_id": "3237eceb715dc5ac46eb80edbde6fe2e24d4", "auth_code": "" } }, "signature": "/NAM67hU7V7/tOQHaWOIRg68c...e8jhN6GIyC5idy9hiQ==" }
Дополнительные материалы
Для организации работы с оплатами через Payment Page также могут быть полезны следующие материалы:
Оплаты через Gate
Общая информация
Для оплаты через Gate с использованием метода QRIS со стороны веб-сервиса необходимо:
- Отправить запрос, содержащий требуемые параметры и подпись, на рабочий URL ecommpay.
- Отобразить пользователю инструкцию для оплаты.
- Принять оповещение о результате оплаты.
Полная схема проведения оплаты представлена далее.
Рис.: Проведение оплаты через Gate
- Пользователь на стороне веб-сервиса инициирует оплату через провайдера.
- От веб-сервиса на заданный URL ecommpay передаётся запрос на проведение оплаты через Gate.
- Запрос на проведение оплаты поступает в платёжную платформу ecommpay.
- Выполняется начальная обработка запроса, в рамках которой обеспечивается проверка наличия обязательных параметров и корректной подписи.
- От платёжной платформы к веб-сервису направляется ответ с информацией о получении запроса и его корректности (подробнее).
- Выполняется дальнейшая обработка запроса.
- От платёжной платформы к веб-сервису направляется оповещение с данными для отображения платёжной инструкции пользователю.
- Пользователю отображается платёжная инструкция.
- Пользователь выполняет необходимые действия для оплаты.
- На стороне сервиса провайдера выполняется обработка платежа.
- От сервиса провайдера к платёжной платформе направляется уведомление о результате оплаты.
- От платёжной платформы к веб-сервису направляется оповещение о результате оплаты.
- От веб-сервиса пользователю направляется информация о результате оплаты.
Информация о формате запросов и параметрах инициации оплат методом QRIS через Gate, а также о формате оповещений о результатах оплат приведена далее, общая информация о работе с API см. в разделе Работа с API.
Формат запросов
При работе с запросами на оплаты с применением метода QRIS необходимо учитывать следующее:
- Должен использоваться запрос к конечной точке
/v2/payment/banks/indonesia-qr/sale
, отправляемый методом POST. Этот запрос относится к группе запросов /v2/payment/banks/{payment_method}/sale. - В запросе должны использоваться следующие объекты и параметры:
- general — основные сведения:
- project_id — идентификатор проекта, полученный от ecommpay при интеграции;
- payment_id — идентификатор платежа, уникальный в рамках проекта;
- signature — подпись запроса, составленная после указания целевых параметров (подробнее — в разделе Использование подписи к данным);
- customer — сведения о пользователе:
- ip_address — IP-адрес пользователя;
- id — идентификатор пользователя, уникальный в рамках проекта;
- payment — сведения о платеже:
- amount — сумма платежа, указанная в дробных единицах валюты. При использовании валюты IDR в запросе на оплату сумму платежа необходимо округлять до целых чисел. Если в запросе указывается иная валюта, то сумма платежа конвертируется на стороне ecommpay в эквивалентную сумму в валюте IDR и также округляется до целых чисел. Информацию об особенностях округления суммы следует уточнять у специалистов технической поддержки ecommpay.
- currency — код валюты платежа в формате ISO-4217 alpha-3.
- general — основные сведения:
- Дополнительно могут использоваться все параметры, указанные в спецификации.
Таким образом, корректный запрос на оплату с применением метода QRIS должен содержать идентификаторы проекта и платежа, подпись и IP-адрес пользователя, валюту и сумму платежа:
Рис.: Пример запроса на оплату
{ "general": { "project_id": 1234567, "payment_id": "12278b5d662764c9506...c5c35", "signature": "GINgwlggTvpF9AnkT8rUUVC7bmSCAa...JChDjj40xI5vOA7w==" }, "customer": { "id": "customer1", "ip_address": "1.1.1.1" }, "payment": { "amount": 1000000, "currency": "IDR" } }
Форматы данных для отображения платёжной инструкции
Для отображения платёжной инструкции необходимо принять и обработать оповещение от платёжной платформы, содержащее данные о платеже в массиве display_data, и отобразить пользователю платёжную инструкцию.
Массив display_data содержит следующие параметры:
- type — тип передаваемых данных (в значении всегда передаётся
qr_data
); - title — название передаваемых данных, которые необходимо отобразить пользователю (в значении всегда передаётся
qr_code_data
); - data — строка с закодированным изображением QR-кода.
Далее приведён фрагмент оповещения, содержащего данные для отображения пользователю.
"display_data": [ { "type": "qr_data", "title": "qr_code_data", "data": "00020101021226530012...40014ID.CO.QRIS.WWW0215ID20200311332370303URE5204323753033605405100005502015802ID5911TARGETWIRES6007jakarta61059999962470703A015036323777b2dadc0aa04fdb82a0cc2349be345c63048782" } ]
Формат оповещений
Для оповещений о результатах оплат с применением метода QRIS используется стандартный формат, описание которого представлено в разделе Оповещения.
В следующем примере оповещение свидетельствует о том, что в рамках проекта 1234
для пользователя customer1
была успешно проведена оплата в размере 100 000,00 IDR
.
Рис.: Пример оповещения о проведенной оплате
{ "project_id": 1234, "payment": { "id": "ABC12345", "type": "purchase", "status": "success", "date": "2021-06-03T09:18:49+0000", "method": "indonesia-qr", "sum": { "amount": 10000000, "currency": "IDR" }, "description": "" }, "customer": { "id": "customer1" }, "operation": { "id": 66524010061681, "type": "sale", "status": "success", "date": "2021-06-03T09:18:49+0000", "created_date": "2021-06-03T09:04:56+0000", "request_id": "312be99ad68be48100c724ce274e...066525", "sum_initial": { "amount": 10000000, "currency": "IDR" }, "sum_converted": { "amount": 10000000, "currency": "IDR" }, "code": "0", "message": "Success", "provider": { "id": 5861, "payment_id": "32376801d1f6b6b6406...a02b4e45c", "auth_code": "", "date": "2021-06-03T09:18:39+0000" } }, "signature": "LaWvR4EPqYRvsuU7Hl0H09l6uYR0dCIvFYSK...eiLtrjaJxLAhCBsxA==" } }
В следующем примере оплата была отклонена.
Рис.: Пример оповещения об отказе в проведении оплаты
{ "id": "7890", "type": "purchase", "status": "decline", "date": "2021-06-04T06:19:47+0000", "method": "indonesia-qr", "sum": { "amount": 1000000, "currency": "IDR" }, "description": "" }, "customer": { "id": "1" }, "operation": { "id": 79864010068961, "type": "sale", "status": "decline", "date": "2021-06-04T06:19:47+0000", "created_date": "2021-06-03T06:19:31+0000", "request_id": "1504560d8c125cb12199c320ac41c...079865", "sum_initial": { "amount": 1000000, "currency": "IDR" }, "sum_converted": { "amount": 1000000, "currency": "IDR" }, "code": "20000", "message": "General decline", "provider": { "id": 5861, "payment_id": "3237eceb715dc5ac46eb80edbde6fe2e24d4", "auth_code": "" } }, "signature": "/NAM67hU7V7/tOQHaWOIRg68c...e8jhN6GIyC5idy9hiQ==" }
Дополнительные материалы
Для организации работы с оплатами через Gate также могут быть полезны следующие материалы:
Анализ результатов проведения платежей
Как и при работе с другими платёжными методами, которые предоставляет ecommpay, при использовании метода QRIS доступны разные способы анализа информации о платежах и операциях с применением этого метода — как в отдельности, так и в совокупности с другими методами.
Всю необходимую информацию можно получать и анализировать средствами Dashboard, в том числе с помощью аналитических панелей на вкладке Analytics.
Также можно выгружать нужную информацию для последующего анализа с помощью специализированных аналитических средств сторонних разработчиков:
- Dashboard позволяет выгружать данные в форматах CSV и XLS с помощью инструментов на вкладке Платежи. При этом можно выполнять разовые выгрузки информации на локальный компьютер и задействовать периодическую выгрузку и отправку информации на заданные адреса электронной почты.
- Data API позволяет получать информацию в формате JSON и отправлять ее на заданный URL — для этого применяются запросы /operations/get.
С любыми вопросами о возможностях анализа можно обращаться в службу технической поддержки ecommpay.