Документация
Создание магазина
Укажите только URL проекта. Весь процесс обычно занимает не более 5 минут.
Еще необходимо чтобы проект соответствовал требованиям системы.
Настройки магазина
Внимание! Технические настройки магазина сохраняются один раз, будьте внимательны. Далее самостоятельно изменить их не получиться, только через тикет.
Описание параметров
Секретное слово | Используется для формирования подписи в форме оплаты и скрипте оповещения. |
---|---|
URL оповещения | Страница Вашего сайта, на который будут отправлены данные с информацией о платеже. Метод отправки: GET / POST |
Успешный URL | Страница Вашего сайта, на которую будет перенаправлен пользователь после успешной оплаты. Передает номер заказа order и номер платежа inv методом GET |
Неудачный URL | Страница Вашего сайта, на которую будет перенаправлен пользователь в случае неудачной оплаты. Передает номер заказа order и номер платежа inv методом GET |
Интеграция | Режим интеграции сделан для упрощения переноса сайта от другого сервиса приема платежей. Подробнее По-умолчанию: Нет. |
Настройка формы оплаты (форм. ссылки)
Создаем форму оплаты в виде ссылки на страницу оплаты.
Данные передается методом GET / POST на адрес https://realkassa.ru/pay
При использовании интеграции, параметры передаются по правилам вашей старой платежной системы.
Описание параметров
Обязательные параметры | |
---|---|
shop | ID Вашего магазина |
amount | Сумма платежа |
order | Номер заказа (также это может быть название товара или логин пользователя, для зачисления средств) |
sign | Подпись (методика формирования подписи в платежной форме) |
Необязательные параметры | |
method | Предлагаемый метод/способ платежа (список валют). Плательщик сможет изменить его в процессе оплаты. |
desc | Описание платежа |
Email плательщика | |
phone | Номер телефона плательщика (только цифры с кодом города, например: 74999905568) |
ap_key | Так же Вы можете передавать свои параметры, которые наш сервер вернет на Ваш URL оповещения. Ключи параметров должны начинаться с ap_ и содержать только латинские символы и цифры. Значения параметров могут содержать только латинские буквы, цифры и символы '-', '_'. Например: <input type="text" name="ap_name" value="ivanov"> <input type="text" name="ap_login" value="ivanov1971"> |
Формирование подписи в платежной форме
Подпись для платежной формы формируется путем нахождения MD5-хеша от строки
"ID Вашего магазина:Сумма платежа:Секретное слово:Номер заказа", пример на PHP:
md5('1011:100.11:secret:154')
Пример платежной формы:
<?php $shop_id = '1011'; $secret = 'secret'; $order_id = '154'; $order_amount = '100.11'; $sign = md5($shop_id.':'.$order_amount.':'.$secret.':'.$order_id); ?> <form method="GET" action="https://realkassa.ru/pay"> <input type="hidden" name="shop" value="<?php=$shop_id?>"> <input type="hidden" name="amount" value="<?php=$order_amount?>"> <input type="hidden" name="order" value="<?php=$order_id?>"> <input type="hidden" name="sign" value="<?php=$sign?>"> <input type="hidden" name="desc" value="Form pay for documentation"> <input type="submit" name="pay" value="Оплатить"> </form>
Оповещение о платеже
После успешной оплаты, на ваш URL оповещения будут отправлены HTTP данные.
Опять же! При использовании интеграции, название параметров соответствуют вашей старой платежной системы.
(за доп. помощью обращайтесь в в службу поддержки)
Описание параметров
SHOP_ID | ID Вашего магазина |
---|---|
AMOUNT | Сумма заказа |
ORDER_ID | Ваш номер заказа |
INV_ID | Номер операции Realkassa |
P_EMAIL | Email плательщика |
CUR_ID | ID электронной валюты, которой был оплачен заказ (список валют) |
SIGN | Подпись (методика формирования подписи в данных оповещения) |
ap_key | Дополнительные параметры с префиксом ap_ переданные в форму оплаты |
Подтверждение заявки
Для проверки успешной обработки платежа в вашем URL оповещения выводите/возвращайте текст со словом OK
Внимание! Ответ также может соответствовать требованиям вашей прошлой платежной системы, если вы используете интеграцию.
В противном случае Realkassa будет повторять отправку оповещения до тех пор, пока не получит нужного ответа.
(если в настройках указано)
Проверка IP
Рекомендуем так же проверять IP адрес сервера отправляющего Вам информацию, наши IP адреса - 95.216.201.160,
Всегда актуальный список по адресу: https://realkassa.ru/ips.json
Пример функции на PHP:
function getIP() { if (isset($_SERVER['HTTP_CF_CONNECTING_IP'])) return $_SERVER['HTTP_CF_CONNECTING_IP']; if (isset($_SERVER['HTTP_X_FORWARDED_FOR'])) return $_SERVER['HTTP_X_FORWARDED_FOR']; if (isset($_SERVER['HTTP_X_REAL_IP'])) return $_SERVER['HTTP_X_REAL_IP']; return $_SERVER['REMOTE_ADDR']; } if (!in_array(getIP(), json_decode(file_get_contents('https://realkassa.ru/ips.json'), true))) { die("hacking attempt!"); }
Пример обработчика платежа
//Секретное слово $secret = 'secret'; function getIP() { if (isset($_SERVER['HTTP_CF_CONNECTING_IP'])) return $_SERVER['HTTP_CF_CONNECTING_IP']; if (isset($_SERVER['HTTP_X_FORWARDED_FOR'])) return $_SERVER['HTTP_X_FORWARDED_FOR']; if (isset($_SERVER['HTTP_X_REAL_IP'])) return $_SERVER['HTTP_X_REAL_IP']; return $_SERVER['REMOTE_ADDR']; } if (!in_array(getIP(), json_decode(file_get_contents('https://realkassa.ru/ips.json'), true))) { die("hacking attempt!"); } $sign = md5($_REQUEST['SHOP_ID'].':'.$_REQUEST['AMOUNT'].':'.$secret.':'.$_REQUEST['ORDER_ID']); if ($sign != $_REQUEST['SIGN']) { die("wrong sign"); } //Так же, рекомендуется добавить проверку на сумму платежа и не была ли эта заявка уже оплачена или отменена //Оплата прошла успешно, можно проводить операцию. die('OK');
Формирование подписи в скрипте оповещения
Подпись для скрипта оповещения формируется путем нахождения MD5-хеша от строки
"ID Вашего магазина:Сумма платежа:Секретное слово:Номер заказа", пример на PHP:
md5($_REQUEST['SHOP_ID'].':'.$_REQUEST['AMOUNT'].':secret:'.$_REQUEST['ORDER_ID'])
Список доступных валют
Название | Метод |
---|---|
Яндекс.Деньги | ym |
WebMoney | wm |
QIWI кошелек | qiwi |
Payeer | payeer |
Банковская карта | card |
Bitcoin | btc |
МТС | mts |
Мегафон | megafon |
Теле2 | tele2 |
Билайн | beeline |
Терминалы России | qterminal |
Интеграция
Режим интеграции сделан для упрощенного перехода с другого сервиса приема платежей в наш сервис.
Для этого в настройках магазина выберите Интеграция
свою старую платежную систему и внесите несколько изменений в свои скрипты оплаты.
Robokassa:
URL перехода | Используйте https://realkassa.ru/pay вместо https://auth.robokassa.ru/Merchant/Index.aspx |
---|---|
MerchantLogin | ID Вашего магазина на сервисе Realkassa |
InvId | Номер счета в магазине (нужно указывать обязательно) |
Пароль #1 | Секретное слово на сервисе Realkassa |
Пароль #2 | Секретное слово на сервисе Realkassa |
Все остальное оставьте без изменений |
Freekassa:
URL перехода | Используйте https://realkassa.ru/pay вместо http://www.free-kassa.ru/merchant/cash.php |
---|---|
MERCHANT_ID | ID Вашего магазина на сервисе Realkassa |
Секретное слово | Секретное слово на сервисе Realkassa |
Секретное слово 2 | Секретное слово на сервисе Realkassa |
Все остальные данные оставьте без изменений |
Interkassa:
URL перехода | Используйте https://realkassa.ru/pay вместо https://sci.interkassa.com/ |
---|---|
ik_co_id | ID Вашего магазина на сервисе Realkassa |
ik_pm_no | Номер или описание заказа (нужно указывать обязательно) |
Secret Key | Секретное слово на сервисе Realkassa |
Sign Key | Внимание! Формировать нужно подпись по нашей схеме в MD5:ik_sign = md5(ik_co_id:ik_am:SecretKey:ik_pm_no); |
Все остальные данные оставьте без изменений |
Payeer:
URL перехода | Используйте https://realkassa.ru/pay вместо https://payeer.com/merchant/ |
---|---|
m_shop | ID Вашего магазина на сервисе Realkassa |
m_key | Секретное слово на сервисе Realkassa |
m_sign | Внимание! Формировать нужно подпись по следующей схеме:arHash = array( m_shop, m_orderid, m_amount, m_key ); m_sign = strtoupper(hash('sha256', implode(":", arHash))); |
Все остальные данные оставьте без изменений |
Unitpay:
URL перехода | Используйте https://realkassa.ru/pay/index/index/PUBLIC_KEY вместо https://unitpay.ru/pay/PUBLIC_KEY |
---|---|
PUBLIC_KEY | ID Вашего магазина на сервисе Realkassa |
secretKey | currencyСекретное слово на сервисе Realkassa |
currency | Используйте RUB |
signature | Пример формирования цифровой подписи на PHP:function getFormSignature($account, $currency, $desc, $sum, $secretKey) { $hashStr = $account.'{up}'.$currency.'{up}'.$desc.'{up}'.$sum.'{up}'.$secretKey; return hash('sha256', $hashStr); } |
Все остальные данные оставьте без изменений |
API
API позволит вам интегрировать некоторые функции нашего сервиса в ваше приложение.
Все запросы отправляются методом GET / POST, ответ в формате JSON.
Внимание! Слишком частое обращение к API может привести к блокировке.
Проверка баланса
Для получения баланса, необходимо отправить запрос на URL:
https://realkassa.ru/api/v1/account/getBalance
Передаваемые параметры:
Параметр | Значение | Описание |
---|---|---|
token | строка | Ключ API, доступен в настройках профиля. |
Пример запроса:
https://realkassa.ru/api/v1/account/getBalance?token=1sExK9ISODXdzqFJCKtKyHtqENFoHveu
Пример ответа:
{ "balance" : "11.88" }
Создание выплаты
Для создания выплаты, необходимо отправить запрос на URL:
https://realkassa.ru/api/v1/payouts/getRequest
Передаваемые параметры:
Параметр | Значение | Описание |
---|---|---|
token | строка | Ключ API, доступен в настройках профиля. |
pay_type | строка | Код доступной платежной системы для выплаты. |
amount | число | Сумма выплаты. |
wallet | строка | Номер кошелька в допустимом формате. |
Пример запроса:
https://realkassa.ru/api/v1/payouts/getRequest?token=1sExK9ISODXdzqFJCKtKyHtqENFoHveu&pay_type=qiwi&amount=100.00&wallet=74999905568
Пример ответа:
{ "success" : "Payout created" "payout_id" : "32", "payout_wallet" : "74999905568", "payout_wallet_type" : "qiwi", "payout_amount" : "97.00", "payout_amount_down" : "100.00", "payout_status" : "wait" }
Информация о выплате
Для получения информации о выплате, необходимо отправить запрос на URL:
https://realkassa.ru/api/v1/payouts/getInfo
Передаваемые параметры:
Параметр | Значение | Описание |
---|---|---|
token | строка | Ключ API, доступен в настройках профиля. |
payout_id | число | ID выплаты. |
Пример запроса:
https://realkassa.ru/api/v1/payouts/getInfo?token=1sExK9ISODXdzqFJCKtKyHtqENFoHveu&payout_id=32
Пример ответа:
{ "payout_id" : "32", "payout_wallet" : "74999905568", "payout_wallet_type" : "qiwi", "payout_amount" : "97.00", "payout_amount_down" : "100.00", "payout_status" : "success", "payout_date_success" : "2018-02-08 17:09:02", "payout_date_add" : "2018-02-08 17:08:42" }