This commit is contained in:
Alan
2026-02-14 19:34:54 +03:00
commit 5c3329238b
867 changed files with 214778 additions and 0 deletions

View File

@@ -0,0 +1,57 @@
<?php
require_once('api/Simpla.php');
class RBKMoney extends Simpla
{
public function checkout_form($order_id, $button_text = null)
{
if(empty($button_text))
$button_text = 'Перейти к оплате';
$order = $this->orders->get_order((int)$order_id);
$payment_method = $this->payment->get_payment_method($order->payment_method_id);
$payment_settings = $this->payment->get_payment_settings($payment_method->id);
$payment_currency = $this->money->get_currency(intval($payment_method->currency_id));
$shop_id = $payment_settings['rbkmoney_id'];
// номер заказа
// number of order
$order_id = $order->id;
// описание заказа
// order description
$order_description = 'Оплата заказа №'.$order->id;
// сумма заказа
// sum of order
$amount = $this->money->convert($order->total_price, $payment_method->currency_id, false);
$currency_code = $payment_currency->code;
// адрес, на который попадет пользователь по окончанию продажи в случае успеха
$redirect_url_ok = $this->config->root_url.'/order/'.$order->url;
// адрес, на который попадет пользователь по окончанию продажи в случае неудачи
$redirect_url_failed = $this->config->root_url.'/order/'.$order->url;
// Email покупателя
$user_email = $order->email;
$button = "<form action='https://rbkmoney.ru/acceptpurchase.aspx' method=POST>".
"<input type=hidden name=eshopId value='$shop_id'>".
"<input type=hidden name=orderId value='$order_id'>".
"<input type=hidden name=serviceName value='$order_description'>".
"<input type=hidden name=recipientAmount value='$amount'>".
"<input type=hidden name=recipientCurrency value='$currency_code'>".
"<input type=hidden name=successUrl value='$redirect_url_ok'>".
"<input type=hidden name=failUrl value='$redirect_url_failed'>".
"<input type=hidden name=user_email value='$user_email'>".
"<input type=submit class=payment_button value='$button_text'>".
"</form>";
return $button;
}
}

View File

@@ -0,0 +1,100 @@
<?php
/**
* Simpla CMS
*
* @copyright 2011 Denis Pikusov
* @link http://simplacms.ru
* @author Denis Pikusov
*
* К этому скрипту обращается RBKMoney в процессе оплаты
*
*/
// Работаем в корневой директории
chdir ('../../');
require_once('api/Simpla.php');
$simpla = new Simpla();
// Сумма платежа
// Сумма, которую заплатил покупатель. Дробная часть отделяется точкой.
$amount = $_POST['recipientAmount'];
//Номер сайта продавца (eshopId);
$shop_id = $_POST['eshopId'];
//Номер счета продавца (orderId);
$order_id = $_POST['orderId'];
//Описание покупки (serviceName);
$order_description = $_POST['serviceName'];
//Номер счета в системе RBK Money (eshopAccount);
$eshopAccount = $_POST['eshopAccount'];
//Валюта платежа (recipientCurrency);
$currency = $_POST['recipientCurrency'];
//Статус платежа (paymentStatus);
$status = $_POST['paymentStatus'];
if($status != 5)
exit();
//Имя покупателя (userName);
$username = $_POST['userName'];
//Email покупателя (userEmail);
$email = $_POST['userEmail'];
$paymentData = $_POST['paymentData'];
$crc = $_POST['hash'];
////////////////////////////////////////////////
// Выберем заказ из базы
////////////////////////////////////////////////
$order = $simpla->orders->get_order(intval($order_id));
if(empty($order))
die('Оплачиваемый заказ не найден');
////////////////////////////////////////////////
// Выбираем из базы соответствующий метод оплаты
////////////////////////////////////////////////
$method = $simpla->payment->get_payment_method(intval($order->payment_method_id));
if(empty($method))
die("Неизвестный метод оплаты");
$settings = unserialize($method->settings);
$secret_key = $settings['rbkmoney_secret_key'];
// Проверяем контрольную подпись
$my_crc = md5("$shop_id::$order_id::$order_description::$eshopAccount::$amount::$currency::$status::$username::$email::$paymentData::$secret_key");
if(strtoupper($my_crc) != strtoupper($crc))
die ("bad sign\n");
// Нельзя оплатить уже оплаченный заказ
if($order->paid)
die('Этот заказ уже оплачен');
// Сумма заказа у нас в магазине
// Должна быть равна переданной сумме
if($amount != $simpla->money->convert($order->total_price, $method->currency_id, false) || $amount<=0)
die("incorrect price\n");
// Проверка наличия товара для RBK не актуальна, так как платёж проходит независимо от нашего ответа
/*
$purchases = $simpla->orders->get_purchases($order->id);
foreach($purchases as $purchase)
{
$variant = $simpla->variants->get_variant(intval($purchase->variant_id));
if(empty($variant) || (!$variant->infinity && $variant->stock < $purchase->amount))
{
die("Нехватка товара $purchase->product_name $purchase->variant_name");
}
}
*/
// Установим статус оплачен
$simpla->orders->update_order(intval($order->id), array('paid'=>1));
// Спишем товары
$simpla->orders->close(intval($order->id));
$simpla->notify->email_order_user(intval($order->id));
$simpla->notify->email_order_admin(intval($order->id));
die("OK".$order_id."\n");

Binary file not shown.

After

Width:  |  Height:  |  Size: 88 KiB

View File

@@ -0,0 +1,14 @@
<?xml version="1.0" encoding="UTF-8"?>
<module>
<name>
RBK Money
</name>
<settings>
<variable>rbkmoney_id</variable>
<name>ID магазина</name>
</settings>
<settings>
<variable>rbkmoney_secret_key</variable>
<name>Секретный ключ</name>
</settings>
</module>