Файл: ai-bolit/ai-bolit.php
Строк: 3141
<?php
///////////////////////////////////////////////////////////////////////////
// Created and developed by Greg Zemskov
// Email: audit@revisium.com, http://revisium.com/ai/, skype: greg_zemskov
// Commercial usage is not allowed without a license purchase or written permission of author
// Source code usage is not allowed without author's permission
// Certificated in Federal Institute of Industrial Property in 2012
// http://revisium.com/ai/i/mini_aibolit.jpg
///////////////////////////////////////////////////////////////////////////
define('AI_EXPERT', 0); // put 1 for expert mode and 0 for basic check
//define('LANG', 'EN');
define('LANG', 'RU');
define('PASS', 'put_any_strong_password_here'); // Put any strong password to open the script from web
define('REPORT_MASK_PHPSIGN', 1);
define('REPORT_MASK_SPAMLINKS', 2);
define('REPORT_MASK_DOORWAYS', 4);
define('REPORT_MASK_SUSP', 8);
define('REPORT_MASK_CANDI', 16);
define('REPORT_MASK_WRIT', 32);
define('REPORT_MASK_FULL', REPORT_MASK_PHPSIGN | REPORT_MASK_SPAMLINKS | REPORT_MASK_DOORWAYS | REPORT_MASK_SUSP | REPORT_MASK_CANDI | REPORT_MASK_WRIT);
$defaults = array(
'path' => dirname(__FILE__),
'scan_all_files' => 0, // full scan (rather than just a .js, .php, .html, .htaccess)
'scan_delay' => 1, // delay in file scanning to reduce system load
'max_size_to_scan' => '1M',
'site_url' => '', // website url
'no_rw_dir' => 0,
'report_mask' => REPORT_MASK_FULL // full-featured report
);
define('DEBUG_MODE', 0);
define('DIR_SEPARATOR', '/');
define('DOUBLECHECK_FILE', 'AI-BOLIT-DOUBLECHECK.php');
if ((isset($_SERVER['OS']) && stripos('Win', $_SERVER['OS']) !== false)/* && stripos('CygWin', $_SERVER['OS']) === false)*/) {
define('DIR_SEPARATOR', '\');
}
if (LANG == 'RU') {
///////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
// RUSSIAN INTERFACE
///////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
define('AI_STR_001', '<h3>AI-Болит v.%s — ищет вредоносный код и вирусы в файлах.</h3><h5>Григорий Земсков, 2012-2014, <a target=_blank href="http://revisium.com/ai/">Страница проекта на revisium.com.</a> %s</h5>');
define('AI_STR_002', '<div class="update">Проверьте обновление на сайте <a href="http://revisium.com/ai/">http://revisium.com/ai/</a>. Возможно, ваша версия скрипта уже устарела.</div>');
define('AI_STR_003', 'ВНИМАНИЕ! Не оставляйте файл ai-bolit.php или файл отчета на сервере, и не давайте прямых ссылок с других сайтов на файл отчета или скрипта. Отчет содержит важную информацию о вашем сайте или сервере, сохраните его в надежном месте от посторонних глаз!');
define('AI_STR_004', 'Путь');
define('AI_STR_005', 'Дата создания');
define('AI_STR_006', 'Дата модификации');
define('AI_STR_007', 'Размер');
define('AI_STR_008', 'Конфигурация PHP');
define('AI_STR_009', "Вы установили слабый пароль на скрипт AI-BOLIT. Укажите пароль не менее 8 символов, содержащий латинские буквы в верхнем и нижнем регистре, а также цифры. Например, такой <b>%s</b>");
define('AI_STR_010', "Запустите скрипт с паролем, который установлен в переменной PASS (в начале файла). <br/>Например, так http://ваш_сайт_и_путь_до_скрипта/ai-bolit.php?p=<b>%s</b>");
define('AI_STR_011', 'Текущая директория не доступна для чтения скрипту. Пожалуйста, укажите права на доступ <b>rwxr-xr-x</b> или с помощью командной строки <b>chmod +r имя_директории</b>');
define('AI_STR_012', "<div class="rep">Текущая база скрипта содержит %s шелл-сигнатур, а также %s других вредоносных фрагментов. Затрачено времени: <b>%s</b
>.<br/>Сканирование начато: %s. Сканирование завершено: %s</div> ");
define('AI_STR_013', '<div class="rep">Всего проверено %s директорий и %s файлов.</div>');
define('AI_STR_014', '<div class="rep" style="color: #0000A0">Внимание, скрипт выполнил быструю проверку сайта. Проверяются только наиболее критические файлы, но часть вредоносных скриптов может быть не обнаружена. Пожалуйста, запустите скрипт из командной строки для выполнения полного тестирования. Подробнее смотрите в <a href="http://revisium.com/ai/faq.php">FAQ вопрос №10</a>.</div>');
define('AI_STR_015', '<div class="sec">Критические замечания</div>');
define('AI_STR_016', 'Найдены сигнатуры шелл-скрипта. Подозрение на вредоносный скрипт:');
define('AI_STR_017', 'Шелл-скрипты не найдены.');
define('AI_STR_018', 'Найдены сигнатуры javascript вирусов:');
define('AI_STR_019', 'Найдены сигнатуры исполняемых файлов unix. Они могут быть вредоносными файлами:');
define('AI_STR_020', 'Двойное расширение, зашифрованный контент или подозрение на вредоносный скрипт. Требуется дополнительный анализ:');
define('AI_STR_021', 'Подозрение на вредоносный скрипт:');
define('AI_STR_022', 'Список файловых ссылок (symlinks):');
define('AI_STR_023', 'Список скрытых файлов:');
define('AI_STR_024', 'Скорее всего этот файл лежит в каталоге с дорвеем:');
define('AI_STR_025', 'Не найдено директорий c дорвеями');
define('AI_STR_026', 'Предупреждения');
define('AI_STR_027', 'Опасный код в .htaccess (редирект на внешний сервер, подмена расширений или автовнедрение кода):');
define('AI_STR_028', 'В не .php файле содержится стартовая сигнатура PHP кода. Возможно, там вредоносный код:');
define('AI_STR_029', 'В этих файлах размещен код по продаже ссылок. Убедитесь, что размещали его вы:');
define('AI_STR_030', 'Непроверенные файлы - ошибка чтения');
define('AI_STR_031', 'В этих файлах размещены невидимые ссылки. Подозрение на ссылочный спам:');
define('AI_STR_032', 'Список невидимых ссылок:');
define('AI_STR_033', 'Отображены только первые ');
define('AI_STR_034', 'Найдены директории, в которых подозрительно много файлов .php или .html. Подозрение на дорвей:');
define('AI_STR_035', 'Скрипт использует код, который часто используются во вредоносных скриптах:');
define('AI_STR_036', 'Директории из файла .adirignore были пропущены при сканировании:');
define('AI_STR_037', 'Версии найденных CMS:');
define('AI_STR_038', 'Большие файлы (больше чем %s! Пропущено:');
define('AI_STR_039', 'Не найдено файлов больше чем %s');
define('AI_STR_040', 'Временные файлы или файлы(каталоги)-кандидаты на удаление по ряду причин:');
define('AI_STR_041', 'Потенциально небезопасно! Директории, доступные скрипту на запись:');
define('AI_STR_042', 'Не найдено директорий, доступных на запись скриптом');
define('AI_STR_043', 'Использовано памяти при сканировании: ');
define('AI_STR_044', '<div id="igid" style="display: none;"><div class="sec">Добавить в список игнорируемых</div><form name="ignore"><textarea name="list" style="width: 600px; height: 400px;"></textarea></form><div class="details">Скопируйте этот список и вставьте его в файл .aignore, чтобы исключить эти файлы из отчета.</div></div>');
define('AI_STR_045', '<div class="notice"><span class="vir">[!]</span> В скрипте отключено полное сканирование файлов, проверяются только .php, .html, .htaccess. Чтобы выполнить более тщательное сканирование, <br/>поменяйте значение настройки на <b>'scan_all_files' => 1</b> в самом верху скрипта. Скрипт в этом случае может работать очень долго. Рекомендуется отключить на хостинге лимит по времени выполнения, либо запускать скрипт из командной строки.</div>');
define('AI_STR_046', '[x] закрыть сообщение');
define('AI_STR_047', '<div class="offer" id="ofr"><span style="font-size: 15px;"><a href="http://www.revisium.com/ru/order/" target="_blank">Лечение сайта от вирусов. Защита от взлома. Гарантия.</a></span><br/><p>Быстро и качественно вылечим Ваш сайт от вирусов, удалим вредоносный код с сайта, поставим защиту от взлома. <a href="http://www.revisium.com/ru/order/">Пишите</a>.</p><a href="http://www.revisium.com/ru/order/" target="_blank">www.revisium.com →</a><p>Смотрите <a href="http://www.revisium.com/ru/quotes/" target=_blank>отзывы клиентов</a><p><p>Также приглашаем в <a href="http://vk.com/siteprotect" style="color: white" target="_blank">группу ВКонтакте: "Безопасность Веб-сайтов"</a>');
define('AI_STR_048', '<p>Если у вас есть эккаунт ВКонтакте, приглашаю в <a href="http://vk.com/siteprotect" target=_blank>группу "Безопасность Веб-сайтов"</a>: там я делюсь опытом защиты веб-сайтов и поиска вредоносных скриптов.</p>');
define('AI_STR_049', 'Отказ от гарантий: даже если скрипт не нашел вредоносных скриптов на сайте, автор не гарантирует их полное отсутствие, а также не несет ответственности за возможные последствия работы скрипта ai-bolit.php или неоправданные ожидания пользователей относительно функциональности и возможностей.');
define('AI_STR_050', 'Замечания и предложения по работе скрипта присылайте на <a href="mailto:audit@revisium.com">audit@revisium.com</a>.<p>Также буду чрезвычайно благодарен за любые упоминания скрипта ai-bolit на вашем сайте, в блоге, среди друзей, знакомых и клиентов. Ссылочку можно поставить на <a href="http://revisium.com/ai/">http://revisium.com/ai/</a>. <p>Если будут вопросы - пишите <a href="mailto:audit@revisium.com">audit@revisium.com</a>. Кстати, еще я собрал точную <a href="http://gzq.ru/">базу IP адресов</a> по городам России и Украины.');
define('AI_STR_051', 'Отчет по ');
define('AI_STR_052', 'Эвристический анализ обнаружил подозрительные файлы. Проверьте их на наличие вредоносного кода.');
define('AI_STR_053', 'Много косвенных вызовов функции');
define('AI_STR_054', 'Подозрение на обфусцированные переменные');
define('AI_STR_055', 'Подозрительное использование массива глобальных переменных');
define('AI_STR_056', 'Дробление строки на символы');
define('AI_STR_057', 'Сканирование выполнено в обычном режиме. Некоторые вредоносные скрипты могут быть не обнаружены.<br> Желательно проверить сайт в режиме "Эксперт". Подробно описано в <a href="http://www.revisium.com/ai/faq.php">FAQ</a> и инструкции к скрипту.');
} else {
///////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
// ENGLISH INTERFACE
///////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
define('AI_STR_001', '<h3>AI-BOLIT v.%s — Enhanced Server-Side Detector of Viruses, Malicious and Hacker's Scripts.</h3><h5>Greg Zemskov, 2012-2014, <a target=_blank href="http://revisium.com/aibo/">AI-BOLIT web site.</a>. Non-commercial use only.</h5>');
define('AI_STR_002', '<div class="update">Check for updates on <a href="http://revisium.com/ai/">http://revisium.com/ai/</a>. Probably your version is out-of-date.</div>');
define('AI_STR_003', 'Caution! Do not leave either ai-bolit.php or report file on server and do not provide direct links to the report file. Report file contains sensitive information about your website which could be used by hackers. So keep it in safe place and don't leave on website!');
define('AI_STR_004', 'Path');
define('AI_STR_005', 'Created');
define('AI_STR_006', 'Modified');
define('AI_STR_007', 'Size');
define('AI_STR_008', 'PHP Info');
define('AI_STR_009', "Your password for AI-BOLIT is weak. Password must be more than 8 character length, contain both latin letters in upper and lower case, and digits. E.g. <b>%s</b>");
define('AI_STR_010', "Open AI-BOLIT with password specified in the beggining of file in PASS variable. <br/>E.g. http://you_website.com/ai-bolit.php?p=<b>%s</b>");
define('AI_STR_011', 'Current folder is not readable. Please change permission for <b>rwxr-xr-x</b> or using command line <b>chmod +r folder_name</b>');
define('AI_STR_012', "<div class="rep">%s malicious signatures known, %s virus signatures and other malicious code. Elapsed: <b>%s</b
>.<br/>Started: %s. Stopped: %s</div> ");
define('AI_STR_013', '<div class="rep">Scanned %s folders and %s files.</div>');
define('AI_STR_014', '<div class="rep" style="color: #0000A0">Attention! Script has performed quick scan. It scans only .html/.js/.php files in quick scan mode so some of malicious scripts might not be detected. <br>Please launch script from a command line thru SSH to perform full scan.');
define('AI_STR_015', '<div class="sec">Critical</div>');
define('AI_STR_016', 'Shell script signatures detected. Might be a malicious or hacker's script:');
define('AI_STR_017', 'Shell scripts signatures not detected.');
define('AI_STR_018', 'Javascript virus signatures detected:');
define('AI_STR_019', 'Unix executables signatures detected. They might be a malicious binaries or rootkits:');
define('AI_STR_020', 'Suspicious encoded strings, extra .php extention or external includes detected in PHP files. Might be a malicious or hacker's script:');
define('AI_STR_021', 'Might be a malicious or hacker's script:');
define('AI_STR_022', 'Symlinks:');
define('AI_STR_023', 'Hidden files:');
define('AI_STR_024', 'Files might be a part of doorway:');
define('AI_STR_025', 'Doorway folders not detected');
define('AI_STR_026', 'Warnings');
define('AI_STR_027', 'Malicious code in .htaccess (redirect to external server, extention handler replacement or malicious code auto-append):');
define('AI_STR_028', 'Non-PHP file has PHP signature. Check for malicious code:');
define('AI_STR_029', 'This script has black-SEO links or linkfarm. Check if it was installed by your:');
define('AI_STR_030', 'Reading error. Skipped.');
define('AI_STR_031', 'These files have invisible links, might be black-seo stuff:');
define('AI_STR_032', 'List of invisible links:');
define('AI_STR_033', 'Displayed first ');
define('AI_STR_034', 'Folders contained too many .php or .html files. Might be a doorway:');
define('AI_STR_035', 'Suspicious code detected. It's usually used in malicious scrips:');
define('AI_STR_036', 'The following list of files specified in .adirignore has been skipped:');
define('AI_STR_037', 'CMS found:');
define('AI_STR_038', 'Large files (greater than %s! Skipped:');
define('AI_STR_039', 'Files greater than %s not found');
define('AI_STR_040', 'Files recommended to be remove due to security reason:');
define('AI_STR_041', 'Potentially unsafe! Folders which are writable for scripts:');
define('AI_STR_042', 'Writable folders not found');
define('AI_STR_043', 'Memory used: ');
define('AI_STR_044', '<div id="igid" style="display: none;"><div class="sec">Add to ignore list</div><form name="ignore"><textarea name="list" style="width: 600px; height: 400px;"></textarea></form><div class="details">Copy and paste the following list into .aignore to eliminate these files from AI-BOLIT report.</div></div>');
define('AI_STR_045', '<div class="notice"><span class="vir">[!]</span> Ai-BOLIT is working in quick scan mode, only .php, .html, .htaccess files will be checked. Change the following setting 'scan_all_files' => 1 to perform full scanning.</b>. </div>');
define('AI_STR_046', '[x] close window');
define('AI_STR_047', '<div class="offer" id="ofr"><span style="font-size: 15px;"><a href="http://www.revisium.com/ru/order/" target="_blank">
We will protect your website against hackers and viruses with guarantee!</a></span><br/>
<p>We completely remove malicious software and scripts from your website, protect website against hackers, check servers for rootkits and suid-files, teach you how to keep your website secured. <a href="http://www.revisium.com/en/order/">Contact Us</a>');
define('AI_STR_048', '');
define('AI_STR_049', "Disclaimer: I'm not liable to you for any damages, including general, special, incidental or consequential damages arising out of the use or inability to use the script (including but not limited to loss of data or report being rendered inaccurate or failure of the script). There's no warranty for the program. Use at your own risk. ");
define('AI_STR_050', "I'm sincerely appreciate reports for any bugs you may found in the script. Please email me: <a href="mailto:audit@revisium.com">audit@revisium.com</a>.<p> Also I appriciate any reference to the script in your blog or forum posts. Thank you for the link to download page: <a href="http://revisium.com/aibo/">http://revisium.com/aibo/</a>");
define('AI_STR_051', 'Report for ');
define('AI_STR_052', 'Heuristic Analyzer has detected suspicious files. Check if they are malware.');
define('AI_STR_053', 'Function called by reference');
define('AI_STR_054', 'Suspected for obfuscated variables');
define('AI_STR_055', 'Suspected for $GLOBAL array usage');
define('AI_STR_056', 'Abnormal split of string');
define('AI_STR_057', 'Scanning has been done in simple mode. It is strongly recommended to perform scanning in "Expert" mode. See readme.txt for details.');
}
///////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
// This is signatures wrapped into base64.
$g_DBShe = unserialize(base64_decode("YTozNTQ6e2k6MDtzOjE1OiJOZXRAZGRyZXNzIE1haWwiO2k6MTtzOjM0OiJQYXNzd29yZDo8cz4iLiRfUE9TVFs8cT5wYXNzd2Q8cT5dIjtpOjI7czoxNToiQ3JlYXRlZCBCeSBFTU1BIjtpOjM7czoxMjoiR0lGODlBOzw/cGhwIjtpOjQ7czoyODoib1RhdDhEM0RzRTgnJn5oVTA2Q0NINTskZ1lTcSI7aTo1O3M6MjA6IiRtZDU9bWQ1KCIkcmFuZG9tIik7IjtpOjY7czo2OiIzeHAxcjMiO2k6NztzOjMyOiIkaW09c3Vic3RyKCR0eCwkcCsyLCRwMi0oJHArMikpOyI7aTo4O3M6MTU6Ik5pbmphVmlydXMgSGVyZSI7aTo5O3M6MjE6IjdQMXRkK05XbGlhSS9oV2taNFZYOSI7aToxMDtzOjQ6IkFtIXIiO2k6MTE7czoxMDoiPGRvdD5JcklzVCI7aToxMjtzOjEwOiJuZHJvaXxodGNfIjtpOjEzO3M6MTA6ImFuZGV4fG9vZ2wiO2k6MTQ7czoxNzoiSGFja2VkIEJ5IEVuRExlU3MiO2k6MTU7czoxNzoiKCRfUE9TVFsiZGlyIl0pKTsiO2k6MTY7czo1NToiKCRpbmRhdGEsJGI2ND0xKXtpZigkYjY0PT0xKXskY2Q9YmFzZTY0X2RlY29kZSgkaW5kYXRhKSI7aToxNztzOjc1OiIkaW09c3Vic3RyKCRpbSwwLCRpKS5zdWJzdHIoJGltLCRpMisxLCRpNC0oJGkyKzEpKS5zdWJzdHIoJGltLCRpNCsxMixzdHJsZW4iO2k6MTg7czoxODoiPD9waHAgZWNobyAiIyEhIyI7IjtpOjE5O3M6MTA6IlB1bmtlcjJCb3QiO2k6MjA7czoxMToiJHNoM2xsQ29sb3IiO2k6MjE7czo0NzoiQGNocigoJGhbJGVbJG9dXTw8NCkrKCRoWyRlWysrJG9dXSkpO319ZXZhbCgkZCkiO2k6MjI7czozNjoicHBjfG1pZHB8d2luZG93cyBjZXxtdGt8ajJtZXxzeW1iaWFuIjtpOjIzO3M6NDA6ImFiYWNob3xhYml6ZGlyZWN0b3J5fGFib3V0fGFjb29ufGFsZXhhbmEiO2k6MjQ7czo1OiJaZWQweCI7aToyNTtzOjg6Iltjb2RlcnpdIjtpOjI2O3M6ODoiZGFya21pbnoiO2k6Mjc7czoxMzoiUmVhTF9QdU5pU2hFciI7aToyODtzOjExOiJbIFBocHJveHkgXSI7aToyOTtzOjc6Ik9vTl9Cb3kiO2k6MzA7czoyMDoiX19WSUVXU1RBVEVFTkNSWVBURUQiO2k6MzE7czo2OiJNNGxsM3IiO2k6MzI7czoyNToiY3JlYXRlRmlsZXNGb3JJbnB1dE91dHB1dCI7aTozMztzOjg6IlBhc2hrZWxhIjtpOjM0O3M6MjI6Il5jXmFebF5wXmVecl5fXmdeZV5yXnAiO2k6MzU7czoxNDoiPT0gImJpbmRzaGVsbCIiO2k6MzY7czoxNToiV2ViY29tbWFuZGVyIGF0IjtpOjM3O3M6MjU6Imlzc2V0KCRfUE9TVFsnZXhlY2dhdGUnXSkiO2k6Mzg7czozNzoiZndyaXRlKCRmcHNldHYsIGdldGVudigiSFRUUF9DT09LSUUiKSI7aTozOTtzOjIwOiItSS91c3IvbG9jYWwvYmFuZG1pbiI7aTo0MDtzOjIxOiIkT09PMDAwMDAwPXVybGRlY29kZSgiO2k6NDE7czo4OiJZRU5Jx0VSSSI7aTo0MjtzOjE1OiJsZXRha3Nla2FyYW5nKCkiO2k6NDM7czo2OiJkM2xldGUiO2k6NDQ7czoyMDoiZWNobyAiPHNjcmlwdD5hbGVydCgiO2k6NDU7czo0MzoiZnVuY3Rpb24gdXJsR2V0Q29udGVudHMoJHVybCwgJHRpbWVvdXQgPSA1KSI7aTo0NjtzOjQ2OiJvdmVyZmxvdy15OnNjcm9sbDtcIj4iLiRsaW5rcy4kaHRtbF9tZlsnYm9keSddIjtpOjQ3O3M6NjoiJGV2YTF0IjtpOjQ4O3M6MTY6Ik1hZGUgYnkgRGVsb3JlYW4iO2k6NDk7czo3NToiaWYoZW1wdHkoJF9HRVRbJ3ppcCddKSBhbmQgZW1wdHkoJF9HRVRbJ2Rvd25sb2FkJ10pICYgZW1wdHkoJF9HRVRbJ2ltZyddKSl7IjtpOjUwO3M6NjU6InN0cl9yb3QxMygkYmFzZWFbKCRkaW1lbnNpb24qJGRpbWVuc2lvbi0xKSAtICgkaSokZGltZW5zaW9uKyRqKV0pIjtpOjUxO3M6NjA6IlIwbEdPRGxoRXdBUUFMTUFBQUFBQVAvLy81eWNBTTdPWS8vL25QLy96di9PblBmMzkvLy8vd0FBQUFBQSI7aTo1MjtzOjQ1OiJwcmVnX21hdGNoKCchTUlEUHxXQVB8V2luZG93cy5DRXxQUEN8U2VyaWVzNjAiO2k6NTM7czo0NzoicHJlZ19tYXRjaCgnLyg/PD1SZXdyaXRlUnVsZSkuKig/PVxbTFwsUlw9MzAyXF0iO2k6NTQ7czozNzoiJHVybCA9ICR1cmxzW3JhbmQoMCwgY291bnQoJHVybHMpLTEpXSI7aTo1NTtzOjgwOiJ3cF9wb3N0cyBXSEVSRSBwb3N0X3R5cGUgPSAncG9zdCcgQU5EIHBvc3Rfc3RhdHVzID0gJ3B1Ymxpc2gnIE9SREVSIEJZIGBJRGAgREVTQyI7aTo1NjtzOjY1OiJodHRwOi8vJy4kX1NFUlZFUlsnSFRUUF9IT1NUJ10udXJsZGVjb2RlKCRfU0VSVkVSWydSRVFVRVNUX1VSSSddKSI7aTo1NztzOjM2OiJmd3JpdGUoJGYsZ2V0X2Rvd25sb2FkKCRfR0VUWyd1cmwnXSkiO2k6NTg7czoyNToiaW5pX3NldCgibWFnaWNfcXVvdGVzX2dwYyI7aTo1OTtzOjI1OiJpbmlfc2V0KCdtYWdpY19xdW90ZXNfZ3BjIjtpOjYwO3M6NzQ6IiRwYXJhbSB4ICRuLnN1YnN0ciAoJHBhcmFtLCBsZW5ndGgoJHBhcmFtKSAtIGxlbmd0aCgkY29kZSklbGVuZ3RoKCRwYXJhbSkpIjtpOjYxO3M6NDc6IiR0aW1lX3N0YXJ0ZWQuJHNlY3VyZV9zZXNzaW9uX3VzZXIuc2Vzc2lvbl9pZCgpIjtpOjYyO3M6NDg6IiR0aGlzLT5GLT5HZXRDb250cm9sbGVyKCRfU0VSVkVSWydSRVFVRVNUX1VSSSddKSI7aTo2MztzOjIxOiJsdWNpZmZlckBsdWNpZmZlci5vcmciO2k6NjQ7czoyNzoiYmFzZTY0X2RlY29kZSgkY29kZV9zY3JpcHQpIjtpOjY1O3M6MjE6InVubGluaygkd3JpdGFibGVfZGlycyI7aTo2NjtzOjQxOiJmaWxlX2dldF9jb250ZW50cyh0cmltKCRmWyRfR0VUWydpZCddXSkpOyI7aTo2NztzOjEwOiJDeWJlc3RlcjkwIjtpOjY4O3M6NTU6ImlzX2NhbGxhYmxlKCdleGVjJykgYW5kICFpbl9hcnJheSgnZXhlYycsICRkaXNhYmxlZnVuY3MiO2k6Njk7czoxNDoiJEdMT0JBTFNbJ19fX18iO2k6NzA7czoxODoidGltZSgpIC0gMTA1MjAwMjAwIjtpOjcxO3M6Mjc6Ii9ob21lL215ZGlyL2VnZ2Ryb3AvZmlsZXN5cyI7aTo3MjtzOjI5OiItLURDQ0RJUiBbbGluZGV4ICRVc2VyKCRpKSAyXSI7aTo3MztzOjEyOiJ1bmJpbmQgUkFXIC0iO2k6NzQ7czoxMToicHV0Ym90ICRib3QiO2k6NzU7czoxMzoicHJpdm1zZyAkbmljayI7aTo3NjtzOjI2OiJwcm9jIGh0dHA6OkNvbm5lY3Qge3Rva2VufSI7aTo3NztzOjQzOiJzZXQgZ29vZ2xlKGRhdGEpIFtodHRwOjpkYXRhICRnb29nbGUocGFnZSldIjtpOjc4O3M6MjI6ImJpbmQgam9pbiAtICogZ29wX2pvaW4iO2k6Nzk7czoxMzoicHJpdm1zZyAkY2hhbiI7aTo4MDtzOjI0OiJyNGFUYy5kUG50RS9menRTRjFiSDNSSDAiO2k6ODE7czoxMDoiYmluZCBkY2MgLSI7aTo4MjtzOjM1OiJraWxsIC1DSExEIFwkYm90cGlkID4vZGV2L251bGwgMj4mMSI7aTo4MztzOjUwOiJyZWdzdWIgLWFsbCAtLSAsIFtzdHJpbmcgdG9sb3dlciAkb3duZXJdICIiIG93bmVycyI7aTo4NDtzOjMwOiJiaW5kIGZpbHQgLSAiXDAwMUFDVElPTiAqXDAwMSIiO2k6ODU7czoyNzoiYXl1IHByMSBwcjIgcHIzIHByNCBwcjUgcHI2IjtpOjg2O3M6MjA6InNldCBwcm90ZWN0LXRlbG5ldCAwIjtpOjg3O3M6MzM6Ii91c3IvbG9jYWwvYXBhY2hlL2Jpbi9odHRwZCAtRFNTTCI7aTo4ODtzOjc2OiIkdHN1MltyYW5kKDAsY291bnQoJHRzdTIpIC0gMSldLiR0c3UxW3JhbmQoMCxjb3VudCgkdHN1MSkgLSAxKV0uJHRzdTJbcmFuZCgwIjtpOjg5O3M6NjoidWRwOi8vIjtpOjkwO3M6MTk6ImZvcGVuKCcvZXRjL3Bhc3N3ZCciO2k6OTE7czoxMToiZjBWTVJnRUJBUUEiO2k6OTI7czoyMzoiaXNfd3JpdGFibGUoIi92YXIvdG1wIikiO2k6OTM7czozNToiMGQwYTBkMGE2NzZjNmY2MjYxNmMyMDI0NmQ3OTVmNzM2ZDciO2k6OTQ7czo5OiJldGFsZm5pemciO2k6OTU7czozNzoiSkhacGMybDBZMjkxYm5RZ1BTQWtTRlJVVUY5RFQwOUxTVVZmViI7aTo5NjtzOjEzOiJlZG9jZWRfNDZlc2FiIjtpOjk3O3M6NToiZS8qLi8iO2k6OTg7czoyODoiQHNldGNvb2tpZSgiaGl0IiwgMSwgdGltZSgpKyI7aTo5OTtzOjIzOiJldmFsKGZpbGVfZ2V0X2NvbnRlbnRzKCI7aToxMDA7czo0NjoiZmluZF9kaXJzKCRncmFuZHBhcmVudF9kaXIsICRsZXZlbCwgMSwgJGRpcnMpOyI7aToxMDE7czo2OToiQGNvcHkoJF9GSUxFU1tmaWxlTWFzc11bdG1wX25hbWVdLCRfUE9TVFtwYXRoXS4kX0ZJTEVTW2ZpbGVNYXNzXVtuYW1lIjtpOjEwMjtzOjc2OiJpbnQzMigoKCR6ID4+IDUgJiAweDA3ZmZmZmZmKSBeICR5IDw8IDIpICsgKCgkeSA+PiAzICYgMHgxZmZmZmZmZikgXiAkeiA8PCA0IjtpOjEwMztzOjExOiJWT0JSQSBHQU5HTyI7aToxMDQ7czo1OToiZWNobyB5IDsgc2xlZXAgMSA7IH0gfCB7IHdoaWxlIHJlYWQgOyBkbyBlY2hvIHokUkVQTFk7IGRvbmUiO2k6MTA1O3M6OToiPHN0ZGxpYi5oIjtpOjEwNjtzOjQ1OiJhZGRfZmlsdGVyKCd0aGVfY29udGVudCcsICdfYmxvZ2luZm8nLCAxMDAwMSkiO2k6MTA3O3M6MTc6Iml0c29rbm9wcm9ibGVtYnJvIjtpOjEwODtzOjI4OiJpZiBzZWxmLmhhc2hfdHlwZSA9PSAncHdkdW1wIjtpOjEwOTtzOjU5OiIkZnJhbWV3b3JrLnBsdWdpbnMubG9hZCgiI3tycGN0eXBlLmRvd25jYXNlfXJwYyIsIG9wdHMpLnJ1biI7aToxMTA7czo1Nzoic3VicHJvY2Vzcy5Qb3BlbignJXNnZGIgLXAgJWQgLWJhdGNoICVzJyAlIChnZGJfcHJlZml4LCBwIjtpOjExMTtzOjU3OiJhcmdwYXJzZS5Bcmd1bWVudFBhcnNlcihkZXNjcmlwdGlvbj1oZWxwLCBwcm9nPSJzY3R1bm5lbCIiO2k6MTEyO3M6MzI6InJ1bGVfcmVxID0gcmF3X2lucHV0KCJTb3VyY2VGaXJlIjtpOjExMztzOjUwOiJvcy5zeXN0ZW0oJ2VjaG8gYWxpYXMgbHM9Ii5scy5iYXNoIiA+PiB+Ly5iYXNocmMnKSI7aToxMTQ7czo0MjoiY29ubmVjdGlvbi5zZW5kKCJzaGVsbCAiK3N0cihvcy5nZXRjd2QoKSkrIjtpOjExNTtzOjY3OiJwcmludCgiWyFdIEhvc3Q6ICIgKyBob3N0bmFtZSArICIgbWlnaHQgYmUgZG93biFcblshXSBSZXNwb25zZSBDb2RlIjtpOjExNjtzOjY5OiJkZWYgZGFlbW9uKHN0ZGluPScvZGV2L251bGwnLCBzdGRvdXQ9Jy9kZXYvbnVsbCcsIHN0ZGVycj0nL2Rldi9udWxsJykiO2k6MTE3O3M6ODM6InN1YnByb2Nlc3MuUG9wZW4oY21kLCBzaGVsbCA9IFRydWUsIHN0ZG91dD1zdWJwcm9jZXNzLlBJUEUsIHN0ZGVycj1zdWJwcm9jZXNzLlNURE9VIjtpOjExODtzOjQ3OiJpZihpc3NldCgkX0dFVFsnaG9zdCddKSYmaXNzZXQoJF9HRVRbJ3RpbWUnXSkpeyI7aToxMTk7czoxNToiTklHR0VSUy5OSUdHRVJTIjtpOjEyMDtzOjI1OiJIVFRQIGZsb29kIGNvbXBsZXRlIGFmdGVyIjtpOjEyMTtzOjIxOiI4MCAtYiAkMSAtaSBldGgwIC1zIDgiO2k6MTIyO3M6MTM6ImV4cGxvaXRjb29raWUiO2k6MTIzO3M6MjY6InN5c3RlbSgicGhwIC1mIHhwbCAkaG9zdCIpIjtpOjEyNDtzOjExOiJzaCBnbyAkMS4keCI7aToxMjU7czoxMjoiYXo4OHBpeDAwcTk4IjtpOjEyNjtzOjMwOiJ1bmxlc3Mob3BlbihQRkQsJGdfdXBsb2FkX2RiKSkiO2k6MTI3O3M6MTE6Ind3dy50MHMub3JnIjtpOjEyODtzOjM5OiIkdmFsdWUgPX4gcy8lKC4uKS9wYWNrKCdjJyxoZXgoJDEpKS9lZzsiO2k6MTI5O3M6MTQ6IlRoZSBEYXJrIFJhdmVyIjtpOjEzMDtzOjYxOiJRM0psWkdsMElEb2dWVzVrWlhKbmNtOTFibVFnUkdWMmFXd2dKbTVpYzNBN0lDQjhEUW84WVNCb2NtVm1QIjtpOjEzMTtzOjI5OiJ9ZWxzZWlmKCRfR0VUWydwYWdlJ109PSdkZG9zJyI7aToxMzI7czoxNjoieyRfUE9TVFsncm9vdCddfSI7aToxMzM7czozOToiSS9nY1ovdlgwQTEwRERSRGc3RXprL2QrMys4cXZxcVMxSzArQVhZIjtpOjEzNDtzOjQ5OiInaHR0cGQuY29uZicsJ3Zob3N0cy5jb25mJywnY2ZnLnBocCcsJ2NvbmZpZy5waHAnIjtpOjEzNTtzOjY0OiJGSjNGa3VQS0ZrVS81M1dFQm1JYWlwa3RuTHdRVzh6NDlkYzFyYmJMcXN3OGU2OWw2dkpNKzMvMTI0eFZuKzdsIjtpOjEzNjtzOjEwMjoiXHUwMDNjXHUwMDY5XHUwMDZkXHUwMDY3XHUwMDIwXHUwMDczXHUwMDcyXHUwMDYzXHUwMDNkXHUwMDIyXHUwMDY4XHUwMDc0XHUwMDc0XHUwMDcwXHUwMDNhXHUwMDJmXHUwMDJmIjtpOjEzNztzOjU1OiI0NjM4Mzk2MTBjMDAwYjAwODAwMTAwZmZmZmZmZmZmZmZmMjFmOTA0MDEwMDAwMDEwMDJjMDAwIjtpOjEzODtzOjM3OiJYVkZOYXdJeEVMMEwvb2RoaFpKb2NGMnYyb0tJQlNtdG9udHJaIjtpOjEzOTtzOjM2OiI3VmgzV0ZQWnRqOHBrRUFTRWlRSVNEc29DaWdkUmtDREpBSUMiO2k6MTQwO3M6MzY6Ijk3UUVYUkFzOTljOThIZGpvaDl6WmlUUjEyR2F6b0pVSWlMVSI7aToxNDE7czozMDoiZnJlYWQoJGZwLCBmaWxlc2l6ZSgkZmljaGVybykpIjtpOjE0MjtzOjI0OiIkYmFzbGlrPSRfUE9TVFsnYmFzbGlrJ10iO2k6MTQzO3M6MTg6InByb2Nfb3BlbignSUhTdGVhbSI7aToxNDQ7czo1NjoiXHgzMVx4ZGJceGY3XHhlM1x4NTNceDQzXHg1M1x4NmFceDAyXHg4OVx4ZTFceGIwXHg2Nlx4Y2QiO2k6MTQ1O3M6NTg6IkFBQUFBQUFBTUFBd0FCQUFBQWVBVUFBRFFBQUFEc0NRQUFBQUFBQURRQUlBQURBQ2dBRndBVUFBRUEiO2k6MTQ2O3M6MzE6IiRpbmlbJ3VzZXJzJ10gPSBhcnJheSgncm9vdCcgPT4iO2k6MTQ3O3M6NTg6IkhKM0hqdXRja29SZnBYZjlBMXpRTzJBd0RSclJleTl1R3ZUZWV6NzlxQWFvMWEwcmd1ZGtaa1I4UmEiO2k6MTQ4O3M6NTA6ImN1cmxfc2V0b3B0KCRjaCwgQ1VSTE9QVF9VUkwsICJodHRwOi8vJGhvc3Q6MjA4MiIpIjtpOjE0OTtzOjE2OiJzeXN0ZW0oIndob2FtaSIpIjtpOjE1MDtzOjM5OiJ0YW9PSTh1eUxieklTTElOOUZzWGRLN2grL2RkMlluSVJVb3RCbE4iO2k6MTUxO3M6NzI6ImJNRml1YlJ3SXpxaUhoa1BrSWFwVFIzZFZENUFva3E4bVJGZE1ta1BVWGpXUlNjSi9XZlJmTHBQUGJHeThndGlVcGx1b2cwZCI7aToxNTI7czo3MToiNW9IblJuNmlkb3pOeGtVNmhoZGF1THlieTZMSXF4V1ZSUWRKblcxcUhIZU1SbDU5TTJTcXczRGtCVXpWOEtLbTFwclk5V1giO2k6MTUzO3M6NTg6IjNIanF4Y2xrWmZwV2IxU3d6d1RtcDFLWURBZXcrVEZ0NEgzajU5a3pXNmVkTVJuTFAzL3RZU0JQbWYiO2k6MTU0O3M6NjQ6IjwlPSAiXCIgJiBvU2NyaXB0TmV0LkNvbXB1dGVyTmFtZSAmICJcIiAmIG9TY3JpcHROZXQuVXNlck5hbWUgJT4iO2k6MTU1O3M6MTA0OiJzcWxDb21tYW5kLlBhcmFtZXRlcnMuQWRkKCgoVGFibGVDZWxsKWRhdGFHcmlkSXRlbS5Db250cm9sc1swXSkuVGV4dCwgU3FsRGJUeXBlLkRlY2ltYWwpLlZhbHVlID0gZGVjaW1hbCI7aToxNTY7czo5MDoiUmVzcG9uc2UuV3JpdGUoIjxicj4oICkgPGEgaHJlZj0/dHlwZT0xJmZpbGU9IiAmIHNlcnZlci5VUkxlbmNvZGUoaXRlbS5wYXRoKSAmICJcPiIgJiBpdGVtIjtpOjE1NztzOjExMToibmV3IEZpbGVTdHJlYW0oUGF0aC5Db21iaW5lKGZpbGVJbmZvLkRpcmVjdG9yeU5hbWUsIFBhdGguR2V0RmlsZU5hbWUoaHR0cFBvc3RlZEZpbGUuRmlsZU5hbWUpKSwgRmlsZU1vZGUuQ3JlYXRlIjtpOjE1ODtzOjcxOiJSZXNwb25zZS5Xcml0ZShTZXJ2ZXIuSHRtbEVuY29kZSh0aGlzLkV4ZWN1dGVDb21tYW5kKHR4dENvbW1hbmQuVGV4dCkpKSI7aToxNTk7czo4MzoiPCU9UmVxdWVzdC5TZXJ2ZXJ2YXJpYWJsZXMoIlNDUklQVF9OQU1FIiklPj90eHRwYXRoPTwlPVJlcXVlc3QuUXVlcnlTdHJpbmcoInR4dHBhdGgiO2k6MTYwO3M6NjA6Im91dHN0ciArPSBzdHJpbmcuRm9ybWF0KCI8YSBocmVmPSc/ZmRpcj17MH0nPnsxfS88L2E+Jm5ic3A7IiI7aToxNjE7czozNjoiaW5jbHVkZSgkX1NFUlZFUlsnSFRUUF9VU0VSX0FHRU5UJ10pIjtpOjE2MjtzOjYxOiJRT2lLV0FnVjYxM0x2c3RLWStVQjk4SlpUUkdJaFlCZEh1SkNBd20rWHRoMTZBd1E4WDR0UE1jTVZaUXRlIjtpOjE2MztzOjMzOiJyZS5maW5kYWxsKGRpcnQrJyguKiknLHByb2dubSlbMF0iO2k6MTY0O3M6NDA6ImZpbmQgLyAtbmFtZSAuc3NoID4gJGRpci9zc2hrZXlzL3NzaGtleXMiO2k6MTY1O3M6NjA6IkZTX2Noa19mdW5jX2xpYmM9KCAkKHJlYWRlbGYgLXMgJEZTX2xpYmMgfCBncmVwIF9jaGtAQCB8IGF3ayI7aToxNjY7czo0OToiTHk4M01UZzNPV1F5TVRKa1l6aGpZbVkwWkRSbVpEQTBOR0V6WkRFM1pqazNabUkyTiI7aToxNjc7czo5NToiJGZpbGUgPSAkX0ZJTEVTWyJmaWxlbmFtZSJdWyJuYW1lIl07IGVjaG8gIjxhIGhyZWY9XCIkZmlsZVwiPiRmaWxlPC9hPiI7fSBlbHNlIHtlY2hvKCJlbXB0eSIpO30iO2k6MTY4O3M6NDg6IkRKN1ZJVTdSSUNYcjZzRUVWMmNCdEhEU09lOW5WZHBFR2hFbXZSVlJOVVJmdzF3USI7aToxNjk7czo1MToiTHo4X0x5OHZEeDhlX3Y3LTd1N3Uzczd1enM3T3pxNnVucTdlcnE2dXZxNS1qbzZ1am41IjtpOjE3MDtzOjgzOiJpVkJPUncwS0dnb0FBQUFOU1VoRVVnQUFBQW9BQUFBSUNBWUFBQURBLW02MkFBQUFBWE5TUjBJQXJzNGM2UUFBQUFSblFVMUJBQUN4and2OFlRVSI7aToxNzE7czo3MToiUDJsQ1Axb3VXZzFXYzBFb0pGOURTMVJxSjNOSVFVOG5aRDVUVXo0bmMxbDRKeWsrWFExV0xrMWxPVTE2S0NJdlQwZzlUVWciO2k6MTcyO3M6Njk6IkQxMCsrM3FCbkhmeWgxaUk1dFp2NnZXaU8xaFZRdkRaNWNyS1YwTHR1eW8zcXczY0FnTXV6QjZMWEFSQlM3SWU5QlR4bSI7aToxNzM7czo3NDoiZTVXclBZTk01dURVQzJ3cnNaSHlSTFNEZzF5V1NtTXpQY3pXbUZGQUZxR1IwRVRjcmZhNU1TUWVDY0hCRWM1Y2twWlI2Q3JXdjEiO2k6MTc0O3M6NTE6InNlcnZlci48L3A+XHJcbjwvYm9keT48L2h0bWw+IjtleGl0O31pZihwcmVnX21hdGNoKCI7aToxNzU7czo0MzoiT0RFMU5EVmpaR1F5WkdFeE5HWTVaalE0T1dGbE5XRXdNakZrT1dFek5qRSI7aToxNzY7czo3NzoiJEZjaG1vZCwkRmRhdGEsJE9wdGlvbnMsJEFjdGlvbiwkaGRkYWxsLCRoZGRmcmVlLCRoZGRwcm9jLCR1bmFtZSwkaWRkKTpzaGFyZWQiO2k6MTc3O3M6MTU6InBocCAiLiR3c29fcGF0aCI7aToxNzg7czo2MToiJHByb2Q9InN5Ii4icyIuInRlbSI7JGlkPSRwcm9kKCRfUkVRVUVTVFsncHJvZHVjdCddKTskeydpZCd9OyI7aToxNzk7czozMDoiQGFzc2VydCgkX1JFUVVFU1RbJ1BIUFNFU1NJRCddIjtpOjE4MDtzOjY4OiJQT1NUIHskcGF0aH17JGNvbm5lY3Rvcn0/Q29tbWFuZD1GaWxlVXBsb2FkJlR5cGU9RmlsZSZDdXJyZW50Rm9sZGVyPSI7aToxODE7czozMDoiZmluZCAvIC10eXBlIGYgLW5hbWUgLmh0cGFzc3dkIjtpOjE4MjtzOjMxOiJmaW5kIC8gLXR5cGUgZiAtcGVybSAtMDIwMDAgLWxzIjtpOjE4MztzOjMxOiJmaW5kIC8gLXR5cGUgZiAtcGVybSAtMDQwMDAgLWxzIjtpOjE4NDtzOjg3OiIiYWRtaW4xLnBocCIsICJhZG1pbjEuaHRtbCIsICJhZG1pbjIucGhwIiwgImFkbWluMi5odG1sIiwgInlvbmV0aW0ucGhwIiwgInlvbmV0aW0uaHRtbCIiO2k6MTg1O3M6OTc6IkBwYXRoMT0oJ2FkbWluLycsJ2FkbWluaXN0cmF0b3IvJywnbW9kZXJhdG9yLycsJ3dlYmFkbWluLycsJ2FkbWluYXJlYS8nLCdiYi1hZG1pbi8nLCdhZG1pbkxvZ2luLyciO2k6MTg2O3M6MzY6ImNhdCAke2Jsa2xvZ1syXX0gfCBncmVwICJyb290Ong6MDowIiI7aToxODc7czo0NjoiP3VybD0nLiRfU0VSVkVSWydIVFRQX0hPU1QnXSkudW5saW5rKFJPT1RfRElSLiI7aToxODg7czo0NjoibG9uZyBpbnQ6dCgwLDMpPXIoMCwzKTstMjE0NzQ4MzY0ODsyMTQ3NDgzNjQ3OyI7aToxODk7czo3NToiY3JlYXRlX2Z1bmN0aW9uKCImJCIuImZ1bmN0aW9uIiwiJCIuImZ1bmN0aW9uID0gY2hyKG9yZCgkIi4iZnVuY3Rpb24pLTMpOyIpIjtpOjE5MDtzOjE2OiJldmExZllsYmFrQmNWU2lyIjtpOjE5MTtzOjg2OiJmdW5jdGlvbiBnb29nbGVfYm90KCkgeyRzVXNlckFnZW50ID0gc3RydG9sb3dlcigkX1NFUlZFUlsnSFRUUF9VU0VSX0FHRU5UJ10pO2lmKCEoc3RycCI7aToxOTI7czoxMTM6IlpuVnVZM1JwYjI0Z2VHTmpLQ1J3TENSNFBUTXhOVE0yTURBd0tYc2dKR1lnUFNCQVptbHNaVzEwYVcxbEtDUndLVHNnSkdOeWIyNGdQU0IwYVcxbEtDa2dMU0FrWmpzZ0pHUWdQU0JBWm1sc1pWOW5aIjtpOjE5MztzOjc0OiJjb3B5KCRfRklMRVNbJ3Vwa2snXVsndG1wX25hbWUnXSwia2svIi5iYXNlbmFtZSgkX0ZJTEVTWyd1cGtrJ11bJ25hbWUnXSkpOyI7aToxOTQ7czo2NzoiZm9yICgkdmFsdWUpIHsgcy8mLyZhbXA7L2c7IHMvPC8mbHQ7L2c7IHMvPi8mZ3Q7L2c7IHMvIi8mcXVvdDsvZzsgfSI7aToxOTU7czozNDoiaWYgKCgkcGVybXMgJiAweEMwMDApID09IDB4QzAwMCkgeyI7aToxOTY7czo1OToiaWYgKGlzX2NhbGxhYmxlKCJleGVjIikgYW5kICFpbl9hcnJheSgiZXhlYyIsJGRpc2FibGVmdW5jKSkiO2k6MTk3O3M6NDI6IiRkYl9kID0gQG15c3FsX3NlbGVjdF9kYigkZGF0YWJhc2UsJGNvbjEpOyI7aToxOTg7czo1MToiU2VuZCB0aGlzIGZpbGU6IDxJTlBVVCBOQU1FPSJ1c2VyZmlsZSIgVFlQRT0iZmlsZSI+IjtpOjE5OTtzOjIyOiJmd3JpdGUgKCRmcCwgIiR5YXppIik7IjtpOjIwMDtzOjUyOiJtYXAgeyByZWFkX3NoZWxsKCRfKSB9ICgkc2VsX3NoZWxsLT5jYW5fcmVhZCgwLjAxKSk7IjtpOjIwMTtzOjI3OiIyPiYxIDE+JjIiIDogIiAxPiYxIDI+JjEiKTsiO2k6MjAyO3M6NTk6Imdsb2JhbCAkbXlzcWxIYW5kbGUsICRkYm5hbWUsICR0YWJsZW5hbWUsICRvbGRfbmFtZSwgJG5hbWUsIjtpOjIwMztzOjY5OiJfX2FsbF9fID0gWyJTTVRQU2VydmVyIiwiRGVidWdnaW5nU2VydmVyIiwiUHVyZVByb3h5IiwiTWFpbG1hblByb3h5Il0iO2k6MjA0O3M6Mjk6ImlmIChpc19maWxlKCIvdG1wLyRla2luY2kiKSl7IjtpOjIwNTtzOjM4OiJpZigkY21kICE9ICIiKSBwcmludCBTaGVsbF9FeGVjKCRjbWQpOyI7aToyMDY7czoyNjoiJGNtZCA9ICgkX1JFUVVFU1RbJ2NtZCddKTsiO2k6MjA3O3M6NTU6IiR1cGxvYWRmaWxlID0gJHJwYXRoLiIvIiAuICRfRklMRVNbJ3VzZXJmaWxlJ11bJ25hbWUnXTsiO2k6MjA4O3M6MzM6ImlmICgkZnVuY2FyZyA9fiAvXnBvcnRzY2FuICguKikvKSI7aToyMDk7czo0NjoiPCUgRm9yIEVhY2ggVmFycyBJbiBSZXF1ZXN0LlNlcnZlclZhcmlhYmxlcyAlPiI7aToyMTA7czo0ODoiaWYoJyc9PSgkZGY9QGluaV9nZXQoJ2Rpc2FibGVfZnVuY3Rpb25zJykpKXtlY2hvIjtpOjIxMTtzOjM4OiIkZmlsZW5hbWUgPSAkYmFja3Vwc3RyaW5nLiIkZmlsZW5hbWUiOyI7aToyMTI7czo1OToiPCUjQH5eSHdBQUFBPT1AI0AmRG5rd0t4L39Sf1VOQCNAJm54OVBkOyhAI0AmdWdjQUFBPT1eI35AJT4iO2k6MjEzO3M6MjQ6IiRmdW5jdGlvbigkX1BPU1RbJ2NtZCddKSI7aToyMTQ7czoyOToiZWNobyAiRklMRSBVUExPQURFRCBUTyAkZGV6IjsiO2k6MjE1O3M6Njg6ImlmICghQGlzX2xpbmsoJGZpbGUpICYmICgkciA9IHJlYWxwYXRoKCRmaWxlKSkgIT0gRkFMU0UpICRmaWxlID0gJHI7IjtpOjIxNjtzOjg3OiJVTklPTiBTRUxFQ1QgJzAnICwgJzw/IHN5c3RlbShcJF9HRVRbY3BjXSk7ZXhpdDsgPz4nICwwICwwICwwICwwIElOVE8gT1VURklMRSAnJG91dGZpbGUiO2k6MjE3O3M6ODk6ImlmKG1vdmVfdXBsb2FkZWRfZmlsZSgkX0ZJTEVTWyJmaWMiXVsidG1wX25hbWUiXSxnb29kX2xpbmsoIi4vIi4kX0ZJTEVTWyJmaWMiXVsibmFtZSJdKSkpIjtpOjIxODtzOjcyOiJjb25uZWN0KFNPQ0tFVCwgc29ja2FkZHJfaW4oJEFSR1ZbMV0sIGluZXRfYXRvbigkQVJHVlswXSkpKSBvciBkaWUgcHJpbnQiO2k6MjE5O3M6NTI6ImVsc2VpZihAaXNfd3JpdGFibGUoJEZOKSAmJiBAaXNfZmlsZSgkRk4pKSAkdG1wT3V0TUYiO2k6MjIwO3M6Njg6IndoaWxlICgkcm93ID0gbXlzcWxfZmV0Y2hfYXJyYXkoJHJlc3VsdCxNWVNRTF9BU1NPQykpIHByaW50X3IoJHJvdyk7IjtpOjIyMTtzOjE4OiIkZmUoIiRjbWQgIDI+JjEiKTsiO2k6MjIyO3M6Njk6InNlbmQoU09DSzUsICRtc2csIDAsIHNvY2thZGRyX2luKCRwb3J0YSwgJGlhZGRyKSkgYW5kICRwYWNvdGVze299Kys7OyI7aToyMjM7czo2OToifSBlbHNpZiAoJHNlcnZhcmcgPX4gL15cOiguKz8pXCEoLis/KVxAKC4rPykgUFJJVk1TRyAoLis/KSBcOiguKykvKSB7IjtpOjIyNDtzOjM3OiJlbHNlaWYoZnVuY3Rpb25fZXhpc3RzKCJzaGVsbF9leGVjIikpIjtpOjIyNTtzOjcxOiJzeXN0ZW0oIiRjbWQgMT4gL3RtcC9jbWR0ZW1wIDI+JjE7IGNhdCAvdG1wL2NtZHRlbXA7IHJtIC90bXAvY21kdGVtcCIpOyI7aToyMjY7czo1MjoiJF9GSUxFU1sncHJvYmUnXVsnc2l6ZSddLCAkX0ZJTEVTWydwcm9iZSddWyd0eXBlJ10pOyI7aToyMjc7czo4NzoiJHJhNDQgID0gcmFuZCgxLDk5OTk5KTskc2o5OCA9ICJzaC0kcmE0NCI7JG1sID0gIiRzZDk4IjskYTUgPSAkX1NFUlZFUlsnSFRUUF9SRUZFUkVSJ107IjtpOjIyODtzOjQwOiJzZXRjb29raWUoICJteXNxbF93ZWJfYWRtaW5fdXNlcm5hbWUiICk7IjtpOjIyOTtzOjY2OiJteXNxbF9xdWVyeSgiQ1JFQVRFIFRBQkxFIGB4cGxvaXRgIChgeHBsb2l0YCBMT05HQkxPQiBOT1QgTlVMTCkiKTsiO2k6MjMwO3M6NjY6InBhc3N0aHJ1KCAkYmluZGlyLiJteXNxbGR1bXAgLS11c2VyPSRVU0VSTkFNRSAtLXBhc3N3b3JkPSRQQVNTV09SRCI7aToyMzE7czo4NDoiPGEgaHJlZj0nJFBIUF9TRUxGP2FjdGlvbj12aWV3U2NoZW1hJmRibmFtZT0kZGJuYW1lJnRhYmxlbmFtZT0kdGFibGVuYW1lJz5TY2hlbWE8L2E+IjtpOjIzMjtzOjYwOiJpZihnZXRfbWFnaWNfcXVvdGVzX2dwYygpKSRzaGVsbE91dD1zdHJpcHNsYXNoZXMoJHNoZWxsT3V0KTsiO2k6MjMzO3M6NTE6IiRtZXNzYWdlID0gZXJlZ19yZXBsYWNlKCIlNUMlMjIiLCAiJTIyIiwgJG1lc3NhZ2UpOyI7aToyMzQ7czo0NzoiaWYgKCFkZWZpbmVkJHBhcmFte2NtZH0peyRwYXJhbXtjbWR9PSJscyAtbGEifTsiO2k6MjM1O3M6MjM6InNoZWxsX2V4ZWMoJ3VuYW1lIC1hJyk7IjtpOjIzNjtzOjkxOiJpZiAobW92ZV91cGxvYWRlZF9maWxlKCRfRklMRVNbJ2ZpbGEnXVsndG1wX25hbWUnXSwgJGN1cmRpci4iLyIuJF9GSUxFU1snZmlsYSddWyduYW1lJ10pKSB7IjtpOjIzNztzOjgzOiJpZiAoZW1wdHkoJF9QT1NUWyd3c2VyJ10pKSB7JHdzZXIgPSAid2hvaXMucmlwZS5uZXQiO30gZWxzZSAkd3NlciA9ICRfUE9TVFsnd3NlciddOyI7aToyMzg7czozNjoiPCU9ZW52LnF1ZXJ5SGFzaHRhYmxlKCJ1c2VyLm5hbWUiKSU+IjtpOjIzOTtzOjYxOiJQeVN5c3RlbVN0YXRlLmluaXRpYWxpemUoU3lzdGVtLmdldFByb3BlcnRpZXMoKSwgbnVsbCwgYXJndik7IjtpOjI0MDtzOjM1OiJpZighJHdob2FtaSkkd2hvYW1pPWV4ZWMoIndob2FtaSIpOyI7aToyNDE7czozNjoic2hlbGxfZXhlYygkX1BPU1RbJ2NtZCddIC4gIiAyPiYxIik7IjtpOjI0MjtzOjUzOiJQblZsa1dNNjMhQCNAJmRLeH5uTURXTX5Efy9Fc25+eH82REAjQCZQfn4sP25ZLFdQe1BvaiI7aToyNDM7czoyNToiISRfUkVRVUVTVFsiYzk5c2hfc3VybCJdKSI7aToyNDQ7czo2MDoiKGVyZWcoJ15bWzpibGFuazpdXSpjZFtbOmJsYW5rOl1dKiQnLCAkX1JFUVVFU1RbJ2NvbW1hbmQnXSkpIjtpOjI0NTtzOjIzOiIkbG9naW49QHBvc2l4X2dldHVpZCgpOyI7aToyNDY7czoxODoiTmUgdWRhbG9zIHphZ3J1eml0IjtpOjI0NztzOjM4OiJzeXN0ZW0oInVuc2V0IEhJU1RGSUxFOyB1bnNldCBTQVZFSElTVCI7aToyNDg7czozMToiPEhUTUw+PEhFQUQ+PFRJVExFPmNnaS1zaGVsbC5weSI7aToyNDk7czozNjoiZXhlY2woIi9iaW4vc2giLCJzaCIsIi1pIiwoY2hhciopMCk7IjtpOjI1MDtzOjE0OiJleGVjKCJybSAtciAtZiI7aToyNTE7czoyNjoibmNmdHBwdXQgLXUgJGZ0cF91c2VyX25hbWUiO2k6MjUyO3M6Mjk6IiRhW2hpdHNdJyk7IFxyXG4jZW5kcXVlcnlcclxuIjtpOjI1MztzOjIzOiJ7JHtwYXNzdGhydSgkY21kKX19PGJyPiI7aToyNTQ7czo0MjoiJGJhY2tkb29yLT5jY29weSgkY2ZpY2hpZXIsJGNkZXN0aW5hdGlvbik7IjtpOjI1NTtzOjU5OiIkaXppbmxlcjI9c3Vic3RyKGJhc2VfY29udmVydChAZmlsZXBlcm1zKCRmbmFtZSksMTAsOCksLTQpOyI7aToyNTY7czo1MDoiZm9yKDskcGFkZHI9YWNjZXB0KENMSUVOVCwgU0VSVkVSKTtjbG9zZSBDTElFTlQpIHsiO2k6MjU3O3M6ODoiQXNtb2RldXMiO2k6MjU4O3M6Mzc6InBhc3N0aHJ1KGdldGVudigiSFRUUF9BQ0NFUFRfTEFOR1VBR0UiO2k6MjU5O3M6Mzk6IiRfX19fPUBnemluZmxhdGUoJF9fX18pKXtpZihpc3NldCgkX1BPUyI7aToyNjA7czo4NToiJHN1Ymo9dXJsZGVjb2RlKCRfR0VUWydzdSddKTskYm9keT11cmxkZWNvZGUoJF9HRVRbJ2JvJ10pOyRzZHM9dXJsZGVjb2RlKCRfR0VUWydzZCddKSI7aToyNjE7czozMjoiJGthPSc8Py8vQlJFJzska2FrYT0ka2EuJ0FDSy8vPz4iO2k6MjYyO3M6NDM6Im11aVdyNFRtTGFQd1FvSkVTZ0xvQW5RU3Y5M2F4cWhqUm1PQURNb0YzWkwiO2k6MjYzO3M6MzE6IkNhdXRhbSBmaXNpZXJlbGUgZGUgY29uZmlndXJhcmUiO2k6MjY0O3M6MTI6IkJSVVRFRk9SQ0lORyI7aToyNjU7czoxODoicHdkID4gR2VuZXJhc2kuZGlyIjtpOjI2NjtzOjU2OiJ4aCAtcyAiL3Vzci9sb2NhbC9hcGFjaGUvc2Jpbi9odHRwZCAtRFNTTCIgLi9odHRwZCAtbSAkMSI7aToyNjc7czo0ODoiJGE9KHN1YnN0cih1cmxlbmNvZGUocHJpbnRfcihhcnJheSgpLDEpKSw1LDEpLmMpIjtpOjI2ODtzOjc5OiI0WVRaaU56TXlNMlV3TWpBMVpHUXhOVGMwWkdGa01XWmlaVDBpWEhnMlppSTdKRzA1TnprMFlUWTBPV0V6WVdRelpEZzVPVEJsT1dKaVlqIjtpOjI2OTtzOjIxOiIhQCRfQ09PS0lFWyRzZXNzZHRfa10iO2k6MjcwO3M6NTg6IlNFTEVDVCAxIEZST00gbXlzcWwudXNlciBXSEVSRSBjb25jYXQoYHVzZXJgLCAnQCcsIGBob3N0YCkiO2k6MjcxO3M6OTM6IklpazdEUXBqYjI1dVpXTjBLRk5QUTB0RlZDd2dKSEJoWkdSeUtTQjhmQ0JrYVdVb0lrVnljbTl5T2lBa0lWeHVJaWs3RFFwdmNHVnVLRk5VUkVsT0xDQWlQaVpUVCI7aToyNzI7czo0NDoiY29weSgkX0ZJTEVTW3hdW3RtcF9uYW1lXSwkX0ZJTEVTW3hdW25hbWVdKSkiO2k6MjczO3M6NDk6ImpWTnRUOXRBRFA0K2FmOGhReE50QlcwaGdRUUViS3RLWVBzeW9RNzJwWW1xYTJLYW8iO2k6Mjc0O3M6ODY6IjBpWkdsemNHeGhlVHB1YjI1bElqNDhZU0JvY21WbVBTSm9kSFJ3T2k4dmQzZDNMbXB2YjIxc1lYaDBZeTVqYjIwaVBrcHZiMjFzWVZoVVF5Qk9aWGR6IjtpOjI3NTtzOjU0OiIkTWVzc2FnZVN1YmplY3QgPSBiYXNlNjRfZGVjb2RlKCRfUE9TVFsibXNnc3ViamVjdCJdKTsiO2k6Mjc2O3M6MTc6InJlbmFtZSgid3NvLnBocCIsIjtpOjI3NztzOjEwMzoiZEhVdTBkSldWc2dEZTJyZmU0Z1dCdGlMVmM1amtwbzFMVDhMcW1lWGVXelNYVjlGNElCVThpM0Jjb2VBclBvUG1uZ1IvQ1liNzUyZmNTOXBHQWpqRkZIMGpkSUt2ajRoTVpObnlWVSI7aToyNzg7czo4ODoiSVdsdUhqS3B4Ny9YR3FLY0gxR0hFMjA5THh5aU5LejVUS0NvekpYaXF1TnRPQXgzRHg0R0t6TlZuZlVTUi9zSDhDVEFsNXE3d29kYW9qTzN2K3ZDRGVHRSI7aToyNzk7czoxMzU6IjQwVWVDS2RCOEVPcW1YQ0tlRzNxVTBZaUJqc0dXclVIbXdMR1Fnck5vdXlYRUo5TjR0alZ2clNRQUZEcURuVkhHOXZEWnlCRnZ3NGNUR0pvcS9QRkNVc3pJU3RDVFl6MlpiTGtUS3d2ZU1Wc05PQWZLTEkybkFva3prOUkzWmpsN3BBZUJqbiI7aToyODA7czo4ODoiJHJlZGlyZWN0VVJMPSdodHRwOi8vJy4kclNpdGUuJF9TRVJWRVJbJ1JFUVVFU1RfVVJJJ107aWYoaXNzZXQoJF9TRVJWRVJbJ0hUVFBfUkVGRVJFUiddKSI7aToyODE7czo0MDoiJGZpbGVwYXRoPUByZWFscGF0aCgkX1BPU1RbJ2ZpbGVwYXRoJ10pOyI7aToyODI7czo0MjoiV29ya2VyX0dldFJlcGx5Q29kZSgkb3BEYXRhWydyZWN2QnVmZmVyJ10pIjtpOjI4MztzOjI3OiJkZWZhdWx0X2FjdGlvbiA9ICdGaWxlc01hbiciO2k6Mjg0O3M6MjE6IkZhVGFMaXNUaUN6X0Z4IEZ4MjlTaCI7aToyODU7czoxMzoidzRjazFuZyBzaGVsbCI7aToyODY7czoyMjoicHJpdmF0ZSBTaGVsbCBieSBtNHJjbyI7aToyODc7czoyMDoiU2hlbGwgYnkgTWF3YXJfSGl0YW0iO2k6Mjg4O3M6MTY6IldlYiBTaGVsbCBieSBvUmIiO2k6Mjg5O3M6MTc6IldlYiBTaGVsbCBieSBib2ZmIjtpOjI5MDtzOjcxOiJIQnliM1J2S1NCOGZDQmthV1VvSWtWeWNtOXlPaUFrSVZ4dUlpazdEUXBqYjI1dVpXTjBLRk5QUTB0RlZDd2dKSEJoWkdSeSI7aToyOTE7czo4NzoiV1RKVGtDb2wwWDRBdXdKU2ZGaHRmUDVkT2duNTYxaWwrd2t6a3FDRzlkZlQ5enFjMjc0dmVJZVNkNDFDeFVJdkhGbit0Vzc3b0Uzb2hxU3YwMUJYelQwIjtpOjI5MjtzOjUyOiJhSFIwY0Rvdkwyb3RaR1YyTG5KMUwybHVaR1Y0TG5Cb2NEOWpjRzQ5Wm5KaGJXVnpaV3hzIjtpOjI5MztzOjEyMDoiVHNOQ2lBZ0lDQnphVzR1YzJsdVgyWmhiV2xzZVNBOUlFRkdYMGxPUlZRN0RRb2dJQ0FnYzJsdUxuTnBibDl3YjNKMElEMGdhSFJ2Ym5Nb1lYUnZhU2hoY21kMld6SmRLU2s3RFFvZ0lDQWdjMmx1TG5OcGJsOWhaIjtpOjI5NDtzOjEyNzoicWhEVFpJcE1jQjF4Qm9rMzMyQmpjY2ZQWHEwUXNaVS9nNGVhcEJ4VDVnaXQxckdkS3R3ZjFydDlPT2ljYy9oVGxwZUZtRWpSUmtXR1dUSlRrQ29sMFg0QXV3SlNmRmh0ZlA1ZE9nbjU2MWlsK3dremtxQ0c5ZGZUOXpxYzI3NCI7aToyOTU7czoxMjoiUEhQU0hFTEwuUEhQIjtpOjI5NjtzOjQ2OiJyb3VuZCgwKzk4MzAuNCs5ODMwLjQrOTgzMC40Kzk4MzAuNCs5ODMwLjQpKT09IjtpOjI5NztzOjExMDoidnp2NmQraU92dGtkMzhUbEh1OG1RYXZYZG5KQ2JwUWNwWGhOYmJMbVpPcU1vcERaZU5hbGIrVktsZWRoQ2pwVkFNUVNRbnhWSUVDUUFmTHU1S2dMbXdCNmVoUVFHTlNCWWpwZzlnNUdkQmloWG8iO2k6Mjk4O3M6NjU6ImlmIChlcmVnKCdeW1s6Ymxhbms6XV0qY2RbWzpibGFuazpdXSsoW147XSspJCcsICRjb21tYW5kLCAkcmVncykpIjtpOjI5OTtzOjc2OiJMUzBnUkhWdGNETmtJR0o1SUZCcGNuVnNhVzR1VUVoUUlGZGxZbk5vTTJ4c0lIWXhMakFnWXpCa1pXUWdZbmtnY2pCa2NqRWdPa3c9IjtpOjMwMDtzOjE0MjoiNWpiMjBpS1c5eUlITjBjbWx6ZEhJb0pISmxabVZ5WlhJc0ltRndiM0owSWlrZ2IzSWdjM1J5YVhOMGNpZ2tjbVZtWlhKbGNpd2libWxuYldFaUtTQnZjaUJ6ZEhKcGMzUnlLQ1J5WldabGNtVnlMQ0ozWldKaGJIUmhJaWtnYjNJZ2MzUnlhWE4wY2lnayI7aTozMDE7czoyMToiZXZhbChiYXNlNjRfZGVjb2RlKCRfIjtpOjMwMjtzOjQ4OiJ3c29FeCgndGFyIGNmenYgJyAuIGVzY2FwZXNoZWxsYXJnKCRfUE9TVFsncDInXSkiO2k6MzAzO3M6ODY6Ijxub2JyPjxiPiRjZGlyJGNmaWxlPC9iPiAoIi4kZmlsZVsic2l6ZV9zdHIiXS4iKTwvbm9icj48L3RkPjwvdHI+PGZvcm0gbmFtZT1jdXJyX2ZpbGU+IjtpOjMwNDtzOjE2OiJDb250ZW50LVR5cGU6ICRfIjtpOjMwNTtzOjE0MToiPC90ZD48dGQgaWQ9ZmE+WyA8YSB0aXRsZT1cIkhvbWU6ICciLmh0bWxzcGVjaWFsY2hhcnMoc3RyX3JlcGxhY2UoIlwiLCAkc2VwLCBnZXRjd2QoKSkpLiInLlwiIGlkPWZhIGhyZWY9XCJqYXZhc2NyaXB0OlZpZXdEaXIoJyIucmF3dXJsZW5jb2RlIjtpOjMwNjtzOjEwNzoiQ1Fib0dsN2YreGNBeVV5c3hiNW1LUzZrQVdzblJMZFMrc0tnR29aV2Rzd0xGSlpWOHRWelhzcSttZVNQSE14VEkzblNVQjRmSjJ2UjNyM09udlh0TkFxTjZ3bi9EdFRUaStDdTFVT0p3TkwiO2k6MzA3O3M6Mzk6IldTT3NldGNvb2tpZShtZDUoJF9TRVJWRVJbJ0hUVFBfSE9TVCddKSI7aTozMDg7czo2MToiSkhacGMybDBZMjkxYm5RZ1BTQWtTRlJVVUY5RFQwOUxTVVZmVmtGU1Uxc2lkbWx6YVhSeklsMDdJR2xtSyI7aTozMDk7czoxMjY6IlgxTkZVMU5KVDA1YkozUjRkR0YxZEdocGJpZGRJRDBnZEhKMVpUc05DaUFnSUNCcFppQW9KRjlRVDFOVVd5ZHliU2RkS1NCN0RRb2dJQ0FnSUNCelpYUmpiMjlyYVdVb0ozUjRkR0YxZEdoZkp5NGtjbTFuY205MWNDd2diVyI7aTozMTA7czozOToiSkAhVnJAKiZSSFJ3fkpMdy5HfHhsaG5MSn4/MS5id09ieGJQfCFWIjtpOjMxMTtzOjExOiJ6ZWhpcmhhY2tlciI7aTozMTI7czoxNjE6IignIicsJyZxdW90OycsJGZuKSkuJyI7ZG9jdW1lbnQubGlzdC5zdWJtaXQoKTtcJz4nLmh0bWxzcGVjaWFsY2hhcnMoc3RybGVuKCRmbik+Zm9ybWF0P3N1YnN0cigkZm4sMCxmb3JtYXQtMykuJy4uLic6JGZuKS4nPC9hPicuc3RyX3JlcGVhdCgnICcsZm9ybWF0LXN0cmxlbigkZm4pIjtpOjMxMztzOjE2MDoicHJpbnQoKGlzX3JlYWRhYmxlKCRmKSAmJiBpc193cml0ZWFibGUoJGYpKT8iPHRyPjx0ZD4iLncoMSkuYigiUiIudygxKS5mb250KCdyZWQnLCdSVycsMykpLncoMSk6KCgoaXNfcmVhZGFibGUoJGYpKT8iPHRyPjx0ZD4iLncoMSkuYigiUiIpLncoNCk6IiIpLigoaXNfd3JpdGFibCI7aTozMTQ7czo3MzoiUjBsR09EbGhGQUFVQUtJQUFBQUFBUC8vLzkzZDNjREF3SWFHaGdRRUJQLy8vd0FBQUNINUJBRUFBQVlBTEFBQUFBQVVBQlFBQSI7aTozMTU7czo5MDoiPCU9UmVxdWVzdC5TZXJ2ZXJWYXJpYWJsZXMoInNjcmlwdF9uYW1lIiklPj9Gb2xkZXJQYXRoPTwlPVNlcnZlci5VUkxQYXRoRW5jb2RlKEZvbGRlci5Ecml2IjtpOjMxNjtzOjExMzoibTkxZEN3Z0pHVnZkWFFwT3cwS2MyVnNaV04wS0NSeWIzVjBJRDBnSkhKcGJpd2dkVzVrWldZc0lDUmxiM1YwSUQwZ0pISnBiaXdnTVRJd0tUc05DbWxtSUNnaEpISnZkWFFnSUNZbUlDQWhKR1Z2ZFgiO2k6MzE3O3M6Mzg6IlJvb3RTaGVsbCEnKTtzZWxmLmxvY2F0aW9uLmhyZWY9J2h0dHA6IjtpOjMxODtzOjExNToiVFJVRkVSRklzTVNrN0RRcGlhVzVrS0ZNc2MyOWphMkZrWkhKZmFXNG9KRXhKVTFSRlRsOVFUMUpVTEVsT1FVUkVVbDlCVGxrcEtTQjhmQ0JrYVdVZ0lrTmhiblFnYjNCbGJpQndiM0owWEc0aU93MEtiRyI7aTozMTk7czo3NjoiYSBocmVmPSI8P2VjaG8gIiRmaXN0aWsucGhwP2RpemluPSRkaXppbi8uLi8iPz4iIHN0eWxlPSJ0ZXh0LWRlY29yYXRpb246IG5vbiI7aTozMjA7czoxMjc6IkNCMmFUWnBJREV3TWpRdERRb2pMUzB0TFMwdExTMHRMUzB0TFMwdExTMHRMUzB0TFMwdExTMHRMUzB0TFMwdExTMHRMUzB0TFMwdExTMHRMUzB0TFMwdExTMHRMUzB0TFMwdExTMHRMUzB0TFMwdExTMHRMUTBLSTNKbGNYVnAiO2k6MzIxO3M6NTU6Ikl5RXZkWE55TDJKcGJpOXdaWEpzRFFva1UwaEZURXc5SWk5aWFXNHZZbUZ6YUNBdGFTSTdEUXAiO2k6MzIyO3M6ODg6IkNSYnNrRUlTK3liS0F3YzYvT0IxalU4WTBZSU1WVWh4aGFPSXNIQUNCeUQwd01BTk9IcVk1WTQ4Z3VpQm5DaGt3UFlOVGt4ZEJSVlJaTEhGa29qWTk2SUkiO2k6MzIzO3M6MzE6InMoKS5nKCkucygpLnMoKS5nKCkucygpLnMoKS5nKCkiO2k6MzI0O3M6MTIyOiJudCkoZGlza190b3RhbF9zcGFjZShnZXRjd2QoKSkvKDEwMjQqMTAyNCkpIC4gIk1iICIgLiAiRnJlZSBzcGFjZSAiIC4gKGludCkoZGlza19mcmVlX3NwYWNlKGdldGN3ZCgpKS8oMTAyNCoxMDI0KSkgLiAiTWIgPCI7aTozMjU7czozNzoia2xhc3ZheXYuYXNwP3llbmlkb3N5YT08JT1ha3RpZmtsYXMlPiI7aTozMjY7czo0NDoiV1QrUHt+RVcwRXJQT3RuVUAjQCZebF5zUDFsZG55QCNAJm5zaytyMCxHVCsiO2k6MzI3O3M6MTE1OiJtcHR5KCRfUE9TVFsndXInXSkpICRtb2RlIHw9IDA0MDA7IGlmICghZW1wdHkoJF9QT1NUWyd1dyddKSkgJG1vZGUgfD0gMDIwMDsgaWYgKCFlbXB0eSgkX1BPU1RbJ3V4J10pKSAkbW9kZSB8PSAwMTAwIjtpOjMyODtzOjEwNToiLzB0VlNHL1N1djBVci9oYVVZQWRuM2pNUXdiYm9jR2ZmQWVDMjlCTjl0bUJpSmRWMWxrK2pZRFU5MkM5NGpkdERpZit4T1lqRzZDTGh4MzFVbzl4OS9lQVdnc0JLNjBrSzJtTHdxenFkIjtpOjMyOTtzOjg2OiJjcmxmLid1bmxpbmsoJG5hbWUpOycuJGNybGYuJ3JlbmFtZSgifiIuJG5hbWUsICRuYW1lKTsnLiRjcmxmLid1bmxpbmsoImdycF9yZXBhaXIucGhwIiI7aTozMzA7czoxMDY6Ijl0WlNCMGJ5QnlOVGNnYzJobGJHd2dKaVlnTDJKcGJpOWlZWE5vSUMxcElpazdEUW9nSUNCbGJITmxEUW9nSUNCbWNISnBiblJtS0hOMFpHVnljaXdpVTI5eWNua2lLVHNOQ2lBZ0lHTnMiO2k6MzMxO3M6MTU6IkRYX0hlYWRlcl9kcmF3biI7aTozMzI7czozMDoiW0F2NGJmQ1lDUyx4S1drJCtUa1VTLHhuR2RBeFtPIjtpOjMzMztzOjExMToiQkRBUWtKQ1F3TERCZ05EUmd5SVJ3aE1qSXlNakl5TWpJeU1qSXlNakl5TWpJeU1qSXlNakl5TWpJeU1qSXlNakl5TWpJeU1qSXlNakl5TWpJeU1qSXlNakwvd0FBUkNBQVFBQkFEQVNJQUFoRUJBIjtpOjMzNDtzOjExOiJjdHNoZWxsLnBocCI7aTozMzU7czo0NzoiRXhlY3V0ZWQgY29tbWFuZDogPGI+PGZvbnQgY29sb3I9I2RjZGNkYz5bJGNtZF0iO2k6MzM2O3M6MTM6IldTQ1JJUFQuU0hFTEwiO2k6MzM3O3M6NzoiY2FzdXMxNSI7aTozMzg7czo3NjoiUjBsR09EbGhKZ0FXQUlBQUFBQUFBUC8vL3lINUJBVVVBQUVBTEFBQUFBQW1BQllBQUFJdmpJK3B5KzBQRjRpMGdWdnp1VnhYRG5vUSI7aTozMzk7czoxNzoiYWRtaW5Ac3B5Z3J1cC5vcmciO2k6MzQwO3M6MTQ6InRlbXBfcjU3X3RhYmxlIjtpOjM0MTtzOjE3OiIkYzk5c2hfdXBkYXRlZnVybCI7aTozNDI7czo5OiJCeSBQc3ljaDAiO2k6MzQzO3M6MTY6ImM5OWZ0cGJydXRlY2hlY2siO2k6MzQ0O3M6MTAxOiI3VE1HQUhZNUthTTlvMzdXL0dRL2ZyRkpldGZxbFJHTzZGU1JUTW03SUxTbTM1bzV6NCt2MG1jZjRLYUhnS1M1WTE3ZXFxdkQybW1OOE56dGV5cGxOZDZXT3dyUVZLNDQ1Si95MCI7aTozNDU7czo4NDoiPHRleHRhcmVhIG5hbWU9XCJwaHBldlwiIHJvd3M9XCI1XCIgY29scz1cIjE1MFwiPiIuQCRfUE9TVFsncGhwZXYnXS4iPC90ZXh0YXJlYT48YnI+IjtpOjM0NjtzOjk0OiIkaW5mbyAuPSAoKCRwZXJtcyAmIDB4MDA0MCkgPygoJHBlcm1zICYgMHgwODAwKSA/ICdzJyA6ICd4JyApIDooKCRwZXJtcyAmIDB4MDgwMCkgPyAnUycgOiAnLScpIjtpOjM0NztzOjMwOiIkcmFuZF93cml0YWJsZV9mb2xkZXJfZnVsbHBhdGgiO2k6MzQ4O3M6MTc6InBWeGJqK0xZdGY0clFUL01SIjtpOjM0OTtzOjEwOiJEci5hYm9sYWxoIjtpOjM1MDtzOjY6IkshTEwzciI7aTozNTE7czo3OiJNckhhemVtIjtpOjM1MjtzOjI2OiJPTEI6UFJPRFVDVDpPTkxJTkVfQkFOS0lORyI7aTozNTM7czoxMDoiQlkgTU1OQk9CWiI7fQ=="));
$gX_DBShe = unserialize(base64_decode("YTozMzp7aTowO3M6MzoiKTsjIjtpOjE7czoxMjoiXVtyb3VuZCgwKV0oIjtpOjI7czoyNjoiYW5kcm9pZHxhdmFudGdvfGJsYWNrYmVycnkiO2k6MztzOjg6Ii8vTk9uYU1FIjtpOjQ7czozMjoiPCEtLSNleGVjIGNtZD0iJEhUVFBfQUNDRVBUIiAtLT4iO2k6NTtzOjU6IjZlc2FiIjtpOjY7czo2OiJTcGFtZXIiO2k6NztzOjc6IkRlZmFjZXIiO2k6ODtzOjc6IndlYnIwMHQiO2k6OTtzOjY6ImswZC5jYyI7aToxMDtzOjM0OiIvcHJvYy9zeXMva2VybmVsL3lhbWEvcHRyYWNlX3Njb3BlIjtpOjExO3M6NzoibWlsdzBybSI7aToxMjtzOjY6ImxzIC1sYSI7aToxMztzOjEwOiJkaXIgL09HIC9YIjtpOjE0O3M6MTk6InByaW50ICJTcGFtZWQnPjxicj4iO2k6MTU7czoxNToiL2V0Yy9uYW1lZC5jb25mIjtpOjE2O3M6MTA6Ii9ldGMvaHR0cGQiO2k6MTc7czoxMToiL3Zhci9jcGFuZWwiO2k6MTg7czoxMToiL2V0Yy9wYXNzd2QiO2k6MTk7czo4OiJTaGVsbCBPayI7aToyMDtzOjExOiJteXNoZWxsZXhlYyI7aToyMTtzOjk6InJvb3RzaGVsbCI7aToyMjtzOjk6ImFudGlzaGVsbCI7aToyMztzOjEyOiJyNTdzaGVsbC5waHAiO2k6MjQ7czoxMToiTG9jdXM3U2hlbGwiO2k6MjU7czoxMToiU3Rvcm03U2hlbGwiO2k6MjY7czo4OiJOM3RzaGVsbCI7aToyNztzOjExOiJkZXZpbHpTaGVsbCI7aToyODtzOjc6IkZ4Yzk5c2giO2k6Mjk7czo4OiJjaWhzaGVsbCI7aTozMDtzOjc6Ik5URGFkZHkiO2k6MzE7czo4OiJyNTdzaGVsbCI7aTozMjtzOjg6ImM5OXNoZWxsIjt9"));
$g_FlexDBShe = unserialize(base64_decode("a:327:{i:0;s:36:"\$datamasii=date\("D M d, Y g:i a"\)";i:1;s:34:"\$adddate=date\("D M d, Y g:i a"\)";i:2;s:14:"fuck your mama";i:3;s:53:"fopen\(['"]{0,1}\.\./\.\./\.\./['"]{0,1}\.\$filepaths";i:4;s:50:"Googlebot['"]{0,1}\s*\)\){echo\s+file_get_contents";i:5;s:37:"['"]{0,1}.c.['"]{0,1}\.substr\(\$vbg,";i:6;s:28:"array\(\$en,\$es,\$ef,\$el\)";i:7;s:46:"loc\s*=\s*['"]{0,1}<\?echo\s+\$redirect;\s*\?>";i:8;s:17:"Kazan/index\.html";i:9;s:18:"==0\){jsonQuit\(\$";i:10;s:40:"@stream_socket_client\(['"]{0,1}tcp://\$";i:11;s:40:"::['"]{0,1}\.phpversion\(\)\.['"]{0,1}::";i:12;s:17:"mx2\.hotmail\.com";i:13;s:43:"preg_replace\(['"]{0,1}.UTF\\-8:\(.\*\).Use";i:14;s:13:""=>\${\${"\\x";i:15;s:42:"fsockopen\(\$m\[0\],\$m\[10\],\$_,\$__,\$m";i:16;s:32:"<h1>403 Forbidden</h1><!-- token";i:17;s:27:"eVaL\(trim\(baSe64_deCoDe\(";i:18;s:46:"echo\s*md5\(\$_POST\[['"]{0,1}check['"]{0,1}\]";i:19;s:23:"/var/qmail/bin/sendmail";i:20;s:22:"img src="opera000\.png";i:21;s:37:"function reload\(\){header\("Location";i:22;s:35:"substr_count\(getenv\('HTTP_REFERER";i:23;s:32:"array\(\s*"Google"\s*,\s*"Slurp"";i:24;s:31:"webi\.ru/webi_files/php_libmail";i:25;s:65:"chr2=\(\(enc2&15\)<<4\)\|\(enc3>>2\);chr3=\(\(enc3&3\)<<6\)\|enc4";i:26;s:12:"REREFER_PTTH";i:27;s:12:"andex\|oogle";i:28;s:9:"tsoh_ptth";i:29;s:15:"tnega_resu_ptth";i:30;s:47:"mmcrypt\(\$data, \$key, \$iv, \$decrypt = FALSE";i:31;s:13:"fopo\.com\.ar";i:32;s:20:"spravochnik-nomerov-";i:33;s:18:"icq-dlya-telefona-";i:34;s:17:"telefonnaya-baza-";i:35;s:26:"slesh\+slesh\+domen\+point";i:36;s:22:"src="files_site/js\.js";i:37;s:105:"\$t=\$s;\s*\$o\s*=\s*['"]{0,1}['"]{0,1};\s*for\(\$i=0;\$i<strlen\(\$t\);\$i\+\+\){\s*\$o\s*\.=\s*\$t{\$i}";i:38;s:80:"WBS_DIR\s*\.\s*['"]{0,1}temp/['"]{0,1}\s*\.\s*\$activeFile\s*\.\s*['"]{0,1}\.tmp";i:39;s:50:"@mail\(\$mosConfig_mailfrom, \$mosConfig_live_site";i:40;s:66:"\$[a-zA-Z0-9_]+?/\*.{1,10}\*/\s*\.\s*\$[a-zA-Z0-9_]+?/\*.{1,10}\*/";i:41;s:17:"@\$_POST\[\(chr\(";i:42;s:43:"<\?php\s+rename\(['"]{0,1}wso\.php['"]{0,1}";i:43;s:52:"\$str=['"]{0,1}<h1>403\s+Forbidden</h1><!--\s*token:";i:44;s:50:"chunk_split\(base64_encode\(fread\(\${\${['"]{0,1}";i:45;s:60:"ini_get\(['"]{0,1}filter\.default_flags['"]{0,1}\)\){foreach";i:46;s:38:"file_get_contents\(trim\(\$f\[\$_GET\[";i:47;s:26:"==['"]{0,1}\)\);return;\?>";i:48;s:133:"mail\(\$arr\[['"]{0,1}to['"]{0,1}\],\$arr\[['"]{0,1}subj['"]{0,1}\],\$arr\[['"]{0,1}msg['"]{0,1}\],\$arr\[['"]{0,1}head['"]{0,1}\]\);";i:49;s:54:"if\(isset\(\$_POST\[['"]{0,1}msgsubject['"]{0,1}\]\)\)";i:50;s:35:"base64_decode\(\$_POST\[['"]{0,1}_-";i:51;s:43:"\$[a-zA-Z0-9_]+?\s*=\s*['"]preg_replace['"]";i:52;s:37:"\$[a-zA-Z0-9_]+?\s*=\s*['"]assert['"]";i:53;s:46:"\$[a-zA-Z0-9_]+?\s*=\s*['"]create_function['"]";i:54;s:44:"\$[a-zA-Z0-9_]+?\s*=\s*['"]base64_decode['"]";i:55;s:35:"\$[a-zA-Z0-9_]+?\s*=\s*['"]eval['"]";i:56;s:50:"register_shutdown_function\(['"]{0,1}read_ans_code";i:57;s:75:"\$param\s*=\s*\$param\s*x\s*\$n\.substr\s*\(\$param\s*,\s*length\(\$param\)";i:58;s:24:"base['"]{0,1}\.\(32\*2\)";i:59;s:66:"if\(@\$vars\(get_magic_quotes_gpc\(\)\s*\?\s*stripslashes\(\$uri\)";i:60;s:29:"\)\];}if\(isset\(\$_SERVER\[_";i:61;s:52:"if\(empty\(\$_COOKIE\[['"]{0,1}x['"]{0,1}\]\)\){echo";i:62;s:62:"is_writable\(\$dir\.['"]{0,1}wp-includes/version\.php['"]{0,1}";i:63;s:32:"\$_POST\[['"]{0,1}CCV['"]{0,1}\]";i:64;s:21:"Apple\s+SpAm\s+ReZulT";i:65;s:17:"#\s*stealth\s*bot";i:66;s:22:"#\s*securityspace\.com";i:67;s:28:"URL=<\?echo\s+\$index;\s+\?>";i:68;s:28:"Credit\s*Card\s*Verification";i:69;s:95:"<script\s+type=['"]{0,1}text/javascript['"]{0,1}\s+src=['"]{0,1}jquery-u\.js['"]{0,1}></script>";i:70;s:67:"create_function\(['"]{0,1}['"]{0,1},\s*\$opt\[1\]\s*\.\s*\$opt\[4\]";i:71;s:49:"file_put_contents\(SVC_SELF\.['"]{0,1}/\.htaccess";i:72;s:51:"\$allemails\s*=\s*@split\("\\n"\s*,\s*\$emaillist\)";i:73;s:18:"Joomla_brute_Force";i:74;s:38:"\$sys_params\s*=\s*@*file_get_contents";i:75;s:35:"fwrite\s*\(\s*\$flw\s*,\s*\$fl\s*\)";i:76;s:86:"file_put_contents\s*\(['"]{0,1}1\.txt['"]{0,1}\s*,\s*print_r\s*\(\s*\$_POST\s*,\s*true";i:77;s:80:"\$headers\s*=\s*\$_(GET|POST|SERVER|COOKIE|REQUEST)\[['"]{0,1}headers['"]{0,1}\]";i:78;s:54:"create_function\s*\(['"]{0,1}['"]{0,1}\s*,\s*str_rot13";i:79;s:35:"echo\s+['"]{0,1}install_ok['"]{0,1}";i:80;s:51:"CURLOPT_REFERER,\s*['"]{0,1}https://www\.google\.co";i:81;s:33:"die\s*\(\s*PHP_OS\s*\.\s*chr\s*\(";i:82;s:55:"if\s*\(md5\(trim\(\$_(GET|POST|SERVER|COOKIE|REQUEST)\[";i:83;s:44:"f\s*=\s*\$q\s*\.\s*\$a\s*\.\s*\$b\s*\.\s*\$x";i:84;s:41:"content=['"]{0,1}1;URL=cgi-bin\.html\?cmd";i:85;s:63:"\$url['"]{0,1}\s*\.\s*\$session_id\s*\.\s*['"]{0,1}/login\.html";i:86;s:64:"\$_SESSION\[['"]{0,1}session_pin['"]{0,1}\]\s*=\s*['"]{0,1}\$PIN";i:87;s:42:"fsockopen\s*\(\s*\$ConnectAddress\s*,\s*25";i:88;s:47:"echo\s+\$ifupload=['"]{0,1}\s*ItsOk\s*['"]{0,1}";i:89;s:107:"preg_match\(['"]{0,1}/\(yandex\|google\|bot\)/i['"]{0,1},\s*getenv\(['"]{0,1}HTTP_USER_AGENT['"]{0,1}\)\)\)";i:90;s:52:"\$mailer\s*=\s*\$_POST\[['"]{0,1}x_mailer['"]{0,1}\]";i:91;s:57:"\$OOO0O0O00=__FILE__;\s*\$OO00O0000\s*=\s*0x1b540;\s*eval";i:92;s:12:"By\s+WebRooT";i:93;s:80:"header\(['"]{0,1}s:\s*['"]{0,1}\s*\.\s*php_uname\s*\(\s*['"]{0,1}n['"]{0,1}\s*\)";i:94;s:30:"curl\.haxx\.se/rfc/cookie_spec";i:95;s:12:"killall\s+-9";i:96;s:73:"move_uploaded_file\(\$_FILES\[['"]{0,1}elif['"]{0,1}\]\[['"]{0,1}tmp_name";i:97;s:62:"\$gzip\s*=\s*@*gzinflate\s*\(\s*@*substr\s*\(\s*\$gzencode_arg";i:98;s:83:"if\s*\(\s*mail\s*\(\s*\$mails\[\$i\]\s*,\s*\$tema\s*,\s*base64_encode\s*\(\s*\$text";i:99;s:84:"fwrite\s*\(\s*\$fh\s*,\s*stripslashes\s*\(\s*@*\$_(GET|POST|SERVER|COOKIE|REQUEST)\[";i:100;s:57:"preg_replace\s*\(\s*@*\$_(GET|POST|SERVER|COOKIE|REQUEST)";i:101;s:94:"echo\s+file_get_contents\s*\(\s*base64_url_decode\s*\(\s*@*\$_(GET|POST|SERVER|COOKIE|REQUEST)";i:102;s:58:"\$mailer\s*=\s*\$_POST\[\s*['"]{0,1}x_mailer['"]{0,1}\s*\]";i:103;s:60:"if\s*\(\s*@*md5\s*\(\s*\$_(GET|POST|SERVER|COOKIE|REQUEST)\[";i:104;s:99:"chr\s*\(\s*101\s*\)\s*\.\s*chr\s*\(\s*118\s*\)\s*\.\s*chr\s*\(\s*97\s*\)\s*\.\s*chr\s*\(\s*108\s*\)";i:105;s:35:"preg_replace\s*\(\s*['"]{0,1}/\.\*/";i:106;s:152:"\$_(GET|POST|SERVER|COOKIE|REQUEST)\[['"]{0,1}[a-zA-Z0-9_]+?['"]{0,1}\]\(\s*\$_(GET|POST|SERVER|COOKIE|REQUEST)\[['"]{0,1}[a-zA-Z0-9_]+?['"]{0,1}\]\s*\)";i:107;s:74:"=\s*\$GLOBALS\[\s*['"]{0,1}_(GET|POST|SERVER|COOKIE|REQUEST)['"]{0,1}\s*\]";i:108;s:75:"\$resultFUL\s*=\s*stripcslashes\s*\(\s*\$_POST\[['"]{0,1}resultFUL['"]{0,1}";i:109;s:15:"/usr/sbin/httpd";i:110;s:64:"echo\s+stripslashes\s*\(\s*\$_(GET|POST|SERVER|COOKIE|REQUEST)\[";i:111;s:32:"PRIVMSG\.\*:\.owner\\s\+\(\.\*\)";i:112;s:83:"print\s+\$sock\s+['"]{0,1}NICK ['"]{0,1}\s+\.\s+\$nick\s+\.\s+['"]{0,1}\\n['"]{0,1}";i:113;s:80:"\$url\s*=\s*\$url\s*\.\s*['"]{0,1}\?['"]{0,1}\s*\.\s*http_build_query\(\$query\)";i:114;s:123:"preg_match_all\(['"]{0,1}/<a href="\\/url\\\?q=\(\.\+\?\)\[&\|"\]\+/is['"]{0,1}, \$page\[['"]{0,1}exe['"]{0,1}\], \$links\)";i:115;s:106:"<script\s+language=['"]{0,1}JavaScript['"]{0,1}>\s*parent\.window\.opener\.location\s*=\s*['"]{0,1}http://";i:116;s:77:"\$p\s*=\s*strpos\s*\(\s*\$tx\s*,\s*['"]{0,1}{#['"]{0,1}\s*,\s*\$p2\s*\+\s*2\)";i:117;s:29:"ErrorDocument\s+400\s+http://";i:118;s:29:"ErrorDocument\s+500\s+http://";i:119;s:15:"\(msie\|opera\)";i:120;s:49:"RewriteCond\s*%{HTTP_USER_AGENT}\s*\.\*ndroid\.\*";i:121;s:28:"google\|yandex\|bot\|rambler";i:122;s:99:"if\s*\(\s*is_dir\s*\(\s*\$FullPath\s*\)\s*\)\s*AllDir\s*\(\s*\$FullPath\s*,\s*\$Files\s*\);\s*}\s*}";i:123;s:167:"['"]{0,1}From:\s*['"]{0,1}\.\$_POST\[['"]{0,1}realname['"]{0,1}\]\.['"]{0,1} ['"]{0,1}\.['"]{0,1} <['"]{0,1}\.\$_POST\[['"]{0,1}from['"]{0,1}\]\.['"]{0,1}>\\n['"]{0,1}";i:124;s:53:"<!--#exec\s+cmd=['"]{0,1}\$HTTP_ACCEPT['"]{0,1}\s*-->";i:125;s:26:"\[-\]\s+Connection\s+faild";i:126;s:63:"if\(/\^\\:\$owner!\.\*\\@\.\*PRIVMSG\.\*:\.msgflood\(\.\*\)/\){";i:127;s:34:"print\s*\$sock "PRIVMSG "\.\$owner";i:128;s:64:"\]=['"]{0,1}ip['"]{0,1}\s*;\s*if\s*\(\s*isset\s*\(\s*\$_SERVER\[";i:129;s:51:"\]\s*}\s*=\s*trim\s*\(\s*array_pop\s*\(\s*\${\s*\${";i:130;s:30:"print\("#\s+info\s+OK\\n\\n"\)";i:131;s:132:"\$user_agent\s*=\s*preg_replace\s*\(\s*['"]{0,1}\|User\\\.Agent\\:\[\\s \]\?\|i['"]{0,1}\s*,\s*['"]{0,1}['"]{0,1}\s*,\s*\$user_agent";i:132;s:71:"\$p\s*=\s*strpos\(\$tx\s*,\s*['"]{0,1}{#['"]{0,1}\s*,\s*\$p2\s*\+\s*2\)";i:133;s:101:"create_function\s*\(\s*['"]{0,1}\$m['"]{0,1}\s*,\s*['"]{0,1}if\s*\(\s*\$m\s*\[\s*0x01\s*\]\s*==\s*"L"";i:134;s:89:"\$letter\s*=\s*str_replace\s*\(\s*\$ARRAY\[0\]\[\$j\]\s*,\s*\$arr\[\$ind\]\s*,\s*\$letter";i:135;s:21:"eval\s*\(\s*str_rot13";i:136;s:38:"eval\s*\(\s*gzinflate\s*\(\s*str_rot13";i:137;s:48:"function\s*chmod_R\s*\(\s*\$path\s*,\s*\$perm\s*";i:138;s:9:"IrIsT\.Ir";i:139;s:11:"Hacked\s+By";i:140;s:33:"symbian\|midp\|wap\|phone\|pocket";i:141;s:46:"if\s*\(detect_mobile_device\(\)\)\s*{\s*header";i:142;s:37:"\$post\s*=\s*['"]{0,1}\\x77\\x67\\x65";i:143;s:37:"echo\s*['"]{0,1}answer=error['"]{0,1}";i:144;s:34:"url=<\?php\s*echo\s*\$rand_url;\?>";i:145;s:45:"if\(CheckIPOperator\(\)\s*&&\s*!isModem\(\)\)";i:146;s:59:"strpos\(\$ua,\s*['"]{0,1}yandexbot['"]{0,1}\)\s*!==\s*false";i:147;s:134:"if\s*\(\$key\s*!=\s*['"]{0,1}mail_to['"]{0,1}\s*&&\s*\$key\s*!=\s*['"]{0,1}smtp_server['"]{0,1}\s*&&\s*\$key\s*!=\s*['"]{0,1}smtp_port";i:148;s:52:"echo['"]{0,1}<center><b>Done\s*==>\s*\$userfile_name";i:149;s:25:"['"]{0,1}e/\*\./['"]{0,1}";i:150;s:26:"assert\s*\(\s*stripslashes";i:151;s:51:"\)\s*\.\s*substr\s*\(\s*md5\s*\(\s*strrev\s*\(\s*\$";i:152;s:65:"\$fl\s*=\s*"<meta http-equiv=\\"Refresh\\"\s+content=\\"0;\s*URL=";i:153;s:90:",\s*array\s*\('\.','\.\.','Thumbs\.db'\)\s*\)\s*\)\s*{\s*continue;\s*}\s*if\s*\(\s*is_file";i:154;s:83:"if\s*\(\s*\$dataSize\s*<\s*BOTCRYPT_MAX_SIZE\s*\)\s*rc4\s*\(\s*\$data,\s*\$cryptkey";i:155;s:43:"str_rot13\s*\(\s*['"]{0,1}tmvasyng['"]{0,1}";i:156;s:48:"str_rot13\s*\(\s*['"]{0,1}onfr64_qrpbqr['"]{0,1}";i:157;s:178:"if\s*\(\s*\$_POST\[\s*['"]{0,1}path['"]{0,1}\s*\]\s*==\s*['"]{0,1}['"]{0,1}\s*\)\s*{\s*\$uploadfile\s*=\s*\$_FILES\[\s*['"]{0,1}file['"]{0,1}\s*\]\[\s*['"]{0,1}name['"]{0,1}\s*\]";i:158;s:99:"if\s*\(\s*fwrite\s*\(\s*\$handle\s*,\s*file_get_contents\s*\(\s*\$_(GET|POST|SERVER|COOKIE|REQUEST)";i:159;s:89:"array_key_exists\s*\(\s*\$fileRas\s*,\s*\$fileType\)\s*\?\s*\$fileType\[\s*\$fileRas\s*\]";i:160;s:65:"urlencode\(print_r\(array\(\),1\)\),5,1\)\.c\),\$c\);}eval\(\$d\)";i:161;s:44:"if\s*\(\s*function_exists\s*\(\s*'pcntl_fork";i:162;s:43:"find\s+/\s+-type\s+f\s+-perm\s+-04000\s+-ls";i:163;s:38:"execl\("/bin/sh", "/bin/sh", "-i", 0\)";i:164;s:41:"function\s+inject\(\$file,\s*\$injection=";i:165;s:32:"fclose\(\$f\);\s*echo\s*"o\.k\."";i:166;s:72:"preg_replace\s*\(\s*\$exif\[\s*'Make'\s*\]\s*,\s*\$exif\[\s*'Model'\s*\]";i:167;s:72:"\^downloads/\(\[0-9\]\*\)/\(\[0-9\]\*\)/\$\s+downloads\.php\?c=\$1&p=\$2";i:168;s:81:"\$res=mysql_query\(['"]{0,1}SELECT\s+\*\s+FROM\s+`watchdog_old_05`\s+WHERE\s+page";i:169;s:52:"RewriteRule\s+\.\*\s+index\.php\?url=\$0\s+\[L,QSA\]";i:170;s:100:"IO::Socket::INET->new\(Proto\s*=>\s*"tcp"\s*,\s*LocalPort\s*=>\s*36000\s*,\s*Listen\s*=>\s*SOMAXCONN";i:171;s:39:"eval\s*\(*\s*strrev\s*\(*\s*str_replace";i:172;s:212:"@move_uploaded_file\s*\(\s*\$_FILES\[\s*['"]{0,1}message['"]{0,1}\s*\]\[\s*['"]{0,1}tmp_name['"]{0,1}\s*\]\s*,\s*\$security_code\s*\.\s*"/"\s*\.\s*\$_FILES\[['"]{0,1}message['"]{0,1}\]\[['"]{0,1}name['"]{0,1}\]\)";i:173;s:82:"\$URL\s*=\s*\$urls\[\s*rand\(\s*0\s*,\s*count\s*\(\s*\$urls\s*\)\s*-\s*1\s*\)\s*\]";i:174;s:232:"isset\s*\(\s*\$_FILES\[\s*['"]{0,1}x['"]{0,1}\s*\]\s*\)\s*\?\s*\(\s*is_uploaded_file\s*\(\s*\$_FILES\[\s*['"]{0,1}x['"]{0,1}\s*\]\[\s*['"]{0,1}tmp_name['"]{0,1}\s*\]\s*\)\s*\?\s*\(\s*copy\s*\(\s*\$_FILES\[\s*['"]{0,1}x['"]{0,1}\s*\]";i:175;s:87:"if\s*\(\s*\$i\s*<\s*\(\s*count\s*\(\s*\$_POST\[\s*['"]{0,1}q['"]{0,1}\s*\]\s*\)\s*-\s*1";i:176;s:38:"echo\s*\(*\s*['"]{0,1}NO FILE['"]{0,1}";i:177;s:190:"move_uploaded_file\s*\(*\s*\$_FILES\[\s*['"]{0,1}filename['"]{0,1}\s*\]\[\s*['"]{0,1}tmp_name['"]{0,1}\s*\]\s*,\s*\$_FILES\[\s*['"]{0,1}filename['"]{0,1}\s*\]\[\s*['"]{0,1}name['"]{0,1}\s*\]";i:178;s:70:"file_get_contents\s*\(*\s*ADMIN_REDIR_URL\s*,\s*false\s*,\s*\$ctx\s*\)";i:179;s:28:"copy\s*\(\s*['"]{0,1}http://";i:180;s:12:"tmhapbzcerff";i:181;s:97:"content=['"]{0,1}no-cache['"]{0,1};\s*\$config\[['"]{0,1}description['"]{0,1}\]\s*\.=\s*['"]{0,1}";i:182;s:74:"clearstatcache\(\s*\);\s*if\s*\(\s*!is_dir\s*\(\s*\$fld\s*\)\s*\)\s*return";i:183;s:97:"\$rBuffLen\s*=\s*ord\s*\(\s*VC_Decrypt\s*\(\s*fread\s*\(\s*\$input,\s*1\s*\)\s*\)\s*\)\s*\*\s*256";i:184;s:9:"IrSecTeam";i:185;s:92:"@setcookie\(['"]{0,1}m['"]{0,1},\s*['"]{0,1}[a-zA-Z0-9_]+?['"]{0,1},\s*time\(\)\s*\+\s*86400";i:186;s:123:"@header\(['"]{0,1}Location:\s*['"]{0,1}\.['"]{0,1}h['"]{0,1}\.['"]{0,1}t['"]{0,1}\.['"]{0,1}t['"]{0,1}\.['"]{0,1}p['"]{0,1}";i:187;s:67:"set_time_limit\s*\(\s*0\s*\);\s*if\s*\(!SecretPageHandler::checkKey";i:188;s:106:"return\s*\(\s*strstr\s*\(\s*\$s\s*,\s*'echo'\s*\)\s*==\s*false\s*\?\s*\(\s*strstr\s*\(\s*\$s\s*,\s*'print'";i:189;s:85:"time\(\)\s*\+\s*10000\s*,\s*['"]{0,1}/['"]{0,1}\);\s*echo\s+\$m_zz;\s*eval\s*\(\$m_zz";i:190;s:145:"if\(!empty\(\$_FILES\[['"]{0,1}message['"]{0,1}\]\[['"]{0,1}name['"]{0,1}\]\)\s+AND\s+\(md5\(\$_POST\[['"]{0,1}nick['"]{0,1}\]\)\s*==\s*['"]{0,1}";i:191;s:47:"str_rot13\s*\(\s*gzinflate\s*\(\s*base64_decode";i:192;s:50:"gzuncompress\s*\(\s*str_rot13\s*\(\s*base64_decode";i:193;s:50:"gzuncompress\s*\(\s*base64_decode\s*\(\s*str_rot13";i:194;s:61:"gzinflate\s*\(\s*base64_decode\s*\(\s*str_rot13\s*\(\s*strrev";i:195;s:61:"gzinflate\s*\(\s*base64_decode\s*\(\s*strrev\s*\(\s*str_rot13";i:196;s:44:"gzinflate\s*\(\s*base64_decode\s*\(\s*strrev";i:197;s:68:"gzinflate\s*\(\s*base64_decode\s*\(\s*base64_decode\s*\(\s*str_rot13";i:198;s:54:"base64_decode\s*\(\s*gzuncompress\s*\(\s*base64_decode";i:199;s:47:"gzinflate\s*\(\s*base64_decode\s*\(\s*str_rot13";i:200;s:47:"gzinflate\s*\(\s*str_rot13\s*\(\s*base64_decode";i:201;s:33:"gzuncompress\s*\(\s*base64_decode";i:202;s:30:"gzinflate\s*\(\s*base64_decode";i:203;s:25:"eval\s*\(\s*base64_decode";i:204;s:17:"Brazil\s+HackTeam";i:205;s:90:"\$tld\s*=\s*array\s*\(\s*['"]{0,1}com['"]{0,1},['"]{0,1}org['"]{0,1},['"]{0,1}net['"]{0,1}";i:206;s:37:"str_ireplace\s*\(*\s*['"]{0,1}</head>";i:207;s:55:"define\s*\(*\s*['"]{0,1}SBCID_REQUEST_FILE['"]{0,1}\s*,";i:208;s:39:"preg_replace\s*\(*\s*['"]{0,1}/\.\+/esi";i:209;s:17:"Mysterious\s+Wire";i:210;s:55:"\$headers\s*\.=\s*\$_POST\[['"]{0,1}eMailAdd['"]{0,1}\]";i:211;s:38:"define\s*\(\s*['"]{0,1}DEFCALLBACKMAIL";i:212;s:47:"default_action\s*=\s*['"]{0,1}FilesMan['"]{0,1}";i:213;s:38:"echo\s+@file_get_contents\s*\(\s*\$get";i:214;s:156:"if\s*\(\s*stripos\s*\(\s*\$_SERVER\[['"]{0,1}HTTP_USER_AGENT['"]{0,1}\]\s*,\s*['"]{0,1}Android['"]{0,1}\)\s*!==false\s*&&\s*!\$_COOKIE\[['"]{0,1}dle_user_id";i:215;s:44:"if\s*\(\s*preg_match\s*\(\s*['"]{0,1}#yandex";i:216;s:70:"header\s*\(['"]{0,1}Location:\s*['"]{0,1}\s*\.\s*\$to\s*\.\s*urldecode";i:217;s:15:"Dc0RHa['"]{0,1}";i:218;s:15:"['"]{0,1}aHR0cD";i:219;s:36:"!touch\(['"]{0,1}\.\./\.\./language/";i:220;s:32:"eval\(stripslashes\(\\\$_REQUEST";i:221;s:78:"document\.write\s*\(\s*['"]{0,1}<script\s+src=['"]{0,1}http://<\?=\$domain\?>/";i:222;s:85:"exit\s*\(\s*['"]{0,1}<script>\s*setTimeout\s*\(\s*\\['"]{0,1}document\.location\.href";i:223;s:28:"function\s+sql2_safe\s*\(\s*";i:224;s:41:"\$postResult\s*=\s*curl_exec\s*\(*\s*\$ch";i:225;s:87:"&&\s*function_exists\s*\(*\s*['"]{0,1}getmxrr['"]{0,1}\)\s*\)\s*{\s*@getmxrr\s*\(*\s*\$";i:226;s:57:"is__writable\s*\(*\s*\$path\s*\.\s*uniqid\s*\(*\s*mt_rand";i:227;s:28:"file_put_contentz\s*\(*\s*\$";i:228;s:31:"=\s*array_map\s*\(*\s*strrev\s*";i:229;s:9:"\$___\s*=";i:230;s:55:"@*gzinflate\s*\(\s*@*base64_decode\s*\(\s*@*str_replace";i:231;s:87:"fopen\s*\(*\s*"http://"\s*\.\s*\$check_domain\s*\.\s*":80"\s*\.\s*\$check_doc\s*,\s*"r"";i:232;s:43:"@\$_COOKIE\[['"]{0,1}statCounter['"]{0,1}\]";i:233;s:35:"if\s*\(*\s*@*preg_match\s*\(*\s*str";i:234;s:94:"array_pop\s*\(*\s*\$workReplace\s*,\s*\$_(GET|POST|SERVER|COOKIE|REQUEST)\s*,\s*\$countKeysNew";i:235;s:64:"(GET|POST|SERVER|COOKIE|REQUEST)\s*\[\s*['"]{0,1}___['"]{0,1}\s*";i:236;s:33:"\(\s*['"]{0,1}INSHELL['"]{0,1}\s*";i:237;s:47:"\$b\s*\.\s*\$p\s*\.\s*\$h\s*\.\s*\$k\s*\.\s*\$v";i:238;s:145:"\$[a-zA-Z0-9_]+?\s*\(\s*\d+\s*\^\s*\d+\s*\)\s*\.\s*\$[a-zA-Z0-9_]+?\s*\(\s*\d+\s*\^\s*\d+\s*\)\s*\.\s*\$[a-zA-Z0-9_]+?\s*\(\s*\d+\s*\^\s*\d+\s*\)";i:239;s:114:"=\s*preg_split\s*\(\s*['"]{0,1}/\\,\(\\ \+\)\?/['"]{0,1},\s*@*ini_get\s*\(\s*['"]{0,1}disable_functions['"]{0,1}\)";i:240;s:125:"if\s*\(!function_exists\s*\(\s*['"]{0,1}posix_getpwuid['"]{0,1}\s*\)\s*&&\s*!in_array\s*\(\s*['"]{0,1}posix_getpwuid['"]{0,1}";i:241;s:43:"stream_socket_client\s*\(\s*['"]{0,1}tcp://";i:242;s:143:"preg_replace\s*\(\s*['"]{0,1}/\^\(www\|ftp\)\\\./i['"]{0,1}\s*,\s*['"]{0,1}['"]{0,1},\s*@\$_SERVER\s*\[\s*['"]{0,1}HTTP_HOST['"]{0,1}\s*\]\s*\)";i:243;s:261:"if\s*\(*\s*isset\s*\(*\s*\$_(GET|POST|SERVER|COOKIE|REQUEST)\s*\[\s*['"]{0,1}[a-zA-Z_0-9]+['"]{0,1}\s*\]\s*\)*\s*\)\s*{\s*\$[a-zA-Z_0-9]+\s*=\s*\$_(GET|POST|SERVER|COOKIE|REQUEST)\s*\[\s*['"]{0,1}[a-zA-Z_0-9]+['"]{0,1}\s*\];\s*eval\s*\(*\s*\$[a-zA-Z_0-9]+\s*\)*";i:244;s:81:"eval\s*\(*\s*stripslashes\s*\(*\s*array_pop\(*\$_(GET|POST|SERVER|COOKIE|REQUEST)";i:245;s:154:"if\s+\(\s*strpos\s*\(\s*\$url\s*,\s*['"]{0,1}js/mootools\.js['"]{0,1}\s*\)\s*===\s*false\s+&&\s+strpos\s*\(\s*\$url\s*,\s*['"]{0,1}js/caption\.js['"]{0,1}";i:246;s:68:"if\s+\(*\s*mail\s*\(\s*\$recp\s*,\s*\$subj\s*,\s*\$stunt\s*,\s*\$frm";i:247;s:43:"<\?php\s+\$_F\s*=\s*__FILE__\s*;\s*\$_X\s*=";i:248;s:104:"\$x\d+\s*=\s*['"]{0,1}.+?['"]{0,1}\s*;\s*\$x\d+\s*=\s*['"]{0,1}.+?['"]{0,1}\s*;\s*\$x\d+\s*=\s*['"]{0,1}";i:249;s:115:"\$beecode\s*=@*file_get_contents\s*['"]{0,1}\(*\s*\$urlpurs\s*['"]{0,1}\)*\s*;\s*echo\s+['"]{0,1}\$beecode['"]{0,1}";i:250;s:101:"\$GLOBALS\[\s*['"]{0,1}.+?['"]{0,1}\s*\]\[\s*\d+\s*\]\(\s*\$_\d+\s*,\s*_\d+\s*\(\s*\d+\s*\)\s*\)\s*\)";i:251;s:73:"preg_replace\s*\(*\s*['"]{0,1}/\.\*\[.+?\]\?/e['"]{0,1}\s*,\s*str_replace";i:252;s:149:"\$GLOBALS\[['"]{0,1}.+?['"]{0,1}\]=Array\s*\(\s*base64_decode\s*\(\s*['"]{0,1}.+?['"]{0,1}\s*\)\s*,\s*base64_decode\s*\(\s*['"]{0,1}.+?['"]{0,1}\s*\)";i:253;s:200:"UNION\s+SELECT\s+['"]{0,1}0['"]{0,1}\s*,\s*['"]{0,1}<\? system\(\\\$_(GET|POST|SERVER|COOKIE|REQUEST)\[cpc\]\);exit;\s*\?>['"]{0,1}\s*,\s*0\s*,0\s*,\s*0\s*,\s*0\s+INTO\s+OUTFILE\s+['"]{0,1}\$['"]{0,1}";i:254;s:93:"isset\(*\$_@*(GET|POST|SERVER|COOKIE|REQUEST)\[['"]{0,1}.+?['"]{0,1}\]\)*\s*or\s*die\(*.*?\)*";i:255;s:66:"isset\s*\(*\s*\$_POST\s*\[\s*['"]{0,1}execgate['"]{0,1}\s*\]\s*\)*";i:256;s:81:"fwrite\s*\(*\s*\$fpsetv\s*,\s*getenv\s*\(\s*['"]{0,1}HTTP_COOKIE['"]{0,1}\s*\)\s*";i:257;s:57:"Options\s+FollowSymLinks\s+MultiViews\s+Indexes\s+ExecCGI";i:258;s:31:"symlink\s*\(*\s*['"]{0,1}/home/";i:259;s:70:"function\s+urlGetContents\s*\(*\s*\$url\s*,\s*\$timeout\s*=\s*\d+\s*\)";i:260;s:49:"strrev\(*\s*['"]{0,1}edoced_46esab['"]{0,1}\s*\)*";i:261;s:42:"strrev\(*\s*['"]{0,1}tressa['"]{0,1}\s*\)*";i:262;s:25:"exec\s*\(\s*['"]{0,1}ipfw";i:263;s:136:"wp_posts\s+WHERE\s+post_type\s*=\s*['"]{0,1}post['"]{0,1}\s+AND\s+post_status\s*=\s*['"]{0,1}publish['"]{0,1}\s+ORDER\s+BY\s+`ID`\s+DESC";i:264;s:112:"file_get_contents\s*\(*\s*trim\s*\(\s*\$.+?\[\$_(GET|POST|SERVER|COOKIE|REQUEST)\[['"]{0,1}.+?['"]{0,1}\]\]\)\);";i:265;s:195:"is_callable\s*\(*\s*['"]{0,1}(system|shell_exec|passthru|popen|proc_open)['"]{0,1}\)*\s+and\s+!in_array\s*\(*\s*['"]{0,1}(system|shell_exec|passthru|popen|proc_open)['"]{0,1}\s*,\s*\$disablefuncs";i:266;s:24:"\$GLOBALS\[['"]{0,1}____";i:267;s:43:"fopen\s*\(*\s*['"]{0,1}/etc/passwd['"]{0,1}";i:268;s:59:"eval\s*\(*@*\s*stripslashes\s*\(*\s*array_pop\s*\(*\s*@*\$_";i:269;s:41:"eval\s*\(*@*\s*stripslashes\s*\(*\s*@*\$_";i:270;s:52:"is_writable\s*\(*\s*['"]{0,1}/var/tmp['"]{0,1}\s*\)*";i:271;s:74:"@*setcookie\s*\(*\s*['"]{0,1}hit['"]{0,1},\s*1\s*,\s*time\s*\(*\s*\)*\s*\+";i:272;s:36:"eval\s*\(*\s*file_get_contents\s*\(*";i:273;s:46:"preg_replace\s*\(*\s*['"]{0,1}/\.\*/e['"]{0,1}";i:274;s:81:"\s*{\s*\$_(GET|POST|SERVER|COOKIE|REQUEST)\s*\[\s*['"]{0,1}root['"]{0,1}\s*\]\s*}";i:275;s:135:"['"]{0,1}httpd\.conf['"]{0,1}\s*,\s*['"]{0,1}vhosts\.conf['"]{0,1}\s*,\s*['"]{0,1}cfg\.php['"]{0,1}\s*,\s*['"]{0,1}config\.php['"]{0,1}";i:276;s:33:"proc_open\s*\(\s*['"]{0,1}IHSteam";i:277;s:88:"\$ini\s*\[\s*['"]{0,1}users['"]{0,1}\s*\]\s*=\s*array\s*\(\s*['"]{0,1}root['"]{0,1}\s*=>";i:278;s:88:"curl_setopt\s*\(\s*\$ch\s*,\s*CURLOPT_URL\s*,\s*['"]{0,1}http://\$host:\d+['"]{0,1}\s*\)";i:279;s:45:"system\s*\(*\s*['"]{0,1}whoami['"]{0,1}\s*\)*";i:280;s:52:"find\s+/\s+-name\s+\.ssh\s+>\s+\$dir/sshkeys/sshkeys";i:281;s:37:"require_once\s*\(*\s*['"]{0,1}images/";i:282;s:37:"include_once\s*\(*\s*['"]{0,1}images/";i:283;s:58:"require_once\s*\(*\s*@*\$_(GET|POST|SERVER|COOKIE|REQUEST)";i:284;s:58:"include_once\s*\(*\s*@*\$_(GET|POST|SERVER|COOKIE|REQUEST)";i:285;s:32:"require\s*\(*\s*['"]{0,1}images/";i:286;s:32:"include\s*\(*\s*['"]{0,1}images/";i:287;s:53:"require\s*\(*\s*@*\$_(GET|POST|SERVER|COOKIE|REQUEST)";i:288;s:53:"include\s*\(*\s*@*\$_(GET|POST|SERVER|COOKIE|REQUEST)";i:289;s:52:"assert\s*\(*\s*@*\$_(GET|POST|SERVER|COOKIE|REQUEST)";i:290;s:50:"eval\s*\(*\s*@*\$_(GET|POST|SERVER|COOKIE|REQUEST)";i:291;s:25:"php\s+"\s*\.\s*\$wso_path";i:292;s:89:"@*assert\s*\(*\s*\$_(GET|POST|SERVER|COOKIE|REQUEST)\s*\[\s*['"]{0,1}.+?['"]{0,1}\s*\]\s*";i:293;s:10:"eva1.+?Sir";i:294;s:93:"\$cmd\s*=\s*\(\s*@*\$_(GET|POST|SERVER|COOKIE|REQUEST)\s*\[\s*['"]{0,1}.+?['"]{0,1}\s*\]\s*\)";i:295;s:96:"\$function\s*\(*\s*@*\$_(GET|POST|SERVER|COOKIE|REQUEST)\s*\[\s*['"]{0,1}cmd['"]{0,1}\s*\]\s*\)*";i:296;s:23:"\$fe\("\$cmd\s+2>&1"\);";i:297;s:88:"system\("\$cmd\s+1>\s*/tmp/cmdtemp\s+2>&1;\s*cat\s+/tmp/cmdtemp;\s*rm\s+/tmp/cmdtemp"\);";i:298;s:63:"setcookie\(*\s*['"]{0,1}mysql_web_admin_username['"]{0,1}\s*\)*";i:299;s:53:"shell_exec\s*\(*\s*['"]{0,1}uname\s+-a['"]{0,1}\s*\)*";i:300;s:94:"shell_exec\s*\(*\s*@*\$_POST\s*\[\s*['"]{0,1}.+?['"]{0,1}\s*\]\s*\.\s*"\s*2\s*>\s*&1\s*"\s*\)*";i:301;s:43:"!@*\$_REQUEST\s*\[\s*"c99sh_surl"\s*\]\s*\)";i:302;s:37:"\$login\s*=\s*@*posix_getuid\(*\s*\)*";i:303;s:30:"exec\s*\(*\s*['"]{0,1}rm\s*-fr";i:304;s:30:"exec\s*\(*\s*['"]{0,1}rm\s*-rf";i:305;s:34:"exec\s*\(*\s*['"]{0,1}rm\s*-r\s*-f";i:306;s:31:"ncftpput\s*-u\s*\$ftp_user_name";i:307;s:102:"runcommand\s*\(\s*['"]{0,1}shellhelp['"]{0,1}\s*,\s*['"]{0,1}(GET|POST|SERVER|COOKIE|REQUEST)['"]{0,1}";i:308;s:55:"{\s*\$\s*{\s*passthru\s*\(*\s*\$cmd\s*\)\s*}\s*}\s*<br>";i:309;s:53:"passthru\s*\(*\s*getenv\s*\(*\s*'HTTP_ACCEPT_LANGUAGE";i:310;s:53:"passthru\s*\(*\s*getenv\s*\(*\s*"HTTP_ACCEPT_LANGUAGE";i:311;s:87:"SELECT\s+1\s+FROM\s+mysql\.user\s+WHERE\s+concat\(\s*`user`\s*,\s*'@'\s*,\s*`host`\s*\)";i:312;s:97:"\$MessageSubject\s*=\s*base64_decode\s*\(\s*\$_POST\s*\[\s*['"]{0,1}msgsubject['"]{0,1}\s*\]\s*\)";i:313;s:44:"rename\s*\(\s*['"]{0,1}wso\.php['"]{0,1}\s*,";i:314;s:68:"filepath\s*=\s*@*realpath\s*\(\s*\$_POST\s*\[\s*"filepath"\s*\]\s*\)";i:315;s:68:"filepath\s*=\s*@*realpath\s*\(\s*\$_POST\s*\[\s*'filepath'\s*\]\s*\)";i:316;s:40:"eval\s*\(*\s*base64_decode\s*\(*\s*@*\$_";i:317;s:87:"wsoEx\s*\(\s*'\s*tar\s*cfzv\s*'\s*\.\s*escapeshellarg\s*\(\s*\$_POST\[\s*'p2'\s*\]\s*\)";i:318;s:68:"WSOsetcookie\s*\(\s*md5\s*\(\s*@*\$_SERVER\[\s*"HTTP_HOST"\s*\]\s*\)";i:319;s:68:"WSOsetcookie\s*\(\s*md5\s*\(\s*@*\$_SERVER\[\s*'HTTP_HOST'\s*\]\s*\)";i:320;s:150:"\$info \.= \(\(\$perms\s*&\s*0x0040\)\s*\?\(\(\$perms\s*&\s*0x0800\)\s*\?\s*'s'\s*:\s*'x'\s*\)\s*:\(\(\$perms\s*&\s*0x0800\)\s*\?\s*'S'\s*:\s*'-'\s*\)";i:321;s:30:"default_action\s*=\s*'FilesMan";i:322;s:33:"system\s+file\s+do\s+not\s+delete";i:323;s:19:"hacked\s+by\s+Hmei7";i:324;s:11:"by\s+Grinay";i:325;s:23:"Captain\s+Crunch\s+Team";i:326;s:96:"\$_(GET|POST|SERVER|COOKIE|REQUEST)\[\s*['"]{0,1}p2['"]{0,1}\s*\]\s*==\s*['"]{0,1}chmod['"]{0,1}";}"));
$gX_FlexDBShe = unserialize(base64_decode("YTo1Nzp7aTowO3M6NTY6IndoaWxlXChjb3VudFwoXCRsaW5lc1wpPlwkY29sX3phcFwpIGFycmF5X3BvcFwoXCRsaW5lc1wpIjtpOjE7czoxMDQ6InNpdGVfZnJvbT1bJyJdezAsMX1cLlwkX1NFUlZFUlxbWyciXXswLDF9SFRUUF9IT1NUWyciXXswLDF9XF1cLlsnIl17MCwxfSZzaXRlX2ZvbGRlcj1bJyJdezAsMX1cLlwkZlxbMVxdIjtpOjI7czozMToiXCRmaWxlYlxzKj1ccypmaWxlX2dldF9jb250ZW50cyI7aTozO3M6MzM6InBvcnRsZXRzL2ZyYW1ld29yay9zZWN1cml0eS9sb2dpbiI7aTo0O3M6Mjk6IlwkYlxzKj1ccyptZDVfZmlsZVwoXCRmaWxlYlwpIjtpOjU7czo0NToiTW96aWxsYS81XC4wXHMqXChjb21wYXRpYmxlO1xzKkdvb2dsZWJvdC8yXC4xIjtpOjY7czo1MToiXCRkYXRhXHMqPVxzKmFycmF5XChbJyJdezAsMX10ZXJtaW5hbFsnIl17MCwxfVxzKj0+IjtpOjc7czo3Nzoic3RyaXN0clwoXCRfU0VSVkVSXFtbJyJdezAsMX1IVFRQX1VTRVJfQUdFTlRbJyJdezAsMX1cXSxccypbJyJdezAsMX1ZYW5kZXhCb3QiO2k6ODtzOjQ2OiJwcmVnX3JlcGxhY2VcKFxzKlsnIl17MCwxfWVbJyJdezAsMX0sWyciXXswLDF9IjtpOjk7czoxNjoiKC4pXC5cKlwyW2Etel0qZSI7aToxMDtzOjE0OiJyb290QGxvY2FsaG9zdCI7aToxMTtzOjQ1OiJwaHBfWyciXXswLDF9XC5cJGV4dFwuWyciXXswLDF9XC5kbGxbJyJdezAsMX0iO2k6MTI7czoxNjoiKFxcXFxcZFxkXGQpezcsfSI7aToxMztzOjUzOiIoXFxcXHh7MCwxfVthLWZBLUYwLTldW2EtZkEtRjAtOV18XFxcXFswLTldezEsM30pezcsfSI7aToxNDtzOjMwOiIvZVsnIl17MCwxfVxzKixccypbJyJdezAsMX1cXHgiO2k6MTU7czoyNDoicGFnZV9maWxlcy9zdHlsZTAwMFwuY3NzIjtpOjE2O3M6MTc6IjwvYm9keT5ccyo8c2NyaXB0IjtpOjE3O3M6NjY6IlJld3JpdGVDb25kXHMqJXtIVFRQOkFjY2VwdC1MYW5ndWFnZX1ccypcKHJ1XHxydS1ydVx8dWtcKVxzKlxbTkNcXSI7aToxODtzOjQyOiJSZXdyaXRlQ29uZFxzKiV7SFRUUDp4LW9wZXJhbWluaS1waG9uZS11YX0iO2k6MTk7czozNDoiUmV3cml0ZUNvbmRccyole0hUVFA6eC13YXAtcHJvZmlsZSI7aToyMDtzOjIyOiJldmFsXHMqXChccypnZXRfb3B0aW9uIjtpOjIxO3M6MTY6IlNwYW1ccytjb21wbGV0ZWQiO2k6MjI7czoyOToiZWNob1xzK1snIl17MCwxfWdvb2RbJyJdezAsMX0iO2k6MjM7czo2MDoiXCRfKEdFVHxQT1NUfFNFUlZFUnxDT09LSUV8UkVRVUVTVClcW1snIl17MCwxfWN2dlsnIl17MCwxfVxdIjtpOjI0O3M6MTE6IkNWVjpccypcJGN2IjtpOjI1O3M6MTU6IlwkYXV0aF9wYXNzXHMqPSI7aToyNjtzOjIyOiI8aDE+TG9hZGluZ1wuXC5cLjwvaDE+IjtpOjI3O3M6MTI6InBocGluZm9cKFwpOyI7aToyODtzOjI1OiJbJyJdezAsMX0vXC5cKi9lWyciXXswLDF9IjtpOjI5O3M6Mzg6ImVjaG9ccytbJyJdezAsMX1vXC5rXC5bJyJdezAsMX07XHMqXD8+IjtpOjMwO3M6NTg6IjxtZXRhXHMraHR0cC1lcXVpdj0iUmVmcmVzaCJccytjb250ZW50PSJcZCs7XHMqVVJMPWh0dHA6Ly8iO2k6MzE7czo1NzoiPG1ldGFccytodHRwLWVxdWl2PSJyZWZyZXNoIlxzK2NvbnRlbnQ9IlxkKztccyp1cmw9PFw/cGhwIjtpOjMyO3M6NjY6IihzeXN0ZW18c2hlbGxfZXhlY3xwYXNzdGhydXxwb3Blbnxwcm9jX29wZW4pXHMqXCgqXHMqWyciXXswLDF9d2dldCI7aTozMztzOjY3OiJzdHJjaHJccypcKCpccypcJF9TRVJWRVJcW1xzKlsnIl17MCwxfUhUVFBfVVNFUl9BR0VOVFsnIl17MCwxfVxzKlxdIjtpOjM0O3M6Njc6InN0cnN0clxzKlwoKlxzKlwkX1NFUlZFUlxbXHMqWyciXXswLDF9SFRUUF9VU0VSX0FHRU5UWyciXXswLDF9XHMqXF0iO2k6MzU7czo2Nzoic3RycG9zXHMqXCgqXHMqXCRfU0VSVkVSXFtccypbJyJdezAsMX1IVFRQX1VTRVJfQUdFTlRbJyJdezAsMX1ccypcXSI7aTozNjtzOjQ5OiJnenVuY29tcHJlc3NccypcKCpccypzdWJzdHJccypcKCpccypiYXNlNjRfZGVjb2RlIjtpOjM3O3M6MjM6IkFkZEhhbmRsZXJccytwaHAtc2NyaXB0IjtpOjM4O3M6MzM6IkFkZFR5cGVccythcHBsaWNhdGlvbi94LWh0dHBkLXBocCI7aTozOTtzOjEwOiJwY250bF9leGVjIjtpOjQwO3M6NjU6IihzeXN0ZW18c2hlbGxfZXhlY3xwYXNzdGhydXxwb3Blbnxwcm9jX29wZW4pXCgqWyciXXswLDF9Y2RccysvdG1wIjtpOjQxO3M6Mjc6IlwkT09PLis/PVxzKnVybGRlY29kZVxzKlwoKiI7aTo0MjtzOjEyOiJybVxzKy1mXHMrLXIiO2k6NDM7czoxMjoicm1ccystclxzKy1mIjtpOjQ0O3M6ODoicm1ccystZnIiO2k6NDU7czo4OiJybVxzKy1yZiI7aTo0NjtzOjk1OiJhZGRfZmlsdGVyXHMqXCgqXHMqWyciXXswLDF9dGhlX2NvbnRlbnRbJyJdezAsMX1ccyosXHMqWyciXXswLDF9X2Jsb2dpbmZvWyciXXswLDF9XHMqLFxzKi4rP1wpKiI7aTo0NztzOjI5OiJldmFsXHMqXCgqXHMqZ2V0X29wdGlvblxzKlwoKiI7aTo0ODtzOjk1OiIoc3lzdGVtfHNoZWxsX2V4ZWN8cGFzc3RocnV8cG9wZW58cHJvY19vcGVuKVxzKlwoKlxzKkAqXCRfKEdFVHxQT1NUfFNFUlZFUnxDT09LSUV8UkVRVUVTVClccypcWyI7aTo0OTtzOjU5OiJiYXNlNjRfZGVjb2RlXHMqXCgqXHMqQCpcJF8oR0VUfFBPU1R8U0VSVkVSfENPT0tJRXxSRVFVRVNUKSI7aTo1MDtzOjg6ImxzXHMrLWxhIjtpOjUxO3M6OTg6ImlmXHMqXChccyppc19jYWxsYWJsZVxzKlwoKlxzKlsnIl17MCwxfShzeXN0ZW18c2hlbGxfZXhlY3xwYXNzdGhydXxwb3Blbnxwcm9jX29wZW4pWyciXXswLDF9XHMqXCkqIjtpOjUyO3M6NTE6ImRvY3VtZW50XC53cml0ZVxzKlwoXHMqdW5lc2NhcGVccypcKFxzKlsnIl17MCwxfSUzQyI7aTo1MztzOjEwNToiaWZccypcKFxzKmZ1bmN0aW9uX2V4aXN0c1xzKlwoXHMqWyciXXswLDF9KHN5c3RlbXxzaGVsbF9leGVjfHBhc3N0aHJ1fHBvcGVufHByb2Nfb3BlbilbJyJdezAsMX1ccypcKVxzKlwpIjtpOjU0O3M6NDA6ImV2YWxccypcKCpccypnemluZmxhdGVccypcKCpccypzdHJfcm90MTMiO2k6NTU7czoxOToicm91bmRccypcKFxzKjBccypcKyI7aTo1NjtzOjE5OiJDb250ZW50LVR5cGU6XHMqXCRfIjt9"));
$g_ExceptFlex = unserialize(base64_decode("YTo3MTp7aTowO3M6ODoic29ydFwoXCkiO2k6MTtzOjEwOiJtdXN0LXJldmFsIjtpOjI7czo5OiJyZXRyaWV2YWwiO2k6MztzOjk6ImRvdWJsZXZhbCI7aTo0O3M6NjY6InJlcXVpcmVccypcKCpccypcJF9TRVJWRVJcW1xzKlsnIl17MCwxfURPQ1VNRU5UX1JPT1RbJyJdezAsMX1ccypcXSI7aTo1O3M6NzE6InJlcXVpcmVfb25jZVxzKlwoKlxzKlwkX1NFUlZFUlxbXHMqWyciXXswLDF9RE9DVU1FTlRfUk9PVFsnIl17MCwxfVxzKlxdIjtpOjY7czo2NjoiaW5jbHVkZVxzKlwoKlxzKlwkX1NFUlZFUlxbXHMqWyciXXswLDF9RE9DVU1FTlRfUk9PVFsnIl17MCwxfVxzKlxdIjtpOjc7czo3MToiaW5jbHVkZV9vbmNlXHMqXCgqXHMqXCRfU0VSVkVSXFtccypbJyJdezAsMX1ET0NVTUVOVF9ST09UWyciXXswLDF9XHMqXF0iO2k6ODtzOjE3OiJcJHNtYXJ0eS0+X2V2YWxcKCI7aTo5O3M6MzA6InByZXBccytybVxzKy1yZlxzKyV7YnVpbGRyb290fSI7aToxMDtzOjIyOiJUT0RPOlxzK3JtXHMrLXJmXHMrdGhlIjtpOjExO3M6Mjc6Imtyc29ydFwoXCR3cHNtaWxpZXN0cmFuc1wpOyI7aToxMjtzOjYzOiJkb2N1bWVudFwud3JpdGVcKHVuZXNjYXBlXCgiJTNDc2NyaXB0IHNyYz0nIiBcKyBnYUpzSG9zdCBcKyAiZ28iO2k6MTM7czo2OiJcLmV4ZWMiO2k6MTQ7czo4OiJleGVjXChcKSI7aToxNTtzOjI0OiJcJHgxID0gXCR0aGlzLT53IC0gXCR4MTsiO2k6MTY7czozMToiYXNvcnRcKFwkQ2FjaGVEaXJPbGRGaWxlc0FnZVwpOyI7aToxNztzOjEzOiJcKCdyNTdzaGVsbCcsIjtpOjE4O3M6MjU6ImV2YWxcKCJsaXN0ZW5lciA9ICJcK2xpc3QiO2k6MTk7czo4OiJldmFsXChcKSI7aToyMDtzOjMzOiJwcmVnX3JlcGxhY2VfY2FsbGJhY2tcKCcvXFx7XChpbWEiO2k6MjE7czoyMToiZXZhbCBcKF9jdE1lbnVJbml0U3RyIjtpOjIyO3M6Mjk6ImJhc2U2NF9kZWNvZGVcKFwkYWNjb3VudEtleVwpIjtpOjIzO3M6Mzk6ImJhc2U2NF9kZWNvZGVcKFwkZGF0YVwpXCk7IFwkYXBpLT5zZXRSZSI7aToyNDtzOjQ4OiJyZXF1aXJlXChcJF9TRVJWRVJcW1xcIkRPQ1VNRU5UX1JPT1RcXCJcXVwuXFwiL2IiO2k6MjU7czo2NToiYmFzZTY0X2RlY29kZVwoXCRfUkVRVUVTVFxbJ3BhcmFtZXRlcnMnXF1cKTsgaWZcKENoZWNrU2VyaWFsaXplZEQiO2k6MjY7czo2MzoicGNudGxfZXhlYycgPT4gQXJyYXlcKEFycmF5XCgxXCksIFwkYXJSZXN1bHRcWydTRUNVUklOR19GVU5DVElPIjtpOjI3O3M6Mzk6ImVjaG8gIjxzY3JpcHQ+YWxlcnRcKCciXC5DVXRpbDo6SlNFc2NhcCI7aToyODtzOjY4OiJiYXNlNjRfZGVjb2RlXChcJF9SRVFVRVNUXFsndGl0bGVfY2hhbmdlcl9saW5rJ1xdXCk7IGlmIFwoc3RybGVuXChcJCI7aToyOTtzOjUxOiJldmFsXCgnXCRoZXhkdGltZSA9ICInIFwuIFwkaGV4ZHRpbWUgXC4gJyI7J1wpOyBcJGYiO2k6MzA7czo1MjoiZWNobyAiPHNjcmlwdD5hbGVydFwoJ1wkcm93LT50aXRsZSAtICJcLl9NT0RVTEVfSVNfRSI7aTozMTtzOjM3OiJlY2hvICI8c2NyaXB0PmFsZXJ0XCgnXCRjaWRzICJcLl9DQU5OIjtpOjMyO3M6NDE6ImlmXCgxXCkgeyBcJHZfaG91ciA9IFwoXCRwX2hlYWRlclxbJ210aW1lIjtpOjMzO3M6NzA6ImRvY3VtZW50XC53cml0ZVwodW5lc2NhcGVcKCIlM0NzY3JpcHQlMjBzcmM9JTIyaHR0cCIgXCsgXChcKCJodHRwczoiID0iO2k6MzQ7czo1NzoiZG9jdW1lbnRcLndyaXRlXCh1bmVzY2FwZVwoIiUzQ3NjcmlwdCBzcmM9JyIgXCsgcGtCYXNlVVJMIjtpOjM1O3M6MzI6ImVjaG8gIjxzY3JpcHQ+YWxlcnRcKCciXC5KVGV4dDo6IjtpOjM2O3M6MjU6IidmaWxlbmFtZSdcKSwgXCgncjU3c2hlbGwiO2k6Mzc7czo0MzoiZWNobyAiPHNjcmlwdD5hbGVydFwoJyIgXC4gXCRlcnJNc2cgXC4gIidcKSI7aTozODtzOjQyOiJlY2hvICI8c2NyaXB0PmFsZXJ0XChcXCJFcnJvciB3aGVuIGxvYWRpbmciO2k6Mzk7czo0MzoiZWNobyAiPHNjcmlwdD5hbGVydFwoJyJcLkpUZXh0OjpfXCgnVkFMSURfRSI7aTo0MDtzOjg6ImV2YWxcKFwpIjtpOjQxO3M6ODoiJ3N5c3RlbSciO2k6NDI7czo2OiInZXZhbCciO2k6NDM7czo2OiIiZXZhbCIiO2k6NDQ7czo2OiJjb3B5XCgiO2k6NDU7czo3OiJfc3lzdGVtIjtpOjQ2O3M6OToic2F2ZTJjb3B5IjtpOjQ3O3M6MTA6ImZpbGVzeXN0ZW0iO2k6NDg7czo4OiJzZW5kbWFpbCI7aTo0OTtzOjg6ImNhbkNobW9kIjtpOjUwO3M6OToiZG91YmxldmFsIjtpOjUxO3M6MTY6Im9wZXJhdGluZyBzeXN0ZW0iO2k6NTI7czoxMDoiZ2xvYmFsZXZhbCI7aTo1MztzOjIxOiJ3aXRoIDAvMC8wIGlmIFwoMVwpIHsiO2k6NTQ7czo0ODoiXCR4MiA9IFwkcGFyYW1cW1snIl17MCwxfXhbJyJdezAsMX1cXSBcKyBcJHdpZHRoIjtpOjU1O3M6MTE6InNwZWNpYWxpc2VkIjtpOjU2O3M6MTk6IndwX2dldF9jdXJyZW50X3VzZXIiO2k6NTc7czo3OiItPmNobW9kIjtpOjU4O3M6NzoiX21haWxcKCI7aTo1OTtzOjc6Il9jb3B5XCgiO2k6NjA7czo0Njoic3RycG9zXChcJF9TRVJWRVJcWydIVFRQX1VTRVJfQUdFTlQnXF0sICdEcnVwYSI7aTo2MTtzOjQ1OiJzdHJwb3NcKFwkX1NFUlZFUlxbJ0hUVFBfVVNFUl9BR0VOVCdcXSwgJ01TSUUiO2k6NjI7czo0NToic3RycG9zXChcJF9TRVJWRVJcWyJIVFRQX1VTRVJfQUdFTlQiXF0sICdNU0lFIjtpOjYzO3M6MTc6ImV2YWwgXChjbGFzc1N0clwpIjtpOjY0O3M6MzE6ImZ1bmN0aW9uX2V4aXN0c1woJ2Jhc2U2NF9kZWNvZGUiO2k6NjU7czo0NDoiZWNobyAiPHNjcmlwdD5hbGVydFwoJyJcLkpUZXh0OjpfXCgnVkFMSURfRU0iO2k6NjY7czo1MjoiXCR4MSA9IFwkbWluX3g7IFwkeDIgPSBcJG1heF94OyBcJHkxID0gXCRtaW5feTsgXCR5MiI7aTo2NztzOjU1OiJcJGN0bVxbJ2EnXF1cKVwpIHsgXCR4ID0gXCR4IFwqIFwkdGhpcy0+azsgXCR5ID0gXChcJHRoIjtpOjY4O3M6NjA6IlsnIl17MCwxfWNyZWF0ZV9mdW5jdGlvblsnIl17MCwxfSwgWyciXXswLDF9Z2V0X3Jlc291cmNlX3R5cCI7aTo2OTtzOjQ5OiJbJyJdezAsMX1jcmVhdGVfZnVuY3Rpb25bJyJdezAsMX0sIFsnIl17MCwxfWNyeXB0IjtpOjcwO3M6Njk6InN0cnBvc1woXCRfU0VSVkVSXFtbJyJdezAsMX1IVFRQX1VTRVJfQUdFTlRbJyJdezAsMX1cXSwgWyciXXswLDF9THlueCI7fQ=="));
$g_SusDB = unserialize(base64_decode("YToxMjc6e2k6MDtzOjEyOiJbJyJdZXZhbFsnIl0iO2k6MTtzOjIxOiJbJyJdYmFzZTY0X2RlY29kZVsnIl0iO2k6MjtzOjIzOiJbJyJdY3JlYXRlX2Z1bmN0aW9uWyciXSI7aTozO3M6MTQ6IlsnIl1hc3NlcnRbJyJdIjtpOjQ7czo3OiJTcGFtbWVyIjtpOjU7czo0MDoiaW5pX2dldFxzKlwoKlsnIl17MCwxfXNhZmVfbW9kZVsnIl17MCwxfSI7aTo2O3M6MTU6ImV2YWxccypbJyJcKFwkXSI7aTo3O3M6MTc6ImFzc2VydFxzKlsnIlwoXCRdIjtpOjg7czoyODoic3JwYXRoOi8vXC5cLi9cLlwuL1wuXC4vXC5cLiI7aTo5O3M6MTI6InBocGluZm9ccypcKCI7aToxMDtzOjE2OiJTSE9XXHMrREFUQUJBU0VTIjtpOjExO3M6MTI6IlxicG9wZW5ccypcKCI7aToxMjtzOjk6ImV4ZWNccypcKCI7aToxMztzOjEzOiJcYnN5c3RlbVxzKlwoIjtpOjE0O3M6MTU6IlxicGFzc3RocnVccypcKCI7aToxNTtzOjE2OiJcYnByb2Nfb3BlblxzKlwoIjtpOjE2O3M6MTU6InNoZWxsX2V4ZWNccypcKCI7aToxNztzOjE2OiJpbmlfcmVzdG9yZVxzKlwoIjtpOjE4O3M6OToiXGJkbFxzKlwoIjtpOjE5O3M6MTQ6Ilxic3ltbGlua1xzKlwoIjtpOjIwO3M6MTI6IlxiY2hncnBccypcKCI7aToyMTtzOjE0OiJcYmluaV9zZXRccypcKCI7aToyMjtzOjEzOiJcYnB1dGVudlxzKlwoIjtpOjIzO3M6MTM6ImdldG15dWlkXHMqXCgiO2k6MjQ7czoxNDoiZnNvY2tvcGVuXHMqXCgiO2k6MjU7czoxNzoicG9zaXhfc2V0dWlkXHMqXCgiO2k6MjY7czoxNzoicG9zaXhfc2V0c2lkXHMqXCgiO2k6Mjc7czoxODoicG9zaXhfc2V0cGdpZFxzKlwoIjtpOjI4O3M6MTU6InBvc2l4X2tpbGxccypcKCI7aToyOTtzOjI3OiJhcGFjaGVfY2hpbGRfdGVybWluYXRlXHMqXCgiO2k6MzA7czoxMjoiXGJjaG1vZFxzKlwoIjtpOjMxO3M6MTI6IlxiY2hkaXJccypcKCI7aTozMjtzOjE1OiJwY250bF9leGVjXHMqXCgiO2k6MzM7czoxNDoiXGJ2aXJ0dWFsXHMqXCgiO2k6MzQ7czoxNToicHJvY19jbG9zZVxzKlwoIjtpOjM1O3M6MjA6InByb2NfZ2V0X3N0YXR1c1xzKlwoIjtpOjM2O3M6MTk6InByb2NfdGVybWluYXRlXHMqXCgiO2k6Mzc7czoxNDoicHJvY19uaWNlXHMqXCgiO2k6Mzg7czoxMzoiZ2V0bXlnaWRccypcKCI7aTozOTtzOjE5OiJwcm9jX2dldHN0YXR1c1xzKlwoIjtpOjQwO3M6MTU6InByb2NfY2xvc2VccypcKCI7aTo0MTtzOjE5OiJlc2NhcGVzaGVsbGNtZFxzKlwoIjtpOjQyO3M6MTk6ImVzY2FwZXNoZWxsYXJnXHMqXCgiO2k6NDM7czoxNjoic2hvd19zb3VyY2VccypcKCI7aTo0NDtzOjEzOiJcYnBjbG9zZVxzKlwoIjtpOjQ1O3M6MTM6InNhZmVfZGlyXHMqXCgiO2k6NDY7czoxNjoiaW5pX3Jlc3RvcmVccypcKCI7aTo0NztzOjEwOiJjaG93blxzKlwoIjtpOjQ4O3M6MTA6ImNoZ3JwXHMqXCgiO2k6NDk7czoxNzoic2hvd25fc291cmNlXHMqXCgiO2k6NTA7czoxOToibXlzcWxfbGlzdF9kYnNccypcKCI7aTo1MTtzOjIxOiJnZXRfY3VycmVudF91c2VyXHMqXCgiO2k6NTI7czoxMjoiZ2V0bXlpZFxzKlwoIjtpOjUzO3M6MTE6IlxibGVha1xzKlwoIjtpOjU0O3M6MTU6InBmc29ja29wZW5ccypcKCI7aTo1NTtzOjIxOiJnZXRfY3VycmVudF91c2VyXHMqXCgiO2k6NTY7czoxMToic3lzbG9nXHMqXCgiO2k6NTc7czoxODoiXCRkZWZhdWx0X3VzZV9hamF4IjtpOjU4O3M6MjE6ImV2YWxccypcKCpccyp1bmVzY2FwZSI7aTo1OTtzOjc6IkZMb29kZVIiO2k6NjA7czozMToiZG9jdW1lbnRcLndyaXRlXHMqXChccyp1bmVzY2FwZSI7aTo2MTtzOjExOiJcYmNvcHlccypcKCI7aTo2MjtzOjIzOiJtb3ZlX3VwbG9hZGVkX2ZpbGVccypcKCI7aTo2MztzOjg6IlwuMzMzMzMzIjtpOjY0O3M6ODoiXC42NjY2NjYiO2k6NjU7czoyMToicm91bmRccypcKCpccyowXHMqXCkqIjtpOjY2O3M6MTExOiJjb3B5XHMqXCgqXHMqXCRfRklMRVNccypcW1xzKlsnIl17MCwxfWZpbGVbJyJdezAsMX1ccypcXVxbXHMqWyciXXswLDF9dG1wX25hbWVbJyJdezAsMX1ccypcXVxzKixccypcJHVwbG9hZGZpbGUiO2k6Njc7czoxMjY6Im1vdmVfdXBsb2FkZWRfZmlsZXNccypcKCpccypcJF9GSUxFU1xzKlxbXHMqWyciXXswLDF9ZmlsZVsnIl17MCwxfVxzKlxdXFtccypbJyJdezAsMX10bXBfbmFtZVsnIl17MCwxfVxzKlxdXHMqLFxzKlwkdXBsb2FkZmlsZSI7aTo2ODtzOjUwOiJpbmlfZ2V0XHMqXChccypbJyJdezAsMX1kaXNhYmxlX2Z1bmN0aW9uc1snIl17MCwxfSI7aTo2OTtzOjM2OiJVTklPTlxzK1NFTEVDVFxzK1snIl17MCwxfTBbJyJdezAsMX0iO2k6NzA7czoxMDoiMlxzKj5ccyomMSI7aTo3MTtzOjU3OiJlY2hvXHMqXCgqXHMqXCRfU0VSVkVSXFtbJyJdezAsMX1ET0NVTUVOVF9ST09UWyciXXswLDF9XF0iO2k6NzI7czozNzoiPVxzKkFycmF5XHMqXCgqXHMqYmFzZTY0X2RlY29kZVxzKlwoKiI7aTo3MztzOjE0OiJraWxsYWxsXHMrLVxkKyI7aTo3NDtzOjc6ImVyaXVxZXIiO2k6NzU7czoxMDoidG91Y2hccypcKCI7aTo3NjtzOjc6InNzaGtleXMiO2k6Nzc7czo4OiJAaW5jbHVkZSI7aTo3ODtzOjg6IkByZXF1aXJlIjtpOjc5O3M6Mzg6IkBpbmlfc2V0XHMqXCgqWyciXXswLDF9YWxsb3dfdXJsX2ZvcGVuIjtpOjgwO3M6MTg6IkBmaWxlX2dldF9jb250ZW50cyI7aTo4MTtzOjE3OiJmaWxlX3B1dF9jb250ZW50cyI7aTo4MjtzOjQ2OiJhbmRyb2lkXHMqXHxccyptaWRwXHMqXHxccypqMm1lXHMqXHxccypzeW1iaWFuIjtpOjgzO3M6Mjg6IkBzZXRjb29raWVccypcKCpbJyJdezAsMX1oaXQiO2k6ODQ7czoxMDoiQGZpbGVvd25lciI7aTo4NTtzOjY6IjxrdWt1PiI7aTo4NjtzOjU6InN5cGV4IjtpOjg3O3M6OToiXCRiZWVjb2RlIjtpOjg4O3M6ODoiQmFja2Rvb3IiO2k6ODk7czoxNDoicGhwX3VuYW1lXHMqXCgiO2k6OTA7czo1NToibWFpbFxzKlwoKlxzKlwkdG9ccyosXHMqXCRzdWJqXHMqLFxzKlwkbXNnXHMqLFxzKlwkZnJvbSI7aTo5MTtzOjY3OiJtYWlsXHMqXCgqXHMqXCRzZW5kXHMqLFxzKlwkc3ViamVjdFxzKixccypcJGhlYWRlcnNccyosXHMqXCRtZXNzYWdlIjtpOjkyO3M6NjU6Im1haWxccypcKCpccypcJHRvXHMqLFxzKlwkc3ViamVjdFxzKixccypcJG1lc3NhZ2VccyosXHMqXCRoZWFkZXJzIjtpOjkzO3M6MTIwOiJzdHJwb3NccypcKCpccypcJG5hbWVccyosXHMqWyciXXswLDF9SFRUUF9bJyJdezAsMX1ccypcKSpccyohPT1ccyowXHMqJiZccypzdHJwb3NccypcKCpccypcJG5hbWVccyosXHMqWyciXXswLDF9UkVRVUVTVF8iO2k6OTQ7czo1MzoiaXNfZnVuY3Rpb25fZW5hYmxlZFxzKlwoXHMqWyciXXswLDF9aWdub3JlX3VzZXJfYWJvcnQiO2k6OTU7czozMDoiZWNob1xzKlwoKlxzKmZpbGVfZ2V0X2NvbnRlbnRzIjtpOjk2O3M6MjY6ImVjaG9ccypcKCpbJyJdezAsMX08c2NyaXB0IjtpOjk3O3M6MzE6InByaW50XHMqXCgqXHMqZmlsZV9nZXRfY29udGVudHMiO2k6OTg7czoyNzoicHJpbnRccypcKCpbJyJdezAsMX08c2NyaXB0IjtpOjk5O3M6ODU6IjxtYXJxdWVlXHMrc3R5bGVccyo9XHMqWyciXXswLDF9cG9zaXRpb25ccyo6XHMqYWJzb2x1dGVccyo7XHMqd2lkdGhccyo6XHMqXGQrXHMqcHhccyoiO2k6MTAwO3M6NDI6Ij1ccypbJyJdezAsMX1cLlwuL1wuXC4vXC5cLi93cC1jb25maWdcLnBocCI7aToxMDE7czo3OiJlZ2dkcm9wIjtpOjEwMjtzOjk6InJ3eHJ3eHJ3eCI7aToxMDM7czoxNToiZXJyb3JfcmVwb3J0aW5nIjtpOjEwNDtzOjE3OiJcYmNyZWF0ZV9mdW5jdGlvbiI7aToxMDU7czo0Mzoie1xzKnBvc2l0aW9uXHMqOlxzKmFic29sdXRlO1xzKmxlZnRccyo6XHMqLSI7aToxMDY7czoxNToiPHNjcmlwdFxzK2FzeW5jIjtpOjEwNztzOjY2OiJfWyciXXswLDF9XHMqXF1ccyo9XHMqQXJyYXlccypcKFxzKmJhc2U2NF9kZWNvZGVccypcKCpccypbJyJdezAsMX0iO2k6MTA4O3M6MzM6IkFkZFR5cGVccythcHBsaWNhdGlvbi94LWh0dHBkLWNnaSI7aToxMDk7czo0NDoiZ2V0ZW52XHMqXCgqXHMqWyciXXswLDF9SFRUUF9DT09LSUVbJyJdezAsMX0iO2k6MTEwO3M6NDU6Imlnbm9yZV91c2VyX2Fib3J0XHMqXCgqXHMqWyciXXswLDF9MVsnIl17MCwxfSI7aToxMTE7czoyMToiXCRfUkVRVUVTVFxzKlxbXHMqJTIyIjtpOjExMjtzOjUxOiJ1cmxccypcKFsnIl17MCwxfWRhdGFccyo6XHMqaW1hZ2UvcG5nO1xzKmJhc2U2NFxzKiwiO2k6MTEzO3M6NTE6InVybFxzKlwoWyciXXswLDF9ZGF0YVxzKjpccyppbWFnZS9naWY7XHMqYmFzZTY0XHMqLCI7aToxMTQ7czozMDoiOlxzKnVybFxzKlwoXHMqWyciXXswLDF9PFw/cGhwIjtpOjExNTtzOjE3OiI8L2h0bWw+Lis/PHNjcmlwdCI7aToxMTY7czoxNzoiPC9odG1sPi4rPzxpZnJhbWUiO2k6MTE3O3M6NTU6IihzeXN0ZW18c2hlbGxfZXhlY3xwYXNzdGhydXxwb3Blbnxwcm9jX29wZW4pXHMqWyciXChcJF0iO2k6MTE4O3M6MTE6IlxibWFpbFxzKlwoIjtpOjExOTtzOjQ2OiJmaWxlX2dldF9jb250ZW50c1xzKlwoKlxzKlsnIl17MCwxfXBocDovL2lucHV0IjtpOjEyMDtzOjExODoiPG1ldGFccytodHRwLWVxdWl2PVsnIl17MCwxfUNvbnRlbnQtdHlwZVsnIl17MCwxfVxzK2NvbnRlbnQ9WyciXXswLDF9dGV4dC9odG1sO1xzKmNoYXJzZXQ9d2luZG93cy0xMjUxWyciXXswLDF9Pjxib2R5PiI7aToxMjE7czo2MjoiPVxzKmRvY3VtZW50XC5jcmVhdGVFbGVtZW50XChccypbJyJdezAsMX1zY3JpcHRbJyJdezAsMX1ccypcKTsiO2k6MTIyO3M6Njk6ImRvY3VtZW50XC5ib2R5XC5pbnNlcnRCZWZvcmVcKGRpdixccypkb2N1bWVudFwuYm9keVwuY2hpbGRyZW5cWzBcXVwpOyI7aToxMjM7czo3NzoiPHNjcmlwdFxzK3R5cGU9InRleHQvamF2YXNjcmlwdCJccytzcmM9Imh0dHA6Ly9bYS16QS1aMC05X10rP1wucGhwIj48L3NjcmlwdD4iO2k6MTI0O3M6Mjc6ImVjaG9ccytbJyJdezAsMX1va1snIl17MCwxfSI7aToxMjU7czoxODoiL3Vzci9zYmluL3NlbmRtYWlsIjtpOjEyNjtzOjIzOiIvdmFyL3FtYWlsL2Jpbi9zZW5kbWFpbCI7fQ=="));
$g_SusDBPrio = unserialize(base64_decode("YToxMjE6e2k6MDtpOjA7aToxO2k6MDtpOjI7aTowO2k6MztpOjA7aTo0O2k6MDtpOjU7aTowO2k6NjtpOjA7aTo3O2k6MDtpOjg7aTowO2k6OTtpOjE7aToxMDtpOjE7aToxMTtpOjA7aToxMjtpOjA7aToxMztpOjA7aToxNDtpOjA7aToxNTtpOjA7aToxNjtpOjA7aToxNztpOjA7aToxODtpOjA7aToxOTtpOjA7aToyMDtpOjA7aToyMTtpOjA7aToyMjtpOjA7aToyMztpOjA7aToyNDtpOjA7aToyNTtpOjA7aToyNjtpOjA7aToyNztpOjA7aToyODtpOjA7aToyOTtpOjA7aTozMDtpOjE7aTozMTtpOjE7aTozMjtpOjA7aTozMztpOjA7aTozNDtpOjA7aTozNTtpOjA7aTozNjtpOjA7aTozNztpOjA7aTozODtpOjA7aTozOTtpOjA7aTo0MDtpOjA7aTo0MTtpOjA7aTo0MjtpOjA7aTo0MztpOjA7aTo0NDtpOjA7aTo0NTtpOjA7aTo0NjtpOjA7aTo0NztpOjA7aTo0ODtpOjA7aTo0OTtpOjA7aTo1MDtpOjA7aTo1MTtpOjA7aTo1MjtpOjA7aTo1MztpOjA7aTo1NDtpOjA7aTo1NTtpOjA7aTo1NjtpOjA7aTo1NztpOjE7aTo1ODtpOjA7aTo1OTtpOjA7aTo2MDtpOjI7aTo2MTtpOjE7aTo2MjtpOjA7aTo2MztpOjA7aTo2NDtpOjA7aTo2NTtpOjI7aTo2NjtpOjI7aTo2NztpOjA7aTo2ODtpOjA7aTo2OTtpOjA7aTo3MDtpOjI7aTo3MTtpOjE7aTo3MjtpOjA7aTo3MztpOjA7aTo3NDtpOjE7aTo3NTtpOjA7aTo3NjtpOjE7aTo3NztpOjE7aTo3ODtpOjE7aTo3OTtpOjM7aTo4MDtpOjI7aTo4MTtpOjA7aTo4MjtpOjI7aTo4MztpOjA7aTo4NDtpOjA7aTo4NTtpOjI7aTo4NjtpOjA7aTo4NztpOjA7aTo4ODtpOjA7aTo4OTtpOjE7aTo5MDtpOjE7aTo5MTtpOjE7aTo5MjtpOjE7aTo5MztpOjA7aTo5NDtpOjI7aTo5NTtpOjI7aTo5NjtpOjI7aTo5NztpOjI7aTo5ODtpOjI7aTo5OTtpOjE7aToxMDA7aToxO2k6MTAxO2k6MztpOjEwMjtpOjM7aToxMDM7aToxO2k6MTA0O2k6MztpOjEwNTtpOjM7aToxMDY7aToyO2k6MTA3O2k6MDtpOjEwODtpOjM7aToxMDk7aToxO2k6MTEwO2k6MTtpOjExMTtpOjM7aToxMTI7aTozO2k6MTEzO2k6MztpOjExNDtpOjE7aToxMTU7aToxO2k6MTE2O2k6MTtpOjExNztpOjQ7aToxMTg7aToxO2k6MTE5O2k6MztpOjEyMDtpOjA7fQ=="));
$g_AdwareSig = unserialize(base64_decode("YToyOTp7aTowO3M6MTk6Il9fbGlua2ZlZWRfcm9ib3RzX18iO2k6MTtzOjEzOiJMSU5LRkVFRF9VU0VSIjtpOjI7czoxNDoiTGlua2ZlZWRDbGllbnQiO2k6MztzOjE4OiJfX3NhcGVfZGVsaW1pdGVyX18iO2k6NDtzOjI5OiJkaXNwZW5zZXJcLmFydGljbGVzXC5zYXBlXC5ydSI7aTo1O3M6MTE6IkxFTktfY2xpZW50IjtpOjY7czoxMToiU0FQRV9jbGllbnQiO2k6NztzOjE2OiJfX2xpbmtmZWVkX2VuZF9fIjtpOjg7czoxNjoiU0xBcnRpY2xlc0NsaWVudCI7aTo5O3M6MTc6Ii0+R2V0TGlua3NccypcKFwpIjtpOjEwO3M6MTc6ImRiXC50cnVzdGxpbmtcLnJ1IjtpOjExO3M6Mzc6ImNsYXNzXHMrQ01fY2xpZW50XHMrZXh0ZW5kc1xzKkNNX2Jhc2UiO2k6MTI7czoxOToibmV3XHMrQ01fY2xpZW50XChcKSI7aToxMztzOjE2OiJ0bF9saW5rc19kYl9maWxlIjtpOjE0O3M6MTU6IlRydXN0bGlua0NsaWVudCI7aToxNTtzOjEzOiItPlxzKlNMQ2xpZW50IjtpOjE2O3M6MTY2OiJpc3NldFxzKlwoKlxzKlwkX1NFUlZFUlxzKlxbXHMqWyciXXswLDF9SFRUUF9VU0VSX0FHRU5UWyciXXswLDF9XHMqXF1ccypcKVxzKiYmXHMqXCgqXHMqXCRfU0VSVkVSXHMqXFtccypbJyJdezAsMX1IVFRQX1VTRVJfQUdFTlRbJyJdezAsMX1cXVxzKj09XHMqWyciXXswLDF9TE1QX1JvYm90IjtpOjE3O3M6NDM6IlwkbGlua3MtPlxzKnJldHVybl9saW5rc1xzKlwoKlxzKlwkbGliX3BhdGgiO2k6MTg7czo0NDoiXCRsaW5rc19jbGFzc1xzKj1ccypuZXdccytHZXRfbGlua3NccypcKCpccyoiO2k6MTk7czo1MjoiWyciXXswLDF9XHMqLFxzKlsnIl17MCwxfVwuWyciXXswLDF9XHMqXCkqXHMqO1xzKlw/PiI7aToyMDtzOjc6Imxldml0cmEiO2k6MjE7czoxMDoiZGFwb3hldGluZSI7aToyMjtzOjY6InZpYWdyYSI7aToyMztzOjY6ImNpYWxpcyI7aToyNDtzOjg6InByb3ZpZ2lsIjtpOjI1O3M6MTk6ImNsYXNzXHMrVFdlZmZDbGllbnQiO2k6MjY7czoxODoibmV3XHMrU0xDbGllbnRcKFwpIjtpOjI3O3M6MjQ6Il9fbGlua2ZlZWRfYmVmb3JlX3RleHRfXyI7aToyODtzOjE2OiJfX3Rlc3RfdGxfbGlua19fIjt9"));
$g_JSVirSig = unserialize(base64_decode("a:116:{i:0;s:70:"userAgent\|pp\|http\|dazalyz['"]{0,1}\.split\(['"]{0,1}\|['"]{0,1}\),0";i:1;s:41:"f='f'\+'r'\+'o'\+'m'\+'Ch'\+'arC'\+'ode';";i:2;s:22:"\.prototype\.a}catch\(";i:3;s:37:"try{Boolean\(\)\.prototype\.q}catch\(";i:4;s:34:"if\(Ref\.indexOf\('\.google\.'\)!=";i:5;s:86:"indexOf\|if\|rc\|length\|msn\|yahoo\|referrer\|altavista\|ogo\|bi\|hp\|var\|aol\|query";i:6;s:54:"Array\.prototype\.slice\.call\(arguments\)\.join\(""\)";i:7;s:82:"q=document\.createElement\("d"\+"i"\+"v"\);q\.appendChild\(q\+""\);}catch\(qw\){h=";i:8;s:79:"\+zz;ss=\[\];f='fr'\+'om'\+'Ch';f\+='arC';f\+='ode';w=this;e=w\[f\["substr"\]\(";i:9;s:115:"s5\(q5\){return \+\+q5;}function yf\(sf,we\){return sf\.substr\(we,1\);}function y1\(wb\){if\(wb==168\)wb=1025;else";i:10;s:64:"if\(navigator\.userAgent\.match\(/\(android\|midp\|j2me\|symbian";i:11;s:106:"document\.write\('<script language="JavaScript" type="text/javascript" src="'\+domain\+'"></scr'\+'ipt>'\)";i:12;s:31:"http://phsp\.ru/_/go\.php\?sid=";i:13;s:17:"</html>\s*<script";i:14;s:17:"</html>\s*<iframe";i:15;s:66:"=navigator\[appVersion_var\]\.indexOf\("MSIE"\)!=-1\?'<iframe name";i:16;s:7:"\\x65At";i:17;s:9:"\\x61rCod";i:18;s:22:""fr"\+"omC"\+"harCode"";i:19;s:11:"="ev"\+"al"";i:20;s:78:"\[\(\(e\)\?"s":""\)\+"p"\+"lit"\]\("a\$"\[\(\(e\)\?"su":""\)\+"bstr"\]\(1\)\);";i:21;s:39:"f='fr'\+'om'\+'Ch';f\+='arC';f\+='ode';";i:22;s:20:"f\+=\(h\)\?'ode':"";";i:23;s:41:"f='f'\+'r'\+'o'\+'m'\+'Ch'\+'arC'\+'ode';";i:24;s:50:"f='fromCh';f\+='arC';f\+='qgode'\["substr"\]\(2\);";i:25;s:16:"var\s+div_colors";i:26;s:9:"var\s+_0x";i:27;s:20:"CoreLibrariesHandler";i:28;s:7:"pingnow";i:29;s:8:"serchbot";i:30;s:10:"km0ae9gr6m";i:31;s:6:"c3284d";i:32;s:8:"\\x68arC";i:33;s:8:"\\x6dCha";i:34;s:7:"\\x6fde";i:35;s:7:"\\x6fde";i:36;s:8:"\\x43ode";i:37;s:7:"\\x72om";i:38;s:7:"\\x43ha";i:39;s:7:"\\x72Co";i:40;s:8:"\\x43ode";i:41;s:10:"\.dyndns\.";i:42;s:9:"\.dyndns-";i:43;s:79:"}\s*else\s*{\s*document\.write\s*\(\s*['"]{0,1}\.['"]{0,1}\)\s*}\s*}\s*R\(\s*\)";i:44;s:45:"document\.write\(unescape\('%3Cdiv%20id%3D%22";i:45;s:18:"\.bitcoinplus\.com";i:46;s:41:"\.split\("&&"\);h=2;s="";if\(m\)for\(i=0;";i:47;s:48:"document\.write\s*\(\s*unescape\s*\(['"]{0,1}%3c";i:48;s:41:"<iframe\s+src="http://deluxesclicks\.pro/";i:49;s:45:"3Bfor\|fromCharCode\|2C27\|3D\|2C88\|unescape";i:50;s:58:";\s*document\.write\(['"]{0,1}<iframe\s*src="http://ya\.ru";i:51;s:110:"w\.document\.body\.appendChild\(script\);\s*clearInterval\(i\);\s*}\s*}\s*,\s*\d+\s*\)\s*;\s*}\s*\)\(\s*window";i:52;s:110:"if\(!g\(\)&&window\.navigator\.cookieEnabled\){document\.cookie="1=1;expires="\+e\.toGMTString\(\)\+";path=/";";i:53;s:70:"nn_param_preloader_container\|5001\|hidden\|innerHTML\|inject\|visible";i:54;s:31:"<!-- [a-zA-Z0-9_]+?\|\|stat -->";i:55;s:85:"&parameter=\$keyword&se=\$se&ur=1&HTTP_REFERER='\+encodeURIComponent\(document\.URL\)";i:56;s:48:"windows\|series\|60\|symbos\|ce\|mobile\|symbian";i:57;s:29:"\["eval"\]\(s\);}}}}</script>";i:58;s:59:"kC70FMblyJkFWZodCKl1WYOdWYUlnQzRnbl1WZsVEdldmL05WZtV3YvRGI9";i:59;s:55:"{k=i;s=s\.concat\(ss\(eval\(asq\(\)\)-1\)\);}z=s;eval\(";i:60;s:130:"document\.cookie\.match\(new\s+RegExp\(\s*"\(\?:\^\|; \)"\s*\+\s*name\.replace\(/\(\[\\\.\$\?\*\|{}\\\(\\\)\\\[\\\]\\/\\\+\^\]\)/g";i:61;s:86:"setCookie\s*\(*\s*"arx_tt"\s*,\s*1\s*,\s*dt\.toGMTString\(\)\s*,\s*['"]{0,1}/['"]{0,1}";i:62;s:14:"/\*214afaae\*/";i:63;s:144:"document\.cookie\.match\s*\(\s*new\s+RegExp\s*\(\s*"\(\?:\^\|;\s*\)"\s*\+\s*name\.replace\s*\(/\(\[\\\.\$\?\*\|{}\\\(\\\)\\\[\\\]\\/\\\+\^\]\)/g";i:64;s:98:"var\s+dt\s+=\s+new\s+Date\(\),\s+expiryTime\s+=\s+dt\.setTime\(\s+dt\.getTime\(\)\s+\+\s+900000000";i:65;s:105:"if\s*\(\s*num\s*===\s*0\s*\)\s*{\s*return\s*1;\s*}\s*else\s*{\s*return\s+num\s*\*\s*rFact\(\s*num\s*-\s*1";i:66;s:41:"\+=String\.fromCharCode\(parseInt\(0\+'x'";i:67;s:83:"<script\s+language="JavaScript">\s*parent\.window\.opener\.location="http://vk\.com";i:68;s:44:"location\.replace\(['"]{0,1}http://v5k45\.ru";i:69;s:129:";try{\+\+document\.body}catch\(q\){aa=function\(ff\){for\(i=0;i<z\.length;i\+\+\){za\+=String\[ff\]\(e\(v\+\(z\[i\]\)\)-12\);}};}";i:70;s:142:"document\.write\s*\(['"]{0,1}<['"]{0,1}\s*\+\s*x\[0\]\s*\+\s*['"]{0,1} ['"]{0,1}\s*\+\s*x\[4\]\s*\+\s*['"]{0,1}>\.['"]{0,1}\s*\+x\s*\[2\]\s*\+";i:71;s:60:"if\(t\.length==2\){z\+=String\.fromCharCode\(parseInt\(t\)\+";i:72;s:74:"window\.onload\s*=\s*function\(\)\s*{\s*if\s*\(document\.cookie\.indexOf\(";i:73;s:79:"document\.getElementsByTagName\(['"]{0,1}head['"]{0,1}\)\[0\]\.appendChild\(a\)";i:74;s:97:"\.style\.height\s*=\s*['"]{0,1}0px['"]{0,1};window\.onload\s*=\s*function\(\)\s*{document\.cookie";i:75;s:122:"\.src=\(['"]{0,1}htps:['"]{0,1}==document\.location\.protocol\?['"]{0,1}https://ssl['"]{0,1}:['"]{0,1}http://['"]{0,1}\)\+";i:76;s:30:"404\.php['"]{0,1}>\s*</script>";i:77;s:76:"preg_match\(['"]{0,1}/sape/i['"]{0,1}\s*,\s*\$_SERVER\[['"]{0,1}HTTP_REFERER";i:78;s:28:"ip\(hone\|od\)\|iris\|kindle";i:79;s:48:"smartphone\|blackberry\|mtk\|bada\|windows phone";i:80;s:74:"div\.innerHTML\s*\+=\s*['"]{0,1}<embed\s+id="dummy2"\s+name="dummy2"\s+src";i:81;s:73:"setTimeout\(['"]{0,1}addNewObject\(\)['"]{0,1},\d+\);}}};addNewObject\(\)";i:82;s:51:"\(b=document\)\.head\.appendChild\(b\.createElement";i:83;s:40:"position:absolute;left:-\d+px;top:-\d+px";i:84;s:30:"Chrome\|iPad\|iPhone\|IEMobile";i:85;s:30:"compal\|elaine\|fennec\|hiptop";i:86;s:21:"-\s*PayPal\s*</title>";i:87;s:22:"-\s*Privati\s*</title>";i:88;s:19:"<title>\s*UniCredit";i:89;s:19:"Bank\s+of\s+America";i:90;s:25:"Alibaba&nbsp;Manufacturer";i:91;s:20:"Verified\s+by\s+Visa";i:92;s:21:"Hong\s+Leong\s+Online";i:93;s:30:"Your\s+account\s+\|\s+Log\s+in";i:94;s:53:"{position:absolute;top:-9999px;}</style><div\s+class=";i:95;s:128:"if\s*\(\(ua\.indexOf\(['"]{0,1}chrome['"]{0,1}\)\s*==\s*-1\s*&&\s*ua\.indexOf\("win"\)\s*!=\s*-1\)\s*&&\s*navigator\.javaEnabled";i:96;s:58:"parent\.window\.opener\.location=['"]{0,1}http://vk\.com\.";i:97;s:41:"\]\.substr\(0,1\)\);}}return this;},\\u00";i:98;s:68:"javascript\|head\|toLowerCase\|chrome\|win\|javaEnabled\|appendChild";i:99;s:56:";c=1};while\(c--\){if\(k\[c\]\){p=p\.replace\(new RegExp";i:100;s:54:";document\.write\(['"]{0,1}<scr['"]{0,1}\+['"]{0,1}ipt";i:101;s:17:"sexfromindia\.com";i:102;s:11:"filekx\.com";i:103;s:13:"stummann\.net";i:104;s:14:"http://xzx\.pm";i:105;s:18:"\.hopto\.me/jquery";i:106;s:11:"mobi-go\.in";i:107;s:18:"bankofamerica\.com";i:108;s:16:"myfilestore\.com";i:109;s:17:"filestore72\.info";i:110;s:16:"file2store\.info";i:111;s:15:"url2short\.info";i:112;s:18:"filestore123\.info";i:113;s:12:"url123\.info";i:114;s:14:"dollarade\.com";i:115;s:11:"secclik\.ru";}"));
//var_dump($g_FlexDBShe);
//exit;
$g_UnsafeFilesArray = array('td*.php', 'a{1,}.php', 'zd*.php', '123.php', 'testd*.php', 'asd.php', 'info.php', 'CHANGELOG.php',
'COPYRIGHT.php', 'CREDITS.php', 'INSTALL.php', 'LICENSE.php', 'LICENSES.php', 'backup.+?.zip',
'backup.+?.tar.gz', 'backup.+?.tgz',
'phpinfo.php', 'changelog.txt', 'readme.txt', 'INSTALLATION.php', 'dump.php', 'changelog.log');
$g_UnsafeDirArray = array('install', 'backup', 'webalizer', 'awstats');
////////////////////////////////////////////////////////////////////////////
if (!isCli() && !isset($_SERVER['HTTP_USER_AGENT'])) {
echo "#####################################################n";
echo "# Error: cannot run on php-cgi. Requires php as cli #n";
echo "# #n";
echo "# See FAQ: http://revisium.com/ai/faq.php #n";
echo "#####################################################n";
exit;
}
define('AI_VERSION', '20140103');
define('INFO_M', base64_decode('PGZvbnQgY29sb3I9I0UwNjA2MD7QotC+0LvRjNC60L4g0LTQu9GPINC90LXQutC+0LzQvNC10YDRh9C10YHQutC+0LPQviDQuNGB0L/QvtC70YzQt9C+0LLQsNC90LjRjyE8L2ZvbnQ+PC9oNT4='));
////////////////////////////////////////////////////////////////////////////
$l_Res = '';
$g_Structure = array();
$g_Counter = 0;
$g_NotRead = array();
$g_FileInfo = array();
$g_Iframer = array();
$g_PHPCodeInside = array();
$g_CriticalJS = array();
$g_HeuristicDetected = array();
$g_HeuristicType = array();
$g_UnixExec = array();
$g_SkippedFolders = array();
$g_UnsafeFilesFound = array();
$g_CMS = array();
$g_SymLinks = array();
$g_HiddenFiles = array();
$g_TotalFolder = 0;
$g_TotalFiles = 0;
$g_FoundTotalDirs = 0;
$g_FoundTotalFiles = 0;
if (!isCli()) {
$defaults['site_url'] = 'http://' . $_SERVER['HTTP_HOST'] . '/';
}
define('CRC32_LIMIT', pow(2, 31) - 1);
define('CRC32_DIFF', CRC32_LIMIT * 2 -2);
error_reporting(E_ALL ^ E_NOTICE ^ E_WARNING);
set_time_limit(0);
ini_set('max_execution_time', '90000');
ini_set('memory_limit','256M');
if (!function_exists('stripos')) {
function stripos($par_Str, $par_Entry, $Offset = 0) {
return strpos(strtolower($par_Str), strtolower($par_Entry), $Offset);
}
}
/**
* Print file
*/
function printFile() {
$l_FileName = $_GET['fn'];
$l_CRC = isset($_GET['c']) ? (int)$_GET['c'] : 0;
$l_Content = implode('', file($l_FileName));
$l_FileCRC = realCRC($l_Content);
if ($l_FileCRC != $l_CRC) {
echo 'Доступ запрещен.';
exit;
}
echo '<pre>' . htmlspecialchars($l_Content) . '</pre>';
}
/**
*
*/
function realCRC($str_in, $full = false)
{
$in = crc32( $full ? normal($str_in) : $str_in );
return ($in > CRC32_LIMIT) ? ($in - CRC32_DIFF) : $in;
}
/**
* Determine php script is called from the command line interface
* @return bool
*/
function isCli()
{
return php_sapi_name() == 'cli';
}
/*
*
*/
function shanonEntropy($par_Str)
{
$dic = array();
$len = strlen($par_Str);
for ($i = 0; $i < $len; $i++) {
$dic[$par_Str[$i]]++;
}
$result = 0.0;
$frequency = 0.0;
foreach ($dic as $item)
{
$frequency = (float)$item / (float)$len;
$result -= $frequency * (log($frequency) / log(2));
}
return $result;
}
function generatePassword ($length = 9)
{
// start with a blank password
$password = "";
// define possible characters - any character in this string can be
// picked for use in the password, so if you want to put vowels back in
// or add special characters such as exclamation marks, this is where
// you should do it
$possible = "2346789bcdfghjkmnpqrtvwxyzBCDFGHJKLMNPQRTVWXYZ";
// we refer to the length of $possible a few times, so let's grab it now
$maxlength = strlen($possible);
// check for length overflow and truncate if necessary
if ($length > $maxlength) {
$length = $maxlength;
}
// set up a counter for how many characters are in the password so far
$i = 0;
// add random characters to $password until $length is reached
while ($i < $length) {
// pick a random character from the possible ones
$char = substr($possible, mt_rand(0, $maxlength-1), 1);
// have we already used this character in $password?
if (!strstr($password, $char)) {
// no, so it's OK to add it onto the end of whatever we've already got...
$password .= $char;
// ... and increase the counter by one
$i++;
}
}
// done!
return $password;
}
/**
* Print to console
* @param mixed $text
* @param bool $add_lb Add line break
* @return void
*/
function stdOut($text, $add_lb = true)
{
global $BOOL_RESULT;
if (!isCli())
return;
if (is_bool($text))
{
$text = $text ? 'true' : 'false';
}
else if (is_null($text))
{
$text = 'null';
}
if (!is_scalar($text))
{
$text = print_r($text, true);
}
if (!$BOOL_RESULT)
{
@fwrite(STDOUT, $text . ($add_lb ? "n" : ''));
}
}
/**
* Print progress
* @param int $num Current file
*/
function printProgress($num, &$par_File)
{
$total_files = $GLOBALS['g_FoundTotalFiles'];
$elapsed_time = microtime(true) - START_TIME;
$stat = '';
if ($elapsed_time >= 1)
{
$elapsed_seconds = round($elapsed_time, 0);
$fs = floor($num / $elapsed_seconds);
$left_files = $total_files - $num;
if ($fs > 0)
{
$left_time = ($left_files / $fs); //ceil($left_files / $fs);
$stat = '. [Avg: ' . round($fs,2) . ' files/s' . ($left_time > 0 ? ' Left: ' . seconds2Human($left_time) : '') . ']';
}
}
$l_FN = substr($par_File, -60);
$text = "Scanning file [$l_FN] $num of {$total_files}" . $stat;
$text = str_pad($text, 160, ' ', STR_PAD_RIGHT);
stdOut(str_repeat(chr(8), 160) . $text, false);
}
/**
* Seconds to human readable
* @param int $seconds
* @return string
*/
function seconds2Human($seconds)
{
$r = '';
$_seconds = floor($seconds);
$ms = $seconds - $_seconds;
$seconds = $_seconds;
if ($hours = floor($seconds / 3600))
{
$r .= $hours . (isCli() ? ' h ' : ' час ');
$seconds = $seconds % 3600;
}
if ($minutes = floor($seconds / 60))
{
$r .= $minutes . (isCli() ? ' m ' : ' мин ');
$seconds = $seconds % 60;
}
if ($minutes<3) $r .= ' ' . $seconds + ($ms > 0 ? round($ms, 5) : 0) . (isCli() ? ' s' : ' сек'); //' сек' - not good for shell
return $r;
}
if (isCli())
{
$cli_options = array(
'm:' => 'memory:',
's:' => 'size:',
'a' => 'all',
'd:' => 'delay:',
'r:' => 'report:',
'f' => 'fast',
'j:' => 'file',
'p:' => 'path:',
'q' => 'quite',
'h' => 'help'
);
$options = getopt(implode('', array_keys($cli_options)), array_values($cli_options));
if (isset($options['h']) OR isset($options['help']))
{
$memory_limit = ini_get('memory_limit');
echo <<<HELP
AI-Bolit - Script to search for shells and other malicious software.
Usage: php {$_SERVER['PHP_SELF']} [OPTIONS] [PATH]
Current default path is: {$defaults['path']}
Mandatory arguments to long options are mandatory for short options too.
-j, --file=FILE Specified path and filename to scan the only file
-p, --path=PATH Directory path to scan, by default the file directory is used
Current path: {$defaults['path']}
-m, --memory=SIZE Maximum amount of memory a script may consume. Current value: $memory_limit
Can take shorthand byte values (1M, 1G...)
-s, --size=SIZE Scan files are smaller than SIZE. 0 - All files. Current value: {$defaults['max_size_to_scan']}
-a, --all Scan all files (by default scan. js,. php,. html,. htaccess)
-d, --delay=INT delay in milliseconds when scanning files to reduce load on the file system (Default: 1)
-r, --report=PATH Filename of report html, by default 'AI-BOLIT-REPORT-dd-mm-YYYY_hh-mm.html' is used, relative to scan path
Enter your email address if you wish to report has been sent to the email.
You can also specify multiple email separated by commas.
-q, Use only with -j. Quiet result check of file, 1=Infected
--help display this help and exit
HELP;
exit;
}
$l_FastCli = false;
if (
(isset($options['memory']) AND !empty($options['memory']) AND ($memory = $options['memory']))
OR (isset($options['m']) AND !empty($options['m']) AND ($memory = $options['m']))
)
{
$memory = getBytes($memory);
if ($memory > 0)
{
$defaults['memory_limit'] = $memory;
}
}
if (
(isset($options['file']) AND !empty($options['file']) AND ($file = $options['file']) !== false)
OR (isset($options['j']) AND !empty($options['j']) AND ($file = $options['j']) !== false)
)
{
define('SCAN_FILE', $file);
}
if (
(isset($options['size']) AND !empty($options['size']) AND ($size = $options['size']) !== false)
OR (isset($options['s']) AND !empty($options['s']) AND ($size = $options['s']) !== false)
)
{
$size = getBytes($size);
$defaults['max_size_to_scan'] = $size > 0 ? $size : 0;
}
if (
(isset($options['file']) AND !empty($options['file']) AND ($file = $options['file']) !== false)
OR (isset($options['j']) AND !empty($options['j']) AND ($file = $options['j']) !== false)
AND (isset($options['q']))
)
{
$BOOL_RESULT = true;
}
if (isset($options['f']))
{
$l_FastCli = true;
}
if (
(isset($options['delay']) AND !empty($options['delay']) AND ($delay = $options['delay']) !== false)
OR (isset($options['d']) AND !empty($options['d']) AND ($delay = $options['d']) !== false)
)
{
$delay = (int) $delay;
if (!($delay < 0))
{
$defaults['scan_delay'] = $delay;
}
}
if (isset($options['all']) OR isset($options['a']))
{
$defaults['scan_all_files'] = 1;
}
if (
(isset($options['report']) AND ($report = $options['report']) !== false)
OR (isset($options['r']) AND ($report = $options['r']) !== false)
)
{
define('REPORT', $report);
}
defined('REPORT') OR define('REPORT', 'AI-BOLIT-REPORT-' . date('d-m-Y_H-i') . '-' . rand(1, 999999) . '.html');
$last_arg = max(1, sizeof($_SERVER['argv']) - 1);
if (isset($_SERVER['argv'][$last_arg]))
{
$path = $_SERVER['argv'][$last_arg];
if (
substr($path, 0, 1) != '-'
AND (substr($_SERVER['argv'][$last_arg - 1], 0, 1) != '-' OR array_key_exists(substr($_SERVER['argv'][$last_arg - 1], -1), $cli_options)))
{
$defaults['path'] = $path;
}
}
if (
(isset($options['path']) AND !empty($options['path']) AND ($path = $options['path']) !== false)
OR (isset($options['p']) AND !empty($options['p']) AND ($path = $options['p']) !== false)
)
{
$defaults['path'] = $path;
}
}
// Init
define('MAX_ALLOWED_PHP_HTML_IN_DIR', 100);
define('BASE64_LENGTH', 69);
define('MAX_PREVIEW_LEN', 80);
define('MAX_EXT_LINKS', 1001);
// Perform full scan when running from command line
if (isCli() || isset($_GET['full'])) {
$defaults['scan_all_files'] = 1;
}
if ($l_FastCli) {
$defaults['scan_all_files'] = 0;
}
define('SCAN_ALL_FILES', (bool) $defaults['scan_all_files']);
define('SCAN_DELAY', (int) $defaults['scan_delay']);
define('MAX_SIZE_TO_SCAN', getBytes($defaults['max_size_to_scan']));
if ($defaults['memory_limit'] AND ($defaults['memory_limit'] = getBytes($defaults['memory_limit'])) > 0)
ini_set('memory_limit', $defaults['memory_limit']);
define('START_TIME', microtime(true));
define('ROOT_PATH', realpath($defaults['path']));
if (!ROOT_PATH)
{
if (isCli()) {
die(stdOut("Directory '{$defaults['path']}' not found!"));
}
}
elseif(!is_readable(ROOT_PATH))
{
if (isCli()) {
die(stdOut("Cannot read directory '" . ROOT_PATH . "'!"));
}
}
define('CURRENT_DIR', getcwd());
chdir(ROOT_PATH);
// Проверяем отчет
if (isCli() AND REPORT !== '' AND !getEmails(REPORT))
{
$report = str_replace('\', '/', REPORT);
$abs = strpos($report, '/') === 0 ? DIR_SEPARATOR : '';
$report = array_values(array_filter(explode('/', $report)));
$report_file = array_pop($report);
$report_path = realpath($abs . implode(DIR_SEPARATOR, $report));
define('REPORT_FILE', $report_file);
define('REPORT_PATH', $report_path);
if (REPORT_FILE AND REPORT_PATH AND is_file(REPORT_PATH . DIR_SEPARATOR . REPORT_FILE))
{
@unlink(REPORT_PATH . DIR_SEPARATOR . REPORT_FILE);
}
}
if (function_exists('phpinfo')) {
ob_start();
phpinfo();
$l_PhpInfo = ob_get_contents();
ob_end_clean();
$l_PhpInfo = str_replace('border: 1px', '', $l_PhpInfo);
preg_match('|<body>(.*)</body>|smi', $l_PhpInfo, $l_PhpInfoBody);
}
$l_Result =<<<MAIN_PAGE
<html>
<head>
<meta http-equiv="Content-Type" content="text/html;charset=utf-8" >
<META NAME="ROBOTS" CONTENT="NOINDEX,NOFOLLOW">
<style type="text/css">
body {
font-family: Georgia;
color: #303030;
background: #FFFFF0;
font-size: 12px;
margin: 20px;
padding: 0;
}
h3 {
font-size: 27px;
margin: 0 0;
}
.sec {
font-size: 25px;
margin-bottom: 10px;
}
.warn {
color: #FF4C00;
margin: 0 0 20px 0;
}
.warn .it {
color: #FF4C00;
}
.warn2 {
color: #42ADFF;
margin: 0 0 20px 0;
}
.warn2 .it {
color: #42ADFF;
}
.ok {
color: #007F0E;
margin: 0 0 20px 0;
}
.vir {
color: #A00000;
margin: 0 0 20px 0;
}
.vir .it {
color: #A00000;
}
.disclaimer {
font-size: 11px;
font-family: Arial;
color: #505050;
margin: 10px 0 10px 0;
}
.thanx {
border: 1px solid #F0F0F0;
padding: 20px 20px 10px 20px;
font-size: 12px;
font-family: Arial;
background: #FBFFBA;
}
.footer {
margin: 40px 0 0 0;
}
.rep {
margin: 10px 0 20px 0;
font-size: 11px;
font-family: Arial;
}
.php_ok
{
color: #007F0E;
}
.php_bad
{
color: #A00000;
}
.notice
{
border: 1px solid cornflowerblue;
padding: 10px;
font-size: 12px;
font-family: Arial;
background: #E8F8F8;
}
.offer {
-webkit-border-radius: 6px;
-moz-border-radius: 6px;
border-radius: 6px;
position: absolute;
width: 350px;
right: 100px;
top: 85px;
background: #E06060;
color: white;
font-size: 11px;
font-family: Arial;
padding: 20px 20px 10px 20px;
}
.offer2 {
-webkit-border-radius: 6px;
-moz-border-radius: 6px;
border-radius: 6px;
position: absolute;
width: 350px;
right: 100px;
top: 100px;
background: #30A030;
color: white;
font-size: 11px;
font-family: Arial;
padding: 20px 20px 10px 20px;
}
.offer A, .offer2 A {
color: yellow;
}
.update {
color: red;
font-size: 12px;
font-family: Arial;
margin: 0 0 20px 0;
}
.updateinfo {
color: blue;
font-size: 12px;
font-family: Arial;
margin: 0 0 20px 0;
}
.tbg0 {
}
.tbg1 {
background: #F0F0F0;
}
.it {
font-size: 12px;
font-family: Arial;
}
.ctd {
font-size: 12px;
font-family: Arial;
color: #909090;
}
.flist {
margin: 10px 0 30px 0;
}
.tbgh {
background: #E0E0E0;
}
TH {
text-align: left;
font-size: 12px;
font-family: Arial;
color: #909090;
}
.details {
font-size: 9px;
font-family: Arial;
color: #303030;
}
.marker
{
color: #FF0000;
font-size: 16px;
font-weight: 700;
}
</style>
<script language="javascript">
function addToIgnore(par_Lnk, par_FN, par_CRC) {
var o = document.getElementById('igid');
var ta = document.forms.ignore.list;
ta.value = ta.value + par_FN + String.fromCharCode(09) + par_CRC + String.fromCharCode(10);
par_Lnk.innerHTML = 'Добавлено';
o.style.display = 'block';
}
</script>
</head>
<body>
<noindex>
MAIN_PAGE;
////////////////////////////////////////////////////////////////////////////
$l_Result .= sprintf(AI_STR_001, AI_VERSION, INFO_M);
$l_CreationTime = filemtime(__FILE__);
if (time() - $l_CreationTime > 86400 * 7) {
$l_Result .= AI_STR_002;
}
$l_Result .= '<div class="update" style="margin: 20px 0 20px 0; padding: 20px; width: 500px; border: 1px solid #400000"><b>' . AI_STR_003 . '</b></div>';
if (!AI_EXPERT) {
$l_Result .= '<div class="updateinfo">' . AI_STR_057 . '</div>';
}
define('QCR_INDEX_FILENAME', 'fn');
define('QCR_INDEX_TYPE', 'type');
define('QCR_INDEX_WRITABLE', 'wr');
define('QCR_SVALUE_FILE', '1');
define('QCR_SVALUE_FOLDER', '0');
/**
* Extract emails from the string
* @param string $email
* @return array of strings with emails or false on error
*/
function getEmails($email)
{
$email = preg_split('#[,s;]#', $email, -1, PREG_SPLIT_NO_EMPTY);
$r = array();
for ($i = 0, $size = sizeof($email); $i < $size; $i++)
{
if (function_exists('filter_var')) {
if (filter_var($email[$i], FILTER_VALIDATE_EMAIL))
{
$r[] = $email[$i];
}
} else {
// for PHP4
if (strpos($email[$i], '@') !== false) {
$r[] = $email[$i];
}
}
}
return empty($r) ? false : $r;
}
/**
* Get bytes from shorthand byte values (1M, 1G...)
* @param int|string $val
* @return int
*/
function getBytes($val)
{
$val = trim($val);
$last = strtolower($val{strlen($val) - 1});
switch($last) {
case 't':
$val *= 1024;
case 'g':
$val *= 1024;
case 'm':
$val *= 1024;
case 'k':
$val *= 1024;
}
return intval($val);
}
/**
* Format bytes to human readable
* @param int $bites
* @return string
*/
function bytes2Human($bites)
{
if ($bites < 1024)
{
return $bites . ' b';
}
elseif (($kb = $bites / 1024) < 1024)
{
return number_format($kb, 2) . ' Kb';
}
elseif (($mb = $kb / 1024) < 1024)
{
return number_format($mb, 2) . ' Mb';
}
elseif (($gb = $mb / 1024) < 1024)
{
return number_format($gb, 2) . ' Gb';
}
else
{
return number_format($gb / 1024, 2) . 'Tb';
}
}
///////////////////////////////////////////////////////////////////////////
function needIgnore($par_FN, $par_CRC) {
global $g_IgnoreList;
for ($i = 0; $i < count($g_IgnoreList); $i++) {
if (strpos($par_FN, $g_IgnoreList[$i][0]) !== false) {
if ($par_CRC == $g_IgnoreList[$i][1]) {
return true;
}
}
}
return false;
}
///////////////////////////////////////////////////////////////////////////
function printList($par_List, $par_Details = null, $par_NeedIgnore = false) {
global $g_Structure;
$l_Result = '';
$l_Result .= "<div class="flist"><table cellspacing=1 cellpadding=4 border=0>";
$l_Result .= "<tr class="tbgh" . ( $i % 2 ). "">";
$l_Result .= "<th>" . AI_STR_004 . "</th>";
$l_Result .= "<th>" . AI_STR_005 . "</th>";
$l_Result .= "<th>" . AI_STR_006 . "</th>";
$l_Result .= "<th width=90>" . AI_STR_007 . "</th>";
$l_Result .= "<th width=90>CRC32</th>";
$l_Result .= "</tr>";
for ($i = 0; $i < count($par_List); $i++) {
$l_Pos = $par_List[$i];
if ($par_NeedIgnore) {
if (needIgnore($g_Structure['n'][$par_List[$i]], $g_Structure['crc'][$l_Pos])) {
continue;
}
}
$l_Creat = $g_Structure['c'][$l_Pos] > 0 ? date("d/m/Y H:i:s", $g_Structure['c'][$l_Pos]) : '-';
$l_Modif = $g_Structure['m'][$l_Pos] > 0 ? date("d/m/Y H:i:s", $g_Structure['m'][$l_Pos]) : '-';
$l_Size = $g_Structure['s'][$l_Pos] > 0 ? bytes2Human($g_Structure['s'][$l_Pos]) : '-';
if ($par_Details != null) {
$l_WithMarket = preg_replace('|@AI_MARKER@|smi', '<span class="marker">|</span>', $par_Details[$i]);
$l_Body = '<div class="details">' . $l_WithMarket . '</div>';
} else {
$l_Body = '';
}
$l_Result .= '<tr class="tbg' . ( $i % 2 ). '">';
if (is_file($g_Structure['n'][$l_Pos])) {
$l_Result .= '<td><div class="it"><a class="it" target="_blank" href="'. $defaults['site_url'] . 'ai-bolit.php?fn=' .
$g_Structure['n'][$l_Pos] . '&ph=' . realCRC(PASS) . '&c=' . $g_Structure['crc'][$l_Pos] . '">' . $g_Structure['n'][$l_Pos] . '</a></div>' . $l_Body . '</td>';
} else {
$l_Result .= '<td><div class="it">' . $g_Structure['n'][$par_List[$i]] . '</div></td>';
}
$l_Result .= '<td><div class="ctd">' . $l_Creat . '</div></td>';
$l_Result .= '<td><div class="ctd">' . $l_Modif . '</div></td>';
$l_Result .= '<td><div class="ctd">' . $l_Size . '</div></td>';
$l_Result .= '<td><div class="ctd"><a href="#" onclick="addToIgnore(this, '' . $g_Structure['n'][$l_Pos] . '','' . $g_Structure['crc'][$l_Pos] . '');return false;">' . $g_Structure['crc'][$l_Pos] . '</a></div></td>';
$l_Result .= '</tr>';
}
$l_Result .= "</table></div>";
return $l_Result;
}
///////////////////////////////////////////////////////////////////////////
function extractValue(&$par_Str, $par_Name) {
if (preg_match('|<tr><td class="e">s*'.$par_Name.'s*</td><td class="v">(.+?)</td>|sm', $par_Str, $l_Result)) {
return str_replace('no value', '', strip_tags($l_Result[1]));
}
}
///////////////////////////////////////////////////////////////////////////
function QCR_ExtractInfo($par_Str) {
$l_PhpInfoSystem = extractValue($par_Str, 'System');
$l_PhpPHPAPI = extractValue($par_Str, 'Server API');
$l_AllowUrlFOpen = extractValue($par_Str, 'allow_url_fopen');
$l_AllowUrlInclude = extractValue($par_Str, 'allow_url_include');
$l_DisabledFunction = extractValue($par_Str, 'disable_functions');
$l_DisplayErrors = extractValue($par_Str, 'display_errors');
$l_ErrorReporting = extractValue($par_Str, 'error_reporting');
$l_ExposePHP = extractValue($par_Str, 'expose_php');
$l_LogErrors = extractValue($par_Str, 'log_errors');
$l_MQGPC = extractValue($par_Str, 'magic_quotes_gpc');
$l_MQRT = extractValue($par_Str, 'magic_quotes_runtime');
$l_OpenBaseDir = extractValue($par_Str, 'open_basedir');
$l_RegisterGlobals = extractValue($par_Str, 'register_globals');
$l_SafeMode = extractValue($par_Str, 'safe_mode');
$l_DisabledFunction = ($l_DisabledFunction == '' ? '-?-' : $l_DisabledFunction);
$l_OpenBaseDir = ($l_OpenBaseDir == '' ? '-?-' : $l_OpenBaseDir);
$l_Result = '<div class="sec">' . AI_STR_008 . ': ' . phpversion() . '</div>';
$l_Result .= 'System Version: <span class="php_ok">' . $l_PhpInfoSystem . '</span><br/>';
$l_Result .= 'PHP API: <span class="php_ok">' . $l_PhpPHPAPI. '</span><br/>';
$l_Result .= 'allow_url_fopen: <span class="php_' . ($l_AllowUrlFOpen == 'On' ? 'bad' : 'ok') . '">' . $l_AllowUrlFOpen. '</span><br/>';
$l_Result .= 'allow_url_include: <span class="php_' . ($l_AllowUrlInclude == 'On' ? 'bad' : 'ok') . '">' . $l_AllowUrlInclude. '</span><br/>';
$l_Result .= 'disable_functions: <span class="php_' . ($l_DisabledFunction == '-?-' ? 'bad' : 'ok') . '">' . $l_DisabledFunction. '</span><br/>';
$l_Result .= 'display_errors: <span class="php_' . ($l_DisplayErrors == 'On' ? 'ok' : 'bad') . '">' . $l_DisplayErrors. '</span><br/>';
$l_Result .= 'error_reporting: <span class="php_ok">' . $l_ErrorReporting. '</span><br/>';
$l_Result .= 'expose_php: <span class="php_' . ($l_ExposePHP == 'On' ? 'bad' : 'ok') . '">' . $l_ExposePHP. '</span><br/>';
$l_Result .= 'log_errors: <span class="php_' . ($l_LogErrors == 'On' ? 'ok' : 'bad') . '">' . $l_LogErrors . '</span><br/>';
$l_Result .= 'magic_quotes_gpc: <span class="php_' . ($l_MQGPC == 'On' ? 'ok' : 'bad') . '">' . $l_MQGPC. '</span><br/>';
$l_Result .= 'magic_quotes_runtime: <span class="php_' . ($l_MQRT == 'On' ? 'bad' : 'ok') . '">' . $l_MQRT. '</span><br/>';
$l_Result .= 'register_globals: <span class="php_' . ($l_RegisterGlobals == 'On' ? 'bad' : 'ok') . '">' . $l_RegisterGlobals . '</span><br/>';
$l_Result .= 'open_basedir: <span class="php_' . ($l_OpenBaseDir == '-?-' ? 'bad' : 'ok') . '">' . $l_OpenBaseDir . '</span><br/>';
if (phpversion() < '5.3.0') {
$l_Result .= 'safe_mode (PHP < 5.3.0): <span class="php_' . ($l_SafeMode == 'On' ? 'ok' : 'bad') . '">' . $l_SafeMode. '</span><br/>';
}
return $l_Result . '<p>';
}
///////////////////////////////////////////////////////////////////////////
function QCR_Debug($par_Str) {
if (!DEBUG_MODE) {
return;
}
$l_MemInfo = ' ';
if (function_exists('memory_get_usage')) {
$l_MemInfo .= ' curmem=' . bytes2Human(memory_get_usage());
}
if (function_exists('memory_get_peak_usage')) {
$l_MemInfo .= ' maxmem=' . bytes2Human(memory_get_peak_usage());
}
stdOut(date('H:i:s') . ': ' . $par_Str . $l_MemInfo);
}
///////////////////////////////////////////////////////////////////////////
function QCR_ScanDirectories($l_RootDir)
{
global $g_Structure, $g_Counter, $g_Doorway, $g_FoundTotalFiles, $g_FoundTotalDirs,
$defaults, $g_SkippedFolders, $g_UrlIgnoreList, $g_DirIgnoreList, $g_UnsafeFilesArray, $g_UnsafeDirArray,
$g_UnsafeFilesFound, $g_SymLinks, $g_HiddenFiles;
$l_DirCounter = 0;
$l_DoorwayFilesCounter = 0;
$l_SourceDirIndex = $g_Counter - 1;
QCR_Debug('Scan ' . $l_RootDir);
$l_QuotedSeparator = quotemeta(DIR_SEPARATOR);
$l_NeedCheckCandi = ($defaults['report_mask'] & REPORT_MASK_CANDI) == REPORT_MASK_CANDI;
if ($l_DIRH = @opendir($l_RootDir))
{
while (($l_FileName = readdir($l_DIRH)) !== false)
{
if ($l_FileName == '.' || $l_FileName == '..') continue;
if (is_link($l_FileName))
{
$g_SymLinks[] = $l_FileName;
continue;
}
$l_FileName = $l_RootDir . DIR_SEPARATOR . $l_FileName;
$l_Ext = substr($l_FileName, strrpos($l_FileName, '.') + 1);
$l_IsDir = is_dir($l_FileName);
// which files should be scanned
$l_NeedToScan = SCAN_ALL_FILES || (in_array($l_Ext, array(
'js', 'php', 'php3', 'phtml', 'shtml', 'khtml',
'php4', 'php5', 'tpl', 'inc', 'htaccess', 'html', 'htm'
)));
if (strpos(basename($l_FileName), '.') === 0) {
$g_HiddenFiles[] = $l_FileName;
}
if ($l_IsDir)
{
// if folder in ignore list
$l_Skip = false;
for ($dr = 0; $dr < count($g_DirIgnoreList); $dr++) {
if (($g_DirIgnoreList[$dr] != '') &&
preg_match('#' . $g_DirIgnoreList[$dr] . '#', $l_FileName, $l_Found)) {
$l_Skip = true;
}
}
// skip on ignore
if ($l_Skip) {
$g_SkippedFolders[] = $l_FileName;
continue;
}
$g_Structure['d'][$g_Counter] = $l_IsDir;
$g_Structure['n'][$g_Counter] = $l_FileName;
$l_DirCounter++;
if ($l_NeedCheckCandi) {
for ($j = 0; $j < count($g_UnsafeDirArray); $j++) {
if (preg_match('|' . $l_QuotedSeparator . $g_UnsafeDirArray[$j] . '$|i', $l_FileName, $l_Found)) {
$g_UnsafeFilesFound[] = $g_Counter;
break;
}
}
}
if ($l_DirCounter > MAX_ALLOWED_PHP_HTML_IN_DIR)
{
$g_Doorway[] = $l_SourceDirIndex;
$l_DirCounter = -655360;
}
$g_Counter++;
$g_FoundTotalDirs++;
QCR_ScanDirectories($l_FileName);
} else
{
if ($l_NeedToScan)
{
$g_FoundTotalFiles++;
if (in_array($l_Ext, array(
'php', 'php3',
'php4', 'php5', 'html', 'htm', 'phtml', 'shtml', 'khtml'
))
)
{
$l_DoorwayFilesCounter++;
if ($l_DoorwayFilesCounter > MAX_ALLOWED_PHP_HTML_IN_DIR)
{
$g_Doorway[] = $l_SourceDirIndex;
$l_DoorwayFilesCounter = -655360;
}
}
$l_Stat = stat($l_FileName);
$g_Structure['d'][$g_Counter] = $l_IsDir;
$g_Structure['n'][$g_Counter] = $l_FileName;
$g_Structure['s'][$g_Counter] = $l_Stat['size'];
$g_Structure['c'][$g_Counter] = $l_Stat['ctime'];
$g_Structure['m'][$g_Counter] = $l_Stat['mtime'];
if ($l_NeedCheckCandi) {
for ($j = 0; $j < count($g_UnsafeFilesArray); $j++) {
if (preg_match('|' . $l_QuotedSeparator . $g_UnsafeFilesArray[$j] . '|i', $l_FileName, $l_Found)) {
$g_UnsafeFilesFound[] = $g_Counter;
break;
}
}
}
$g_Counter++;
}
}
}
closedir($l_DIRH);
}
return $g_Structure;
}
///////////////////////////////////////////////////////////////////////////
function QCR_ScanFile($l_TheFile)
{
global $g_Structure, $g_Counter, $g_Doorway, $g_FoundTotalFiles, $g_FoundTotalDirs,
$defaults, $g_SkippedFolders, $g_UrlIgnoreList, $g_DirIgnoreList, $g_UnsafeFilesArray, $g_UnsafeDirArray,
$g_UnsafeFilesFound, $g_SymLinks, $g_HiddenFiles;
QCR_Debug('Scan file ' . $l_TheFile);
$l_Stat = stat($l_TheFile);
$g_Structure['d'][$g_Counter] = false;
$g_Structure['n'][$g_Counter] = $l_TheFile;
$g_Structure['s'][$g_Counter] = $l_Stat['size'];
$g_Structure['c'][$g_Counter] = $l_Stat['ctime'];
$g_Structure['m'][$g_Counter] = $l_Stat['mtime'];
$g_Counter++;
return $g_Structure;
}
///////////////////////////////////////////////////////////////////////////
function getFragment($par_Content, $par_Pos) {
$l_MaxChars = MAX_PREVIEW_LEN;
$l_MaxLen = strlen($par_Content);
$l_RightPos = min($par_Pos + $l_MaxChars, $l_MaxLen);
$l_MinPos = max(0, $par_Pos - $l_MaxChars);
$l_Res = substr($par_Content, $l_MinPos, $par_Pos - $l_MinPos) .
'@AI_MARKER@' .
substr($par_Content, $par_Pos, $l_RightPos - $par_Pos - 1);
return htmlspecialchars($l_Res);
}
///////////////////////////////////////////////////////////////////////////
function escapedHexToHex($escaped)
{ $GLOBALS['g_EncObfu']++; return chr(hexdec($escaped[1])); }
function escapedOctDec($escaped)
{ $GLOBALS['g_EncObfu']++; return chr(octdec($escaped[1])); }
function escapedDec($escaped)
{ $GLOBALS['g_EncObfu']++; return chr($escaped[1]); }
///////////////////////////////////////////////////////////////////////////
if (!defined('T_ML_COMMENT')) {
define('T_ML_COMMENT', T_COMMENT);
} else {
define('T_DOC_COMMENT', T_ML_COMMENT);
}
function UnwrapObfu($par_Content) {
$GLOBALS['g_EncObfu'] = 0;
$par_Content = preg_replace_callback('/\\x([a-fA-F0-9]{1,2})/i','escapedHexToHex', $par_Content);
$par_Content = preg_replace_callback('/\\([0-9]{1,3})/i','escapedOctDec', $par_Content);
// $par_Content = preg_replace_callback('/\\([0-9]{2})/i','escapedDec', $par_Content);
$par_Content = preg_replace('/['"]s*?.s*?['"]/smi', '', $par_Content);
return $par_Content;
}
///////////////////////////////////////////////////////////////////////////
function QCR_SearchPHP($src)
{
if (preg_match("/(<?php[ws]{5,})/smi", $src, $l_Found, PREG_OFFSET_CAPTURE)) {
return $l_Found[0][1];
}
// if (preg_match("/(<%[ws]{10,})/smi", $src, $l_Found, PREG_OFFSET_CAPTURE)) {
// return $l_Found[0][1];
// }
if (preg_match("/(<script[^>]*languages*=s*)('|"|)php('|"|)([^>]*>)/i", $src, $l_Found, PREG_OFFSET_CAPTURE)) {
return $l_Found[0][1];
}
return false;
}
///////////////////////////////////////////////////////////////////////////
function knowUrl($par_URL) {
global $g_UrlIgnoreList;
for ($jk = 0; $jk < count($g_UrlIgnoreList); $jk++) {
if ((stripos($par_URL, $g_UrlIgnoreList[$jk]) !== false)) {
return true;
}
}
return false;
}
///////////////////////////////////////////////////////////////////////////
function QCR_GoScan($par_Offset)
{
global $g_IframerFragment, $g_Iframer, $g_SuspDir, $g_Redirect, $g_Doorway, $g_EmptyLink, $g_Structure, $g_Counter,
$g_WritableDirectories, $g_CriticalPHP, $g_HeuristicType, $g_HeuristicDetected, $g_TotalFolder, $g_TotalFiles, $g_WarningPHP, $g_AdwareList,
$g_CriticalPHP, $g_CriticalJS, $g_UrlIgnoreList, $g_CriticalJSFragment, $g_PHPCodeInside, $g_PHPCodeInsideFragment,
$g_NotRead, $g_WarningPHPFragment, $g_BigFiles, $g_RedirectPHPFragment, $g_EmptyLinkSrc, $g_CriticalPHPFragment,
$g_Base64Fragment, $g_UnixExec, $g_IframerFragment, $g_CMS, $defaults, $g_AdwareListFragment, $g_KnownList;
static $_files_and_ignored = 0;
QCR_Debug('QCR_GoScan ' . $par_Offset);
for ($i = $par_Offset; $i < $g_Counter; $i++)
{
$l_Filename = $g_Structure['n'][$i];
QCR_Debug('Check ' . $l_Filename);
if ($g_Structure['d'][$i])
{
// FOLDER
$g_TotalFolder++;
if (is_writable($l_Filename))
{
$g_WritableDirectories[] = $i;
}
}
else
{
// FILE
if ((MAX_SIZE_TO_SCAN > 0 AND $g_Structure['s'][$i] > MAX_SIZE_TO_SCAN) || ($g_Structure['s'][$i] < 0))
{
$g_BigFiles[] = $i;
}
else
{
$g_TotalFiles++;
$l_Content = @implode('', file($l_Filename));
if (($l_Content == '') && ($g_Structure['s'][$i] > 0)) {
$g_NotRead[] = $i;
}
$g_Structure['crc'][$i] = realCRC($l_Content);
// detect version CMS
if (strpos($l_Filename, DIR_SEPARATOR . 'engine' . DIR_SEPARATOR . 'data' . DIR_SEPARATOR . 'config.php') !== false) {
if (preg_match('|'version_id's*=>s*"(.+?)"|smi', $l_Content, $l_Ver)) {
$g_CMS[] = 'DLE v' . $l_Ver[1];
}
} else
if (strpos($l_Filename, DIR_SEPARATOR . 'wp-includes' . DIR_SEPARATOR . 'version.php') !== false) {
if (preg_match('|$wp_versions*=s*'(.+?)'|smi', $l_Content, $l_Ver)) {
$g_CMS[] = 'Wordpress v' . $l_Ver[1];
}
} else
if (strpos($l_Filename, 'install' . DIR_SEPARATOR . 'consts.php') !== false) {
if (preg_match('|STRING_VERSION',s*'(.+?)'|smi', $l_Content, $l_Ver)) {
$g_CMS[] = 'ShopScript Premium v' . $l_Ver[1];
}
} else
if (strpos($l_Filename, 'bitrix' . DIR_SEPARATOR . 'modules' . DIR_SEPARATOR . 'main' . DIR_SEPARATOR . 'classes' . DIR_SEPARATOR . 'general' . DIR_SEPARATOR . 'version.php') !== false) {
if (preg_match('|define("SM_VERSION","(.+?)")|smi', $l_Content, $l_Ver)) {
$g_CMS[] = 'Bitrix v' . $l_Ver[1];
}
}
$l_KnownCRC = $g_Structure['crc'][$i] + realCRC(basename($l_Filename));
if (in_array($l_KnownCRC, $g_KnownList)) {
printProgress(++$_files_and_ignored, $l_Filename);
continue;
}
$l_Unwrapped = UnwrapObfu($l_Content);
if (function_exists('utf8_decode')) {
$l_Unwrapped = utf8_decode($l_Unwrapped);
}
// ignore itself
if (strpos($l_Content, 'KV238467HNJKGFJHGFDGHGGFD') !== false) {
continue;
}
// warnings
$l_Pos = '';
if (WarningPHP($l_Filename, $l_Unwrapped, $l_Pos))
{ $l_Prio = 1;
if (strpos($l_Filename, '.php') !== false) {
$l_Prio = 0;
}
$g_WarningPHP[$l_Prio][] = $i;
$g_WarningPHPFragment[$l_Prio][] = getFragment($l_Content, $l_Pos);
}
// adware
if (Adware($l_Filename, $l_Unwrapped, $l_Pos))
{
$g_AdwareList[] = $i;
$g_AdwareListFragment[] = getFragment($l_Unwrapped, $l_Pos);
}
// critical
$g_SkipNextCheck = false;
if (CriticalPHP($l_Filename, $i, $l_Unwrapped, $l_Pos))
{
$g_CriticalPHP[] = $i;
$g_CriticalPHPFragment[] = getFragment($l_Unwrapped, $l_Pos);
$g_SkipNextCheck = true;
}
// critical without comments
$a = preg_replace('|/*.*?*/|smiu', '', $l_Unwrapped);
if ((!$g_SkipNextCheck) && CriticalPHP($l_Filename, $i, $a, $l_Pos))
{
$g_CriticalPHP[] = $i;
$g_CriticalPHPFragment[] = getFragment($l_Unwrapped, $l_Pos);
}
$l_TypeDe = 0;
if (ai_check_extra_obfus($l_Content, $l_TypeDe)) {
$g_HeuristicDetected[] = $i;
$g_HeuristicType[] = $l_TypeDe;
}
// critical JS
$l_Pos = CriticalJS($l_Filename, $i, $l_Unwrapped);
if ($l_Pos !== false)
{
$g_CriticalJS[] = $i;
$g_CriticalJSFragment[] = getFragment($l_Unwrapped, $l_Pos);
}
if
(stripos($l_Filename, 'index.php') ||
stripos($l_Filename, 'index.htm') ||
SCAN_ALL_FILES
)
{
// check iframes
if (preg_match_all('|<iframe.+?src.+?>|smi', $l_Unwrapped, $l_Found, PREG_SET_ORDER))
{
for ($kk = 0; $kk < count($l_Found); $kk++) {
$l_Pos = stripos($l_Found[$kk][0], 'http://');
if (($l_Pos !== false) && (!knowUrl($l_Found[$kk][0]))) {
$g_Iframer[] = $i;
$g_IframerFragment[] = getFragment($l_Found[$kk][0], $l_Pos);
}
}
}
// check empty links
if (preg_match_all('|<a[^>]+href([^>]+?)>(.*?)</a>|smi', $l_Unwrapped, $l_Found, PREG_SET_ORDER))
{
for ($kk = 0; $kk < count($l_Found); $kk++) {
if ((stripos($l_Found[$kk][1], 'http://') !== false) &&
(trim(strip_tags($l_Found[$kk][2])) == '')) {
$l_NeedToAdd = true;
if ((stripos($l_Found[$kk][1], $default['site_url']) !== false)
|| knowUrl($l_Found[$kk][1])) {
$l_NeedToAdd = false;
}
if ($l_NeedToAdd && (count($g_EmptyLink) < MAX_EXT_LINKS)) {
$g_EmptyLink[] = $i;
$g_EmptyLinkSrc[$i][] = substr($l_Found[$kk][0], 0, MAX_PREVIEW_LEN);
}
}
}
}
}
// check for PHP code inside any type of file
if ((stripos($l_Filename, '.php') === false) &&
(stripos($l_Filename, '.phtml') === false))
{
$l_Pos = QCR_SearchPHP($l_Content);
if ($l_Pos !== false)
{
$g_PHPCodeInside[] = $i;
$g_PHPCodeInsideFragment[] = getFragment($l_Unwrapped, $l_Pos);
}
}
// articles
if (stripos($l_Filename, 'article_index'))
{
$g_AdwareSig[] = $i;
}
// unix executables
if (strpos($l_Content, chr(127) . 'ELF') !== false)
{
$g_UnixExec[] = $i;
}
// htaccess
if (stripos($l_Filename, '.htaccess'))
{
if (stripos($l_Content, 'index.php?name=$1') !== false ||
stripos($l_Content, 'index.php?m=1') !== false
)
{
$g_SuspDir[] = $i;
}
$l_Pos = stripos($l_Content, '^(%2d|-)[^=]+$');
if ($l_Pos !== false)
{
$g_Redirect[] = $i;
$g_RedirectPHPFragment[] = getFragment($l_Content, $l_Pos);
}
$l_Pos = stripos($l_Content, '%{HTTP_USER_AGENT}');
if ($l_Pos !== false)
{
$g_Redirect[] = $i;
$g_RedirectPHPFragment[] = getFragment($l_Content, $l_Pos);
}
if (
preg_match_all('|(RewriteConds+%{HTTP_HOST}/%1 !^[w.]*([^/]+)/\1$s+[NC])|smi', $l_Content, $l_Found, PREG_OFFSET_CAPTURE)
)
{
$g_Redirect[] = $i;
$g_RedirectPHPFragment[] = getFragment($l_Content, $l_Found[0][1]);
}
//
$l_HTAContent = preg_replace('|^s*#.+$|m', '', $l_Content);
if (
preg_match_all("|RewriteRules+.+?s+http://(.+?)/.+s+[.*R=d+.*]|smi", $l_HTAContent, $l_Found, PREG_SET_ORDER)
)
{
$l_Host = str_replace('www.', '', $_SERVER['HTTP_HOST']);
for ($j = 0; $j < sizeof($l_Found); $j++)
{
$l_Found[$j][1] = str_replace('www.', '', $l_Found[$j][1]);
if ($l_Found[$j][1] != $l_Host)
{
$g_Redirect[] = $i;
break;
}
}
}
unset($l_HTAContent);
$l_Pos = stripos($l_Content, 'auto_prepend_file');
if ($l_Pos !== false) {
$g_Redirect[] = $i;
$g_RedirectPHPFragment[] = getFragment($l_Content, $l_Pos);
}
$l_Pos = stripos($l_Content, 'auto_append_file');
if ($l_Pos !== false) {
$g_Redirect[] = $i;
$g_RedirectPHPFragment[] = getFragment($l_Content, $l_Pos);
}
if (preg_match("|RewriteRules+^(.*)$s+-s+[s*Fs*,s*Ls*]|smi", $l_Content, $l_Found)) {
$g_Redirect[] = $i;
}
}
}
unset($l_Unwrapped);
unset($l_Content);
printProgress(++$_files_and_ignored, $l_Filename);
} // end of if (file)
usleep(SCAN_DELAY * 1000);
} // end of for
}
///////////////////////////////////////////////////////////////////////////
function WarningPHP($l_FN, $l_Content, &$l_Pos)
{
global $g_SusDB;
$l_Res = false;
//print "WarningPHP Start:n";
//print "###########################################################################n";
foreach ($g_SusDB as $l_Item) {
if (preg_match('#(' . $l_Item . ')#smi', $l_Content, $l_Found, PREG_OFFSET_CAPTURE)) {
if (!CheckException($l_Content, $l_Found)) {
$l_Pos = $l_Found[0][1];
//print "nSusDB $l_FN =" . $l_Item." l_Pos=" . $l_Pos . "n";
return true;
}
}
}
//print "###########################################################################n";
//print "WarningPHP End:n";
return $l_Res;
}
///////////////////////////////////////////////////////////////////////////
function Adware($l_FN, $l_Content, &$l_Pos)
{
global $g_AdwareSig;
$l_Res = false;
//print "Adware Start:n";
//print "###########################################################################n";
foreach ($g_AdwareSig as $l_Item) {
if (preg_match('#(' . $l_Item . ')#smi', $l_Content, $l_Found, PREG_OFFSET_CAPTURE)) {
if (!CheckException($l_Content, $l_Found)) {
$l_Pos = $l_Found[0][1];
//print "ng_AdwareSig $l_FN =" . $l_Item." l_Pos=" . $l_Pos . "n";
return true;
}
}
}
//print "Adware End:n";
//print "###########################################################################n";
return $l_Res;
}
///////////////////////////////////////////////////////////////////////////
function CheckException(&$l_Content, &$l_Found) {
global $g_ExceptFlex, $gX_FlexDBShe, $g_FlexDBShe, $gX_DBShe, $g_DBShe, $g_Base64, $g_Base64Fragment;
//print "nCheckException Start -----------------------------:n";
$l_FoundStrPlus = substr($l_Content, max($l_Found[0][1] - 10, 0), 70);
foreach ($g_ExceptFlex as $l_ExceptItem) {
//print "n{{{" . $l_FoundStrPlus . "}}} vs {{{" . $l_ExceptItem . "}}}n";
//print "--------------------------------------------n";
if (preg_match('#(' . $l_ExceptItem . ')#smi', $l_FoundStrPlus, $l_Detected)) {
// print "Matched {{{" . $l_ExceptItem . "}}} in {{{" . $l_FN. "}}}nn";
// print "==========> {{{" . $l_Found[0][0]. "}}}rn";
// print "n" . "CheckException: ****** EXCEPTION *************" . "n";
$l_Exception = true;
return true;
}
}
//print "nCheckException End -----------------------------:n";
return false;
}
///////////////////////////////////////////////////////////////////////////
function CriticalJS($l_FN, $l_Index, $l_Content)
{
global $g_JSVirSig;
$l_Res = false;
//print "###########################################################################n";
//print "CriticalJS Start:" . $l_FN . " index: " . $l_Index . "n";
//print "###########################################################################n";
//echo 'CONTENT:[';
//echo $l_Content."]nn";
foreach ($g_JSVirSig as $l_Item) {
if (preg_match('#(' . $l_Item . ')#smi', $l_Content, $l_Found, PREG_OFFSET_CAPTURE)) {
if (!CheckException($l_Content, $l_Found)) {
$l_Pos = $l_Found[0][1];
//print "CriticalJS " . $l_FN . ' ' . $l_Item . ' l_Pos=' . $l_Pos . "n";
return $l_Pos;
}
}
}
//print "###########################################################################n";
//print "CriticalJS End:n";
return $l_Res;
}
///////////////////////////////////////////////////////////////////////////
function get_descr_heur($type) {
$msg = '';
switch ($type) {
case 1: $msg = AI_STR_053;
break;
case 2: $msg = AI_STR_054;
break;
case 3: $msg = AI_STR_055;
break;
case 4: $msg = AI_STR_056;
break;
}
return $msg;
}
function ai_check_extra_obfus($content, &$type) {
$res = false;
// 1
if (preg_match_all('|($[a-zA-Z0-9_]{3,}[[d+]]s*(s*$)|smiu', $content, $found, PREG_SET_ORDER)) {
$ref_calls = count($found);
}
// 2
if (preg_match_all('|$([a-zA-Z0-9_]{3,}?)s*[;=(]|smi', $content, $found, PREG_SET_ORDER)) {
$obf_var1 = 0;
$obf_var2 = 0;
$arr = array();
foreach ($found as $item) {
$arr[$item[1]] = 1;
}
$found = array_keys($arr);
foreach ($found as $item) {
if (preg_match('|([a-zA-Z]{2,}[0-9]+[a-zA-Z]+){1,}|', $item, $found_ob)) {
$obf_var1++;
}
if (!preg_match('|([aeiouy_])|i', $item, $found_ob) && (strlen($item) > 4)) {
$obf_var2++;
}
if (preg_match('|([0-9bcdfghjklmnpqrstvwxz]{6,})|i', $item, $found_ob) && (strlen($item) > 3)) {
$obf_var3++;
}
}
}
// 3
if (preg_match_all('|($GLOBALS['[a-z_0-9]+'][d+]()|smiu', $content, $found, PREG_SET_ORDER)) {
$ref_glob = count($found);
}
// 4
// if (preg_match_all('|(["'].+?["']s*.s*){10,}|smiu', $content, $found, PREG_SET_ORDER)) {
// $type = 4;
// return true;
// }
/////////////////////////////////////
if ($ref_calls > 10) {
$type = 1;
return true;
}
if ($ref_glob > 10) {
$type = 2;
return true;
}
if ($obf_var1 + $obf_var2 + $obf_var3 >= 3) {
$type = 3;
return true;
}
return false;
}
///////////////////////////////////////////////////////////////////////////
function CriticalPHP($l_FN, $l_Index, $l_Content, &$l_Pos)
{
global $g_ExceptFlex, $gX_FlexDBShe, $g_FlexDBShe, $gX_DBShe, $g_DBShe, $g_Base64, $g_Base64Fragment;
//print "###########################################################################n";
//print "CriticalPHP Start:" . $l_FN . " index: " . $l_Index . "n";
//print "###########################################################################n";
//echo 'CONTENT:[';
//echo $l_Content."]nn";
// KV238467HNJKGFJHGFDGHGGFD
#var_dump($g_ExceptFlex);
foreach ($g_FlexDBShe as $l_Item) {
//print "nSIGNATURE: " . $l_Item . ''."n";
if (preg_match('#(' . $l_Item . ')#smi', $l_Content, $l_Found, PREG_OFFSET_CAPTURE)) {
//print "nIN: {{{" . $l_Found[0][0]. "}}}n";
if (!CheckException($l_Content, $l_Found)) {
//print "n****** VIR *************n";
$l_Pos = $l_Found[0][1];
return true;
}
}
}
if (AI_EXPERT) {
foreach ($gX_FlexDBShe as $l_Item) {
//print "nSIGNATURE: " . $l_Item . ''."n";
if (preg_match('#(' . $l_Item . ')#smi', $l_Content, $l_Found, PREG_OFFSET_CAPTURE)) {
//print "nIN: {{{" . $l_Found[0][0]. "}}}n";
if (!CheckException($l_Content, $l_Found)) {
//print "n****** VIR *************n";
$l_Pos = $l_Found[0][1];
return true;
}
}
}
}
foreach ($g_DBShe as $l_Item) {
$l_Pos = stripos($l_Content, $l_Item);
if ($l_Pos !== false) {
return true;
}
}
if (AI_EXPERT) {
foreach ($gX_DBShe as $l_Item) {
$l_Pos = stripos($l_Content, $l_Item);
if ($l_Pos !== false) {
return true;
}
}
}
//print "###########################################################################n";
//print "CriticalPHP End:" . $l_FN . " index: " . $l_Index . "n";
//print "###########################################################################n";
if ((strpos($l_Content, 'GIF89') === 0) && (strpos($l_FN, '.php') !== false )) {
$l_Pos = 0;
return true;
}
if (strpos($l_FN, '.php.') !== false ) {
$g_Base64[] = $l_Index;
$g_Base64Fragment[] = '".php."';
$l_Pos = 0;
return false;
}
if (preg_match('#((include|require|require_once|include_once)s*(*s*["']http://.+?["'])#smi', $l_Content, $l_Found)) {
$g_Base64[] = $l_Index;
$g_Base64Fragment[] = substr($l_Found[1], 0, MAX_PREVIEW_LEN);
}
// detect base64 suspicious
if (preg_match('|([A-Za-z0-9+/]{' . BASE64_LENGTH . ',})|smi', $l_Content, $l_Found, PREG_OFFSET_CAPTURE)) {
if (preg_match('#(assert|eval|sort|array_map|create_function|base64_decode|gzip_decode|gzip_inflate|preg_replace_callback)s*(#smi',
$l_Content, $l_Found, PREG_OFFSET_CAPTURE)) {
if ((!CheckException($l_Content, $l_Found)) && (!in_array($l_Index, $g_Base64))) {
$g_Base64[] = $l_Index;
$g_Base64Fragment[] = getFragment($l_Content, $l_Found[1][1]);
}
}
}
if (preg_match('|evals*(.+?(.+?(s*implode|smi', $l_Content, $l_Found)) {
$g_Base64[] = $l_Index;
$g_Base64Fragment[] = getFragment($l_Content, $l_Pos);
}
// count number of base64_decode entries
$l_Count = substr_count($l_Content, 'base64_decode');
if ($l_Count > 10) {
$g_Base64[] = $l_Index;
$g_Base64Fragment[] = getFragment($l_Content, stripos($l_Content, 'base64_decode'));
}
return false;
}
///////////////////////////////////////////////////////////////////////////
if (!isCli()) {
header('Content-type: text/html; charset=utf-8');
}
if (!isCli()) {
$l_PassOK = false;
if (strlen(PASS) > 8) {
$l_PassOK = true;
}
if ($l_PassOK && preg_match('|[0-9]|', PASS, $l_Found) && preg_match('|[A-Z]|', PASS, $l_Found) && preg_match('|[a-z]|', PASS, $l_Found) ) {
$l_PassOK = true;
}
if (!$l_PassOK) {
echo sprintf(AI_STR_009, generatePassword());
exit;
}
if (isset($_GET['fn']) && ($_GET['ph'] == crc32(PASS))) {
printFile();
exit;
}
if ($_GET['p'] != PASS) {
echo sprintf(AI_STR_010, generatePassword());
exit;
}
}
if (!is_readable(ROOT_PATH)) {
echo AI_STR_011;
exit;
}
if (isCli()) {
if (defined('REPORT_PATH') AND REPORT_PATH)
{
if (!is_writable(REPORT_PATH))
{
die("nCannot write report. Report dir " . REPORT_PATH . " is not writable.");
}
else if (!REPORT_FILE)
{
die("nCannot write report. Report filename is empty.");
}
else if (($file = REPORT_PATH . DIR_SEPARATOR . REPORT_FILE) AND is_file($file) AND !is_writable($file))
{
die("nCannot write report. Report file '$file' exists but is not writable.");
}
}
}
$g_IgnoreList = array();
$g_DirIgnoreList = array();
$g_UrlIgnoreList = array();
$g_KnownList = array();
$l_IgnoreFilename = '.aignore';
$l_DirIgnoreFilename = '.adirignore';
$l_UrlIgnoreFilename = '.aurlignore';
$l_KnownFilename = '.aknown';
if (file_exists($l_IgnoreFilename)) {
$l_IgnoreListRaw = file($l_IgnoreFilename);
for ($i = 0; $i < count($l_IgnoreListRaw); $i++)
{
$g_IgnoreList[] = explode("t", trim($l_IgnoreListRaw[$i]));
}
unset($l_IgnoreListRaw);
}
if (file_exists($l_DirIgnoreFilename)) {
$g_DirIgnoreList = file($l_DirIgnoreFilename);
for ($i = 0; $i < count($g_DirIgnoreList); $i++) {
$g_DirIgnoreList[$i] = trim($g_DirIgnoreList[$i]);
}
}
if (file_exists($l_UrlIgnoreFilename)) {
$g_UrlIgnoreList = file($l_UrlIgnoreFilename);
for ($i = 0; $i < count($g_UrlIgnoreList); $i++) {
$g_UrlIgnoreList[$i] = trim($g_UrlIgnoreList[$i]);
}
}
if ($l_DIRH = @opendir('.'))
{
while (($l_FileName = readdir($l_DIRH)) !== false)
{
if ($l_FileName == '.' || $l_FileName == '..') continue;
if (strpos($l_FileName, $l_KnownFilename) !== false) {
$g_KnownListTmp = file($l_FileName);
for ($i = 0; $i < count($g_KnownListTmp); $i++) {
$g_KnownListTmp[$i] = trim($g_KnownListTmp[$i]);
}
$g_KnownList = array_merge($g_KnownListTmp, $g_KnownList);
}
}
}
closedir($l_DIRH);
stdOut("Loaded " . count($g_KnownList) . ' known files');
QCR_Debug();
// scan single file
if (defined('SCAN_FILE')) {
if (file_exists(SCAN_FILE) && is_file(SCAN_FILE) && is_readable(SCAN_FILE)) {
stdOut("Start scanning file '" . SCAN_FILE . "'.");
QCR_ScanFile(SCAN_FILE);
} else {
stdOut("Error:" . SCAN_FILE . " either is not a file or readable");
}
} else {
// scan list of files from file
if (file_exists(DOUBLECHECK_FILE)) {
stdOut("Start scanning the list from '" . DOUBLECHECK_FILE . "'.");
$l_List = file(DOUBLECHECK_FILE);
for ($i = 1; $i < count($l_List); $i++) {
QCR_ScanFile(trim($l_List[$i]));
}
} else {
// scan whole file system
stdOut("Start scanning '" . ROOT_PATH . "'.");
QCR_ScanDirectories(ROOT_PATH);
}
}
$g_FoundTotalFiles = count($g_Structure['n']);
QCR_Debug();
stdOut("Founded $g_FoundTotalFiles files in $g_FoundTotalDirs directories.");
stdOut(str_repeat(' ', 160),false);
$g_FoundTotalFiles = count($g_Structure['n']);
QCR_GoScan(0);
QCR_Debug();
////////////////////////////////////////////////////////////////////////////
if ($BOOL_RESULT) {
if ((count($g_CriticalPHP) > 0) OR (count($g_CriticalJS) > 0) OR (count($g_Base64) > 0) OR (count($g_SuspDir) > 0) OR (count($g_Iframer) > 0) OR (count($g_UnixExec) > 0))
{
echo "1n";
exit(0);
}
}
////////////////////////////////////////////////////////////////////////////
$l_Result .= "<div class="sec"><b>" . AI_STR_051 . (isset($_SERVER['HTTP_HOST']) ? $_SERVER['HTTP_HOST'] : realpath('.')) . "</b></div>";
$time_tacked = seconds2Human(microtime(true) - START_TIME);
$l_Result .= sprintf(AI_STR_012, count($g_DBShe) + count($gX_DBShe) + count($g_FlexDBShe), (count($g_SusDB) + count($g_AdwareSig ) + count($g_JSVirSig)), $time_tacked, date('d-m-Y в H:i:s', floor(START_TIME)) , date('d-m-Y в H:i:s'));
$l_Result .= sprintf(AI_STR_013, $g_TotalFolder, $g_TotalFiles);
if (!$defaults['scan_all_files']) {
$l_Result .= AI_STR_014;
}
$l_Result .= AI_STR_015;
$l_ShowOffer = false;
stdOut("nBuilding reportn");
////////////////////////////////////////////////////////////////////////////
// save
if ((count($g_CriticalPHP) > 0) OR (count($g_CriticalJS) > 0) OR (count($g_Base64) > 0) OR (count($g_SuspDir) > 0) OR
(count($g_Iframer) > 0) OR (count($g_UnixExec)))
{
if (!file_exists(DOUBLECHECK_FILE)) {
if ($l_FH = fopen(DOUBLECHECK_FILE, 'w')) {
fputs($l_FH, '<?php die("Forbidden"); ?>' . "n");
$l_CurrPath = dirname(__FILE__);
for ($i = 0; $i < count($g_CriticalPHP); $i++) {
fputs($l_FH, str_replace($l_CurrPath, '.', $g_Structure['n'][$g_CriticalPHP[$i]]) . "n");
//unlink(str_replace($l_CurrPath, '.', $g_Structure['n'][$g_CriticalPHP[$i]]));
}
for ($i = 0; $i < count($g_Base64); $i++) {
fputs($l_FH, str_replace($l_CurrPath, '.', $g_Structure['n'][$g_Base64[$i]]) . "n");
//unlink(str_replace($l_CurrPath, '.', $g_Structure['n'][$g_Base64[$i]]));
}
for ($i = 0; $i < count($g_CriticalJS); $i++) {
fputs($l_FH, str_replace($l_CurrPath, '.', $g_Structure['n'][$g_CriticalJS[$i]]) . "n");
//unlink(str_replace($l_CurrPath, '.', $g_Structure['n'][$g_CriticalJS[$i]]));
}
for ($i = 0; $i < count($g_SuspDir); $i++) {
fputs($l_FH, str_replace($l_CurrPath, '.', $g_Structure['n'][$g_SuspDir[$i]]) . "n");
//unlink(str_replace($l_CurrPath, '.', $g_Structure['n'][$g_SuspDir[$i]]));
}
for ($i = 0; $i < count($g_Iframer); $i++) {
fputs($l_FH, str_replace($l_CurrPath, '.', $g_Structure['n'][$g_Iframer[$i]]) . "n");
//unlink(str_replace($l_CurrPath, '.', $g_Structure['n'][$g_Iframer[$i]]));
}
for ($i = 0; $i < count($g_UnixExec); $i++) {
fputs($l_FH, str_replace($l_CurrPath, '.', $g_Structure['n'][$g_UnixExec[$i]]) . "n");
//unlink(str_replace($l_CurrPath, '.', $g_Structure['n'][$g_UnixExec[$i]]));
}
fclose($l_FH);
} else {
stdOut("Error! Cannot create " . DOUBLECHECK_FILE);
}
} else {
stdOut(DOUBLECHECK_FILE . ' already exists.');
$l_Result .= '<div class="err">' . DOUBLECHECK_FILE . ' already exists.</div>';
}
}
////////////////////////////////////////////////////////////////////////////
stdOut("Building list of shells " . count($g_CriticalPHP));
if (count($g_CriticalPHP) > 0) {
$l_Result .= '<div class="vir"><b>' . AI_STR_016 . '</b>';
$l_Result .= printList($g_CriticalPHP, $g_CriticalPHPFragment, true);
$l_Result .= '</div>';
$l_ShowOffer = true;
} else {
$l_Result .= '<div class="ok"><b>' . AI_STR_017. '</b></div>';
}
stdOut("Building list of js " . count($g_CriticalJS));
if (count($g_CriticalJS) > 0) {
$l_Result .= '<div class="vir"><b>' . AI_STR_018 . '</b>';
$l_Result .= printList($g_CriticalJS, $g_CriticalJSFragment, true);
$l_Result .= "</div>";
$l_ShowOffer = true;
}
stdOut("Building list of unix executables " . count($g_UnixExec));
if (count($g_UnixExec) > 0) {
$l_Result .= "<div class="vir"><b>". AI_STR_019 ."</b>";
$l_Result .= printList($g_UnixExec, '', true);
$l_Result .= "</div>";
$l_ShowOffer = true;
}
stdOut("Building list of base64s " . count($g_Base64));
if (count($g_Base64) > 0) {
$l_ShowOffer = true;
$l_Result .= "<div class="vir"><b>" . AI_STR_020 ."</b>";
$l_Result .= printList($g_Base64, $g_Base64Fragment, true);
$l_Result .= "</div>";
}
stdOut("Building list of iframes " . count($g_Iframer));
if (count($g_Iframer) > 0) {
$l_ShowOffer = true;
$l_Result .= "<div class="vir"><b>" . AI_STR_021 . "</b>";
$l_Result .= printList($g_Iframer, $g_IframerFragment, true);
$l_Result .= "</div>";
}
stdOut("Building list of heuristics " . count($g_HeuristicDetected));
if (count($g_HeuristicDetected) > 0) {
$l_Result .= '<div class="warn"><b>' . AI_STR_052 . '</b><ul>';
for ($i = 0; $i < count($g_HeuristicDetected); $i++) {
$l_Result .= '<li>' . $g_Structure['n'][$g_HeuristicDetected[$i]] . ' (' . get_descr_heur($g_HeuristicType[$i]) . ')</li>';
}
$l_Result .= '</ul></div>';
$l_ShowOffer = true;
}
stdOut("Building list of symlinks " . count($g_SymLinks));
if (count($g_SymLinks) > 0) {
$l_Result .= "<div class="warn"><b>" . AI_STR_022 . "</b><br>";
$l_Result .= implode("<br>", $g_SymLinks);
$l_Result .= "</div>";
}
stdOut("Building list of hidden files " . count($g_HiddenFiles));
if (count($g_HiddenFiles) > 0) {
$l_Result .= "<div class="warn"><b>" . AI_STR_023 . "</b><br>";
$l_Result .= implode("<br>", $g_HiddenFiles);
$l_Result .= "</div>";
}
stdOut("Building list of susp dirs " . count($g_SuspDir));
if (count($g_SuspDir) > 0) {
$l_Result .= "<div class="vir"><b>" . AI_STR_024 . "</b><br>";
$l_Result .= printList($g_SuspDir);
$l_Result .= "</div>";
} else {
$l_Result .= '<div class="ok"><b>' . AI_STR_025 . '</b></div>';
}
stdOut("Building list of redirects " . count($g_Redirect));
$l_Result .= "<div class="sec">" . AI_STR_026 . "</div>";
if (count($g_Redirect) > 0) {
$l_ShowOffer = true;
$l_Result .= "<div class="warn"><b>" . AI_STR_027 . "</b>";
$l_Result .= printList($g_Redirect, $g_RedirectPHPFragment, true);
$l_Result .= "</div>";
}
stdOut("Building list of php inj " . count($g_PHPCodeInside));
if ((count($g_PHPCodeInside) > 0) && (($defaults['report_mask'] & REPORT_MASK_PHPSIGN) == REPORT_MASK_PHPSIGN)) {
$l_ShowOffer = true;
$l_Result .= "<div class="warn"><b>" . AI_STR_028 . "</b>";
$l_Result .= printList($g_PHPCodeInside, $g_PHPCodeInsideFragment, true);
$l_Result .= "</div>";
}
stdOut("Building list of adware " . count($g_AdwareList));
if (count($g_AdwareList) > 0) {
$l_ShowOffer = true;
$l_Result .= "<div class="warn"><b>" . AI_STR_029 . "</b>";
$l_Result .= printList($g_AdwareList, $g_AdwareListFragment, true);
$l_Result .= "</div>";
}
stdOut("Building list of unread files " . count($g_NotRead));
if (count($g_NotRead) > 0) {
$l_ShowOffer = true;
$l_Result .= "<div class="warn"><b>" . AI_STR_030 . ":</b>";
$l_Result .= printList($g_NotRead);
$l_Result .= "</div>";
}
stdOut("Building list of empty links " . count($g_EmptyLink));
if ((count($g_EmptyLink) > 0) && (($defaults['report_mask'] & REPORT_MASK_SPAMLINKS) == REPORT_MASK_SPAMLINKS)) {
$l_ShowOffer = true;
$l_Result .= "<div class="warn"><b>" . AI_STR_031 . "</b>";
$l_Result .= printList($g_EmptyLink, '', true);
$l_Result .= AI_STR_032 . '<br/>';
if (count($g_EmptyLink) == MAX_EXT_LINKS) {
$l_Result .= '(' . AI_STR_033 . MAX_EXT_LINKS . ')<br/>';
}
for ($i = 0; $i < count($g_EmptyLink); $i++) {
$l_Idx = $g_EmptyLink[$i];
for ($j = 0; $j < count($g_EmptyLinkSrc[$l_Idx]); $j++) {
$l_Result .= '<span class="details">' . $g_Structure['n'][$g_EmptyLink[$i]] . ' → ' . htmlspecialchars($g_EmptyLinkSrc[$l_Idx][$j]) . '</span><br/>';
}
}
$l_Result .= "</div>";
}
stdOut("Building list of doorways " . count($g_Doorway));
if ((count($g_Doorway) > 0) && (($defaults['report_mask'] & REPORT_MASK_DOORWAYS) == REPORT_MASK_DOORWAYS)) {
$l_ShowOffer = true;
$l_Result .= "<div class="warn"><b>" . AI_STR_034 . "</b>";
$l_Result .= printList($g_Doorway);
$l_Result .= "</div>";
}
stdOut("Building list of php warnings " . (count($g_WarningPHP[0]) + count($g_WarningPHP[1])));
if (($defaults['report_mask'] & REPORT_MASK_SUSP) == REPORT_MASK_SUSP) {
if ((count($g_WarningPHP[0]) + count($g_WarningPHP[1])) > 0) {
$l_ShowOffer = true;
$l_Result .= "<div class="warn"><b>" . AI_STR_035 . "</b>";
for ($i = 0; $i < count($g_WarningPHP); $i++) {
if (count($g_WarningPHP[$i]) > 0) $l_Result .= printList($g_WarningPHP[$i], $g_WarningPHPFragment[$i], true);
}
$l_Result .= "</div>";
}
}
stdOut("Building list of skipped dirs " . count($g_SkippedFolders));
if (count($g_SkippedFolders) > 0) {
$l_Result .= "<div class="warn2"><b>" . AI_STR_036 . "</b><br/>";
$l_Result .= implode("<br>", $g_SkippedFolders);
$l_Result .= "</div>";
}
stdOut("Building list of writeable dirs " . count($g_WritableDirectories));
if (count($g_CMS) > 0) {
$l_Result .= "<div class="warn2"><b>" . AI_STR_037 . "</b><br/>";
$l_Result .= implode("<br>", $g_CMS);
$l_Result .= "</div>";
}
if (!isCli()) {
$l_Result .= QCR_ExtractInfo($l_PhpInfoBody[1]);
}
$max_size_to_scan = getBytes(MAX_SIZE_TO_SCAN);
$max_size_to_scan = $max_size_to_scan > 0 ? $max_size_to_scan : getBytes('1m');
stdOut("Building list of bigfiles " . count($g_BigFiles));
if (count($g_BigFiles) > 0) {
$l_Result .= "<div class="warn2"><b>" . sprintf(AI_STR_038, bytes2Human($max_size_to_scan)) . "</b>";
$l_Result .= printList($g_BigFiles);
$l_Result .= "</div>";
} else {
if (SCAN_ALL_FILES) {
$l_Result .= '<div class="ok"><b>' . sprintf(AI_STR_039, bytes2Human($max_size_to_scan)) . '</b></div>';
}
}
stdOut("Building list of sensitive files " . count($g_UnsafeFilesFound) . "n");
if ((count($g_UnsafeFilesFound) > 0) && (($defaults['report_mask'] & REPORT_MASK_CANDI) == REPORT_MASK_CANDI)) {
$l_Result .= "<div class="warn2"><b>" . AI_STR_040 . "</b>";
$l_Result .= printList($g_UnsafeFilesFound);
$l_Result .= "</div>";
}
if (!$defaults['no_rw_dir']) {
if ((($defaults['report_mask'] & REPORT_MASK_WRIT) == REPORT_MASK_WRIT)) {
if ((count($g_WritableDirectories) > 0)) {
$l_Result .= "<div class="warn2"><b>" . AI_STR_041 . "</b>";
$l_Result .= printList($g_WritableDirectories);
$l_Result .= "</div>";
} else {
$l_Result .= '<div class="ok"><b>' . AI_STR_042 . '</b></div>';
}
}
}
if (function_exists('memory_get_peak_usage')) {
$l_Result .= AI_STR_043 . bytes2Human(memory_get_peak_usage()) . '<p>';
}
$l_Result .= AI_STR_044;
if (!SCAN_ALL_FILES) {
$l_Result .= AI_STR_045;
}
$l_Result .= '<div class="footer"><div class="disclaimer"><span class="vir">[!]</span> ' . AI_STR_049 . '</div>';
$l_Result .= '<div class="thanx">' . AI_STR_050 . '</div>';
$l_Result .= '</div>';
$l_OfferVK = AI_STR_048;
if ($l_ShowOffer) {
$l_Result .= AI_STR_047 .
'<p><a href="#" onclick="document.getElementById('ofr').style.display='none'" style="color: #303030">' . AI_STR_046 . '</a></p>' .
'</div>';
} else {
$l_Result .= '<div class="offer2" id="ofr2">' . $l_OfferVK .
'<p><a href="#" onclick="document.getElementById('ofr2').style.display='none'" style="color: #303030">' . AI_STR_046 .'</a></p>' .
'</div>';
}
////////////////////////////////////////////////////////////////////////////
if (!isCli())
{
echo $l_Result;
exit;
}
if (!defined('REPORT') OR REPORT === '')
{
die('Report not written.');
}
$emails = getEmails(REPORT);
if (!$emails) {
if ($l_FH = fopen($file, "w")) {
fputs($l_FH, $l_Result);
fclose($l_FH);
stdOut("nReport written to '$file'.");
} else {
stdOut("nCannot create '$file'.");
}
} else {
$headers = array(
'MIME-Version: 1.0',
'Content-type: text/html; charset=UTF-8',
'From: ' . ($defaults['email_from'] ? $defaults['email_from'] : 'AI-Bolit@myhost')
);
for ($i = 0, $size = sizeof($emails); $i < $size; $i++)
{
mail($emails[$i], 'AI-Bolit Report ' . date("d/m/Y H:i", time()), $l_Result, implode("rn", $headers));
}
stdOut("nReport sended to " . implode(', ', $emails));
}
$time_taken = microtime(true) - START_TIME;
$time_taken = number_format($time_taken, 5);
stdOut("Scanning complete! Time taken: " . seconds2Human($time_taken));
stdOut("nn!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!");
stdOut("Attention! DO NOT LEAVE either ai-bolit.php or AI-BOLIT-REPORT-<xxxx>-<yy>.html nfile on server. COPY it locally then REMOVE from server. ");
stdOut("!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!");
QCR_Debug();
?>