Продавец (он же мерчант) – пользователь системы Onpay.ru (интернет-магазин, НКО, ИП и т.п.) обладающий правами получать платежи от третьих лиц через систему Onpay.ru
Клиент – любой пользователь системы Продавца, желающий переводить деньги Продавцу через систему Onpay.ru (покупка товаров и услуг, благотворительные пожертвования и проч.)
Для включения работы по API, Вам нужно:
1. Активировать функцию “Уведомление по API” в разделе Настройки Магазина в Кабинете Продавца Onpay
2. Указать API URL в соответствии со скриптом API на Вашем сервере. В API URL возможно использование кириллицы.
3. Установить секретный ключ для “уведомлений по API”, который должен быть таким же, как в скрипте на Вашем сервере, чтобы позволить генерацию контрольных подписей.
Разрешается использование параметров в указываемом API URL, по которому будут приходить уведомления. При этом накладывается ограничение в виде списка зарезервированных API Onpay параметров, которые запрещается использовать в API URL настроек магазина. Список зарезервированных параметров прилагается:
onpay_id
pay_for
order_amount
order_currency
balance_amount
balance_currency
exchange_rate
type
comment
paymentDateTime
md5
Onpay.ru производит 2 вида запросов к системе Продавца через API:
1. Запрос “check” используется, чтобы получить разрешение от системы Продавца на прием платежа от Клиента. После удачного получения разрешения, Onpay.ru одобрит платёж. С этого момента, если Клиент действительно производит платёж, Продавец может видеть его во вкладке “Платежи” в Кабинете Продавца.
2. Запрос “pay” является, по сути, уведомлением для системы Продавца, о том, что для него принят платеж. После получения уведомления, система Продавца может автоматически отправить заказанные товары или сервисы Клиенту.
Очередность транзакции:
1. Клиент переходит по платежной ссылке на форму Onpay и заполняет данные(если необходимо).
2. Onpay.ru отправляет “check” запрос в адрес Продавца, удостоверяясь, что система Продавца может (и разрешает) принять платёж. Система Продавца проверяет все параметры запроса (существуют ли в системе ID Клиента и заказа, может ли Клиент платить и т.д.).
a. Если система Продавца не позволяет перевод (любой итог, кроме получения кода 0 от системы Продавца) – платёж не будет принят от Клиента.
b. Если API Продавца разрешает перевод (код 0) – Onpay разрешает Клиенту платить.
3. Клиент производит оплату
4. Onpay сохраняет платёж со статусом “Получен” и отправляет запрос типа “pay” в систему Продавца с теми же параметрами, что и запрос “check”, плюс ID платежа и дата/время момента, когда платёж был одобрен.
a. если система Продавца приняла уведомление (код 0) – Onpay.ru изменяет статус этого платежа с “Получен” на “Принят”
b. если система Продавца сообщает о некритичной ошибке – Onpay.ru попробует известить систему Продавца позже. Onpay.ru будет посылать извещения с возрастающими временными интервалами, до тех пор пока система Продавца не примет уведомление или пока не пройдёт 72 часа.
Платежи со статусами “получен” и “принят” могут быть просмотрены во вкладке “Платежи” в Кабинете Продавца Onpay.ru.
Продавцы могут помечать платежи, как “Принятые” вручную во вкладке “Платежи” если API не доступен.
1. Основное АПИ (версия 2.0). В Кабинете продавца выбран по умолчанию (поле селектора на HTTPS 2.0).
2. API 1.0. Старое апи. С этим АПИ, в частности, работают все загружаемые модули с onpaysolutions.ru
3. Специальное АПИ для Insales (его настройка описана отдельно)
4. Гибридные АПИ для упрощения миграции (переход с Робокассы и Интеркассы)
Если сервер магазина недоступен для “check” запроса или возвращает НЕположительный ответ, система Onpay не примет платёж от Клиента.
Если сервер магазина недоступен для “pay” запроса, система Onpay будет повторно отправлять запрос несколько раз в течение следующих 72 часов. Повторяющиеся запросы посылаются с увеличивающимися интервалами. При этом платеж будет зачислен на счет магазина.