HEX
Server: Apache/2.4.57 (Ubuntu) mod_fcgid/2.3.9 OpenSSL/3.0.2
System: Linux vmi267337.contaboserver.net 5.15.0-25-generic #25-Ubuntu SMP Wed Mar 30 15:54:22 UTC 2022 x86_64
User: ohirex (1008)
PHP: 8.2.8
Disabled: pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,exec,system,passthru,shell_exec
Upload Files
File: /home/ohirex/web/ohirex.com/public_html/join/postback.php
<?php
//Включение отладочной информации
ini_set('display_errors', '1');
ini_set('display_startup_errors', 1);
error_reporting(E_ALL);
//Конец включения отладочной информации

require_once 'settings.php';
require_once 'db.php';
require_once 'url.php';
require_once 'requestfunc.php';

$curLink = 'http' . (isset($_SERVER['HTTPS']) ? 's' : '') . '://' . "{$_SERVER['HTTP_HOST']}{$_SERVER['REQUEST_URI']}";
$subid = $_REQUEST['subid'] ?? '';
if ($subid ===''){
    echo "No subid found! Url: $curLink";
    return;
}
$status = $_REQUEST['status'] ?? '';
if ($status ===''){
    echo "No status found! Url: $curLink";
    return;
}
$payout = $_REQUEST['payout'] ?? '';
if ($payout ===''){
    echo "No payout found! Url: $curLink";
    return;
}
$inner_status = '';
switch ($status) {
    case $lead_status_name:
        $inner_status = 'Lead';
        break;
    case $purchase_status_name:
        $inner_status = 'Purchase';
        break;
    case $reject_status_name:
        $inner_status = 'Reject';
        break;
    case $trash_status_name:
        $inner_status = 'Trash';
        break;
}
add_postback_log($subid, $inner_status, $payout);
$res = update_lead($subid, $inner_status, $payout);
foreach ($s2s_postbacks as $s2s) {
    if (!in_array($inner_status, $s2s['events'])) continue;
    if (empty($s2s['url'])) continue;
    $final_url = replace_all_macros($s2s['url']);
    $final_url = str_replace('{status}', $inner_status, $final_url);
    switch ($s2s['method']) {
        case 'GET':
            $s2s_res = get($final_url);
            break;
        case 'POST':
            $urlParts = explode('?', $final_url);
            if (count($urlParts) == 1)
                $params = array();
            else
                parse_str($urlParts[1], $params);
            $s2s_res = post($urlParts[0], $params);
            break;
    }
    add_s2s_log($final_url, $inner_status, $s2s['method'], $s2s_res);
}

if ($res)
    echo "Postback for subid $subid with status $status accepted";
else
    echo "Postback for subid $subid with status $status NOT accepted!";

function add_s2s_log($url, $status, $method, $s2s_res)
{
    //создаёт папку для лога постбэков, если её нет
    if (!file_exists(__DIR__ . "/pblogs")) mkdir(__DIR__ . "/pblogs");
    $file = __DIR__ . "/pblogs/" . date("d.m.y") . ".pb.log";
    $save_order = fopen($file, 'a+');
    fwrite($save_order, date("Y-m-d H:i:s") . " $method $url $status {$s2s_res['info']['http_code']}\n");
    fflush($save_order);
    fclose($save_order);
}

function add_postback_log($subid, $status, $payout)
{
    //создаёт папку для лога постбэков, если её нет
    if (!file_exists(__DIR__ . "/pblogs")) mkdir(__DIR__ . "/pblogs");
    $file = __DIR__ . "/pblogs/" . date("d.m.y") . ".pb.log";
    $save_order = fopen($file, 'a+');
    if ($subid === '' || $status === '') {
        $err_msg = date("Y-m-d H:i:s") . " Error! No subid or status! {$curLink}\n";
        fwrite($save_order, $err_msg);
        fflush($save_order);
        fclose($save_order);
        die($err_msg);
    } else {
        fwrite($save_order, date("Y-m-d H:i:s") . " $subid, $status, $payout\n");
        fflush($save_order);
        fclose($save_order);
    }
}

?>