Аргон
Участник
В общем проблема такая. Делаю выплату на Payeer, очень долго грузится страница, потом показывает ошибку о том что время ожидания истекло (504 Gateway Time out). При этом выплата проходит, с кошелька деньги списываются. Но они не списываются с пользователя в БД и вообще никакая инфа о выплатах в бд не заносится. Подскажите в чем проблема?
Вот код
Вот код
PHP:
<?PHP
$_OPTIMIZATION["title"] = "Payeer выплата";
$usid = $_SESSION["user_id"];
$usname = $_SESSION["user"];
$db->Query("SELECT * FROM db_users_a, db_users_b WHERE db_users_a.id = db_users_b.id AND db_users_a.id = '$user_id'");
$prof_data = $db->FetchArray();
$db->Query("SELECT * FROM db_users_b WHERE id = '$usid' LIMIT 1");
$user_data = $db->FetchArray();
$db->Query("SELECT * FROM db_config WHERE id = '1' LIMIT 1");
$sonfig_site = $db->FetchArray();
$status_array = array( 0 => "Проверяется", 1 => "выплачивается", 2 => "Отменена", 3 => "выплачено");
# Минималка серебром!
$minPay = 1;
?>
<?PHP
function ViewPurse($purse){
if( substr($purse,0,1) != "P" ) return false;
if( !preg_match("/^[0-9]{7,8}$/", substr($purse,1)) ) return false;
return $purse;
}
# Заносим выплату
if(isset($_POST["purse"])){
$purse = ViewPurse($_POST["purse"]);
$sum = intval($_POST["sum"]);
$val = "RUB";
if($purse !== false){
if($sum >= $minPay){
if($sum <= $user_data["money_p"]){
# Проверяем на существующие заявки
$db->Query("SELECT COUNT(*) FROM db_payment WHERE user_id = '$usid' AND (status = '0' OR status = '1')");
if($db->FetchRow() == 0){
### Делаем выплату ###
$payeer = new rfs_payeer($config->AccountNumber, $config->apiId, $config->apiKey);
if ($payeer->isAuth())
{
$arBalance = $payeer->getBalance();
if($arBalance["auth_error"] == 0)
{
$sum_pay = round( ($sum / $sonfig_site["ser_per_wmr"]), 2);
$balance = $arBalance["balance"]["RUB"]["DOSTUPNO"];
if( ($balance) >= ($sum_pay+1)){
$arTransfer = $payeer->transfer(array(
'curIn' => 'RUB', // счет списания
'sum' => $sum_pay, // сумма получения
'curOut' => 'RUB', // валюта получения
'to' => $purse, // получатель (email)
//'to' => '+71112223344', // получатель (телефон)
//'to' => 'P1000000', // получатель (номер счета)
'comment' => iconv('windows-1251', 'utf-8', "Выплата {$sum} руб. с проекта OpenSeason.biz")
//'anonim' => 'Y', // анонимный перевод
//'protect' => 'Y', // протекция сделки
//'protectPeriod' => '3', // период протекции (от 1 до 30 дней)
//'protectCode' => '12345', // код протекции
));
if (!empty($arTransfer["historyId"]))
{
# Снимаем с пользователя
$db->Query("UPDATE db_users_b SET money_p = money_p - '$sum' WHERE id = '$usid'");
# Вставляем запись в выплаты
$da = time();
$dd = $da + 60*60*24*15;
$ppid = $arTransfer["historyId"];
$db->Query("INSERT INTO db_payment (user, user_id, purse, sum, valuta, serebro, payment_id, date_add, status)
VALUES ('$usname','$usid','$purse','$sum_pay','RUB', '$sum','$ppid','".time()."', '3')");
$db->Query("UPDATE db_users_b SET payment_sum = payment_sum + '$sum_pay' WHERE id = '$usid'");
$db->Query("UPDATE db_stats SET all_payments = all_payments + '$sum_pay' WHERE id = '1'");
echo "<center><div class='success'>Выплата успешно произведена</div></center><BR />";
}
else
{
echo "<center><div class='error'>Тех. работы! Попробуйте позже</div></center><BR />";
}
}else echo "<center><div class='error'>Ошибка! Попробуйте заказать выплату через некоторое время</div></center><BR />";
}else echo "<center><div class='error'>Не удалось выплатить! Попробуйте позже</div></center><BR />";
}else echo "<center><div class='error'>Не удалось выплатить! Попробуйте позже</div></center><BR />";
}else echo "<center><div class='error'>У вас имеются необработанные заявки. Дождитесь их выполнения</div></center><BR />";
}else echo "<center><div class='error'>Вы указали больше, чем имеется на вашем счету</div></center><BR />";
}else echo "<center><div class='error'>Минимальная сумма для выплаты составляет {$minPay} Золотая монета.</div></center><BR />";
}else echo "<center><div class='error'>Неверный формат кошелька</div></center><BR />";
}
?>
Последнее редактирование модератором: