Файл: ai-bolit/ai-bolit.php
Строк: 3933
<?php
///////////////////////////////////////////////////////////////////////////
// Created and developed by Greg Zemskov, Revisium Company
// Email: ai@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
////////////////////////////////////////////////////////////////////////////
// Запрещено использование скрипта в коммерческих целях без приобретения лицензии.
// Запрещено использование исходного кода скрипта без приобретения лицензии.
//
// По вопросам приобретения лицензии обращайтесь в компанию "Ревизиум": http://www.revisium.com
// ai@revisium.com
// На скрипт получено авторское свидетельство в Роспатенте
// http://revisium.com/ai/i/mini_aibolit.jpg
///////////////////////////////////////////////////////////////////////////
// put 1 for expert mode, 0 for basic check and 2 for paranoic mode
// установите 1 для режима "Эксперта", 0 для быстрой проверки и 2 для параноидальной проверки (для лечения сайта)
define('AI_EXPERT', 1);
//define('LANG', 'EN');
define('LANG', 'RU');
// Put any strong password to open the script from web
// Впишите вместо put_any_strong_password_here сложный пароль
define('PASS', 'put_any_strong_password_here');
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
/* <-- remove this line to enable "recommendations"
| REPORT_MASK_CANDI | REPORT_MASK_WRIT
remove this line to enable "recommendations" --> */
);
$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' => '512K',
'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>Григорий Земсков, компания "<a href="http://www.revisium.com/">Ревизиум</a>", 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"><b>Оперативное лечение сайта от вирусов. Защита от взлома. Гарантия на работы. </b></a></span><br/><p style="color: #D0FFD0; font-size: 13px;">Быстро и качественно вылечим Ваш сайт от вирусов, удалим вредоносный код с сайта, поставим уникальную защиту от взлома. <a href="http://www.revisium.com/ru/order/" target=_blank>Отправьте нам запрос</a> на сайте www.revisium.com →</p><hr color=#E0E0E0 size=1><p style="color: #E0E0E0">Также приглашаем в группу ВКонтакте<br/> <a href="http://vk.com/siteprotect" target="_blank">"Безопасность Веб-сайтов"</a>. А еще у нас есть твиттер <a href="http://twitter.com/revisium" target=_blank>@revisium</a> и страница <a href="http://www.facebook.com/Revisium" target=_blank>facebook.com/revisium</a>. Присоединяйтесь!</p><hr color=#E0E0E0 size=1><p style="color: #E0E0E0"><b style="color: yellow">[$$$]</b> Если Вы хостер, веб-студия, seo-специалист или вебмастер — напишите нам на ai@revisium.com, для Вас есть партнерская программа.</p>');
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:ai@revisium.com">ai@revisium.com</a>.<p>Также будем чрезвычайно благодарны за любые упоминания скрипта AI-Bolit на вашем сайте, в блоге, среди друзей, знакомых и клиентов. Ссылочку можно поставить на <a href="http://revisium.com/ai/">http://revisium.com/ai/</a>. <p>Если будут вопросы - пишите <a href="mailto:ai@revisium.com">ai@revisium.com</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> и инструкции к скрипту.');
define('AI_STR_058', 'Обнаружены фишинговые страницы:');
} else {
///////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
// ENGLISH INTERFACE
///////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
define('AI_STR_001', '<h3>AI-BOLIT v.%s — Advanced Server-Side Scanner 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.');
define('AI_STR_058', 'Phishing pages detected:');
}
///////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
// This is signatures wrapped into base64.
$g_DBShe = unserialize(base64_decode("a:312:{i:0;s:8:"ZOBUGTEL";i:1;s:13:"MagelangCyber";i:2;s:13:"profexor.hell";i:3;s:20:"<!--COOKIE UPDATE-->";i:4;s:9:"//rasta//";i:5;s:57:"$param2mask.")\=[\<qq>\"](.*?)(?=[\<qq>\"] )[\<qq>\"]/sie";i:6;s:19:"); $i++)$ret.=chr($";i:7;s:27:"ereg_replace(<q>&email&<q>,";i:8;s:13:"]]));}}eval($";i:9;s:30:"fwrite(fopen(dirname(__FILE__)";i:10;s:11:"Baby_Drakon";i:11;s:24:"$isevalfunctionavailable";i:12;s:15:"Net@ddress Mail";i:13;s:34:"Password:<s>".$_POST[<q>passwd<q>]";i:14;s:15:"Created By EMMA";i:15;s:12:"GIF89A;<?php";i:16;s:28:"oTat8D3DsE8'&~hU06CCH5;$gYSq";i:17;s:20:"$md5=md5("$random");";i:18;s:6:"3xp1r3";i:19;s:32:"$im=substr($tx,$p+2,$p2-($p+2));";i:20;s:15:"NinjaVirus Here";i:21;s:21:"7P1td+NWliaI/hWkZ4VX9";i:22;s:10:"<dot>IrIsT";i:23;s:10:"ndroi|htc_";i:24;s:10:"andex|oogl";i:25;s:17:"Hacked By EnDLeSs";i:26;s:17:"($_POST["dir"]));";i:27;s:55:"($indata,$b64=1){if($b64==1){$cd=base64_decode($indata)";i:28;s:75:"$im=substr($im,0,$i).substr($im,$i2+1,$i4-($i2+1)).substr($im,$i4+12,strlen";i:29;s:18:"<?php echo "#!!#";";i:30;s:10:"Punker2Bot";i:31;s:11:"$sh3llColor";i:32;s:47:"@chr(($h[$e[$o]]<<4)+($h[$e[++$o]]));}}eval($d)";i:33;s:36:"ppc|midp|windows ce|mtk|j2me|symbian";i:34;s:40:"abacho|abizdirectory|about|acoon|alexana";i:35;s:5:"Zed0x";i:36;s:8:"darkminz";i:37;s:13:"ReaL_PuNiShEr";i:38;s:7:"OoN_Boy";i:39;s:20:"__VIEWSTATEENCRYPTED";i:40;s:6:"M4ll3r";i:41;s:25:"createFilesForInputOutput";i:42;s:8:"Pashkela";i:43;s:22:"^c^a^l^p^e^r^_^g^e^r^p";i:44;s:14:"== "bindshell"";i:45;s:15:"Webcommander at";i:46;s:25:"isset($_POST['execgate'])";i:47;s:37:"fwrite($fpsetv, getenv("HTTP_COOKIE")";i:48;s:20:"-I/usr/local/bandmin";i:49;s:21:"$OOO000000=urldecode(";i:50;s:8:"YENI3ERI";i:51;s:15:"letaksekarang()";i:52;s:6:"d3lete";i:53;s:43:"function urlGetContents($url, $timeout = 5)";i:54;s:46:"overflow-y:scroll;\">".$links.$html_mf['body']";i:55;s:16:"Made by Delorean";i:56;s:75:"if(empty($_GET['zip']) and empty($_GET['download']) & empty($_GET['img'])){";i:57;s:65:"str_rot13($basea[($dimension*$dimension-1) - ($i*$dimension+$j)])";i:58;s:60:"R0lGODlhEwAQALMAAAAAAP///5ycAM7OY///nP//zv/OnPf39////wAAAAAA";i:59;s:45:"preg_match('!MIDP|WAP|Windows.CE|PPC|Series60";i:60;s:47:"preg_match('/(?<=RewriteRule).*(?=\[L\,R\=302\]";i:61;s:37:"$url = $urls[rand(0, count($urls)-1)]";i:62;s:80:"wp_posts WHERE post_type = 'post' AND post_status = 'publish' ORDER BY `ID` DESC";i:63;s:65:"http://'.$_SERVER['HTTP_HOST'].urldecode($_SERVER['REQUEST_URI'])";i:64;s:36:"fwrite($f,get_download($_GET['url'])";i:65;s:74:"$param x $n.substr ($param, length($param) - length($code)%length($param))";i:66;s:47:"$time_started.$secure_session_user.session_id()";i:67;s:48:"$this->F->GetController($_SERVER['REQUEST_URI'])";i:68;s:21:"luciffer@luciffer.org";i:69;s:27:"base64_decode($code_script)";i:70;s:21:"unlink($writable_dirs";i:71;s:41:"file_get_contents(trim($f[$_GET['id']]));";i:72;s:10:"Cybester90";i:73;s:27:"/home/mydir/eggdrop/filesys";i:74;s:29:"--DCCDIR [lindex $User($i) 2]";i:75;s:12:"unbind RAW -";i:76;s:11:"putbot $bot";i:77;s:13:"privmsg $nick";i:78;s:26:"proc http::Connect {token}";i:79;s:43:"set google(data) [http::data $google(page)]";i:80;s:22:"bind join - * gop_join";i:81;s:13:"privmsg $chan";i:82;s:24:"r4aTc.dPntE/fztSF1bH3RH0";i:83;s:10:"bind dcc -";i:84;s:35:"kill -CHLD \$botpid >/dev/null 2>&1";i:85;s:50:"regsub -all -- , [string tolower $owner] "" owners";i:86;s:30:"bind filt - "\001ACTION *\001"";i:87;s:27:"ayu pr1 pr2 pr3 pr4 pr5 pr6";i:88;s:20:"set protect-telnet 0";i:89;s:33:"/usr/local/apache/bin/httpd -DSSL";i:90;s:76:"$tsu2[rand(0,count($tsu2) - 1)].$tsu1[rand(0,count($tsu1) - 1)].$tsu2[rand(0";i:91;s:19:"fopen('/etc/passwd'";i:92;s:11:"f0VMRgEBAQA";i:93;s:35:"0d0a0d0a676c6f62616c20246d795f736d7";i:94;s:9:"etalfnizg";i:95;s:37:"JHZpc2l0Y291bnQgPSAkSFRUUF9DT09LSUVfV";i:96;s:13:"edoced_46esab";i:97;s:5:"e/*./";i:98;s:28:"@setcookie("hit", 1, time()+";i:99;s:46:"find_dirs($grandparent_dir, $level, 1, $dirs);";i:100;s:69:"@copy($_FILES[fileMass][tmp_name],$_POST[path].$_FILES[fileMass][name";i:101;s:76:"int32((($z >> 5 & 0x07ffffff) ^ $y << 2) + (($y >> 3 & 0x1fffffff) ^ $z << 4";i:102;s:11:"VOBRA GANGO";i:103;s:59:"echo y ; sleep 1 ; } | { while read ; do echo z$REPLY; done";i:104;s:9:"<stdlib.h";i:105;s:45:"add_filter('the_content', '_bloginfo', 10001)";i:106;s:17:"itsoknoproblembro";i:107;s:28:"if self.hash_type == 'pwdump";i:108;s:59:"$framework.plugins.load("#{rpctype.downcase}rpc", opts).run";i:109;s:57:"subprocess.Popen('%sgdb -p %d -batch %s' % (gdb_prefix, p";i:110;s:57:"argparse.ArgumentParser(description=help, prog="sctunnel"";i:111;s:32:"rule_req = raw_input("SourceFire";i:112;s:50:"os.system('echo alias ls=".ls.bash" >> ~/.bashrc')";i:113;s:42:"connection.send("shell "+str(os.getcwd())+";i:114;s:67:"print("[!] Host: " + hostname + " might be down!\n[!] Response Code";i:115;s:69:"def daemon(stdin='/dev/null', stdout='/dev/null', stderr='/dev/null')";i:116;s:83:"subprocess.Popen(cmd, shell = True, stdout=subprocess.PIPE, stderr=subprocess.STDOU";i:117;s:47:"if(isset($_GET['host'])&&isset($_GET['time'])){";i:118;s:15:"NIGGERS.NIGGERS";i:119;s:25:"HTTP flood complete after";i:120;s:21:"80 -b $1 -i eth0 -s 8";i:121;s:13:"exploitcookie";i:122;s:26:"system("php -f xpl $host")";i:123;s:11:"sh go $1.$x";i:124;s:12:"az88pix00q98";i:125;s:30:"unless(open(PFD,$g_upload_db))";i:126;s:11:"www.t0s.org";i:127;s:39:"$value =~ s/%(..)/pack('c',hex($1))/eg;";i:128;s:14:"The Dark Raver";i:129;s:61:"Q3JlZGl0IDogVW5kZXJncm91bmQgRGV2aWwgJm5ic3A7ICB8DQo8YSBocmVmP";i:130;s:29:"}elseif($_GET['page']=='ddos'";i:131;s:16:"{$_POST['root']}";i:132;s:39:"I/gcZ/vX0A10DDRDg7Ezk/d+3+8qvqqS1K0+AXY";i:133;s:64:"FJ3FkuPKFkU/53WEBmIaipktnLwQW8z49dc1rbbLqsw8e69l6vJM+3/124xVn+7l";i:134;s:102:"\u003c\u0069\u006d\u0067\u0020\u0073\u0072\u0063\u003d\u0022\u0068\u0074\u0074\u0070\u003a\u002f\u002f";i:135;s:55:"463839610c000b00800100ffffffffffff21f90401000001002c000";i:136;s:30:"fread($fp, filesize($fichero))";i:137;s:24:"$baslik=$_POST['baslik']";i:138;s:18:"proc_open('IHSteam";i:139;s:56:"\x31\xdb\xf7\xe3\x53\x43\x53\x6a\x02\x89\xe1\xb0\x66\xcd";i:140;s:58:"AAAAAAAAMAAwABAAAAeAUAADQAAADsCQAAAAAAADQAIAADACgAFwAUAAEA";i:141;s:31:"$ini['users'] = array('root' =>";i:142;s:58:"HJ3HjutckoRfpXf9A1zQO2AwDRrRey9uGvTeez79qAao1a0rgudkZkR8Ra";i:143;s:50:"curl_setopt($ch, CURLOPT_URL, "http://$host:2082")";i:144;s:64:"<%= "\" & oScriptNet.ComputerName & "\" & oScriptNet.UserName %>";i:145;s:104:"sqlCommand.Parameters.Add(((TableCell)dataGridItem.Controls[0]).Text, SqlDbType.Decimal).Value = decimal";i:146;s:90:"Response.Write("<br>( ) <a href=?type=1&file=" & server.URLencode(item.path) & "\>" & item";i:147;s:111:"new FileStream(Path.Combine(fileInfo.DirectoryName, Path.GetFileName(httpPostedFile.FileName)), FileMode.Create";i:148;s:71:"Response.Write(Server.HtmlEncode(this.ExecuteCommand(txtCommand.Text)))";i:149;s:83:"<%=Request.Servervariables("SCRIPT_NAME")%>?txtpath=<%=Request.QueryString("txtpath";i:150;s:60:"outstr += string.Format("<a href='?fdir={0}'>{1}/</a>&nbsp;"";i:151;s:61:"QOiKWAgV613LvstKY+UB98JZTRGIhYBdHuJCAwm+Xth16AwQ8X4tPMcMVZQte";i:152;s:33:"re.findall(dirt+'(.*)',prognm)[0]";i:153;s:40:"find / -name .ssh > $dir/sshkeys/sshkeys";i:154;s:60:"FS_chk_func_libc=( $(readelf -s $FS_libc | grep _chk@@ | awk";i:155;s:49:"Ly83MTg3OWQyMTJkYzhjYmY0ZDRmZDA0NGEzZDE3Zjk3ZmI2N";i:156;s:95:"$file = $_FILES["filename"]["name"]; echo "<a href=\"$file\">$file</a>";} else {echo("empty");}";i:157;s:48:"DJ7VIU7RICXr6sEEV2cBtHDSOe9nVdpEGhEmvRVRNURfw1wQ";i:158;s:51:"Lz8_Ly8vDx8e_v7-7u7u3s7uzs7Ozq6unq7erq6uvq5-jo6ujn5";i:159;s:83:"iVBORw0KGgoAAAANSUhEUgAAAAoAAAAICAYAAADA-m62AAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQU";i:160;s:51:"server.</p>\r\n</body></html>";exit;}if(preg_match(";i:161;s:77:"$Fchmod,$Fdata,$Options,$Action,$hddall,$hddfree,$hddproc,$uname,$idd):shared";i:162;s:15:"php ".$wso_path";i:163;s:61:"$prod="sy"."s"."tem";$id=$prod($_REQUEST['product']);${'id'};";i:164;s:30:"@assert($_REQUEST['PHPSESSID']";i:165;s:68:"POST {$path}{$connector}?Command=FileUpload&Type=File&CurrentFolder=";i:166;s:87:""admin1.php", "admin1.html", "admin2.php", "admin2.html", "yonetim.php", "yonetim.html"";i:167;s:97:"@path1=('admin/','administrator/','moderator/','webadmin/','adminarea/','bb-admin/','adminLogin/'";i:168;s:36:"cat ${blklog[2]} | grep "root:x:0:0"";i:169;s:46:"?url='.$_SERVER['HTTP_HOST']).unlink(ROOT_DIR.";i:170;s:46:"long int:t(0,3)=r(0,3);-2147483648;2147483647;";i:171;s:75:"create_function("&$"."function","$"."function = chr(ord($"."function)-3);")";i:172;s:86:"function google_bot() {$sUserAgent = strtolower($_SERVER['HTTP_USER_AGENT']);if(!(strp";i:173;s:74:"copy($_FILES['upkk']['tmp_name'],"kk/".basename($_FILES['upkk']['name']));";i:174;s:67:"for ($value) { s/&/&amp;/g; s/</&lt;/g; s/>/&gt;/g; s/"/&quot;/g; }";i:175;s:42:"$db_d = @mysql_select_db($database,$con1);";i:176;s:51:"Send this file: <INPUT NAME="userfile" TYPE="file">";i:177;s:22:"fwrite ($fp, "$yazi");";i:178;s:52:"map { read_shell($_) } ($sel_shell->can_read(0.01));";i:179;s:27:"2>&1 1>&2" : " 1>&1 2>&1");";i:180;s:59:"global $mysqlHandle, $dbname, $tablename, $old_name, $name,";i:181;s:69:"__all__ = ["SMTPServer","DebuggingServer","PureProxy","MailmanProxy"]";i:182;s:29:"if (is_file("/tmp/$ekinci")){";i:183;s:38:"if($cmd != "") print Shell_Exec($cmd);";i:184;s:26:"$cmd = ($_REQUEST['cmd']);";i:185;s:55:"$uploadfile = $rpath."/" . $_FILES['userfile']['name'];";i:186;s:33:"if ($funcarg =~ /^portscan (.*)/)";i:187;s:46:"<% For Each Vars In Request.ServerVariables %>";i:188;s:48:"if(''==($df=@ini_get('disable_functions'))){echo";i:189;s:38:"$filename = $backupstring."$filename";";i:190;s:59:"<%#@~^HwAAAA==@#@&DnkwKx/RUN@#@&nx9Pd;(@#@&ugcAAA==^#~@%>";i:191;s:24:"$function($_POST['cmd'])";i:192;s:29:"echo "FILE UPLOADED TO $dez";";i:193;s:68:"if (!@is_link($file) && ($r = realpath($file)) != FALSE) $file = $r;";i:194;s:87:"UNION SELECT '0' , '<? system(\$_GET[cpc]);exit; ?>' ,0 ,0 ,0 ,0 INTO OUTFILE '$outfile";i:195;s:89:"if(move_uploaded_file($_FILES["fic"]["tmp_name"],good_link("./".$_FILES["fic"]["name"])))";i:196;s:72:"connect(SOCKET, sockaddr_in($ARGV[1], inet_aton($ARGV[0]))) or die print";i:197;s:52:"elseif(@is_writable($FN) && @is_file($FN)) $tmpOutMF";i:198;s:68:"while ($row = mysql_fetch_array($result,MYSQL_ASSOC)) print_r($row);";i:199;s:18:"$fe("$cmd  2>&1");";i:200;s:69:"send(SOCK5, $msg, 0, sockaddr_in($porta, $iaddr)) and $pacotes{o}++;;";i:201;s:69:"} elsif ($servarg =~ /^\:(.+?)\!(.+?)\@(.+?) PRIVMSG (.+?) \:(.+)/) {";i:202;s:37:"elseif(function_exists("shell_exec"))";i:203;s:71:"system("$cmd 1> /tmp/cmdtemp 2>&1; cat /tmp/cmdtemp; rm /tmp/cmdtemp");";i:204;s:52:"$_FILES['probe']['size'], $_FILES['probe']['type']);";i:205;s:87:"$ra44  = rand(1,99999);$sj98 = "sh-$ra44";$ml = "$sd98";$a5 = $_SERVER['HTTP_REFERER'];";i:206;s:66:"mysql_query("CREATE TABLE `xploit` (`xploit` LONGBLOB NOT NULL)");";i:207;s:66:"passthru( $bindir."mysqldump --user=$USERNAME --password=$PASSWORD";i:208;s:84:"<a href='$PHP_SELF?action=viewSchema&dbname=$dbname&tablename=$tablename'>Schema</a>";i:209;s:60:"if(get_magic_quotes_gpc())$shellOut=stripslashes($shellOut);";i:210;s:47:"if (!defined$param{cmd}){$param{cmd}="ls -la"};";i:211;s:23:"shell_exec('uname -a');";i:212;s:91:"if (move_uploaded_file($_FILES['fila']['tmp_name'], $curdir."/".$_FILES['fila']['name'])) {";i:213;s:83:"if (empty($_POST['wser'])) {$wser = "whois.ripe.net";} else $wser = $_POST['wser'];";i:214;s:36:"<%=env.queryHashtable("user.name")%>";i:215;s:61:"PySystemState.initialize(System.getProperties(), null, argv);";i:216;s:35:"if(!$whoami)$whoami=exec("whoami");";i:217;s:36:"shell_exec($_POST['cmd'] . " 2>&1");";i:218;s:53:"PnVlkWM63!@#@&dKx~nMDWM~D/Esn~x6D@#@&P~~,?nY,WP{Poj";i:219;s:25:"!$_REQUEST["c99sh_surl"])";i:220;s:60:"(ereg('^[[:blank:]]*cd[[:blank:]]*$', $_REQUEST['command']))";i:221;s:23:"$login=@posix_getuid();";i:222;s:38:"system("unset HISTFILE; unset SAVEHIST";i:223;s:31:"<HTML><HEAD><TITLE>cgi-shell.py";i:224;s:36:"execl("/bin/sh","sh","-i",(char*)0);";i:225;s:26:"ncftpput -u $ftp_user_name";i:226;s:29:"$a[hits]'); \r\n#endquery\r\n";i:227;s:23:"{${passthru($cmd)}}<br>";i:228;s:42:"$backdoor->ccopy($cfichier,$cdestination);";i:229;s:59:"$izinler2=substr(base_convert(@fileperms($fname),10,8),-4);";i:230;s:50:"for(;$paddr=accept(CLIENT, SERVER);close CLIENT) {";i:231;s:8:"Asmodeus";i:232;s:37:"passthru(getenv("HTTP_ACCEPT_LANGUAGE";i:233;s:39:"$____=@gzinflate($____)){if(isset($_POS";i:234;s:85:"$subj=urldecode($_GET['su']);$body=urldecode($_GET['bo']);$sds=urldecode($_GET['sd'])";i:235;s:32:"$ka='<?//BRE';$kaka=$ka.'ACK//?>";i:236;s:31:"Cautam fisierele de configurare";i:237;s:12:"BRUTEFORCING";i:238;s:18:"pwd > Generasi.dir";i:239;s:56:"xh -s "/usr/local/apache/sbin/httpd -DSSL" ./httpd -m $1";i:240;s:48:"$a=(substr(urlencode(print_r(array(),1)),5,1).c)";i:241;s:21:"!@$_COOKIE[$sessdt_k]";i:242;s:58:"SELECT 1 FROM mysql.user WHERE concat(`user`, '@', `host`)";i:243;s:44:"copy($_FILES[x][tmp_name],$_FILES[x][name]))";i:244;s:54:"$MessageSubject = base64_decode($_POST["msgsubject"]);";i:245;s:17:"rename("wso.php",";i:246;s:88:"$redirectURL='http://'.$rSite.$_SERVER['REQUEST_URI'];if(isset($_SERVER['HTTP_REFERER'])";i:247;s:40:"$filepath=@realpath($_POST['filepath']);";i:248;s:42:"Worker_GetReplyCode($opData['recvBuffer'])";i:249;s:21:"FaTaLisTiCz_Fx Fx29Sh";i:250;s:13:"w4ck1ng shell";i:251;s:22:"private Shell by m4rco";i:252;s:20:"Shell by Mawar_Hitam";i:253;s:12:"PHPSHELL.PHP";i:254;s:46:"round(0+9830.4+9830.4+9830.4+9830.4+9830.4))==";i:255;s:110:"vzv6d+iOvtkd38TlHu8mQavXdnJCbpQcpXhNbbLmZOqMopDZeNalb+VKledhCjpVAMQSQnxVIECQAfLu5KgLmwB6ehQQGNSBYjpg9g5GdBihXo";i:256;s:65:"if (ereg('^[[:blank:]]*cd[[:blank:]]+([^;]+)$', $command, $regs))";i:257;s:76:"LS0gRHVtcDNkIGJ5IFBpcnVsaW4uUEhQIFdlYnNoM2xsIHYxLjAgYzBkZWQgYnkgcjBkcjEgOkw=";i:258;s:142:"5jb20iKW9yIHN0cmlzdHIoJHJlZmVyZXIsImFwb3J0Iikgb3Igc3RyaXN0cigkcmVmZXJlciwibmlnbWEiKSBvciBzdHJpc3RyKCRyZWZlcmVyLCJ3ZWJhbHRhIikgb3Igc3RyaXN0cigk";i:259;s:21:"eval(base64_decode($_";i:260;s:48:"wsoEx('tar cfzv ' . escapeshellarg($_POST['p2'])";i:261;s:86:"<nobr><b>$cdir$cfile</b> (".$file["size_str"].")</nobr></td></tr><form name=curr_file>";i:262;s:16:"Content-Type: $_";i:263;s:141:"</td><td id=fa>[ <a title=\"Home: '".htmlspecialchars(str_replace("\", $sep, getcwd()))."'.\" id=fa href=\"javascript:ViewDir('".rawurlencode";i:264;s:107:"CQboGl7f+xcAyUysxb5mKS6kAWsnRLdS+sKgGoZWdswLFJZV8tVzXsq+meSPHMxTI3nSUB4fJ2vR3r3OnvXtNAqN6wn/DtTTi+Cu1UOJwNL";i:265;s:39:"WSOsetcookie(md5($_SERVER['HTTP_HOST'])";i:266;s:126:"X1NFU1NJT05bJ3R4dGF1dGhpbiddID0gdHJ1ZTsNCiAgICBpZiAoJF9QT1NUWydybSddKSB7DQogICAgICBzZXRjb29raWUoJ3R4dGF1dGhfJy4kcm1ncm91cCwgbW";i:267;s:39:"J@!Vr@*&RHRw~JLw.G|xlhnLJ~?1.bwObxbP|!V";i:268;s:11:"zehirhacker";i:269;s:161:"('"','&quot;',$fn)).'";document.list.submit();\'>'.htmlspecialchars(strlen($fn)>format?substr($fn,0,format-3).'...':$fn).'</a>'.str_repeat(' ',format-strlen($fn)";i:270;s:160:"print((is_readable($f) && is_writeable($f))?"<tr><td>".w(1).b("R".w(1).font('red','RW',3)).w(1):(((is_readable($f))?"<tr><td>".w(1).b("R").w(4):"").((is_writabl";i:271;s:73:"R0lGODlhFAAUAKIAAAAAAP///93d3cDAwIaGhgQEBP///wAAACH5BAEAAAYALAAAAAAUABQAA";i:272;s:90:"<%=Request.ServerVariables("script_name")%>?FolderPath=<%=Server.URLPathEncode(Folder.Driv";i:273;s:113:"m91dCwgJGVvdXQpOw0Kc2VsZWN0KCRyb3V0ID0gJHJpbiwgdW5kZWYsICRlb3V0ID0gJHJpbiwgMTIwKTsNCmlmICghJHJvdXQgICYmICAhJGVvdX";i:274;s:38:"RootShell!');self.location.href='http:";i:275;s:76:"a href="<?echo "$fistik.php?dizin=$dizin/../"?>" style="text-decoration: non";i:276;s:127:"CB2aTZpIDEwMjQtDQojLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQ0KI3JlcXVp";i:277;s:31:"s().g().s().s().g().s().s().g()";i:278;s:122:"nt)(disk_total_space(getcwd())/(1024*1024)) . "Mb " . "Free space " . (int)(disk_free_space(getcwd())/(1024*1024)) . "Mb <";i:279;s:37:"klasvayv.asp?yenidosya=<%=aktifklas%>";i:280;s:44:"WT+P{~EW0ErPOtnU@#@&^l^sP1ldny@#@&nsk+r0,GT+";i:281;s:115:"mpty($_POST['ur'])) $mode |= 0400; if (!empty($_POST['uw'])) $mode |= 0200; if (!empty($_POST['ux'])) $mode |= 0100";i:282;s:105:"/0tVSG/Suv0Ur/haUYAdn3jMQwbbocGffAeC29BN9tmBiJdV1lk+jYDU92C94jdtDif+xOYjG6CLhx31Uo9x9/eAWgsBK60kK2mLwqzqd";i:283;s:86:"crlf.'unlink($name);'.$crlf.'rename("~".$name, $name);'.$crlf.'unlink("grp_repair.php"";i:284;s:15:"DX_Header_drawn";i:285;s:30:"[Av4bfCYCS,xKWk$+TkUS,xnGdAx[O";i:286;s:111:"BDAQkJCQwLDBgNDRgyIRwhMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjL/wAARCAAQABADASIAAhEBA";i:287;s:11:"ctshell.php";i:288;s:47:"Executed command: <b><font color=#dcdcdc>[$cmd]";i:289;s:13:"WSCRIPT.SHELL";i:290;s:7:"casus15";i:291;s:76:"R0lGODlhJgAWAIAAAAAAAP///yH5BAUUAAEALAAAAAAmABYAAAIvjI+py+0PF4i0gVvzuVxXDnoQ";i:292;s:17:"admin@spygrup.org";i:293;s:14:"temp_r57_table";i:294;s:17:"$c99sh_updatefurl";i:295;s:9:"By Psych0";i:296;s:16:"c99ftpbrutecheck";i:297;s:84:"<textarea name=\"phpev\" rows=\"5\" cols=\"150\">".@$_POST['phpev']."</textarea><br>";i:298;s:94:"$info .= (($perms & 0x0040) ?(($perms & 0x0800) ? 's' : 'x' ) :(($perms & 0x0800) ? 'S' : '-')";i:299;s:30:"$rand_writable_folder_fullpath";i:300;s:10:"Dr.abolalh";i:301;s:6:"K!LL3r";i:302;s:7:"MrHazem";i:303;s:10:"C0derz.com";i:304;s:26:"OLB:PRODUCT:ONLINE_BANKING";i:305;s:10:"BY MMNBOBZ";i:306;s:16:"ConnectBackShell";i:307;s:8:"Hackeado";i:308;s:5:"d3b~X";i:309;s:5:"rahui";i:310;s:9:"Mr.HiTman";i:311;s:10:"Mrlool.exe";}"));
$gX_DBShe = unserialize(base64_decode("YTo0OTp7aTowO3M6MTU6IkRhcmtDcmV3RnJpZW5kcyI7aToxO3M6MTE6IlNpbUF0dGFja2VyIjtpOjI7czoxMjoiXVtyb3VuZCgwKV0oIjtpOjM7czozMjoiPCEtLSNleGVjIGNtZD0iJEhUVFBfQUNDRVBUIiAtLT4iO2k6NDtzOjQ6IkFtIXIiO2k6NTtzOjU6IjZlc2FiIjtpOjY7czo4OiJbY29kZXJ6XSI7aTo3O3M6MTE6IlsgUGhwcm94eSBdIjtpOjg7czo2OiJTcGFtZXIiO2k6OTtzOjc6IkRlZmFjZXIiO2k6MTA7czoxMToiRGV2aWxIYWNrZXIiO2k6MTE7czo3OiJ3ZWJyMDB0IjtpOjEyO3M6NjoiazBkLmNjIjtpOjEzO3M6NTU6ImlzX2NhbGxhYmxlKCdleGVjJykgYW5kICFpbl9hcnJheSgnZXhlYycsICRkaXNhYmxlZnVuY3MiO2k6MTQ7czoxNDoiJEdMT0JBTFNbJ19fX18iO2k6MTU7czoyMzoiaXNfd3JpdGFibGUoIi92YXIvdG1wIikiO2k6MTY7czoyMzoiZXZhbChmaWxlX2dldF9jb250ZW50cygiO2k6MTc7czozNDoiL3Byb2Mvc3lzL2tlcm5lbC95YW1hL3B0cmFjZV9zY29wZSI7aToxODtzOjQ5OiInaHR0cGQuY29uZicsJ3Zob3N0cy5jb25mJywnY2ZnLnBocCcsJ2NvbmZpZy5waHAnIjtpOjE5O3M6NzoiYnIwd3MzciI7aToyMDtzOjc6Im1pbHcwcm0iO2k6MjE7czozNjoiaW5jbHVkZSgkX1NFUlZFUlsnSFRUUF9VU0VSX0FHRU5UJ10pIjtpOjIyO3M6MTA6ImRpciAvT0cgL1giO2k6MjM7czozNDoiaWYgKCgkcGVybXMgJiAweEMwMDApID09IDB4QzAwMCkgeyI7aToyNDtzOjU5OiJpZiAoaXNfY2FsbGFibGUoImV4ZWMiKSBhbmQgIWluX2FycmF5KCJleGVjIiwkZGlzYWJsZWZ1bmMpKSI7aToyNTtzOjQwOiJzZXRjb29raWUoICJteXNxbF93ZWJfYWRtaW5fdXNlcm5hbWUiICk7IjtpOjI2O3M6MTk6InByaW50ICJTcGFtZWQnPjxicj4iO2k6Mjc7czo1MToiJG1lc3NhZ2UgPSBlcmVnX3JlcGxhY2UoIiU1QyUyMiIsICIlMjIiLCAkbWVzc2FnZSk7IjtpOjI4O3M6MTU6Ii9ldGMvbmFtZWQuY29uZiI7aToyOTtzOjEwOiIvZXRjL2h0dHBkIjtpOjMwO3M6MTE6Ii92YXIvY3BhbmVsIjtpOjMxO3M6MTg6Ik5lIHVkYWxvcyB6YWdydXppdCI7aTozMjtzOjE0OiJleGVjKCJybSAtciAtZiI7aTozMztzOjg6IlNoZWxsIE9rIjtpOjM0O3M6MTE6Im15c2hlbGxleGVjIjtpOjM1O3M6OToicm9vdHNoZWxsIjtpOjM2O3M6OToiYW50aXNoZWxsIjtpOjM3O3M6MTI6InI1N3NoZWxsLnBocCI7aTozODtzOjExOiJMb2N1czdTaGVsbCI7aTozOTtzOjExOiJTdG9ybTdTaGVsbCI7aTo0MDtzOjg6Ik4zdHNoZWxsIjtpOjQxO3M6MTE6ImRldmlselNoZWxsIjtpOjQyO3M6MTI6IldlYiBTaGVsbCBieSI7aTo0MztzOjc6IkZ4Yzk5c2giO2k6NDQ7czo4OiJjaWhzaGVsbCI7aTo0NTtzOjc6Ik5URGFkZHkiO2k6NDY7czo4OiJyNTdzaGVsbCI7aTo0NztzOjg6ImM5OXNoZWxsIjtpOjQ4O3M6NjI6IjxkaXYgY2xhc3M9ImJsb2NrIGJ0eXBlMSI+PGRpdiBjbGFzcz0iZHRvcCI+PGRpdiBjbGFzcz0iZGJ0bSI+Ijt9"));
$g_FlexDBShe = unserialize(base64_decode("a:276:{i:0;s:79:"RewriteRule\s+\^\(\.\*\),\(\.\*\)\$\s+\$2\.php\?rewrite_params=\$1&page_url=\$2";i:1;s:58:"function\s+read_pic\(\s*\$A\s*\)\s*{\s*\$a\s*=\s*\$_SERVER";i:2;s:52:"filemtime\(\$basepath\s*\.\s*['"]/configuration\.php";i:3;s:62:"list\s*\(\s*\$host\s*,\s*\$port\s*,\s*\$size\s*,\s*\$exec_time";i:4;s:41:"listing_page\(\s*notice\(\s*['"]symlinked";i:5;s:35:"make_dir_and_file\(\s*\$path_joomla";i:6;s:21:"function\s+inDiapason";i:7;s:41:"&&\s*!empty\(\s*\$_COOKIE\[['"]fill['"]\]";i:8;s:33:"file_exists\s*\(*\s*['"]/var/tmp/";i:9;s:59:"str_replace\(\$find\s*,\s*\$find\s*\.\s*\$html\s*,\s*\$text";i:10;s:36:"\$datamasii=date\("D M d, Y g:i a"\)";i:11;s:34:"\$adddate=date\("D M d, Y g:i a"\)";i:12;s:18:"fuck\s+your\s+mama";i:13;s:50:"Googlebot['"]{0,1}\s*\)\){echo\s+file_get_contents";i:14;s:37:"['"]{0,1}.c.['"]{0,1}\.substr\(\$vbg,";i:15;s:28:"array\(\$en,\$es,\$ef,\$el\)";i:16;s:46:"loc\s*=\s*['"]{0,1}<\?echo\s+\$redirect;\s*\?>";i:17;s:17:"Kazan/index\.html";i:18;s:18:"==0\){jsonQuit\(\$";i:19;s:40:"@stream_socket_client\(['"]{0,1}tcp://\$";i:20;s:30:"::['"]\.phpversion\(\)\.['"]::";i:21;s:38:"preg_replace\(['"].UTF\\-8:\(.\*\).Use";i:22;s:13:""=>\${\${"\\x";i:23;s:42:"fsockopen\(\$m\[0\],\$m\[10\],\$_,\$__,\$m";i:24;s:33:"eVaL\(\s*trim\(\s*baSe64_deCoDe\(";i:25;s:46:"echo\s*md5\(\$_POST\[['"]{0,1}check['"]{0,1}\]";i:26;s:25:"img src=['"]opera000\.png";i:27;s:37:"function reload\(\){header\("Location";i:28;s:40:"substr_count\(getenv\(\\['"]HTTP_REFERER";i:29;s:31:"webi\.ru/webi_files/php_libmail";i:30;s:65:"chr2=\(\(enc2&15\)<<4\)\|\(enc3>>2\);chr3=\(\(enc3&3\)<<6\)\|enc4";i:31;s:12:"REREFER_PTTH";i:32;s:9:"tsoh_ptth";i:33;s:15:"tnega_resu_ptth";i:34;s:47:"mmcrypt\(\$data, \$key, \$iv, \$decrypt = FALSE";i:35;s:13:"fopo\.com\.ar";i:36;s:20:"spravochnik-nomerov-";i:37;s:18:"icq-dlya-telefona-";i:38;s:17:"telefonnaya-baza-";i:39;s:26:"slesh\+slesh\+domen\+point";i:40;s:22:"src="files_site/js\.js";i:41;s:95:"\$t=\$s;\s*\$o\s*=\s*['"]['"];\s*for\(\$i=0;\$i<strlen\(\$t\);\$i\+\+\){\s*\$o\s*\.=\s*\$t{\$i}";i:42;s:80:"WBS_DIR\s*\.\s*['"]{0,1}temp/['"]{0,1}\s*\.\s*\$activeFile\s*\.\s*['"]{0,1}\.tmp";i:43;s:51:"@*mail\(\$mosConfig_mailfrom, \$mosConfig_live_site";i:44;s:66:"\$[a-zA-Z0-9_]+?/\*.{1,10}\*/\s*\.\s*\$[a-zA-Z0-9_]+?/\*.{1,10}\*/";i:45;s:17:"@\$_POST\[\(chr\(";i:46;s:33:"<\?php\s+rename\(['"]wso\.php['"]";i:47;s:52:"\$str=['"]{0,1}<h1>403\s+Forbidden</h1><!--\s*token:";i:48;s:50:"chunk_split\(base64_encode\(fread\(\${\${['"]{0,1}";i:49;s:60:"ini_get\(['"]{0,1}filter\.default_flags['"]{0,1}\)\){foreach";i:50;s:38:"file_get_contents\(trim\(\$f\[\$_GET\[";i:51;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:52;s:54:"if\(isset\(\$_POST\[['"]{0,1}msgsubject['"]{0,1}\]\)\)";i:53;s:35:"base64_decode\(\$_POST\[['"]{0,1}_-";i:54;s:53:"register_shutdown_function\(\s*['"]{0,1}read_ans_code";i:55;s:75:"\$param\s*=\s*\$param\s*x\s*\$n\.substr\s*\(\$param\s*,\s*length\(\$param\)";i:56;s:24:"base['"]{0,1}\.\(32\*2\)";i:57;s:66:"if\(@\$vars\(get_magic_quotes_gpc\(\)\s*\?\s*stripslashes\(\$uri\)";i:58;s:29:"\)\];}if\(isset\(\$_SERVER\[_";i:59;s:42:"if\(empty\(\$_COOKIE\[['"]x['"]\]\)\){echo";i:60;s:52:"is_writable\(\$dir\.['"]wp-includes/version\.php['"]";i:61;s:21:"Apple\s+SpAm\s+ReZulT";i:62;s:17:"#\s*stealth\s*bot";i:63;s:22:"#\s*securityspace\.com";i:64;s:28:"URL=<\?echo\s+\$index;\s+\?>";i:65;s:95:"<script\s+type=['"]{0,1}text/javascript['"]{0,1}\s+src=['"]{0,1}jquery-u\.js['"]{0,1}></script>";i:66;s:57:"create_function\(['"]['"],\s*\$opt\[1\]\s*\.\s*\$opt\[4\]";i:67;s:50:"file_put_contents\(SVC_SELF\s*\.\s*['"]/\.htaccess";i:68;s:51:"\$allemails\s*=\s*@split\("\\n"\s*,\s*\$emaillist\)";i:69;s:18:"Joomla_brute_Force";i:70;s:38:"\$sys_params\s*=\s*@*file_get_contents";i:71;s:35:"fwrite\s*\(\s*\$flw\s*,\s*\$fl\s*\)";i:72;s:86:"file_put_contents\s*\(['"]{0,1}1\.txt['"]{0,1}\s*,\s*print_r\s*\(\s*\$_POST\s*,\s*true";i:73;s:80:"\$headers\s*=\s*\$_(GET|POST|SERVER|COOKIE|REQUEST)\[['"]{0,1}headers['"]{0,1}\]";i:74;s:44:"create_function\s*\(['"]['"]\s*,\s*str_rot13";i:75;s:33:"die\s*\(\s*PHP_OS\s*\.\s*chr\s*\(";i:76;s:55:"if\s*\(md5\(trim\(\$_(GET|POST|SERVER|COOKIE|REQUEST)\[";i:77;s:44:"f\s*=\s*\$q\s*\.\s*\$a\s*\.\s*\$b\s*\.\s*\$x";i:78;s:41:"content=['"]{0,1}1;URL=cgi-bin\.html\?cmd";i:79;s:63:"\$url['"]{0,1}\s*\.\s*\$session_id\s*\.\s*['"]{0,1}/login\.html";i:80;s:64:"\$_SESSION\[['"]{0,1}session_pin['"]{0,1}\]\s*=\s*['"]{0,1}\$PIN";i:81;s:42:"fsockopen\s*\(\s*\$ConnectAddress\s*,\s*25";i:82;s:47:"echo\s+\$ifupload=['"]{0,1}\s*ItsOk\s*['"]{0,1}";i:83;s:77:"preg_match\(['"]/\(yandex\|google\|bot\)/i['"],\s*getenv\(['"]HTTP_USER_AGENT";i:84;s:52:"\$mailer\s*=\s*\$_POST\[['"]{0,1}x_mailer['"]{0,1}\]";i:85;s:57:"\$OOO0O0O00=__FILE__;\s*\$OO00O0000\s*=\s*0x1b540;\s*eval";i:86;s:12:"By\s+WebRooT";i:87;s:80:"header\(['"]{0,1}s:\s*['"]{0,1}\s*\.\s*php_uname\s*\(\s*['"]{0,1}n['"]{0,1}\s*\)";i:88;s:73:"move_uploaded_file\(\$_FILES\[['"]{0,1}elif['"]{0,1}\]\[['"]{0,1}tmp_name";i:89;s:62:"\$gzip\s*=\s*@*gzinflate\s*\(\s*@*substr\s*\(\s*\$gzencode_arg";i:90;s:83:"if\s*\(\s*mail\s*\(\s*\$mails\[\$i\]\s*,\s*\$tema\s*,\s*base64_encode\s*\(\s*\$text";i:91;s:84:"fwrite\s*\(\s*\$fh\s*,\s*stripslashes\s*\(\s*@*\$_(GET|POST|SERVER|COOKIE|REQUEST)\[";i:92;s:94:"echo\s+file_get_contents\s*\(\s*base64_url_decode\s*\(\s*@*\$_(GET|POST|SERVER|COOKIE|REQUEST)";i:93;s:60:"if\s*\(\s*@*md5\s*\(\s*\$_(GET|POST|SERVER|COOKIE|REQUEST)\[";i:94;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:95;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:96;s:75:"\$resultFUL\s*=\s*stripcslashes\s*\(\s*\$_POST\[['"]{0,1}resultFUL['"]{0,1}";i:97;s:15:"/usr/sbin/httpd";i:98;s:32:"PRIVMSG\.\*:\.owner\\s\+\(\.\*\)";i:99;s:83:"print\s+\$sock\s+['"]{0,1}NICK ['"]{0,1}\s+\.\s+\$nick\s+\.\s+['"]{0,1}\\n['"]{0,1}";i:100;s:80:"\$url\s*=\s*\$url\s*\.\s*['"]{0,1}\?['"]{0,1}\s*\.\s*http_build_query\(\$query\)";i:101;s:123:"preg_match_all\(['"]{0,1}/<a href="\\/url\\\?q=\(\.\+\?\)\[&\|"\]\+/is['"]{0,1}, \$page\[['"]{0,1}exe['"]{0,1}\], \$links\)";i:102;s:101:"<script\s+language=['"]{0,1}JavaScript['"]{0,1}>\s*parent\.window\.opener\.location\s*=\s*['"]http://";i:103;s:77:"\$p\s*=\s*strpos\s*\(\s*\$tx\s*,\s*['"]{0,1}{#['"]{0,1}\s*,\s*\$p2\s*\+\s*2\)";i:104;s:15:"\(msie\|opera\)";i:105;s:49:"RewriteCond\s*%{HTTP_USER_AGENT}\s*\.\*ndroid\.\*";i:106;s:99:"if\s*\(\s*is_dir\s*\(\s*\$FullPath\s*\)\s*\)\s*AllDir\s*\(\s*\$FullPath\s*,\s*\$Files\s*\);\s*}\s*}";i:107;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:108;s:53:"<!--#exec\s+cmd=['"]{0,1}\$HTTP_ACCEPT['"]{0,1}\s*-->";i:109;s:26:"\[-\]\s+Connection\s+faild";i:110;s:63:"if\(/\^\\:\$owner!\.\*\\@\.\*PRIVMSG\.\*:\.msgflood\(\.\*\)/\){";i:111;s:34:"print\s*\$sock "PRIVMSG "\.\$owner";i:112;s:64:"\]=['"]{0,1}ip['"]{0,1}\s*;\s*if\s*\(\s*isset\s*\(\s*\$_SERVER\[";i:113;s:51:"\]\s*}\s*=\s*trim\s*\(\s*array_pop\s*\(\s*\${\s*\${";i:114;s:30:"print\("#\s+info\s+OK\\n\\n"\)";i:115;s:112:"\$user_agent\s*=\s*preg_replace\s*\(\s*['"]\|User\\\.Agent\\:\[\\s \]\?\|i['"]\s*,\s*['"]['"]\s*,\s*\$user_agent";i:116;s:71:"\$p\s*=\s*strpos\(\$tx\s*,\s*['"]{0,1}{#['"]{0,1}\s*,\s*\$p2\s*\+\s*2\)";i:117;s:92:"create_function\s*\(\s*['"]\$m['"]\s*,\s*['"]if\s*\(\s*\$m\s*\[\s*0x01\s*\]\s*==\s*['"]L['"]";i:118;s:89:"\$letter\s*=\s*str_replace\s*\(\s*\$ARRAY\[0\]\[\$j\]\s*,\s*\$arr\[\$ind\]\s*,\s*\$letter";i:119;s:9:"IrIsT\.Ir";i:120;s:46:"if\s*\(detect_mobile_device\(\)\)\s*{\s*header";i:121;s:32:"\$post\s*=\s*['"]\\x77\\x67\\x65";i:122;s:27:"echo\s*['"]answer=error['"]";i:123;s:34:"url=<\?php\s*echo\s*\$rand_url;\?>";i:124;s:45:"if\(CheckIPOperator\(\)\s*&&\s*!isModem\(\)\)";i:125;s:59:"strpos\(\$ua,\s*['"]{0,1}yandexbot['"]{0,1}\)\s*!==\s*false";i:126;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:127;s:52:"echo['"]{0,1}<center><b>Done\s*==>\s*\$userfile_name";i:128;s:15:"['"]e/\*\./['"]";i:129;s:28:"assert\s*\(\s*@*stripslashes";i:130;s:51:"\)\s*\.\s*substr\s*\(\s*md5\s*\(\s*strrev\s*\(\s*\$";i:131;s:65:"\$fl\s*=\s*"<meta http-equiv=\\"Refresh\\"\s+content=\\"0;\s*URL=";i:132;s:90:",\s*array\s*\('\.','\.\.','Thumbs\.db'\)\s*\)\s*\)\s*{\s*continue;\s*}\s*if\s*\(\s*is_file";i:133;s:83:"if\s*\(\s*\$dataSize\s*<\s*BOTCRYPT_MAX_SIZE\s*\)\s*rc4\s*\(\s*\$data,\s*\$cryptkey";i:134;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:135;s:99:"if\s*\(\s*fwrite\s*\(\s*\$handle\s*,\s*file_get_contents\s*\(\s*\$_(GET|POST|SERVER|COOKIE|REQUEST)";i:136;s:89:"array_key_exists\s*\(\s*\$fileRas\s*,\s*\$fileType\)\s*\?\s*\$fileType\[\s*\$fileRas\s*\]";i:137;s:65:"urlencode\(print_r\(array\(\),1\)\),5,1\)\.c\),\$c\);}eval\(\$d\)";i:138;s:44:"if\s*\(\s*function_exists\s*\(\s*'pcntl_fork";i:139;s:43:"find\s+/\s+-type\s+f\s+-perm\s+-04000\s+-ls";i:140;s:71:"execl\(['"]/bin/sh['"]\s*,\s*['"]/bin/sh['"]\s*,\s*['"]-i['"]\s*,\s*0\)";i:141;s:41:"function\s+inject\(\$file,\s*\$injection=";i:142;s:38:"fclose\(\$f\);\s*echo\s*['"]o\.k\.['"]";i:143;s:92:"preg_replace\s*\(\s*\$exif\[\s*\\['"]Make\\['"]\s*\]\s*,\s*\$exif\[\s*\\['"]Model\\['"]\s*\]";i:144;s:72:"\^downloads/\(\[0-9\]\*\)/\(\[0-9\]\*\)/\$\s+downloads\.php\?c=\$1&p=\$2";i:145;s:81:"\$res=mysql_query\(['"]{0,1}SELECT\s+\*\s+FROM\s+`watchdog_old_05`\s+WHERE\s+page";i:146;s:52:"RewriteRule\s+\.\*\s+index\.php\?url=\$0\s+\[L,QSA\]";i:147;s:100:"IO::Socket::INET->new\(Proto\s*=>\s*"tcp"\s*,\s*LocalPort\s*=>\s*36000\s*,\s*Listen\s*=>\s*SOMAXCONN";i:148;s:39:"eval\s*\(*\s*strrev\s*\(*\s*str_replace";i:149;s:213:"@*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:150;s:82:"\$URL\s*=\s*\$urls\[\s*rand\(\s*0\s*,\s*count\s*\(\s*\$urls\s*\)\s*-\s*1\s*\)\s*\]";i:151;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:152;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:153;s:70:"file_get_contents\s*\(*\s*ADMIN_REDIR_URL\s*,\s*false\s*,\s*\$ctx\s*\)";i:154;s:12:"tmhapbzcerff";i:155;s:97:"content=['"]{0,1}no-cache['"]{0,1};\s*\$config\[['"]{0,1}description['"]{0,1}\]\s*\.=\s*['"]{0,1}";i:156;s:74:"clearstatcache\(\s*\);\s*if\s*\(\s*!is_dir\s*\(\s*\$fld\s*\)\s*\)\s*return";i:157;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:158;s:9:"IrSecTeam";i:159;s:73:"@header\(['"]Location:\s*['"]\.['"]h['"]\.['"]t['"]\.['"]t['"]\.['"]p['"]";i:160;s:67:"set_time_limit\s*\(\s*0\s*\);\s*if\s*\(!SecretPageHandler::checkKey";i:161;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:162;s:75:"time\(\)\s*\+\s*10000\s*,\s*['"]/['"]\);\s*echo\s+\$m_zz;\s*eval\s*\(\$m_zz";i:163;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:164;s:47:"str_rot13\s*\(\s*gzinflate\s*\(\s*base64_decode";i:165;s:50:"gzuncompress\s*\(\s*str_rot13\s*\(\s*base64_decode";i:166;s:50:"gzuncompress\s*\(\s*base64_decode\s*\(\s*str_rot13";i:167;s:61:"gzinflate\s*\(\s*base64_decode\s*\(\s*str_rot13\s*\(\s*strrev";i:168;s:61:"gzinflate\s*\(\s*base64_decode\s*\(\s*strrev\s*\(\s*str_rot13";i:169;s:44:"gzinflate\s*\(\s*base64_decode\s*\(\s*strrev";i:170;s:68:"gzinflate\s*\(\s*base64_decode\s*\(\s*base64_decode\s*\(\s*str_rot13";i:171;s:54:"base64_decode\s*\(\s*gzuncompress\s*\(\s*base64_decode";i:172;s:47:"gzinflate\s*\(\s*base64_decode\s*\(\s*str_rot13";i:173;s:47:"gzinflate\s*\(\s*str_rot13\s*\(\s*base64_decode";i:174;s:17:"Brazil\s+HackTeam";i:175;s:60:"\$tld\s*=\s*array\s*\(\s*['"]com['"],['"]org['"],['"]net['"]";i:176;s:45:"define\s*\(*\s*['"]SBCID_REQUEST_FILE['"]\s*,";i:177;s:34:"preg_replace\s*\(*\s*['"]/\.\+/esi";i:178;s:17:"Mysterious\s+Wire";i:179;s:51:"\$headers\s*\.=\s*\$_POST\[\s*['"]eMailAdd['"]\s*\]";i:180;s:33:"define\s*\(\s*['"]DEFCALLBACKMAIL";i:181;s:47:"default_action\s*=\s*['"]{0,1}FilesMan['"]{0,1}";i:182;s:38:"echo\s+@file_get_contents\s*\(\s*\$get";i:183;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:184;s:60:"header\s*\(['"]Location:\s*['"]\s*\.\s*\$to\s*\.\s*urldecode";i:185;s:10:"Dc0RHa['"]";i:186;s:36:"!touch\(['"]{0,1}\.\./\.\./language/";i:187;s:38:"eval\(\s*stripslashes\(\s*\\\$_REQUEST";i:188;s:78:"document\.write\s*\(\s*['"]{0,1}<script\s+src=['"]{0,1}http://<\?=\$domain\?>/";i:189;s:85:"exit\s*\(\s*['"]{0,1}<script>\s*setTimeout\s*\(\s*\\['"]{0,1}document\.location\.href";i:190;s:25:"function\s+sql2_safe\s*\(";i:191;s:41:"\$postResult\s*=\s*curl_exec\s*\(*\s*\$ch";i:192;s:87:"&&\s*function_exists\s*\(*\s*['"]{0,1}getmxrr['"]{0,1}\)\s*\)\s*{\s*@getmxrr\s*\(*\s*\$";i:193;s:57:"is__writable\s*\(*\s*\$path\s*\.\s*uniqid\s*\(*\s*mt_rand";i:194;s:28:"file_put_contentz\s*\(*\s*\$";i:195;s:55:"@*gzinflate\s*\(\s*@*base64_decode\s*\(\s*@*str_replace";i:196;s:105:"fopen\s*\(*\s*['"]http://['"]\s*\.\s*\$check_domain\s*\.\s*['"]:80['"]\s*\.\s*\$check_doc\s*,\s*['"]r['"]";i:197;s:43:"@\$_COOKIE\[['"]{0,1}statCounter['"]{0,1}\]";i:198;s:35:"if\s*\(*\s*@*preg_match\s*\(*\s*str";i:199;s:94:"array_pop\s*\(*\s*\$workReplace\s*,\s*\$_(GET|POST|SERVER|COOKIE|REQUEST)\s*,\s*\$countKeysNew";i:200;s:54:"(GET|POST|SERVER|COOKIE|REQUEST)\s*\[\s*['"]___['"]\s*";i:201;s:23:"\(\s*['"]INSHELL['"]\s*";i:202;s:47:"\$b\s*\.\s*\$p\s*\.\s*\$h\s*\.\s*\$k\s*\.\s*\$v";i:203;s:88:"=\s*preg_split\s*\(\s*['"]/\\,\(\\ \+\)\?/['"],\s*@*ini_get\s*\(\s*['"]disable_functions";i:204;s:101:"if\s*\(!function_exists\s*\(\s*['"]posix_getpwuid['"]\s*\)\s*&&\s*!in_array\s*\(\s*['"]posix_getpwuid";i:205;s:123:"preg_replace\s*\(\s*['"]/\^\(www\|ftp\)\\\./i['"]\s*,\s*['"]['"],\s*@\$_SERVER\s*\[\s*['"]{0,1}HTTP_HOST['"]{0,1}\s*\]\s*\)";i:206;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:207;s:81:"eval\s*\(*\s*stripslashes\s*\(*\s*array_pop\(*\$_(GET|POST|SERVER|COOKIE|REQUEST)";i:208;s:139:"if\s+\(\s*strpos\s*\(\s*\$url\s*,\s*['"]js/mootools\.js['"]\s*\)\s*===\s*false\s+&&\s+strpos\s*\(\s*\$url\s*,\s*['"]js/caption\.js['"]{0,1}";i:209;s:68:"if\s+\(*\s*mail\s*\(\s*\$recp\s*,\s*\$subj\s*,\s*\$stunt\s*,\s*\$frm";i:210;s:43:"<\?php\s+\$_F\s*=\s*__FILE__\s*;\s*\$_X\s*=";i:211;s:79:"\$x\d+\s*=\s*['"].+?['"]\s*;\s*\$x\d+\s*=\s*['"].+?['"]\s*;\s*\$x\d+\s*=\s*['"]";i:212;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:213;s:101:"\$GLOBALS\[\s*['"]{0,1}.+?['"]{0,1}\s*\]\[\s*\d+\s*\]\(\s*\$_\d+\s*,\s*_\d+\s*\(\s*\d+\s*\)\s*\)\s*\)";i:214;s:73:"preg_replace\s*\(*\s*['"]{0,1}/\.\*\[.+?\]\?/e['"]{0,1}\s*,\s*str_replace";i:215;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:216;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:217;s:66:"isset\s*\(*\s*\$_POST\s*\[\s*['"]{0,1}execgate['"]{0,1}\s*\]\s*\)*";i:218;s:71:"fwrite\s*\(*\s*\$fpsetv\s*,\s*getenv\s*\(\s*['"]HTTP_COOKIE['"]\s*\)\s*";i:219;s:26:"symlink\s*\(*\s*['"]/home/";i:220;s:70:"function\s+urlGetContents\s*\(*\s*\$url\s*,\s*\$timeout\s*=\s*\d+\s*\)";i:221;s:49:"strrev\(*\s*['"]{0,1}edoced_46esab['"]{0,1}\s*\)*";i:222;s:42:"strrev\(*\s*['"]{0,1}tressa['"]{0,1}\s*\)*";i:223;s:20:"exec\s*\(\s*['"]ipfw";i:224;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:225;s:112:"file_get_contents\s*\(*\s*trim\s*\(\s*\$.+?\[\$_(GET|POST|SERVER|COOKIE|REQUEST)\[['"]{0,1}.+?['"]{0,1}\]\]\)\);";i:226;s:213:"is_callable\s*\(*\s*['"]{0,1}(ftp_exec|system|shell_exec|passthru|popen|proc_open)['"]{0,1}\)*\s+and\s+!in_array\s*\(*\s*['"]{0,1}(ftp_exec|system|shell_exec|passthru|popen|proc_open)['"]{0,1}\s*,\s*\$disablefuncs";i:227;s:24:"\$GLOBALS\[['"]{0,1}____";i:228;s:43:"fopen\s*\(*\s*['"]{0,1}/etc/passwd['"]{0,1}";i:229;s:59:"eval\s*\(*@*\s*stripslashes\s*\(*\s*array_pop\s*\(*\s*@*\$_";i:230;s:41:"eval\s*\(*@*\s*stripslashes\s*\(*\s*@*\$_";i:231;s:74:"@*setcookie\s*\(*\s*['"]{0,1}hit['"]{0,1},\s*1\s*,\s*time\s*\(*\s*\)*\s*\+";i:232;s:36:"eval\s*\(*\s*file_get_contents\s*\(*";i:233;s:46:"preg_replace\s*\(*\s*['"]{0,1}/\.\*/e['"]{0,1}";i:234;s:81:"\s*{\s*\$_(GET|POST|SERVER|COOKIE|REQUEST)\s*\[\s*['"]{0,1}root['"]{0,1}\s*\]\s*}";i:235;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:236;s:33:"proc_open\s*\(\s*['"]{0,1}IHSteam";i:237;s:88:"\$ini\s*\[\s*['"]{0,1}users['"]{0,1}\s*\]\s*=\s*array\s*\(\s*['"]{0,1}root['"]{0,1}\s*=>";i:238;s:88:"curl_setopt\s*\(\s*\$ch\s*,\s*CURLOPT_URL\s*,\s*['"]{0,1}http://\$host:\d+['"]{0,1}\s*\)";i:239;s:45:"system\s*\(*\s*['"]{0,1}whoami['"]{0,1}\s*\)*";i:240;s:52:"find\s+/\s+-name\s+\.ssh\s+>\s+\$dir/sshkeys/sshkeys";i:241;s:52:"assert\s*\(*\s*@*\$_(GET|POST|SERVER|COOKIE|REQUEST)";i:242;s:50:"eval\s*\(*\s*@*\$_(GET|POST|SERVER|COOKIE|REQUEST)";i:243;s:25:"php\s+"\s*\.\s*\$wso_path";i:244;s:89:"@*assert\s*\(*\s*\$_(GET|POST|SERVER|COOKIE|REQUEST)\s*\[\s*['"]{0,1}.+?['"]{0,1}\s*\]\s*";i:245;s:21:"eva1[a-zA-Z0-9_]+?Sir";i:246;s:93:"\$cmd\s*=\s*\(\s*@*\$_(GET|POST|SERVER|COOKIE|REQUEST)\s*\[\s*['"]{0,1}.+?['"]{0,1}\s*\]\s*\)";i:247;s:96:"\$function\s*\(*\s*@*\$_(GET|POST|SERVER|COOKIE|REQUEST)\s*\[\s*['"]{0,1}cmd['"]{0,1}\s*\]\s*\)*";i:248;s:23:"\$fe\("\$cmd\s+2>&1"\);";i:249;s:141:"(ftp_exec|system|shell_exec|passthru|popen|proc_open)\(['"]\$cmd\s+1>\s*/tmp/cmdtemp\s+2>&1;\s*cat\s+/tmp/cmdtemp;\s*rm\s+/tmp/cmdtemp['"]\);";i:250;s:53:"setcookie\(*\s*['"]mysql_web_admin_username['"]\s*\)*";i:251;s:86:"(ftp_exec|system|shell_exec|passthru|popen|proc_open)\s*\(*\s*['"]uname\s+-a['"]\s*\)*";i:252;s:124:"(ftp_exec|system|shell_exec|passthru|popen|proc_open)\s*\(*\s*@*\$_POST\s*\[\s*['"].+?['"]\s*\]\s*\.\s*"\s*2\s*>\s*&1\s*['"]";i:253;s:49:"!@*\$_REQUEST\s*\[\s*['"]c99sh_surl['"]\s*\]\s*\)";i:254;s:37:"\$login\s*=\s*@*posix_getuid\(*\s*\)*";i:255;s:31:"ncftpput\s*-u\s*\$ftp_user_name";i:256;s:82:"runcommand\s*\(\s*['"]shellhelp['"]\s*,\s*['"](GET|POST|SERVER|COOKIE|REQUEST)['"]";i:257;s:55:"{\s*\$\s*{\s*passthru\s*\(*\s*\$cmd\s*\)\s*}\s*}\s*<br>";i:258;s:58:"passthru\s*\(*\s*getenv\s*\(*\s*\\['"]HTTP_ACCEPT_LANGUAGE";i:259;s:56:"passthru\s*\(*\s*getenv\s*\(*\s*['"]HTTP_ACCEPT_LANGUAGE";i:260;s:87:"SELECT\s+1\s+FROM\s+mysql\.user\s+WHERE\s+concat\(\s*`user`\s*,\s*'@'\s*,\s*`host`\s*\)";i:261;s:97:"\$MessageSubject\s*=\s*base64_decode\s*\(\s*\$_POST\s*\[\s*['"]{0,1}msgsubject['"]{0,1}\s*\]\s*\)";i:262;s:47:"rename\s*\(\s*\s*['"]{0,1}wso\.php['"]{0,1}\s*,";i:263;s:74:"filepath\s*=\s*@*realpath\s*\(\s*\$_POST\s*\[\s*['"]filepath['"]\s*\]\s*\)";i:264;s:78:"filepath\s*=\s*@*realpath\s*\(\s*\$_POST\s*\[\s*\\['"]filepath\\['"]\s*\]\s*\)";i:265;s:40:"eval\s*\(*\s*base64_decode\s*\(*\s*@*\$_";i:266;s:107:"wsoEx\s*\(\s*\\['"]\s*tar\s*cfzv\s*\\['"]\s*\.\s*escapeshellarg\s*\(\s*\$_POST\[\s*\\['"]p2\\['"]\s*\]\s*\)";i:267;s:74:"WSOsetcookie\s*\(\s*md5\s*\(\s*@*\$_SERVER\[\s*['"]HTTP_HOST['"]\s*\]\s*\)";i:268;s:78:"WSOsetcookie\s*\(\s*md5\s*\(\s*@*\$_SERVER\[\s*\\['"]HTTP_HOST\\['"]\s*\]\s*\)";i:269;s:170:"\$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:270;s:35:"default_action\s*=\s*\\['"]FilesMan";i:271;s:33:"system\s+file\s+do\s+not\s+delete";i:272;s:19:"hacked\s+by\s+Hmei7";i:273;s:11:"by\s+Grinay";i:274;s:23:"Captain\s+Crunch\s+Team";i:275;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("a:252:{i:0;s:22:"disable_functions=NONE";i:1;s:21:"&_SESSION\[payload\]=";i:2;s:26:"<\?\s*=@`\$[a-zA-Z0-9_]+?`";i:3;s:16:"PHPSHELL_VERSION";i:4;s:69:"touch\(\s*\$_SERVER\[\s*['"]DOCUMENT_ROOT['"]\s*\]\s*\.\s*['"]/engine";i:5;s:81:"file_get_contents\(\s*\$_SERVER\[\s*['"]DOCUMENT_ROOT['"]\s*\]\s*\.\s*['"]/engine";i:6;s:56:"@\$_SERVER\[\s*HTTP_HOST\s*\]>['"]\s*\.\s*['"]\\r\\n['"]";i:7;s:71:"trim\(\s*\$headers\s*\)\s*\)\s*as\s*\$header\s*\)\s*header\(\s*\$header";i:8;s:16:"Coded\s+by\s+EXE";i:9;s:12:"By\s+WebRooT";i:10;s:20:"header\s*\(\s*_\d+\(";i:11;s:41:"if\s*\(function_exists\(\s*['"]pcntl_fork";i:12;s:29:"do_work\(\s*\$index_file\s*\)";i:13;s:83:"\$id\s*\.\s*['"]\?d=['"]\s*\.\s*base64_encode\(\s*\$_SERVER\[\s*['"]HTTP_USER_AGENT";i:14;s:25:"new\s+conectBase\(['"]aHR";i:15;s:90:"file_get_contents\(ROOT_DIR\.['"]/templates/['"]\.\$config\[['"]skin['"]\]\.['"]/main\.tpl";i:16;s:59:"%<!--\\s\*\$marker\\s\*-->\.\+\?<!--\\s\*/\$marker\\s\*-->%";i:17;s:24:"function\s+getfirstshtag";i:18;s:18:"resultsign_warning";i:19;s:29:"file_exists\(\s*\$FileBazaTXT";i:20;s:19:"==\s*['"]cshell['"]";i:21;s:61:"\$_SERVER\[['"]{0,1}REMOTE_ADDR['"]{0,1}\];if\(\(preg_match\(";i:22;s:67:"\$file_for_touch\s*=\s*\$_SERVER\[['"]{0,1}DOCUMENT_ROOT['"]{0,1}\]";i:23;s:23:"\$index_path\s*,\s*0404";i:24;s:30:"read_file_new_2\(\$result_path";i:25;s:38:"chr\(\s*hexdec\(\s*substr\(\s*\$makeup";i:26;s:27:"\d+&@preg_match\(\s*strtr\(";i:27;s:75:"value=['"]<\?\s+(ftp_exec|system|shell_exec|passthru|popen|proc_open)\(['"]";i:28;s:18:"Academico\s+Result";i:29;s:30:"SELECT\s+\*\s+FROM\s+dor_pages";i:30;s:41:"g_delete_on_exit\s*=\s*new\s+DeleteOnExit";i:31;s:52:"if\(preg_match\(['"]#wordpress_logged_in\|admin\|pwd";i:32;s:50:"['"]\.['"]['"]\.['"]['"]\.['"]['"]\.['"]['"]\.['"]";i:33;s:28:"\);function\s+string_cpt\(\$";i:34;s:28:"\$setcook\);setcookie\(\$set";i:35;s:35:"<loc><\?php\s+echo\s+\$current_url;";i:36;s:40:"\$bannedIP\s*=\s*array\(\s*['"]\^66\.102";i:37;s:62:"\$result=smartCopy\(\s*\$source\s*\.\s*['"]/['"]\s*\.\s*\$file";i:38;s:38:"\$fill = \$_COOKIE\[\\['"]fill\\['"]\]";i:39;s:83:"if\(['"]substr_count\(['"]\$_SERVER\[['"]REQUEST_URI['"]\]\s*,\s*['"]query\.php['"]";i:40;s:85:"if\(\s*\$_GET\[\s*['"]id['"]\s*\]!=\s*['"]['"]\s*\)\s*\$id=\$_GET\[\s*['"]id['"]\s*\]";i:41;s:22:"<a\s+href=['"]oshibka-";i:42;s:76:"(ftp_exec|system|shell_exec|passthru|popen|proc_open)\(\s*['"]cd\s+/tmp;wget";i:43;s:55:"getprotobyname\(\s*['"]tcp['"]\s*\)\s+\|\|\s+die\s+shit";i:44;s:47:"file_put_contents\(\s*\$index_path\s*,\s*\$code";i:45;s:66:",\s*['"]/index\\\.\(php\|html\)/i['"]\s*,\s*RecursiveRegexIterator";i:46;s:13:"AOL\s+Details";i:47;s:20:"tHANKs\s+tO\s+Snoppy";i:48;s:20:"Masr1\s+Cyb3r\s+Te4m";i:49;s:18:"Us3\s+Y0ur\s+br41n";i:50;s:20:"Masri\s+Cyber\s+Team";i:51;s:49:"fwrite\(\$fp\s*,\s*strrev\(\s*\$context\s*\)\s*\)";i:52;s:9:"/pmt/rav/";i:53;s:34:"file_get_contents\(\s*['"]/var/tmp";i:54;s:23:"\$in_Perms\s+&\s+0x4000";i:55;s:43:"fopen\(\s*\$root_dir\s*\.\s*['"]/\.htaccess";i:56;s:62:"int32\(\(\(\$z\s*>>\s*5\s*&\s*0x07ffffff\)\s*\^\s*\$y\s*<<\s*2";i:57;s:35:"<guid><\?php\s+echo\s+\$current_url";i:58;s:19:"-klych-k-igre\.html";i:59;s:66:"<div\s+id=['"]link1['"]><button onclick=['"]processTimer\(\);['"]>";i:60;s:11:"scopbin['"]";i:61;s:14:"-Apple_Result-";i:62;s:47:"tar\s+-czf\s+"\s*\.\s*\$FORM{tar}\s*\.\s*"\.tar";i:63;s:14:"CVV2:\s*\$CVV2";i:64;s:63:"\$CVV2C\s*=\s*\$_(GET|POST|SERVER|COOKIE|REQUEST)\[\s*['"]CVV2C";i:65;s:75:"fwrite\(\s*\$f\s*,\s*get_download\(\s*\$_(GET|POST|SERVER|COOKIE|REQUEST)\[";i:66;s:33:"\[\]\s*=\s*['"]RewriteEngine\s+on";i:67;s:98:"substr\(\s*\$string2\s*,\s*strlen\(\s*\$string2\s*\)\s*-\s*9\s*,\s*9\)\s*==\s*['"]{0,1}\[l,r=302\]";i:68;s:13:"=by\s+DRAGON=";i:69;s:40:"__file_get_url_contents\(\s*\$remote_url";i:70;s:82:"\$URL\s*=\s*\$urls\[\s*rand\(\s*0\s*,\s*count\(\s*\$urls\s*\)\s*-\s*1\)\s*\]\.rand";i:71;s:49:"mail\(\s*\$retorno\s*,\s*\$asunto\s*,\s*\$mensaje";i:72;s:78:"call_user_func\(\s*['"]action['"]\s*\.\s*\$_(GET|POST|SERVER|COOKIE|REQUEST)\[";i:73;s:35:"file_exists\(\s*['"]/tmp/tmp-server";i:74;s:27:"\(['"]\$tmpdir/sess_fc\.log";i:75;s:52:"touch\(\s*['"]{0,1}\$basepath/components/com_content";i:76;s:46:"=\$file\(@*\$_(GET|POST|SERVER|COOKIE|REQUEST)";i:77;s:72:"send_smtp\(\s*\$email\[['"]{0,1}adr['"]{0,1}\]\s*,\s*\$subj\s*,\s*\$text";i:78;s:34:"__LINK__<a\s+href=['"]{0,1}http://";i:79;s:44:"scripts\[\s*gzuncompress\(\s*base64_decode\(";i:80;s:78:"!file_put_contents\(\s*\$dbname\s*,\s*\$this->getImageEncodedText\(\s*\$dbname";i:81;s:117:"\$content\s*=\s*http_request\(['"]{0,1}http://['"]{0,1}\s*\.\s*\$_SERVER\[['"]{0,1}SERVER_NAME['"]{0,1}\]\.['"]{0,1}/";i:82;s:60:"mail\(\s*\$MailTo\s*,\s*\$MessageSubject\s*,\s*\$MessageBody";i:83;s:36:"file_put_contents\(\s*['"]{0,1}/home";i:84;s:70:"mail\(\s*\$a\[\d+\]\s*,\s*\$a\[\d+\]\s*,\s*\$a\[\d+\]\s*,\s*\$a\[\d+\]";i:85;s:23:"is_writable=is_writable";i:86;s:23:"exploit-db\.com/search/";i:87;s:14:"David\s*Blaine";i:88;s:33:"crontab\s+-l\|grep\s+-v\s+crontab";i:89;s:80:"(ftp_exec|system|shell_exec|passthru|popen|proc_open)\(\s*['"]{0,1}at\s+now\s+-f";i:90;s:63:"#!/bin/shncd\s+['"]{0,1}['"]{0,1}\.\$SCP\.['"]{0,1}['"]{0,1}nif";i:91;s:44:"file_put_contents\(['"]{0,1}\./libworker\.so";i:92;s:36:"\$user_agent_to_filter\s*=\s*array\(";i:93;s:20:"fopen\(\s*['"]/home/";i:94;s:20:"mkdir\(\s*['"]/home/";i:95;s:39:"#Use['"]{0,1}\s*,\s*file_get_contents\(";i:96;s:29:"eregi\(\s*sql_regcase\(\s*\$_";i:97;s:71:"\$_\[\s*\d+\s*\]\(\s*\$_\[\s*\d+\s*\]\(\$_\[\s*\d+\s*\]\(\s*\$_\[\s*\d+";i:98;s:36:"eval\(\s*\$[a-zA-Z0-9_]+?\(\s*\$<amc";i:99;s:33:"@\$func\(\$cfile, \$cdir\.\$cname";i:100;s:62:"uname\]['"]{0,1}\s*\.\s*php_uname\(\)\s*\.\s*['"]{0,1}\[/uname";i:101;s:54:"\$GLOBALS\[['"]{0,1}[a-zA-Z0-9_]+?['"]{0,1}\]\(\s*NULL";i:102;s:23:"__url_get_contents\(\$l";i:103;s:26:"\$dor_content=preg_replace";i:104;s:73:"(ftp_exec|system|shell_exec|passthru|popen|proc_open)\(['"]ls\s+/var/mail";i:105;s:30:"header\(['"]{0,1}r:\s*no\s+com";i:106;s:48:"preg_match_all\(\s*['"]\|\(\.\*\)<\\!-- js-tools";i:107;s:37:"if\s*\(\s*ini_get\(['"]{0,1}safe_mode";i:108;s:49:"@*file_put_contents\(\s*\$this->file\s*,\s*strrev";i:109;s:41:"/plugins/search/query\.php\?____pgfa=http";i:110;s:91:"mail\(\s*stripslashes\(\$to\)\s*,\s*stripslashes\(\$subject\)\s*,\s*stripslashes\(\$message";i:111;s:85:"\$_(GET|POST|SERVER|COOKIE|REQUEST)\[['"]{0,1}ur['"]{0,1}\]\)\)\s*\$mode\s*\|=\s*0400";i:112;s:82:"ereg_replace\(['"]{0,1}%5C%22['"]{0,1}\s*,\s*['"]{0,1}%22['"]{0,1}\s*,\s*\$message";i:113;s:88:"file_put_contents\(\s*\$name\s*,\s*base64_decode\(\s*\$_(GET|POST|SERVER|COOKIE|REQUEST)";i:114;s:122:"window\.location=b}\s*\)\(\s*navigator\.userAgent\s*\|\|\s*navigator\.vendor\s*\|\|\s*window\.opera\s*,\s*['"]{0,1}http://";i:115;s:89:"\$sape_option\[\s*['"]{0,1}fetch_remote_type['"]{0,1}\s*\]\s*=\s*['"]{0,1}socket['"]{0,1}";i:116;s:105:"\$path\s*=\s*\$_SERVER\[\s*['"]{0,1}DOCUMENT_ROOT['"]{0,1}\s*\]\s*\.\s*['"]{0,1}/images/stories/['"]{0,1}";i:117;s:82:"@*array_diff_ukey\(\s*@*array\(\s*\(string\)\s*\$_(GET|POST|SERVER|COOKIE|REQUEST)";i:118;s:20:"eval\s*\(\s*TPL_FILE";i:119;s:38:"JResponse::setBody\s*\(\s*preg_replace";i:120;s:48:"\s*['"]{0,1}slurp['"]{0,1}\s*,\s*['"]{0,1}msnbot";i:121;s:54:"\s*['"]{0,1}rookee['"]{0,1}\s*,\s*['"]{0,1}webeffector";i:122;s:11:"Coupdegrace";i:123;s:12:"SultanHaikal";i:124;s:60:"file_get_contents\(basename\(\$_SERVER\[['"]{0,1}SCRIPT_NAME";i:125;s:27:"https://appleid\.apple\.com";i:126;s:19:"\$bkeyword_bez=['"]";i:127;s:34:"crc32\(\s*\$_POST\[\s*['"]{0,1}cmd";i:128;s:19:"grep\s+-v\s+crontab";i:129;s:28:"['"]['"]\s*\.\s*gzUncoMpreSs";i:130;s:29:"['"]['"]\s*\.\s*BAse64_deCoDe";i:131;s:32:"eval\(['"]\?>['"]\.base64_decode";i:132;s:27:"curl_init\(\s*base64_decode";i:133;s:12:"milw0rm\.com";i:134;s:45:"\$file\(@*\$_(GET|POST|SERVER|COOKIE|REQUEST)";i:135;s:36:"return\s+base64_decode\(\$a\[\$i\]\)";i:136;s:8:"HarchaLi";i:137;s:60:"plugins/search/query\.php\?____pgfa=http%3A%2F%2Fwww\.google";i:138;s:36:"create_function\(substr\(2,1\),\$s\)";i:139;s:81:"typeof\s*\(dle_admin\)\s*==\s*['"]{0,1}undefined['"]{0,1}\s*\|\|\s*dle_admin\s*==";i:140;s:32:"\[\$o\]\);\$o\+\+\){if\(\$o<16\)";i:141;s:32:"\$S\[\$i\+\+\]\(\$S\[\$i\+\+\]\(";i:142;s:37:"setcookie\(\s*\$z\[0\]\s*,\s*\$z\[1\]";i:143;s:86:"/index\.php\?option=com_jce&task=plugin&plugin=imgmanager&file=imgmanager&version=1576";i:144;s:15:"catatan\s+situs";i:145;s:41:"if\(\s*isset\(\s*\$_REQUEST\[['"]{0,1}cid";i:146;s:40:"str_replace\s*\(\s*['"]{0,1}/public_html";i:147;s:51:"@array\(\s*\(string\)\s*stripslashes\(\s*\$_REQUEST";i:148;s:60:"if\s*\(\s*file_put_contents\s*\(\s*\$index_path\s*,\s*\$code";i:149;s:94:"if\(is_dir\(\$path\.['"]{0,1}/wp-content['"]{0,1}\)\s+AND\s+is_dir\(\$path\.['"]{0,1}/wp-admin";i:150;s:28:"if\(\$o<16\){\$h\[\$e\[\$o\]";i:151;s:9:"by\s+g00n";i:152;s:15:"Auto\s*Xploiter";i:153;s:102:"(ftp_exec|system|shell_exec|passthru|popen|proc_open)\(['"]{0,1}\$_(GET|POST|SERVER|COOKIE|REQUEST)\["";i:154;s:72:"(ftp_exec|system|shell_exec|passthru|popen|proc_open)\(['"]{0,1}cmd\.exe";i:155;s:9:"By\s+DZ27";i:156;s:27:"Ethnic\s+Albanian\s+Hackers";i:157;s:20:"Volgogradindex\.html";i:158;s:32:"\$_Post\[['"]{0,1}SSN['"]{0,1}\]";i:159;s:15:"pack\s+"SnA4x8"";i:160;s:14:"['"]{0,1}DZe1r";i:161;s:12:"TeaM\s+MosTa";i:162;s:63:"if\(mail\(\$email\[\$i\],\s*\$subject,\s*\$message,\s*\$headers";i:163;s:36:"print\s+['"]{0,1}dle_nulled['"]{0,1}";i:164;s:39:"if\s*\(check_acc\(\$login,\$pass,\$serv";i:165;s:38:"preg_replace\(\){return\s+__FUNCTION__";i:166;s:33:"\$opt\s*=\s*\$file\(@*\$_COOKIE\[";i:167;s:36:"if\(@function_exists\(['"]{0,1}fread";i:168;s:108:"for\(\$[a-zA-Z0-9_]+?=\d+;\$[a-zA-Z0-9_]+?<\d+;\$[a-zA-Z0-9_]+?-=\d+\){if\(\$[a-zA-Z0-9_]+?!=\d+\)\s*break;}";i:169;s:35:"\$counterUrl\s*=\s*['"]{0,1}http://";i:170;s:67:"array\(\s*['"]h['"]\s*,\s*['"]t['"]\s*,\s*['"]t['"]\s*,\s*['"]p['"]";i:171;s:42:"if\s*\(function_exists\(['"]scan_directory";i:172;s:62:"\$_SESSION\[['"]{0,1}data_a['"]{0,1}\]\[\$name\]\s*=\s*\$value";i:173;s:38:"Zend\s+Optimization\s+ver\s+1\.0\.0\.1";i:174;s:26:"index\.php\?id=\$1&%{QUERY";i:175;s:86:"@ini_set\s*\(['"]{0,1}include_path['"]{0,1},['"]{0,1}ini_get\s*\(['"]{0,1}include_path";i:176;s:28:"if\s*\(@is_writable\(\$index";i:177;s:28:"\$_POST\[['"]{0,1}smtp_login";i:178;s:37:"_['"]{0,1}\]\[2\]\(['"]{0,1}Location:";i:179;s:34:"if\(@preg_match\(strtr\(['"]{0,1}/";i:180;s:15:"<!--\s+js-tools";i:181;s:7:"uggc://";i:182;s:47:"if \(date\(['"]{0,1}j['"]{0,1}\)\s*-\s*\$newsid";i:183;s:16:"<David\s+Blaine>";i:184;s:25:"\$isevalfunctionavailable";i:185;s:41:"if \(!strpos\(\$strs\[0\],['"]{0,1}<\?php";i:186;s:85:"\$string\s*=\s*\$_SESSION\[['"]{0,1}data_a['"]{0,1}\]\[['"]{0,1}nutzername['"]{0,1}\]";i:187;s:56:"while\(count\(\$lines\)>\$col_zap\) array_pop\(\$lines\)";i:188;s:104:"site_from=['"]{0,1}\.\$_SERVER\[['"]{0,1}HTTP_HOST['"]{0,1}\]\.['"]{0,1}&site_folder=['"]{0,1}\.\$f\[1\]";i:189;s:31:"\$fileb\s*=\s*file_get_contents";i:190;s:33:"portlets/framework/security/login";i:191;s:29:"\$b\s*=\s*md5_file\(\$fileb\)";i:192;s:51:"\$data\s*=\s*array\(['"]{0,1}terminal['"]{0,1}\s*=>";i:193;s:70:"strpos\(\$_SERVER\[['"]{0,1}HTTP_REFERER['"]{0,1}\],\s*['"]{0,1}google";i:194;s:70:"strpos\(\$_SERVER\[['"]{0,1}HTTP_REFERER['"]{0,1}\],\s*['"]{0,1}yandex";i:195;s:77:"stristr\(\$_SERVER\[['"]{0,1}HTTP_USER_AGENT['"]{0,1}\],\s*['"]{0,1}YandexBot";i:196;s:53:"fopen\(['"]{0,1}\.\./\.\./\.\./['"]{0,1}\.\$filepaths";i:197;s:36:"preg_replace\(\s*['"]e['"],['"]{0,1}";i:198;s:40:"([^\?\s])\({0,1}\.[\+\*]\){0,1}\2[a-z]*e";i:199;s:17:"mx2\.hotmail\.com";i:200;s:35:"php_['"]\.\$ext\.['"]\.dll['"]{0,1}";i:201;s:20:"/e['"]\s*,\s*['"]\\x";i:202;s:32:"<h1>403 Forbidden</h1><!-- token";i:203;s:23:"/var/qmail/bin/sendmail";i:204;s:44:"array\(\s*['"]Google['"]\s*,\s*['"]Slurp['"]";i:205;s:12:"andex\|oogle";i:206;s:24:"page_files/style000\.css";i:207;s:21:"==['"]\)\);return;\?>";i:208;s:16:"Spam\s+completed";i:209;s:35:"echo\s+['"]{0,1}install_ok['"]{0,1}";i:210;s:60:"\$_(GET|POST|SERVER|COOKIE|REQUEST)\[['"]{0,1}cvv['"]{0,1}\]";i:211;s:11:"CVV:\s*\$cv";i:212;s:30:"curl\.haxx\.se/rfc/cookie_spec";i:213;s:12:"killall\s+-9";i:214;s:57:"preg_replace\s*\(\s*@*\$_(GET|POST|SERVER|COOKIE|REQUEST)";i:215;s:58:"\$mailer\s*=\s*\$_POST\[\s*['"]{0,1}x_mailer['"]{0,1}\s*\]";i:216;s:30:"preg_replace\s*\(\s*['"]/\.\*/";i:217;s:29:"ErrorDocument\s+400\s+http://";i:218;s:29:"ErrorDocument\s+500\s+http://";i:219;s:28:"google\|yandex\|bot\|rambler";i:220;s:21:"eval\s*\(\s*str_rot13";i:221;s:38:"eval\s*\(\s*gzinflate\s*\(\s*str_rot13";i:222;s:48:"function\s*chmod_R\s*\(\s*\$path\s*,\s*\$perm\s*";i:223;s:33:"symbian\|midp\|wap\|phone\|pocket";i:224;s:28:"echo\s+['"]o\.k\.['"];\s*\?>";i:225;s:72:"@setcookie\(['"]m['"],\s*['"][a-zA-Z0-9_]+?['"],\s*time\(\)\s*\+\s*86400";i:226;s:70:"(ftp_exec|system|shell_exec|passthru|popen|proc_open)\s*\(*\s*['"]wget";i:227;s:33:"gzuncompress\s*\(\s*base64_decode";i:228;s:30:"gzinflate\s*\(\s*base64_decode";i:229;s:25:"eval\s*\(\s*base64_decode";i:230;s:32:"str_ireplace\s*\(*\s*['"]</head>";i:231;s:39:"if\s*\(\s*preg_match\s*\(\s*['"]#yandex";i:232;s:31:"=\s*array_map\s*\(*\s*strrev\s*";i:233;s:9:"\$___\s*=";i:234;s:49:"gzuncompress\s*\(*\s*substr\s*\(*\s*base64_decode";i:235;s:23:"AddHandler\s+php-script";i:236;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:237;s:38:"stream_socket_client\s*\(\s*['"]tcp://";i:238;s:95:"isset\(\s*@*\$_(GET|POST|SERVER|COOKIE|REQUEST)\[['"][a-zA-Z0-9_]+?['"]\]\)\s*or\s*die\(*.*?\)*";i:239;s:57:"Options\s+FollowSymLinks\s+MultiViews\s+Indexes\s+ExecCGI";i:240;s:32:"is_writable\s*\(*\s*['"]/var/tmp";i:241;s:95:"add_filter\s*\(*\s*['"]{0,1}the_content['"]{0,1}\s*,\s*['"]{0,1}_bloginfo['"]{0,1}\s*,\s*.+?\)*";i:242;s:29:"eval\s*\(*\s*get_option\s*\(*";i:243;s:104:"(ftp_exec|system|shell_exec|passthru|popen|proc_open)\s*\(*\s*@*\$_(GET|POST|SERVER|COOKIE|REQUEST)\s*\[";i:244;s:107:"if\s*\(\s*is_callable\s*\(*\s*['"]{0,1}(ftp_exec|system|shell_exec|passthru|popen|proc_open)['"]{0,1}\s*\)*";i:245;s:114:"if\s*\(\s*function_exists\s*\(\s*['"]{0,1}(ftp_exec|system|shell_exec|passthru|popen|proc_open)['"]{0,1}\s*\)\s*\)";i:246;s:74:"(ftp_exec|system|shell_exec|passthru|popen|proc_open)\s*\(*\s*['"]rm\s*-fr";i:247;s:74:"(ftp_exec|system|shell_exec|passthru|popen|proc_open)\s*\(*\s*['"]rm\s*-rf";i:248;s:78:"(ftp_exec|system|shell_exec|passthru|popen|proc_open)\s*\(*\s*['"]rm\s*-r\s*-f";i:249;s:40:"eval\s*\(*\s*gzinflate\s*\(*\s*str_rot13";i:250;s:19:"round\s*\(\s*0\s*\+";i:251;s:19:"Content-Type:\s*\$_";}"));
$gXX_FlexDBShe = unserialize(base64_decode("YToyMDg6e2k6MDtzOjQ4OiJwYXJzZV9xdWVyeV9zdHJpbmdcKFxzKlwkRU5We1xzKlsnIl1RVUVSWV9TVFJJTkciO2k6MTtzOjQ0OiJAXCRbYS16QS1aMC05X10rP1woXHMqXCRbYS16QS1aMC05X10rP1xzKlwpOyI7aToyO3M6Mzk6IlthLXpBLVowLTlfXSs/XChccypbYS16QS1aMC05X10rPz1ccypcKSI7aTozO3M6MTI6IlsnIl1yaW55WyciXSI7aTo0O3M6MTQ6IlsnIl1mbGZncnpbJyJdIjtpOjU7czoxNToiWyciXW9mbmlwaHBbJyJdIjtpOjY7czoxNzoiWyciXTMxdG9yX3J0c1snIl0iO2k6NztzOjE0OiJbJyJddHJlc3NhWyciXSI7aTo4O3M6MTM6ImVkb2NlZF80NmVzYWIiO2k6OTtzOjEyOiJzc2VycG1vY251emciO2k6MTA7czo5OiJldGFsZm5pemciO2k6MTE7czoxMjoiWyciXXJpbnlbJyJdIjtpOjEyO3M6MTQ6IlsnIl1mbGZncnpbJyJdIjtpOjEzO3M6NzoiY3VjdmFzYiI7aToxNDtzOjk6ImZnZV9lYmcxMyI7aToxNTtzOjE0OiJbJyJdbmZmcmVnWyciXSI7aToxNjtzOjEzOiJvbmZyNjRfcXJwYnFyIjtpOjE3O3M6MTI6InRtaGFwYnpjZXJmZiI7aToxODtzOjk6InRtdmFzeW5nciI7aToxOTtzOjQ4OiI8XD9ccypcJFthLXpBLVowLTlfXSs/XChccypcJFthLXpBLVowLTlfXSs/XHMqXCkiO2k6MjA7czoyMToiZGF0YTp0ZXh0L2h0bWw7YmFzZTY0IjtpOjIxO3M6MTM6Im51bGxfZXhwbG9pdHMiO2k6MjI7czoxMzA6ImlmXChpc3NldFwoXCRfUkVRVUVTVFxbWyciXVthLXpBLVowLTlfXSs/WyciXVxdXClcKVxzKntccypcJFthLXpBLVowLTlfXSs/XHMqPVxzKlwkX1JFUVVFU1RcW1snIl1bYS16QS1aMC05X10rP1snIl1cXTtccypleGl0XChcKTsiO2k6MjM7czo1NjoibWFpbFwoXHMqXCRhcnJcW1snIl10b1snIl1cXVxzKixccypcJGFyclxbWyciXXN1YmpbJyJdXF0iO2k6MjQ7czoyNDoidW5saW5rXChccypfX0ZJTEVfX1xzKlwpIjtpOjI1O3M6MjE6Ii1JL3Vzci9sb2NhbC9iYW5kbWFpbiI7aToyNjtzOjQzOiJuYW1lPVsnIl11cGxvYWRlclsnIl1ccytpZD1bJyJddXBsb2FkZXJbJyJdIjtpOjI3O3M6MzE6ImVjaG9ccypbJyJdPGI+VXBsb2FkPHNzPlN1Y2Nlc3MiO2k6Mjg7czozNzoiaGVhZGVyXChccypbJyJdTG9jYXRpb246XHMqXCRsaW5rWyciXSI7aToyOTtzOjUxOiJ0eXBlPVsnIl1zdWJtaXRbJyJdXHMqdmFsdWU9WyciXVVwbG9hZCBmaWxlWyciXVxzKj4iO2k6MzA7czozMDoiZWxzZVxzKntccyplY2hvXHMqWyciXWZhaWxbJyJdIjtpOjMxO3M6NDQ6IlxzKj1ccyppbmlfZ2V0XChccypbJyJdZGlzYWJsZV9mdW5jdGlvbnNbJyJdIjtpOjMyO3M6NTc6IkBlcnJvcl9yZXBvcnRpbmdcKFxzKjBccypcKTtccyppZlxzKlwoXHMqIWlzc2V0XHMqXChccypcJCI7aTozMztzOjU4OiJyb3VuZFxzKlwoXHMqXChccypcJHBhY2tldHNccypcKlxzKjY1XClccyovXHMqMTAyNFxzKixccyoyIjtpOjM0O3M6MTI6Ilplcm9EYXlFeGlsZSI7aTozNTtzOjExOiJTX1xdQF9cXlVcXiI7aTozNjtzOjUwOiI8aW5wdXRccyt0eXBlPXN1Ym1pdFxzK3ZhbHVlPVVwbG9hZFxzKi8+XHMqPC9mb3JtPiI7aTozNztzOjEwODoiaWZcKFxzKiFzb2NrZXRfc2VuZHRvXChccypcJHNvY2tldFxzKixccypcJGRhdGFccyosXHMqc3RybGVuXChccypcJGRhdGFccypcKVxzKixccyowXHMqLFxzKlwkaXBccyosXHMqXCRwb3J0IjtpOjM4O3M6NTQ6InN1YnN0clwoXHMqXCRyZXNwb25zZVxzKixccypcJGluZm9cW1xzKlsnIl1oZWFkZXJfc2l6ZSI7aTozOTtzOjE5OiJkaWVcKFxzKlsnIl1ubyBjdXJsIjtpOjQwO3M6NzQ6IlwkcmV0ID0gXCR0aGlzLT5fZGItPnVwZGF0ZU9iamVjdFwoIFwkdGhpcy0+X3RibCwgXCR0aGlzLCBcJHRoaXMtPl90Ymxfa2V5IjtpOjQxO3M6NDQ6Im9wZW5ccypcKFxzKk1ZRklMRVxzKixccypbJyJdXHMqPlxzKnRhclwudG1wIjtpOjQyO3M6MTg6Ii1cKi1ccypjb25mXHMqLVwqLSI7aTo0MztzOjQ5OiJAdG91Y2hccypcKFxzKlwkY3VyZmlsZVxzKixccypcJHRpbWVccyosXHMqXCR0aW1lIjtpOjQ0O3M6MzM6InRvdWNoXHMqXChccypkaXJuYW1lXChccypfX0ZJTEVfXyI7aTo0NTtzOjI3OiJcLlwuL1wuXC4vXC5cLi9cLlwuL21vZHVsZXMiO2k6NDY7czoyOToiZXhlY1woXHMqWyciXS9iaW4vc2hbJyJdXHMqXCkiO2k6NDc7czoxNToiL3RtcC9cLklDRS11bml4IjtpOjQ4O3M6MTU6Ii90bXAvdG1wLXNlcnZlciI7aTo0OTtzOjI2OiI9XHMqWyciXXNlbmRtYWlsXHMqLXRccyotZiI7aTo1MDtzOjI0OiJwcm9jX2Nsb3NlXChccypcJHByb2Nlc3MiO2k6NTE7czoxNjoiO1xzKi9iaW4vc2hccyotaSI7aTo1MjtzOjIzOiJbJyJdXHMqXHxccyovYmluL3NoWyciXSI7aTo1MztzOjQyOiJAdW1hc2tcKFxzKjA3NzdccyomXHMqflxzKlwkZmlsZXBlcm1pc3Npb24iO2k6NTQ7czo1MjoiY2htb2RcKFxzKlwkW1xzJVwuQFwtXCtcKFwpL2EtekEtWjAtOV9dKz9ccyosXHMqMDc1NSI7aTo1NTtzOjUyOiJjaG1vZFwoXHMqXCRbXHMlXC5AXC1cK1woXCkvYS16QS1aMC05X10rP1xzKixccyowNDA0IjtpOjU2O3M6NDc6InN0cnRvbG93ZXJcKFxzKnN1YnN0clwoXHMqXCR1c2VyX2FnZW50XHMqLFxzKjAsIjtpOjU3O3M6OToiTDNaaGNpOTNkIjtpOjU4O3M6NTU6Ilwkb3V0XHMqXC49XHMqXCR0ZXh0e1xzKlwkaVxzKn1ccypcXlxzKlwka2V5e1xzKlwkalxzKn0iO2k6NTk7czo4NDoiL2luZGV4XC5waHBcP29wdGlvbj1jb21fY29udGVudCZ2aWV3PWFydGljbGUmaWQ9WyciXVwuXCRwb3N0XFtbJyJdezAsMX1pZFsnIl17MCwxfVxdIjtpOjYwO3M6Mjc6IkBjaGRpclwoXHMqXCRfUE9TVFxbXHMqWyciXSI7aTo2MTtzOjY0OiJpc3NldFwoXHMqXCRfQ09PS0lFXFtccyptZDVcKFxzKlwkX1NFUlZFUlxbXHMqWyciXXswLDF9SFRUUF9IT1NUIjtpOjYyO3M6Mjc6InN0cmxlblwoXHMqXCRwYXRoVG9Eb3JccypcKSI7aTo2MztzOjI5OiJmb3BlblwoXHMqWyciXVwuXC4vXC5odGFjY2VzcyI7aTo2NDtzOjQzOiJcJF9QT1NUXFtccypbJyJdezAsMX1lTWFpbEFkZFsnIl17MCwxfVxzKlxdIjtpOjY1O3M6NzI6Im1haWxcKFxzKlwkcmVjaXBpZW50XHMqLFxzKlwkc3ViamVjdFxzKixccypcJG1lc3NhZ2VccyosXHMqXCRoZWFkZXJccypcKSI7aTo2NjtzOjY4OiJtYWlsXChccypcJHNlbmRccyosXHMqXCRzdWJqZWN0XHMqLFxzKlwkbWVzc2FnZVxzKixccypcJGhlYWRlcnNccypcKSI7aTo2NztzOjUzOiJtYWlsXChccypcJHRvXHMqLFxzKlwkc3ViaixccypcJG1zZ1xzKixccypcJGZyb21ccypcKSI7aTo2ODtzOjQzOiJjb250ZW50PSJcZCs7VVJMPWh0dHBzOi8vZG9jc1wuZ29vZ2xlXC5jb20vIjtpOjY5O3M6NDI6Ilwka2V5XHMqPVxzKlwkX0dFVFxbWyciXXswLDF9cVsnIl17MCwxfVxdOyI7aTo3MDtzOjE5OiIvaW5zdHJ1a3RzaXlhLWRseWEtIjtpOjcxO3M6MTQ6Ii9cP2RvPW9zaGlia2EtIjtpOjcyO3M6MTc6Ii9cP2RvPWthay11ZGFsaXQtIjtpOjczO3M6MTU6Imd6aW5mbGF0ZVwoXChcKCI7aTo3NDtzOjIzOiIwXHMqXChccypnenVuY29tcHJlc3NcKCI7aTo3NTtzOjIwOiJcJF9SRVFVRVNUXFtbJyJdbGFsYSI7aTo3NjtzOjQzOiJzdHJwb3NcKFwkaW1ccyosXHMqWyciXTxcP1snIl1ccyosXHMqXCRpXCsxIjtpOjc3O3M6NjM6Imh0dHA6Ly93d3dcLmdvb2dsZVwuY29tL3NlYXJjaFw/cT1bJyJdXC5cJHF1ZXJ5XC5bJyJdJmhsPVwkbGFuZyI7aTo3ODtzOjQzOiJodHRwOi8vZ29cLm1haWxcLnJ1L3NlYXJjaFw/cT1bJyJdXC5cJHF1ZXJ5IjtpOjc5O3M6NTA6Imh0dHA6Ly93d3dcLmJpbmdcLmNvbS9zZWFyY2hcP3E9XCRxdWVyeSZwcT1cJHF1ZXJ5IjtpOjgwO3M6Mzg6InNldFRpbWVvdXRcKFxzKlsnIl1sb2NhdGlvblwucmVwbGFjZVwoIjtpOjgxO3M6MTIwOiIoaW5jbHVkZXxpbmNsdWRlX29uY2V8cmVxdWlyZXxyZXF1aXJlX29uY2UpXHMqXCgqXHMqWyciXVtccyVcLkBcLVwrXChcKS9hLXpBLVowLTlfXSs/L1tccyVcLkBcLVwrXChcKS9hLXpBLVowLTlfXSs/XC5naWYiO2k6ODI7czoxMjA6IihpbmNsdWRlfGluY2x1ZGVfb25jZXxyZXF1aXJlfHJlcXVpcmVfb25jZSlccypcKCpccypbJyJdW1xzJVwuQFwtXCtcKFwpL2EtekEtWjAtOV9dKz8vW1xzJVwuQFwtXCtcKFwpL2EtekEtWjAtOV9dKz9cLmpwZyI7aTo4MztzOjEyMDoiKGluY2x1ZGV8aW5jbHVkZV9vbmNlfHJlcXVpcmV8cmVxdWlyZV9vbmNlKVxzKlwoKlxzKlsnIl1bXHMlXC5AXC1cK1woXCkvYS16QS1aMC05X10rPy9bXHMlXC5AXC1cK1woXCkvYS16QS1aMC05X10rP1wucG5nIjtpOjg0O3M6MTQyOiIoaW5jbHVkZXxpbmNsdWRlX29uY2V8cmVxdWlyZXxyZXF1aXJlX29uY2UpXHMqXCgqXHMqXCRfU0VSVkVSXFtbJyJdezAsMX1ET0NVTUVOVF9ST09UWyciXXswLDF9XF1ccypcLlxzKlsnIl1bXHMlXC5AXC1cK1woXCkvYS16QS1aMC05X10rP1wucG5nIjtpOjg1O3M6MTQyOiIoaW5jbHVkZXxpbmNsdWRlX29uY2V8cmVxdWlyZXxyZXF1aXJlX29uY2UpXHMqXCgqXHMqXCRfU0VSVkVSXFtbJyJdezAsMX1ET0NVTUVOVF9ST09UWyciXXswLDF9XF1ccypcLlxzKlsnIl1bXHMlXC5AXC1cK1woXCkvYS16QS1aMC05X10rP1wuZ2lmIjtpOjg2O3M6MTQyOiIoaW5jbHVkZXxpbmNsdWRlX29uY2V8cmVxdWlyZXxyZXF1aXJlX29uY2UpXHMqXCgqXHMqXCRfU0VSVkVSXFtbJyJdezAsMX1ET0NVTUVOVF9ST09UWyciXXswLDF9XF1ccypcLlxzKlsnIl1bXHMlXC5AXC1cK1woXCkvYS16QS1aMC05X10rP1wuanBnIjtpOjg3O3M6MTA2OiJ1bmxpbmtcKFxzKlwkX1NFUlZFUlxbXHMqWyciXXswLDF9RE9DVU1FTlRfUk9PVFsnIl17MCwxfVxdXHMqXC5ccypbJyJdezAsMX0vYXNzZXRzL2NhY2hlL3RlbXAvRmlsZVNldHRpbmdzIjtpOjg4O3M6NDg6ImlmXChccypzdHJwb3NcKFxzKlwkdmFsdWVccyosXHMqXCRtYXNrXHMqXClccypcKSI7aTo4OTtzOjg6ImFiYWtvL0FPIjtpOjkwO3M6NTU6IlwqL1xzKihpbmNsdWRlfGluY2x1ZGVfb25jZXxyZXF1aXJlfHJlcXVpcmVfb25jZSlccyovXCoiO2k6OTE7czozNDoiZ3JvdXBfY29uY2F0XCgweDIxN2UscGFzc3dvcmQsMHgzYSI7aTo5MjtzOjM3OiJjb25jYXRcKDB4MjE3ZSxwYXNzd29yZCwweDNhLHVzZXJuYW1lIjtpOjkzO3M6MjM6IlwrdW5pb25cK3NlbGVjdFwrMCwwLDAsIjtpOjk0O3M6OToic2V4c2V4c2V4IjtpOjk1O3M6MzU6IlwkYmFzZV9kb21haW5ccyo9XHMqZ2V0X2Jhc2VfZG9tYWluIjtpOjk2O3M6MzE6IiFlcmVnXChbJyJdXF5cKHVuc2FmZV9yYXdcKVw/XCQiO2k6OTc7czo5MToiXCRbYS16QS1aMC05X10rPz1cJFthLXpBLVowLTlfXSs/XChcJFthLXpBLVowLTlfXSs/LFwkW2EtekEtWjAtOV9dKz9cKFsnIl17XCRbYS16QS1aMC05X10rPyI7aTo5ODtzOjE5OiJsbXBfY2xpZW50XChzdHJjb2RlIjtpOjk5O3M6MTY6ImV2YWxcKFsnIl1ccyovXCoiO2k6MTAwO3M6MTU6ImV2YWxcKFsnIl1ccyovLyI7aToxMDE7czozNDoiXCRxdWVyeVxzKyxccytbJyJdZnJvbSUyMGpvc191c2VycyI7aToxMDI7czo3OToiXCRbYS16QS1aMC05X10rP1xbXCRbYS16QS1aMC05X10rP1xdXFtcJFthLXpBLVowLTlfXSs/XFtcZCtcXVwuXCRbYS16QS1aMC05X10rPyI7aToxMDM7czoyOToiXClcKSxQSFBfVkVSU0lPTixtZDVfZmlsZVwoXCQiO2k6MTA0O3M6ODM6IihmdHBfZXhlY3xzeXN0ZW18c2hlbGxfZXhlY3xwYXNzdGhydXxwb3Blbnxwcm9jX29wZW4pXChbJyJdezAsMX1jdXJsXHMrLU9ccytodHRwOi8vIjtpOjEwNTtzOjE5OiJjb2Rlc1wubWFpbmxpbmtcLnJ1IjtpOjEwNjtzOjM2OiJjaG1vZFwoZGlybmFtZVwoX19GSUxFX19cKSxccyowNTExXCkiO2k6MTA3O3M6Mzk6ImxvY2F0aW9uXC5yZXBsYWNlXChcXFsnIl1cJHVybF9yZWRpcmVjdCI7aToxMDg7czoyODoiTW90aGVyWyciXXNccytNYWlkZW5ccytOYW1lOiI7aToxMDk7czo5MDoiKGZ0cF9leGVjfHN5c3RlbXxzaGVsbF9leGVjfHBhc3N0aHJ1fHBvcGVufHByb2Nfb3BlbilcKFsnIl1teXNxbGR1bXBccystaFxzK2xvY2FsaG9zdFxzKy11IjtpOjExMDtzOjc3OiJhcnJheV9tZXJnZVwoXCRleHRccyosXHMqYXJyYXlcKFsnIl13ZWJzdGF0WyciXSxbJyJdYXdzdGF0c1snIl0sWyciXXRlbXBvcmFyeSI7aToxMTE7czozMzoiQ29tZmlybVxzK1RyYW5zYWN0aW9uXHMrUGFzc3dvcmQ6IjtpOjExMjtzOjIyOiJ4cnVtZXJfc3BhbV9saW5rc1wudHh0IjtpOjExMztzOjY6IlNFb0RPUiI7aToxMTQ7czo3MDoiPFw/cGhwXHMrKGluY2x1ZGV8aW5jbHVkZV9vbmNlfHJlcXVpcmV8cmVxdWlyZV9vbmNlKVxzKlwoXHMqWyciXS9ob21lLyI7aToxMTU7czoyMjoiLFsnIl08XD9waHBcXG5bJyJdXC5cJCI7aToxMTY7czo1MDoiPGlmcmFtZVxzK3NyYz1bJyJdaHR0cHM6Ly9kb2NzXC5nb29nbGVcLmNvbS9mb3Jtcy8iO2k6MTE3O3M6MzY6ImV4ZWNccyt7WyciXS9iaW4vc2hbJyJdfVxzK1snIl0tYmFzaCI7aToxMTg7czo0NToiaWZcKGZpbGVfcHV0X2NvbnRlbnRzXChcJGluZGV4X3BhdGgsXHMqXCRjb2RlIjtpOjExOTtzOjMxOiI9XHMqbmV3XHMrRGlyZWN0b3J5SXRlcmF0b3JcKFwkIjtpOjEyMDtzOjUzOiJcJFthLXpBLVowLTlfXSs/ID0gXCRbYS16QS1aMC05X10rP1woWyciXXswLDF9aHR0cDovLyI7aToxMjE7czo1MjoiY1wubGVuZ3RoXCk7fXJldHVyblxzKlxcWyciXVxcWyciXTt9aWZcKCFnZXRDb29raWVcKCI7aToxMjI7czo4OiIjdPpJN/bf0CI7aToxMjM7czozMToic2VsZWN0IGxhbmd1YWdlc19pZCwgbmFtZSwgY29kZSI7aToxMjQ7czo0NDoidXBkYXRlIGNvbmZpZ3VyYXRpb24gc2V0IGNvbmZpZ3VyYXRpb25fdmFsdWUiO2k6MTI1O3M6NjU6InNlbGVjdCBjb25maWd1cmF0aW9uX2lkLCBjb25maWd1cmF0aW9uX3RpdGxlLCBjb25maWd1cmF0aW9uX3ZhbHVlIjtpOjEyNjtzOjM2OiIvYWRtaW4vY29uZmlndXJhdGlvblwucGhwL2xvZ2luXC5waHAiO2k6MTI3O3M6MTAxOiJzdHJfcmVwbGFjZVwoWyciXS5bJyJdXHMqLFxzKlsnIl0uWyciXVxzKixccypzdHJfcmVwbGFjZVwoWyciXS5bJyJdXHMqLFxzKlsnIl0uWyciXVxzKixccypzdHJfcmVwbGFjZSI7aToxMjg7czoxMjoiZG1sbGQwUmhkR0U9IjtpOjEyOTtzOjgxOiIoZnRwX2V4ZWN8c3lzdGVtfHNoZWxsX2V4ZWN8cGFzc3RocnV8cG9wZW58cHJvY19vcGVuKVwoWyciXWx3cC1kb3dubG9hZFxzK2h0dHA6Ly8iO2k6MTMwO3M6Njg6IlwkW2EtekEtWjAtOV9dKz9cKFxzKlsnIl1bJyJdXHMqLFxzKmV2YWxcKFwkW2EtekEtWjAtOV9dKz9ccypcKVxzKlwpIjtpOjEzMTtzOjY3OiJcJFthLXpBLVowLTlfXSs/XChccypcJFthLXpBLVowLTlfXSs/XChccypcJFthLXpBLVowLTlfXSs/XHMqXClccyosIjtpOjEzMjtzOjYwOiJcJFthLXpBLVowLTlfXSs/XChccypcJFthLXpBLVowLTlfXSs/XChccypcJFthLXpBLVowLTlfXSs/XFsiO2k6MTMzO3M6Mzk6IlwkW2EtekEtWjAtOV9dKz9cKFxzKlwkW2EtekEtWjAtOV9dKz9cWyI7aToxMzQ7czo1OToiXChccypcJHNlbmRccyosXHMqXCRzdWJqZWN0XHMqLFxzKlwkbWVzc2FnZVxzKixccypcJGhlYWRlcnMiO2k6MTM1O3M6MTc6Ij1ccypbJyJdL3Zhci90bXAvIjtpOjEzNjtzOjY1OiIoaW5jbHVkZXxpbmNsdWRlX29uY2V8cmVxdWlyZXxyZXF1aXJlX29uY2UpXHMqXCgqXHMqWyciXS92YXIvdG1wLyI7aToxMzc7czoyNjoiZXhpdFwoXCk6ZXhpdFwoXCk6ZXhpdFwoXCkiO2k6MTM4O3M6Mzg6IkFkZFR5cGVccythcHBsaWNhdGlvbi94LWh0dHBkLWNnaVxzK1wuIjtpOjEzOTtzOjM4OiJAbW92ZV91cGxvYWRlZF9maWxlXChccypcJHVzZXJmaWxlX3RtcCI7aToxNDA7czoyMjoiZGlzYWJsZV9mdW5jdGlvbnM9bm9uZSI7aToxNDE7czoxNTU6IlwkW2EtekEtWjAtOV9dKz9cW1xzKlwkW2EtekEtWjAtOV9dKz9ccypcXVxbXHMqXCRbYS16QS1aMC05X10rP1xbXHMqXGQrXHMqXF1ccypcLlxzKlwkW2EtekEtWjAtOV9dKz9cW1xzKlxkK1xzKlxdXHMqXC5ccypcJFthLXpBLVowLTlfXSs/XFtccypcZCtccypcXVxzKlwuIjtpOjE0MjtzOjIyMjoiXCRbYS16QS1aMC05X10rP1xbXHMqXGQrXHMqXF1ccypcLlxzKlwkW2EtekEtWjAtOV9dKz9cW1xzKlxkK1xzKlxdXHMqXC5ccypcJFthLXpBLVowLTlfXSs/XFtccypcZCtccypcXVxzKlwuXHMqXCRbYS16QS1aMC05X10rP1xbXHMqXGQrXHMqXF1ccypcLlxzKlwkW2EtekEtWjAtOV9dKz9cW1xzKlxkK1xzKlxdXHMqXC5ccypcJFthLXpBLVowLTlfXSs/XFtccypcZCtccypcXVxzKlwuXHMqIjtpOjE0MztzOjYwOiJcJFthLXpBLVowLTlfXSs/XChccypcJFthLXpBLVowLTlfXSs/XChccypcJFthLXpBLVowLTlfXSs/XCgiO2k6MTQ0O3M6NDI6Ij1ccypjcmVhdGVfZnVuY3Rpb25cKFsnIl17MCwxfVwkYVsnIl17MCwxfSI7aToxNDU7czo5OiJcJGJcKFsnIl0iO2k6MTQ2O3M6MzE6IlwkYlxzKj1ccypjcmVhdGVfZnVuY3Rpb25cKFsnIl0iO2k6MTQ3O3M6MzY6IlgtTWFpbGVyOlxzKk1pY3Jvc29mdCBPZmZpY2UgT3V0bG9vayI7aToxNDg7czo1NjoiQCpmaWxlX3B1dF9jb250ZW50c1woXCRfKEdFVHxQT1NUfFNFUlZFUnxDT09LSUV8UkVRVUVTVCkiO2k6MTQ5O3M6MTk6IlsnIl0vXGQrL1xbYS16XF1cKmUiO2k6MTUwO3M6NjQ6IlwkXyhHRVR8UE9TVHxTRVJWRVJ8Q09PS0lFfFJFUVVFU1QpXHMqXFtccypbYS16QS1aMC05X10rP1xzKlxdXCgiO2k6MTUxO3M6MTM6IkBleHRyYWN0XHMqXCQiO2k6MTUyO3M6MTM6IkBleHRyYWN0XHMqXCgiO2k6MTUzO3M6Nzc6Im1haWxccypcKFwkZW1haWxccyosXHMqWyciXXswLDF9PVw/VVRGLThcP0JcP1snIl17MCwxfVwuYmFzZTY0X2VuY29kZVwoXCRmcm9tIjtpOjE1NDtzOjgxOiJtYWlsXChcJF9QT1NUXFtbJyJdezAsMX1lbWFpbFsnIl17MCwxfVxdLFxzKlwkX1BPU1RcW1snIl17MCwxfXN1YmplY3RbJyJdezAsMX1cXSwiO2k6MTU1O3M6ODQ6Im1vdmVfdXBsb2FkZWRfZmlsZVxzKlwoXHMqXCRfRklMRVNcW1snIl1bYS16QS1aMC05X10rP1snIl1cXVxbWyciXXRtcF9uYW1lWyciXVxdXHMqLCI7aToxNTY7czo0NToiTW96aWxsYS81XC4wXHMqXChjb21wYXRpYmxlO1xzKkdvb2dsZWJvdC8yXC4xIjtpOjE1NztzOjE0OiJyb290QGxvY2FsaG9zdCI7aToxNTg7czo0MzoiKFxcWzAtOV1bMC05XVswLTldfFxceFswLTlhLWZdWzAtOWEtZl0pezcsfSI7aToxNTk7czoxNzoiPC9ib2R5PlxzKjxzY3JpcHQiO2k6MTYwO3M6NDM6IlwkW2EtekEtWjAtOV9dKz9ccyo9XHMqWyciXXByZWdfcmVwbGFjZVsnIl0iO2k6MTYxO3M6Mzc6IlwkW2EtekEtWjAtOV9dKz9ccyo9XHMqWyciXWFzc2VydFsnIl0iO2k6MTYyO3M6NDY6IlwkW2EtekEtWjAtOV9dKz9ccyo9XHMqWyciXWNyZWF0ZV9mdW5jdGlvblsnIl0iO2k6MTYzO3M6NDQ6IlwkW2EtekEtWjAtOV9dKz9ccyo9XHMqWyciXWJhc2U2NF9kZWNvZGVbJyJdIjtpOjE2NDtzOjM1OiJcJFthLXpBLVowLTlfXSs/XHMqPVxzKlsnIl1ldmFsWyciXSI7aToxNjU7czoyODoiQ3JlZGl0XHMqQ2FyZFxzKlZlcmlmaWNhdGlvbiI7aToxNjY7czo2NjoiUmV3cml0ZUNvbmRccyole0hUVFA6QWNjZXB0LUxhbmd1YWdlfVxzKlwocnVcfHJ1LXJ1XHx1a1wpXHMqXFtOQ1xdIjtpOjE2NztzOjQyOiJSZXdyaXRlQ29uZFxzKiV7SFRUUDp4LW9wZXJhbWluaS1waG9uZS11YX0iO2k6MTY4O3M6MzQ6IlJld3JpdGVDb25kXHMqJXtIVFRQOngtd2FwLXByb2ZpbGUiO2k6MTY5O3M6MjI6ImV2YWxccypcKFxzKmdldF9vcHRpb24iO2k6MTcwO3M6Mjk6ImVjaG9ccytbJyJdezAsMX1nb29kWyciXXswLDF9IjtpOjE3MTtzOjUxOiJDVVJMT1BUX1JFRkVSRVIsXHMqWyciXXswLDF9aHR0cHM6Ly93d3dcLmdvb2dsZVwuY28iO2k6MTcyO3M6MTU6IlwkYXV0aF9wYXNzXHMqPSI7aToxNzM7czo2NDoiPVxzKlwkR0xPQkFMU1xbXHMqWyciXV8oR0VUfFBPU1R8U0VSVkVSfENPT0tJRXxSRVFVRVNUKVsnIl1ccypcXSI7aToxNzQ7czo2NDoiZWNob1xzK3N0cmlwc2xhc2hlc1xzKlwoXHMqXCRfKEdFVHxQT1NUfFNFUlZFUnxDT09LSUV8UkVRVUVTVClcWyI7aToxNzU7czoyMjoiPGgxPkxvYWRpbmdcLlwuXC48L2gxPiI7aToxNzY7czoxMjoicGhwaW5mb1woXCk7IjtpOjE3NztzOjE4NzoiKGV2YWx8YmFzZTY0X2RlY29kZXxnemluZmxhdGV8Z3p1bmNvbXByZXNzfHN0cl9yb3QxM3xtZDUpXHMqXChccyooZXZhbHxiYXNlNjRfZGVjb2RlfGd6aW5mbGF0ZXxnenVuY29tcHJlc3N8c3RyX3JvdDEzfG1kNSlccypcKFxzKihldmFsfGJhc2U2NF9kZWNvZGV8Z3ppbmZsYXRlfGd6dW5jb21wcmVzc3xzdHJfcm90MTN8bWQ1KSI7aToxNzg7czoxMToiSGFja2VkXHMrQnkiO2k6MTc5O3M6MTU6IlsnIl0vXC5cKi9lWyciXSI7aToxODA7czoyODoiZWNob1xzKlwoKlxzKlsnIl1OTyBGSUxFWyciXSI7aToxODE7czoxOTA6Im1vdmVfdXBsb2FkZWRfZmlsZVxzKlwoKlxzKlwkX0ZJTEVTXFtccypbJyJdezAsMX1maWxlbmFtZVsnIl17MCwxfVxzKlxdXFtccypbJyJdezAsMX10bXBfbmFtZVsnIl17MCwxfVxzKlxdXHMqLFxzKlwkX0ZJTEVTXFtccypbJyJdezAsMX1maWxlbmFtZVsnIl17MCwxfVxzKlxdXFtccypbJyJdezAsMX1uYW1lWyciXXswLDF9XHMqXF0iO2k6MTgyO3M6MjM6ImNvcHlccypcKFxzKlsnIl1odHRwOi8vIjtpOjE4MztzOjgyOiI8bWV0YVxzK2h0dHAtZXF1aXY9WyciXXswLDF9UmVmcmVzaFsnIl17MCwxfVxzK2NvbnRlbnQ9WyciXXswLDF9XGQrO1xzKlVSTD1odHRwOi8vIjtpOjE4NDtzOjgxOiI8bWV0YVxzK2h0dHAtZXF1aXY9WyciXXswLDF9cmVmcmVzaFsnIl17MCwxfVxzK2NvbnRlbnQ9WyciXXswLDF9XGQrO1xzKnVybD08XD9waHAiO2k6MTg1O3M6MTA6IlsnIl1hSFIwY0QiO2k6MTg2O3M6Njc6InN0cmNoclxzKlwoKlxzKlwkX1NFUlZFUlxbXHMqWyciXXswLDF9SFRUUF9VU0VSX0FHRU5UWyciXXswLDF9XHMqXF0iO2k6MTg3O3M6Njc6InN0cnN0clxzKlwoKlxzKlwkX1NFUlZFUlxbXHMqWyciXXswLDF9SFRUUF9VU0VSX0FHRU5UWyciXXswLDF9XHMqXF0iO2k6MTg4O3M6Njc6InN0cnBvc1xzKlwoKlxzKlwkX1NFUlZFUlxbXHMqWyciXXswLDF9SFRUUF9VU0VSX0FHRU5UWyciXXswLDF9XHMqXF0iO2k6MTg5O3M6MzM6IkFkZFR5cGVccythcHBsaWNhdGlvbi94LWh0dHBkLXBocCI7aToxOTA7czoxMDoicGNudGxfZXhlYyI7aToxOTE7czo2OToiKGZ0cF9leGVjfHN5c3RlbXxzaGVsbF9leGVjfHBhc3N0aHJ1fHBvcGVufHByb2Nfb3BlbilcKCpbJyJdY2RccysvdG1wIjtpOjE5MjtzOjI3OiJcJE9PTy4rPz1ccyp1cmxkZWNvZGVccypcKCoiO2k6MTkzO3M6MTI6InJtXHMrLWZccystciI7aToxOTQ7czoxMjoicm1ccystclxzKy1mIjtpOjE5NTtzOjg6InJtXHMrLWZyIjtpOjE5NjtzOjg6InJtXHMrLXJmIjtpOjE5NztzOjYzOiIoaW5jbHVkZXxpbmNsdWRlX29uY2V8cmVxdWlyZXxyZXF1aXJlX29uY2UpXHMqXCgqXHMqWyciXWltYWdlcy8iO2k6MTk4O3M6ODk6IihpbmNsdWRlfGluY2x1ZGVfb25jZXxyZXF1aXJlfHJlcXVpcmVfb25jZSlccypcKCpccypAKlwkXyhHRVR8UE9TVHxTRVJWRVJ8Q09PS0lFfFJFUVVFU1QpIjtpOjE5OTtzOjU5OiJiYXNlNjRfZGVjb2RlXHMqXCgqXHMqQCpcJF8oR0VUfFBPU1R8U0VSVkVSfENPT0tJRXxSRVFVRVNUKSI7aToyMDA7czo1MToiZG9jdW1lbnRcLndyaXRlXHMqXChccyp1bmVzY2FwZVxzKlwoXHMqWyciXXswLDF9JTNDIjtpOjIwMTtzOjg6Ii8vTk9uYU1FIjtpOjIwMjtzOjg6ImxzXHMrLWxhIjtpOjIwMztzOjM3OiJpbmlfc2V0XChccypbJyJdezAsMX1tYWdpY19xdW90ZXNfZ3BjIjtpOjIwNDtzOjI4OiJhbmRyb2lkXHxhdmFudGdvXHxibGFja2JlcnJ5IjtpOjIwNTtzOjQxOiJmaW5kXHMrL1xzKy10eXBlXHMrZlxzKy1uYW1lXHMrXC5odHBhc3N3ZCI7aToyMDY7czozNzoiZmluZFxzKy9ccystdHlwZVxzK2ZccystcGVybVxzKy0wMjAwMCI7aToyMDc7czozNzoiZmluZFxzKy9ccystdHlwZVxzK2ZccystcGVybVxzKy0wNDAwMCI7fQ=="));
$g_ExceptFlex = unserialize(base64_decode("YToxMDc6e2k6MDtzOjM3OiJlY2hvICI8c2NyaXB0PiBhbGVydFwoJyJcLlwkZGItPmdldEVyIjtpOjE7czo0MDoiZWNobyAiPHNjcmlwdD4gYWxlcnRcKCciXC5cJG1vZGVsLT5nZXRFciI7aToyO3M6ODoic29ydFwoXCkiO2k6MztzOjEwOiJtdXN0LXJldmFsIjtpOjQ7czo2OiJyaWV2YWwiO2k6NTtzOjk6ImRvdWJsZXZhbCI7aTo2O3M6NjY6InJlcXVpcmVccypcKCpccypcJF9TRVJWRVJcW1xzKlsnIl17MCwxfURPQ1VNRU5UX1JPT1RbJyJdezAsMX1ccypcXSI7aTo3O3M6NzE6InJlcXVpcmVfb25jZVxzKlwoKlxzKlwkX1NFUlZFUlxbXHMqWyciXXswLDF9RE9DVU1FTlRfUk9PVFsnIl17MCwxfVxzKlxdIjtpOjg7czo2NjoiaW5jbHVkZVxzKlwoKlxzKlwkX1NFUlZFUlxbXHMqWyciXXswLDF9RE9DVU1FTlRfUk9PVFsnIl17MCwxfVxzKlxdIjtpOjk7czo3MToiaW5jbHVkZV9vbmNlXHMqXCgqXHMqXCRfU0VSVkVSXFtccypbJyJdezAsMX1ET0NVTUVOVF9ST09UWyciXXswLDF9XHMqXF0iO2k6MTA7czoxNzoiXCRzbWFydHktPl9ldmFsXCgiO2k6MTE7czozMDoicHJlcFxzK3JtXHMrLXJmXHMrJXtidWlsZHJvb3R9IjtpOjEyO3M6MjI6IlRPRE86XHMrcm1ccystcmZccyt0aGUiO2k6MTM7czoyNzoia3Jzb3J0XChcJHdwc21pbGllc3RyYW5zXCk7IjtpOjE0O3M6NjM6ImRvY3VtZW50XC53cml0ZVwodW5lc2NhcGVcKCIlM0NzY3JpcHQgc3JjPSciIFwrIGdhSnNIb3N0IFwrICJnbyI7aToxNTtzOjY6IlwuZXhlYyI7aToxNjtzOjg6ImV4ZWNcKFwpIjtpOjE3O3M6MjQ6IlwkeDEgPSBcJHRoaXMtPncgLSBcJHgxOyI7aToxODtzOjMxOiJhc29ydFwoXCRDYWNoZURpck9sZEZpbGVzQWdlXCk7IjtpOjE5O3M6MTM6IlwoJ3I1N3NoZWxsJywiO2k6MjA7czoyNToiZXZhbFwoImxpc3RlbmVyID0gIlwrbGlzdCI7aToyMTtzOjg6ImV2YWxcKFwpIjtpOjIyO3M6MzM6InByZWdfcmVwbGFjZV9jYWxsYmFja1woJy9cXHtcKGltYSI7aToyMztzOjIxOiJldmFsIFwoX2N0TWVudUluaXRTdHIiO2k6MjQ7czoyOToiYmFzZTY0X2RlY29kZVwoXCRhY2NvdW50S2V5XCkiO2k6MjU7czozOToiYmFzZTY0X2RlY29kZVwoXCRkYXRhXClcKTsgXCRhcGktPnNldFJlIjtpOjI2O3M6NDg6InJlcXVpcmVcKFwkX1NFUlZFUlxbXFwiRE9DVU1FTlRfUk9PVFxcIlxdXC5cXCIvYiI7aToyNztzOjY1OiJiYXNlNjRfZGVjb2RlXChcJF9SRVFVRVNUXFsncGFyYW1ldGVycydcXVwpOyBpZlwoQ2hlY2tTZXJpYWxpemVkRCI7aToyODtzOjYzOiJwY250bF9leGVjJyA9PiBBcnJheVwoQXJyYXlcKDFcKSwgXCRhclJlc3VsdFxbJ1NFQ1VSSU5HX0ZVTkNUSU8iO2k6Mjk7czozOToiZWNobyAiPHNjcmlwdD5hbGVydFwoJyJcLkNVdGlsOjpKU0VzY2FwIjtpOjMwO3M6Njg6ImJhc2U2NF9kZWNvZGVcKFwkX1JFUVVFU1RcWyd0aXRsZV9jaGFuZ2VyX2xpbmsnXF1cKTsgaWYgXChzdHJsZW5cKFwkIjtpOjMxO3M6NTE6ImV2YWxcKCdcJGhleGR0aW1lID0gIicgXC4gXCRoZXhkdGltZSBcLiAnIjsnXCk7IFwkZiI7aTozMjtzOjUyOiJlY2hvICI8c2NyaXB0PmFsZXJ0XCgnXCRyb3ctPnRpdGxlIC0gIlwuX01PRFVMRV9JU19FIjtpOjMzO3M6Mzc6ImVjaG8gIjxzY3JpcHQ+YWxlcnRcKCdcJGNpZHMgIlwuX0NBTk4iO2k6MzQ7czo0MToiaWZcKDFcKSB7IFwkdl9ob3VyID0gXChcJHBfaGVhZGVyXFsnbXRpbWUiO2k6MzU7czo3MDoiZG9jdW1lbnRcLndyaXRlXCh1bmVzY2FwZVwoIiUzQ3NjcmlwdCUyMHNyYz0lMjJodHRwIiBcKyBcKFwoImh0dHBzOiIgPSI7aTozNjtzOjU3OiJkb2N1bWVudFwud3JpdGVcKHVuZXNjYXBlXCgiJTNDc2NyaXB0IHNyYz0nIiBcKyBwa0Jhc2VVUkwiO2k6Mzc7czozMjoiZWNobyAiPHNjcmlwdD5hbGVydFwoJyJcLkpUZXh0OjoiO2k6Mzg7czoyNToiJ2ZpbGVuYW1lJ1wpLCBcKCdyNTdzaGVsbCI7aTozOTtzOjQzOiJlY2hvICI8c2NyaXB0PmFsZXJ0XCgnIiBcLiBcJGVyck1zZyBcLiAiJ1wpIjtpOjQwO3M6NDI6ImVjaG8gIjxzY3JpcHQ+YWxlcnRcKFxcIkVycm9yIHdoZW4gbG9hZGluZyI7aTo0MTtzOjQzOiJlY2hvICI8c2NyaXB0PmFsZXJ0XCgnIlwuSlRleHQ6Ol9cKCdWQUxJRF9FIjtpOjQyO3M6ODoiZXZhbFwoXCkiO2k6NDM7czo4OiInc3lzdGVtJyI7aTo0NDtzOjY6IidldmFsJyI7aTo0NTtzOjY6IiJldmFsIiI7aTo0NjtzOjY6ImNvcHlcKCI7aTo0NztzOjc6Il9zeXN0ZW0iO2k6NDg7czo5OiJzYXZlMmNvcHkiO2k6NDk7czoxMDoiZmlsZXN5c3RlbSI7aTo1MDtzOjg6InNlbmRtYWlsIjtpOjUxO3M6ODoiY2FuQ2htb2QiO2k6NTI7czoxMzoiL2V0Yy9wYXNzd2RcKSI7aTo1MztzOjI0OiJ1ZHA6Ly8nXC5zZWxmOjpcJF9jX2FkZHIiO2k6NTQ7czozNDoiZWRvY2VkXzQ2ZXNhYlwoJydcfCJcKVxcXCknLCAncmVnZSI7aTo1NTtzOjk6ImRvdWJsZXZhbCI7aTo1NjtzOjE2OiJvcGVyYXRpbmcgc3lzdGVtIjtpOjU3O3M6MTA6Imdsb2JhbGV2YWwiO2k6NTg7czoyMToid2l0aCAwLzAvMCBpZiBcKDFcKSB7IjtpOjU5O3M6NDg6IlwkeDIgPSBcJHBhcmFtXFtbJyJdezAsMX14WyciXXswLDF9XF0gXCsgXCR3aWR0aCI7aTo2MDtzOjExOiJzcGVjaWFsaXNlZCI7aTo2MTtzOjE5OiJ3cF9nZXRfY3VycmVudF91c2VyIjtpOjYyO3M6NzoiLT5jaG1vZCI7aTo2MztzOjc6Il9tYWlsXCgiO2k6NjQ7czo3OiJfY29weVwoIjtpOjY1O3M6NDY6InN0cnBvc1woXCRfU0VSVkVSXFsnSFRUUF9VU0VSX0FHRU5UJ1xdLCAnRHJ1cGEiO2k6NjY7czo0NToic3RycG9zXChcJF9TRVJWRVJcWydIVFRQX1VTRVJfQUdFTlQnXF0sICdNU0lFIjtpOjY3O3M6NDU6InN0cnBvc1woXCRfU0VSVkVSXFsiSFRUUF9VU0VSX0FHRU5UIlxdLCAnTVNJRSI7aTo2ODtzOjE3OiJldmFsIFwoY2xhc3NTdHJcKSI7aTo2OTtzOjMxOiJmdW5jdGlvbl9leGlzdHNcKCdiYXNlNjRfZGVjb2RlIjtpOjcwO3M6NDQ6ImVjaG8gIjxzY3JpcHQ+YWxlcnRcKCciXC5KVGV4dDo6X1woJ1ZBTElEX0VNIjtpOjcxO3M6NTI6IlwkeDEgPSBcJG1pbl94OyBcJHgyID0gXCRtYXhfeDsgXCR5MSA9IFwkbWluX3k7IFwkeTIiO2k6NzI7czo1NToiXCRjdG1cWydhJ1xdXClcKSB7IFwkeCA9IFwkeCBcKiBcJHRoaXMtPms7IFwkeSA9IFwoXCR0aCI7aTo3MztzOjYwOiJbJyJdezAsMX1jcmVhdGVfZnVuY3Rpb25bJyJdezAsMX0sIFsnIl17MCwxfWdldF9yZXNvdXJjZV90eXAiO2k6NzQ7czo0OToiWyciXXswLDF9Y3JlYXRlX2Z1bmN0aW9uWyciXXswLDF9LCBbJyJdezAsMX1jcnlwdCI7aTo3NTtzOjY5OiJzdHJwb3NcKFwkX1NFUlZFUlxbWyciXXswLDF9SFRUUF9VU0VSX0FHRU5UWyciXXswLDF9XF0sIFsnIl17MCwxfUx5bngiO2k6NzY7czo2ODoic3Ryc3RyXChcJF9TRVJWRVJcW1snIl17MCwxfUhUVFBfVVNFUl9BR0VOVFsnIl17MCwxfVxdLCBbJyJdezAsMX1NU0kiO2k6Nzc7czoyNToic29ydFwoXCREaXN0cmlidXRpb25cW1wkayI7aTo3ODtzOjI1OiJzb3J0XChmdW5jdGlvblwoYSxiXCl7cmV0IjtpOjc5O3M6MjU6Imh0dHA6Ly93d3dcLmZhY2Vib29rXC5jb20iO2k6ODA7czoyNToiaHR0cDovL21hcHNcLmdvb2dsZVwuY29tLyI7aTo4MTtzOjUyOiJ1ZHA6Ly8nXC5zZWxmOjpcJGNfYWRkciwgODAsIFwkZXJybm8sIFwkZXJyc3RyLCAxNTAwIjtpOjgyO3M6MjA6IlwoXC5cKlwodmlld1wpXD9cLlwqIjtpOjgzO3M6NDQ6ImVjaG8gWyciXXswLDF9PHNjcmlwdD5hbGVydFwoWyciXXswLDF9XCR0ZXh0IjtpOjg0O3M6MTc6InNvcnRcKFwkdl9saXN0XCk7IjtpOjg1O3M6Nzc6Im1vdmVfdXBsb2FkZWRfZmlsZVwoIFwkX0ZJTEVTXFsndXBsb2FkZWRfcGFja2FnZSdcXVxbJ3RtcF9uYW1lJ1xdLCBcJG1vc0NvbmZpIjtpOjg2O3M6MzE6IkNyZWRpdCBDYXJkIFZlcmlmaWNhdGlvbiBDb2RlJzsiO2k6ODc7czoxMjoiZmFsc2VcKSBcKTsjIjtpOjg4O3M6MTU6Im5jeV9uYW1lYCcgXCk7IyI7aTo4OTtzOjQ3OiJzdHJwb3NcKFwkX1NFUlZFUlxbJ0hUVFBfVVNFUl9BR0VOVCdcXSwgJ01hYyBPUyI7aTo5MDtzOjIwOiIvL25vbmFtZTogJzxcPz1DVXRpbCI7aTo5MTtzOjUwOiJkb2N1bWVudFwud3JpdGVcKHVuZXNjYXBlXCgiJTNDc2NyaXB0IHNyYz0nL2JpdHJpeCI7aTo5MjtzOjI1OiJcJF9TRVJWRVIgXFsiUkVNT1RFX0FERFIiIjtpOjkzO3M6MTc6ImFIUjBjRG92TDJOeWJETXVaIjtpOjk0O3M6NTU6IkpSZXNwb25zZTo6c2V0Qm9keVwocHJlZ19yZXBsYWNlXChcJHBhdHRlcm5zLCBcJHJlcGxhY2UiO2k6OTU7czo0MDoiXFx4MWZcXHg4YlxceDA4XFx4MDBcXHgwMFxceDAwXFx4MDBcXHgwMCI7aTo5NjtzOjQwOiJcXHg1MFxceDRiXFx4MDVcXHgwNlxceDAwXFx4MDBcXHgwMFxceDAwIjtpOjk3O3M6NDY6IlxceDA5XFx4MEFcXHgwQlxceDBDXFx4MERcXHgyMFxceDJGXFx4M0VcXVxbXF4iO2k6OTg7czo0MDoiXFx4ODlcXHg1MFxceDRFXFx4NDdcXHgwRFxceDBBXFx4MUFcXHgwQSI7aTo5OTtzOjEwOiJcKTsjaScsICcmIjtpOjEwMDtzOjE3OiJcKTsjbWlzJywgJyAnLCBcJCI7aToxMDE7czoyMDoiXCk7I2knLCBcJGRhdGEsIFwkbWEiO2k6MTAyO3M6MzU6IlwkZnVuY1woIFwkcGFyYW1zXFtcJHR5cGVcXS0+cGFyYW1zIjtpOjEwMztzOjQwOiJcXHgxZlxceDhiXFx4MDhcXHgwMFxceDAwXFx4MDBcXHgwMFxceDAwIjtpOjEwNDtzOjQ1OiJcXHgwMFxceDAxXFx4MDJcXHgwM1xceDA0XFx4MDVcXHgwNlxceDA3XFx4MDgiO2k6MTA1O3M6NDA6IlxceDIxXFx4MjNcXHgyNFxceDI1XFx4MjZcXHgyN1xceDJhXFx4MmIiO2k6MTA2O3M6MzU6IlxceDgzXFx4OEJcXHg4RFxceDlCXFx4OUVcXHg5RlxceEExIjt9"));
$g_SusDB = unserialize(base64_decode("YToxMzE6e2k6MDtzOjE0OiJAKmV4dHJhY3RccypcKCI7aToxO3M6MTQ6IkAqZXh0cmFjdFxzKlwkIjtpOjI7czoxMjoiWyciXWV2YWxbJyJdIjtpOjM7czoyMToiWyciXWJhc2U2NF9kZWNvZGVbJyJdIjtpOjQ7czoyMzoiWyciXWNyZWF0ZV9mdW5jdGlvblsnIl0iO2k6NTtzOjE0OiJbJyJdYXNzZXJ0WyciXSI7aTo2O3M6NDM6ImZvcmVhY2hccypcKFxzKlwkZW1haWxzXHMrYXNccytcJGVtYWlsXHMqXCkiO2k6NztzOjc6IlNwYW1tZXIiO2k6ODtzOjE1OiJldmFsXHMqWyciXChcJF0iO2k6OTtzOjE3OiJhc3NlcnRccypbJyJcKFwkXSI7aToxMDtzOjI4OiJzcnBhdGg6Ly9cLlwuL1wuXC4vXC5cLi9cLlwuIjtpOjExO3M6MTI6InBocGluZm9ccypcKCI7aToxMjtzOjE2OiJTSE9XXHMrREFUQUJBU0VTIjtpOjEzO3M6MTI6IlxicG9wZW5ccypcKCI7aToxNDtzOjk6ImV4ZWNccypcKCI7aToxNTtzOjEzOiJcYnN5c3RlbVxzKlwoIjtpOjE2O3M6MTU6IlxicGFzc3RocnVccypcKCI7aToxNztzOjE2OiJcYnByb2Nfb3BlblxzKlwoIjtpOjE4O3M6MTU6InNoZWxsX2V4ZWNccypcKCI7aToxOTtzOjE2OiJpbmlfcmVzdG9yZVxzKlwoIjtpOjIwO3M6OToiXGJkbFxzKlwoIjtpOjIxO3M6MTQ6Ilxic3ltbGlua1xzKlwoIjtpOjIyO3M6MTI6IlxiY2hncnBccypcKCI7aToyMztzOjE0OiJcYmluaV9zZXRccypcKCI7aToyNDtzOjEzOiJcYnB1dGVudlxzKlwoIjtpOjI1O3M6MTM6ImdldG15dWlkXHMqXCgiO2k6MjY7czoxNDoiZnNvY2tvcGVuXHMqXCgiO2k6Mjc7czoxNzoicG9zaXhfc2V0dWlkXHMqXCgiO2k6Mjg7czoxNzoicG9zaXhfc2V0c2lkXHMqXCgiO2k6Mjk7czoxODoicG9zaXhfc2V0cGdpZFxzKlwoIjtpOjMwO3M6MTU6InBvc2l4X2tpbGxccypcKCI7aTozMTtzOjI3OiJhcGFjaGVfY2hpbGRfdGVybWluYXRlXHMqXCgiO2k6MzI7czoxMjoiXGJjaG1vZFxzKlwoIjtpOjMzO3M6MTI6IlxiY2hkaXJccypcKCI7aTozNDtzOjE1OiJwY250bF9leGVjXHMqXCgiO2k6MzU7czoxNDoiXGJ2aXJ0dWFsXHMqXCgiO2k6MzY7czoxNToicHJvY19jbG9zZVxzKlwoIjtpOjM3O3M6MjA6InByb2NfZ2V0X3N0YXR1c1xzKlwoIjtpOjM4O3M6MTk6InByb2NfdGVybWluYXRlXHMqXCgiO2k6Mzk7czoxNDoicHJvY19uaWNlXHMqXCgiO2k6NDA7czoxMzoiZ2V0bXlnaWRccypcKCI7aTo0MTtzOjE5OiJwcm9jX2dldHN0YXR1c1xzKlwoIjtpOjQyO3M6MTU6InByb2NfY2xvc2VccypcKCI7aTo0MztzOjE5OiJlc2NhcGVzaGVsbGNtZFxzKlwoIjtpOjQ0O3M6MTk6ImVzY2FwZXNoZWxsYXJnXHMqXCgiO2k6NDU7czoxNjoic2hvd19zb3VyY2VccypcKCI7aTo0NjtzOjEzOiJcYnBjbG9zZVxzKlwoIjtpOjQ3O3M6MTM6InNhZmVfZGlyXHMqXCgiO2k6NDg7czoxNjoiaW5pX3Jlc3RvcmVccypcKCI7aTo0OTtzOjEwOiJjaG93blxzKlwoIjtpOjUwO3M6MTA6ImNoZ3JwXHMqXCgiO2k6NTE7czoxNzoic2hvd25fc291cmNlXHMqXCgiO2k6NTI7czoxOToibXlzcWxfbGlzdF9kYnNccypcKCI7aTo1MztzOjIxOiJnZXRfY3VycmVudF91c2VyXHMqXCgiO2k6NTQ7czoxMjoiZ2V0bXlpZFxzKlwoIjtpOjU1O3M6MTE6IlxibGVha1xzKlwoIjtpOjU2O3M6MTU6InBmc29ja29wZW5ccypcKCI7aTo1NztzOjIxOiJnZXRfY3VycmVudF91c2VyXHMqXCgiO2k6NTg7czoxMToic3lzbG9nXHMqXCgiO2k6NTk7czoxODoiXCRkZWZhdWx0X3VzZV9hamF4IjtpOjYwO3M6MjE6ImV2YWxccypcKCpccyp1bmVzY2FwZSI7aTo2MTtzOjc6IkZMb29kZVIiO2k6NjI7czozMToiZG9jdW1lbnRcLndyaXRlXHMqXChccyp1bmVzY2FwZSI7aTo2MztzOjExOiJcYmNvcHlccypcKCI7aTo2NDtzOjIzOiJtb3ZlX3VwbG9hZGVkX2ZpbGVccypcKCI7aTo2NTtzOjg6IlwuMzMzMzMzIjtpOjY2O3M6ODoiXC42NjY2NjYiO2k6Njc7czoyMToicm91bmRccypcKCpccyowXHMqXCkqIjtpOjY4O3M6MTExOiJjb3B5XHMqXCgqXHMqXCRfRklMRVNccypcW1xzKlsnIl17MCwxfWZpbGVbJyJdezAsMX1ccypcXVxbXHMqWyciXXswLDF9dG1wX25hbWVbJyJdezAsMX1ccypcXVxzKixccypcJHVwbG9hZGZpbGUiO2k6Njk7czoxMjY6Im1vdmVfdXBsb2FkZWRfZmlsZXNccypcKCpccypcJF9GSUxFU1xzKlxbXHMqWyciXXswLDF9ZmlsZVsnIl17MCwxfVxzKlxdXFtccypbJyJdezAsMX10bXBfbmFtZVsnIl17MCwxfVxzKlxdXHMqLFxzKlwkdXBsb2FkZmlsZSI7aTo3MDtzOjUwOiJpbmlfZ2V0XHMqXChccypbJyJdezAsMX1kaXNhYmxlX2Z1bmN0aW9uc1snIl17MCwxfSI7aTo3MTtzOjM2OiJVTklPTlxzK1NFTEVDVFxzK1snIl17MCwxfTBbJyJdezAsMX0iO2k6NzI7czoxMDoiMlxzKj5ccyomMSI7aTo3MztzOjU3OiJlY2hvXHMqXCgqXHMqXCRfU0VSVkVSXFtbJyJdezAsMX1ET0NVTUVOVF9ST09UWyciXXswLDF9XF0iO2k6NzQ7czozNzoiPVxzKkFycmF5XHMqXCgqXHMqYmFzZTY0X2RlY29kZVxzKlwoKiI7aTo3NTtzOjE0OiJraWxsYWxsXHMrLVxkKyI7aTo3NjtzOjc6ImVyaXVxZXIiO2k6Nzc7czoxMDoidG91Y2hccypcKCI7aTo3ODtzOjc6InNzaGtleXMiO2k6Nzk7czo4OiJAaW5jbHVkZSI7aTo4MDtzOjg6IkByZXF1aXJlIjtpOjgxO3M6NjI6ImlmXHMqXChtYWlsXHMqXChccypcJHRvLFxzKlwkc3ViamVjdCxccypcJG1lc3NhZ2UsXHMqXCRoZWFkZXJzIjtpOjgyO3M6Mzg6IkBpbmlfc2V0XHMqXCgqWyciXXswLDF9YWxsb3dfdXJsX2ZvcGVuIjtpOjgzO3M6MTg6IkBmaWxlX2dldF9jb250ZW50cyI7aTo4NDtzOjE3OiJmaWxlX3B1dF9jb250ZW50cyI7aTo4NTtzOjQ2OiJhbmRyb2lkXHMqXHxccyptaWRwXHMqXHxccypqMm1lXHMqXHxccypzeW1iaWFuIjtpOjg2O3M6Mjg6IkBzZXRjb29raWVccypcKCpbJyJdezAsMX1oaXQiO2k6ODc7czoxMDoiQGZpbGVvd25lciI7aTo4ODtzOjY6IjxrdWt1PiI7aTo4OTtzOjU6InN5cGV4IjtpOjkwO3M6OToiXCRiZWVjb2RlIjtpOjkxO3M6ODoiQmFja2Rvb3IiO2k6OTI7czoxNDoicGhwX3VuYW1lXHMqXCgiO2k6OTM7czo1NToibWFpbFxzKlwoKlxzKlwkdG9ccyosXHMqXCRzdWJqXHMqLFxzKlwkbXNnXHMqLFxzKlwkZnJvbSI7aTo5NDtzOjI5OiJlY2hvXHMqWyciXTxzY3JpcHQ+XHMqYWxlcnRcKCI7aTo5NTtzOjY3OiJtYWlsXHMqXCgqXHMqXCRzZW5kXHMqLFxzKlwkc3ViamVjdFxzKixccypcJGhlYWRlcnNccyosXHMqXCRtZXNzYWdlIjtpOjk2O3M6NjU6Im1haWxccypcKCpccypcJHRvXHMqLFxzKlwkc3ViamVjdFxzKixccypcJG1lc3NhZ2VccyosXHMqXCRoZWFkZXJzIjtpOjk3O3M6MTIwOiJzdHJwb3NccypcKCpccypcJG5hbWVccyosXHMqWyciXXswLDF9SFRUUF9bJyJdezAsMX1ccypcKSpccyohPT1ccyowXHMqJiZccypzdHJwb3NccypcKCpccypcJG5hbWVccyosXHMqWyciXXswLDF9UkVRVUVTVF8iO2k6OTg7czo1MzoiaXNfZnVuY3Rpb25fZW5hYmxlZFxzKlwoXHMqWyciXXswLDF9aWdub3JlX3VzZXJfYWJvcnQiO2k6OTk7czozMDoiZWNob1xzKlwoKlxzKmZpbGVfZ2V0X2NvbnRlbnRzIjtpOjEwMDtzOjI2OiJlY2hvXHMqXCgqWyciXXswLDF9PHNjcmlwdCI7aToxMDE7czozMToicHJpbnRccypcKCpccypmaWxlX2dldF9jb250ZW50cyI7aToxMDI7czoyNzoicHJpbnRccypcKCpbJyJdezAsMX08c2NyaXB0IjtpOjEwMztzOjg1OiI8bWFycXVlZVxzK3N0eWxlXHMqPVxzKlsnIl17MCwxfXBvc2l0aW9uXHMqOlxzKmFic29sdXRlXHMqO1xzKndpZHRoXHMqOlxzKlxkK1xzKnB4XHMqIjtpOjEwNDtzOjQyOiI9XHMqWyciXXswLDF9XC5cLi9cLlwuL1wuXC4vd3AtY29uZmlnXC5waHAiO2k6MTA1O3M6NzoiZWdnZHJvcCI7aToxMDY7czo5OiJyd3hyd3hyd3giO2k6MTA3O3M6MTU6ImVycm9yX3JlcG9ydGluZyI7aToxMDg7czoxNzoiXGJjcmVhdGVfZnVuY3Rpb24iO2k6MTA5O3M6NDM6Intccypwb3NpdGlvblxzKjpccyphYnNvbHV0ZTtccypsZWZ0XHMqOlxzKi0iO2k6MTEwO3M6MTU6IjxzY3JpcHRccythc3luYyI7aToxMTE7czo2NjoiX1snIl17MCwxfVxzKlxdXHMqPVxzKkFycmF5XHMqXChccypiYXNlNjRfZGVjb2RlXHMqXCgqXHMqWyciXXswLDF9IjtpOjExMjtzOjMzOiJBZGRUeXBlXHMrYXBwbGljYXRpb24veC1odHRwZC1jZ2kiO2k6MTEzO3M6NDQ6ImdldGVudlxzKlwoKlxzKlsnIl17MCwxfUhUVFBfQ09PS0lFWyciXXswLDF9IjtpOjExNDtzOjQ1OiJpZ25vcmVfdXNlcl9hYm9ydFxzKlwoKlxzKlsnIl17MCwxfTFbJyJdezAsMX0iO2k6MTE1O3M6MjE6IlwkX1JFUVVFU1RccypcW1xzKiUyMiI7aToxMTY7czo1MToidXJsXHMqXChbJyJdezAsMX1kYXRhXHMqOlxzKmltYWdlL3BuZztccypiYXNlNjRccyosIjtpOjExNztzOjUxOiJ1cmxccypcKFsnIl17MCwxfWRhdGFccyo6XHMqaW1hZ2UvZ2lmO1xzKmJhc2U2NFxzKiwiO2k6MTE4O3M6MzA6Ijpccyp1cmxccypcKFxzKlsnIl17MCwxfTxcP3BocCI7aToxMTk7czoxNzoiPC9odG1sPi4rPzxzY3JpcHQiO2k6MTIwO3M6MTc6IjwvaHRtbD4uKz88aWZyYW1lIjtpOjEyMTtzOjY0OiIoZnRwX2V4ZWN8c3lzdGVtfHNoZWxsX2V4ZWN8cGFzc3RocnV8cG9wZW58cHJvY19vcGVuKVxzKlsnIlwoXCRdIjtpOjEyMjtzOjExOiJcYm1haWxccypcKCI7aToxMjM7czo0NjoiZmlsZV9nZXRfY29udGVudHNccypcKCpccypbJyJdezAsMX1waHA6Ly9pbnB1dCI7aToxMjQ7czoxMTg6IjxtZXRhXHMraHR0cC1lcXVpdj1bJyJdezAsMX1Db250ZW50LXR5cGVbJyJdezAsMX1ccytjb250ZW50PVsnIl17MCwxfXRleHQvaHRtbDtccypjaGFyc2V0PXdpbmRvd3MtMTI1MVsnIl17MCwxfT48Ym9keT4iO2k6MTI1O3M6NjI6Ij1ccypkb2N1bWVudFwuY3JlYXRlRWxlbWVudFwoXHMqWyciXXswLDF9c2NyaXB0WyciXXswLDF9XHMqXCk7IjtpOjEyNjtzOjY5OiJkb2N1bWVudFwuYm9keVwuaW5zZXJ0QmVmb3JlXChkaXYsXHMqZG9jdW1lbnRcLmJvZHlcLmNoaWxkcmVuXFswXF1cKTsiO2k6MTI3O3M6Nzc6IjxzY3JpcHRccyt0eXBlPSJ0ZXh0L2phdmFzY3JpcHQiXHMrc3JjPSJodHRwOi8vW2EtekEtWjAtOV9dKz9cLnBocCI+PC9zY3JpcHQ+IjtpOjEyODtzOjI3OiJlY2hvXHMrWyciXXswLDF9b2tbJyJdezAsMX0iO2k6MTI5O3M6MTg6Ii91c3Ivc2Jpbi9zZW5kbWFpbCI7aToxMzA7czoyMzoiL3Zhci9xbWFpbC9iaW4vc2VuZG1haWwiO30="));
$g_SusDBPrio = unserialize(base64_decode("YToxMjE6e2k6MDtpOjA7aToxO2k6MDtpOjI7aTowO2k6MztpOjA7aTo0O2k6MDtpOjU7aTowO2k6NjtpOjA7aTo3O2k6MDtpOjg7aToxO2k6OTtpOjE7aToxMDtpOjA7aToxMTtpOjA7aToxMjtpOjA7aToxMztpOjA7aToxNDtpOjA7aToxNTtpOjA7aToxNjtpOjA7aToxNztpOjA7aToxODtpOjA7aToxOTtpOjA7aToyMDtpOjA7aToyMTtpOjA7aToyMjtpOjA7aToyMztpOjA7aToyNDtpOjA7aToyNTtpOjA7aToyNjtpOjA7aToyNztpOjA7aToyODtpOjA7aToyOTtpOjE7aTozMDtpOjE7aTozMTtpOjA7aTozMjtpOjA7aTozMztpOjA7aTozNDtpOjA7aTozNTtpOjA7aTozNjtpOjA7aTozNztpOjA7aTozODtpOjA7aTozOTtpOjA7aTo0MDtpOjA7aTo0MTtpOjA7aTo0MjtpOjA7aTo0MztpOjA7aTo0NDtpOjA7aTo0NTtpOjA7aTo0NjtpOjA7aTo0NztpOjA7aTo0ODtpOjA7aTo0OTtpOjA7aTo1MDtpOjA7aTo1MTtpOjA7aTo1MjtpOjA7aTo1MztpOjA7aTo1NDtpOjA7aTo1NTtpOjA7aTo1NjtpOjE7aTo1NztpOjA7aTo1ODtpOjA7aTo1OTtpOjI7aTo2MDtpOjE7aTo2MTtpOjA7aTo2MjtpOjA7aTo2MztpOjA7aTo2NDtpOjI7aTo2NTtpOjI7aTo2NjtpOjA7aTo2NztpOjA7aTo2ODtpOjA7aTo2OTtpOjI7aTo3MDtpOjE7aTo3MTtpOjA7aTo3MjtpOjA7aTo3MztpOjE7aTo3NDtpOjA7aTo3NTtpOjE7aTo3NjtpOjE7aTo3NztpOjI7aTo3ODtpOjE7aTo3OTtpOjM7aTo4MDtpOjI7aTo4MTtpOjA7aTo4MjtpOjI7aTo4MztpOjA7aTo4NDtpOjA7aTo4NTtpOjI7aTo4NjtpOjA7aTo4NztpOjA7aTo4ODtpOjA7aTo4OTtpOjE7aTo5MDtpOjE7aTo5MTtpOjE7aTo5MjtpOjE7aTo5MztpOjA7aTo5NDtpOjI7aTo5NTtpOjI7aTo5NjtpOjI7aTo5NztpOjI7aTo5ODtpOjI7aTo5OTtpOjE7aToxMDA7aToxO2k6MTAxO2k6MztpOjEwMjtpOjM7aToxMDM7aToxO2k6MTA0O2k6MztpOjEwNTtpOjM7aToxMDY7aToyO2k6MTA3O2k6MDtpOjEwODtpOjM7aToxMDk7aToxO2k6MTEwO2k6MTtpOjExMTtpOjM7aToxMTI7aTozO2k6MTEzO2k6MztpOjExNDtpOjE7aToxMTU7aToxO2k6MTE2O2k6MTtpOjExNztpOjQ7aToxMTg7aToxO2k6MTE5O2k6MztpOjEyMDtpOjA7fQ=="));
$g_AdwareSig = unserialize(base64_decode("YTozMzp7aTowO3M6MTk6Il9fbGlua2ZlZWRfcm9ib3RzX18iO2k6MTtzOjEzOiJMSU5LRkVFRF9VU0VSIjtpOjI7czoxNDoiTGlua2ZlZWRDbGllbnQiO2k6MztzOjE4OiJfX3NhcGVfZGVsaW1pdGVyX18iO2k6NDtzOjI5OiJkaXNwZW5zZXJcLmFydGljbGVzXC5zYXBlXC5ydSI7aTo1O3M6MTE6IkxFTktfY2xpZW50IjtpOjY7czoxMToiU0FQRV9jbGllbnQiO2k6NztzOjE2OiJfX2xpbmtmZWVkX2VuZF9fIjtpOjg7czoxNjoiU0xBcnRpY2xlc0NsaWVudCI7aTo5O3M6MTc6Ii0+R2V0TGlua3NccypcKFwpIjtpOjEwO3M6MTc6ImRiXC50cnVzdGxpbmtcLnJ1IjtpOjExO3M6Mzc6ImNsYXNzXHMrQ01fY2xpZW50XHMrZXh0ZW5kc1xzKkNNX2Jhc2UiO2k6MTI7czoxOToibmV3XHMrQ01fY2xpZW50XChcKSI7aToxMztzOjE2OiJ0bF9saW5rc19kYl9maWxlIjtpOjE0O3M6MjA6ImNsYXNzXHMrbG1wX2Jhc2Vccyt7IjtpOjE1O3M6MTU6IlRydXN0bGlua0NsaWVudCI7aToxNjtzOjEzOiItPlxzKlNMQ2xpZW50IjtpOjE3O3M6MTY2OiJpc3NldFxzKlwoKlxzKlwkX1NFUlZFUlxzKlxbXHMqWyciXXswLDF9SFRUUF9VU0VSX0FHRU5UWyciXXswLDF9XHMqXF1ccypcKVxzKiYmXHMqXCgqXHMqXCRfU0VSVkVSXHMqXFtccypbJyJdezAsMX1IVFRQX1VTRVJfQUdFTlRbJyJdezAsMX1cXVxzKj09XHMqWyciXXswLDF9TE1QX1JvYm90IjtpOjE4O3M6NDM6IlwkbGlua3MtPlxzKnJldHVybl9saW5rc1xzKlwoKlxzKlwkbGliX3BhdGgiO2k6MTk7czo0NDoiXCRsaW5rc19jbGFzc1xzKj1ccypuZXdccytHZXRfbGlua3NccypcKCpccyoiO2k6MjA7czo1MjoiWyciXXswLDF9XHMqLFxzKlsnIl17MCwxfVwuWyciXXswLDF9XHMqXCkqXHMqO1xzKlw/PiI7aToyMTtzOjc6Imxldml0cmEiO2k6MjI7czoxMDoiZGFwb3hldGluZSI7aToyMztzOjY6InZpYWdyYSI7aToyNDtzOjY6ImNpYWxpcyI7aToyNTtzOjg6InByb3ZpZ2lsIjtpOjI2O3M6MTk6ImNsYXNzXHMrVFdlZmZDbGllbnQiO2k6Mjc7czoxODoibmV3XHMrU0xDbGllbnRcKFwpIjtpOjI4O3M6MjQ6Il9fbGlua2ZlZWRfYmVmb3JlX3RleHRfXyI7aToyOTtzOjE2OiJfX3Rlc3RfdGxfbGlua19fIjtpOjMwO3M6MTg6InM6MTE6ImxtcF9jaGFyc2V0IiI7aTozMTtzOjIwOiI9XHMrbmV3XHMrTUxDbGllbnRcKCI7aTozMjtzOjQ3OiJlbHNlXHMraWZccypcKFxzKlwoXHMqc3RycG9zXChccypcJGxpbmtzX2lwXHMqLCI7fQ=="));
$g_JSVirSig = unserialize(base64_decode("a:113:{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:41:"<iframe\s+src="http://deluxesclicks\.pro/";i:48;s:45:"3Bfor\|fromCharCode\|2C27\|3D\|2C88\|unescape";i:49;s:58:";\s*document\.write\(['"]{0,1}<iframe\s*src="http://ya\.ru";i:50;s:110:"w\.document\.body\.appendChild\(script\);\s*clearInterval\(i\);\s*}\s*}\s*,\s*\d+\s*\)\s*;\s*}\s*\)\(\s*window";i:51;s:110:"if\(!g\(\)&&window\.navigator\.cookieEnabled\){document\.cookie="1=1;expires="\+e\.toGMTString\(\)\+";path=/";";i:52;s:70:"nn_param_preloader_container\|5001\|hidden\|innerHTML\|inject\|visible";i:53;s:31:"<!-- [a-zA-Z0-9_]+?\|\|stat -->";i:54;s:85:"&parameter=\$keyword&se=\$se&ur=1&HTTP_REFERER='\+encodeURIComponent\(document\.URL\)";i:55;s:48:"windows\|series\|60\|symbos\|ce\|mobile\|symbian";i:56;s:35:"\[['"]eval['"]\]\(s\);}}}}</script>";i:57;s:59:"kC70FMblyJkFWZodCKl1WYOdWYUlnQzRnbl1WZsVEdldmL05WZtV3YvRGI9";i:58;s:55:"{k=i;s=s\.concat\(ss\(eval\(asq\(\)\)-1\)\);}z=s;eval\(";i:59;s:130:"document\.cookie\.match\(new\s+RegExp\(\s*"\(\?:\^\|; \)"\s*\+\s*name\.replace\(/\(\[\\\.\$\?\*\|{}\\\(\\\)\\\[\\\]\\/\\\+\^\]\)/g";i:60;s:86:"setCookie\s*\(*\s*"arx_tt"\s*,\s*1\s*,\s*dt\.toGMTString\(\)\s*,\s*['"]{0,1}/['"]{0,1}";i:61;s:144:"document\.cookie\.match\s*\(\s*new\s+RegExp\s*\(\s*"\(\?:\^\|;\s*\)"\s*\+\s*name\.replace\s*\(/\(\[\\\.\$\?\*\|{}\\\(\\\)\\\[\\\]\\/\\\+\^\]\)/g";i:62;s:98:"var\s+dt\s+=\s+new\s+Date\(\),\s+expiryTime\s+=\s+dt\.setTime\(\s+dt\.getTime\(\)\s+\+\s+900000000";i:63;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:64;s:41:"\+=String\.fromCharCode\(parseInt\(0\+'x'";i:65;s:83:"<script\s+language="JavaScript">\s*parent\.window\.opener\.location="http://vk\.com";i:66;s:44:"location\.replace\(['"]{0,1}http://v5k45\.ru";i:67;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:68;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:69;s:60:"if\(t\.length==2\){z\+=String\.fromCharCode\(parseInt\(t\)\+";i:70;s:74:"window\.onload\s*=\s*function\(\)\s*{\s*if\s*\(document\.cookie\.indexOf\(";i:71;s:97:"\.style\.height\s*=\s*['"]{0,1}0px['"]{0,1};window\.onload\s*=\s*function\(\)\s*{document\.cookie";i:72;s:122:"\.src=\(['"]{0,1}htps:['"]{0,1}==document\.location\.protocol\?['"]{0,1}https://ssl['"]{0,1}:['"]{0,1}http://['"]{0,1}\)\+";i:73;s:30:"404\.php['"]{0,1}>\s*</script>";i:74;s:76:"preg_match\(['"]{0,1}/sape/i['"]{0,1}\s*,\s*\$_SERVER\[['"]{0,1}HTTP_REFERER";i:75;s:74:"div\.innerHTML\s*\+=\s*['"]{0,1}<embed\s+id="dummy2"\s+name="dummy2"\s+src";i:76;s:73:"setTimeout\(['"]{0,1}addNewObject\(\)['"]{0,1},\d+\);}}};addNewObject\(\)";i:77;s:51:"\(b=document\)\.head\.appendChild\(b\.createElement";i:78;s:30:"Chrome\|iPad\|iPhone\|IEMobile";i:79;s:19:"\$:\({}\+""\)\[\$\]";i:80;s:53:"{position:absolute;top:-9999px;}</style><div\s+class=";i:81;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:82;s:58:"parent\.window\.opener\.location=['"]{0,1}http://vk\.com\.";i:83;s:41:"\]\.substr\(0,1\)\);}}return this;},\\u00";i:84;s:68:"javascript\|head\|toLowerCase\|chrome\|win\|javaEnabled\|appendChild";i:85;s:21:"loadPNGData\(strFile,";i:86;s:20:"\);if\(!~\(['"]{0,1}";i:87;s:23:"//\s*Some\.devices\.are";i:88;s:55:"stripos\s*\(\s*f_haystack\s*,\s*f_needle\s*,\s*f_offset";i:89;s:32:"window\.onerror\s*=\s*killerrors";i:90;s:105:"check_user_agent=\[\s*['"]{0,1}Lunascape['"]{0,1}\s*,\s*['"]{0,1}iPhone['"]{0,1}\s*,\s*['"]{0,1}Macintosh";i:91;s:153:"document\.write\(['"]{0,1}<['"]{0,1}\+['"]{0,1}i['"]{0,1}\+['"]{0,1}f['"]{0,1}\+['"]{0,1}r['"]{0,1}\+['"]{0,1}a['"]{0,1}\+['"]{0,1}m['"]{0,1}\+['"]{0,1}e";i:92;s:17:"sexfromindia\.com";i:93;s:11:"filekx\.com";i:94;s:13:"stummann\.net";i:95;s:14:"http://xzx\.pm";i:96;s:18:"\.hopto\.me/jquery";i:97;s:11:"mobi-go\.in";i:98;s:18:"bankofamerica\.com";i:99;s:16:"myfilestore\.com";i:100;s:17:"filestore72\.info";i:101;s:16:"file2store\.info";i:102;s:15:"url2short\.info";i:103;s:18:"filestore123\.info";i:104;s:12:"url123\.info";i:105;s:14:"dollarade\.com";i:106;s:11:"secclik\.ru";i:107;s:11:"moby-aa\.ru";i:108;s:12:"servload\.ru";i:109;s:48:"stripos\(navigator\.userAgent\s*,\s*list_data\[i";i:110;s:26:"if\s*\(!see_user_agent\(\)";i:111;s:46:"c\.length\);}return\s*['"]['"];}if\(!getCookie";i:112;s:70:"<script\s*type=['"]{0,1}text/javascript['"]{0,1}\s*src=['"]{0,1}ftp://";}"));
$gX_JSVirSig = unserialize(base64_decode("YToxNTp7aTowO3M6NDg6ImRvY3VtZW50XC53cml0ZVxzKlwoXHMqdW5lc2NhcGVccypcKFsnIl17MCwxfSUzYyI7aToxO3M6Njk6ImRvY3VtZW50XC5nZXRFbGVtZW50c0J5VGFnTmFtZVwoWyciXWhlYWRbJyJdXClcWzBcXVwuYXBwZW5kQ2hpbGRcKGFcKSI7aToyO3M6Mjg6ImlwXChob25lXHxvZFwpXHxpcmlzXHxraW5kbGUiO2k6MztzOjQ4OiJzbWFydHBob25lXHxibGFja2JlcnJ5XHxtdGtcfGJhZGFcfHdpbmRvd3MgcGhvbmUiO2k6NDtzOjQwOiJwb3NpdGlvbjphYnNvbHV0ZTtsZWZ0Oi1cZCtweDt0b3A6LVxkK3B4IjtpOjU7czozMDoiY29tcGFsXHxlbGFpbmVcfGZlbm5lY1x8aGlwdG9wIjtpOjY7czo1NjoiO2M9MX07d2hpbGVcKGMtLVwpe2lmXChrXFtjXF1cKXtwPXBcLnJlcGxhY2VcKG5ldyBSZWdFeHAiO2k6NztzOjM3OiJkb2N1bWVudFwud3JpdGVcKFsnIl08c2NyWyciXVwrWyciXWlwIjtpOjg7czo0OToiaWZyYW1lXC5zdHlsZVwud2lkdGhccyo9XHMqWyciXXswLDF9MHB4WyciXXswLDF9OyI7aTo5O3M6MTAxOiJkb2N1bWVudFwuY2FwdGlvbj1udWxsO3dpbmRvd1wuYWRkRXZlbnRcKFsnIl17MCwxfWxvYWRbJyJdezAsMX0sZnVuY3Rpb25cKFwpe3ZhciBjYXB0aW9uPW5ldyBKQ2FwdGlvbiI7aToxMDtzOjEyOiJodHRwOi8vZnRwXC4iO2k6MTE7czo3OiJubm5cLnBtIjtpOjEyO3M6Nzoibm5tXC5wbSI7aToxMztzOjc4OiI8c2NyaXB0XHMqdHlwZT1bJyJdezAsMX10ZXh0L2phdmFzY3JpcHRbJyJdezAsMX1ccypzcmM9WyciXXswLDF9aHR0cDovL2dvb1wuZ2wiO2k6MTQ7czo2NzoiIlxzKlwrXHMqbmV3IERhdGVcKFwpXC5nZXRUaW1lXChcKTtccypkb2N1bWVudFwuYm9keVwuYXBwZW5kQ2hpbGRcKCI7fQ=="));
$g_PhishingSig = unserialize(base64_decode("YToyNjp7aTowO3M6MjE6Ii1ccypQYXlQYWxccyo8L3RpdGxlPiI7aToxO3M6MTY6Ijx0aXRsZT5QYXlccypQYWwiO2k6MjtzOjIyOiItXHMqUHJpdmF0aVxzKjwvdGl0bGU+IjtpOjM7czoxOToiPHRpdGxlPlxzKlVuaUNyZWRpdCI7aTo0O3M6MTk6IkJhbmtccytvZlxzK0FtZXJpY2EiO2k6NTtzOjI1OiJBbGliYWJhJm5ic3A7TWFudWZhY3R1cmVyIjtpOjY7czoyMDoiVmVyaWZpZWRccytieVxzK1Zpc2EiO2k6NztzOjIxOiJIb25nXHMrTGVvbmdccytPbmxpbmUiO2k6ODtzOjMwOiJZb3VyXHMrYWNjb3VudFxzK1x8XHMrTG9nXHMraW4iO2k6OTtzOjE2OiJPbmxpbmVccytCYW5raW5nIjtpOjEwO3M6MTQ6Ik9ubGluZS1CYW5raW5nIjtpOjExO3M6MjI6IlNpZ25ccytpblxzK3RvXHMrWWFob28iO2k6MTI7czoxMToiQkFOQ09MT01CSUEiO2k6MTM7czoxNjoiPHRpdGxlPlxzKkFtYXpvbiI7aToxNDtzOjE1OiI8dGl0bGU+XHMqQXBwbGUiO2k6MTU7czoyMjoiPHRpdGxlPkdvb2dsZVxzK1NlY3VyZSI7aToxNjtzOjI4OiI8dGl0bGU+TWVyYWtccytNYWlsXHMrU2VydmVyIjtpOjE3O3M6MjM6Ijx0aXRsZT5Tb2NrZXRccytXZWJtYWlsIjtpOjE4O3M6MTg6Ijx0aXRsZT5cW0xfUVVFUllcXSI7aToxOTtzOjMxOiI8dGl0bGU+QU5aXHMrSW50ZXJuZXRccytCYW5raW5nIjtpOjIwO3M6MzM6ImNvbVwud2Vic3RlcmJhbmtcLnNlcnZsZXRzXC5Mb2dpbiI7aToyMTtzOjE1OiI8dGl0bGU+XHMqR21haWwiO2k6MjI7czoyNjoiU29jaWFsXHMrU2VjdXJpdHlccytOdW1iZXIiO2k6MjM7czozNjoiXGQrO1VSTD1odHRwczovL3d3d1wud2VsbHNmYXJnb1wuY29tIjtpOjI0O3M6MTg6Ijx0aXRsZT5XZWxscyBGYXJnbyI7aToyNTtzOjQ5OiJwcm9wZXJ0eT0ib2c6c2l0ZV9uYW1lIlxzKmNvbnRlbnQ9IkZhY2Vib29rIlxzKi8+Ijt9"));
//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', 'LICENSE.php', 'LICENSES.php', 'backup.+?.zip',
'backup.+?.tar.gz', 'backup.+?.tgz',
'phpinfo.php', 'changelog.txt', 'readme.txt', 'INSTALLATION.php', 'dump.sql', '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', '20140813');
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_Phishing = 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);
srand(time());
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);
}
}
define('CMS_BITRIX', 'Bitrix');
define('CMS_WORDPRESS', 'Wordpress');
define('CMS_JOOMLA', 'Joomla');
define('CMS_DLE', 'Data Life Engine');
define('CMS_IPB', 'Invision Power Board');
define('CMS_WEBASYST', 'WebAsyst');
define('CMS_OSCOMMERCE', 'OsCommerce');
define('CMS_DRUPAL', 'Drupal');
define('CMS_MODX', 'MODX');
define('CMS_INSTANTCMS', 'Instant CMS');
define('CMS_PHPBB', 'PhpBB');
define('CMS_VBULLETIN', 'vBulletin');
define('CMS_SHOPSCRIPT', 'PHP ShopScript Premium');
define('CMS_VERSION_UNDEFINED', '0.0');
class CmsVersionDetector {
private $root_path;
private $versions;
private $types;
public function __construct($root_path = '.') {
$this->root_path = $root_path;
$this->versions = array();
$this->types = array();
$version = '';
if ($this->checkBitrix($version)) {
$this->addCms(CMS_BITRIX, $version);
}
if ($this->checkWordpress($version)) {
$this->addCms(CMS_WORDPRESS, $version);
}
if ($this->checkJoomla($version)) {
$this->addCms(CMS_JOOMLA, $version);
}
if ($this->checkDle($version)) {
$this->addCms(CMS_DLE, $version);
}
if ($this->checkIpb($version)) {
$this->addCms(CMS_IPB, $version);
}
if ($this->checkWebAsyst($version)) {
$this->addCms(CMS_WEBASYST, $version);
}
if ($this->checkOsCommerce($version)) {
$this->addCms(CMS_OSCOMMERCE, $version);
}
if ($this->checkDrupal($version)) {
$this->addCms(CMS_DRUPAL, $version);
}
if ($this->checkMODX($version)) {
$this->addCms(CMS_MODX, $version);
}
if ($this->checkInstantCms($version)) {
$this->addCms(CMS_INSTANTCMS, $version);
}
if ($this->checkPhpBb($version)) {
$this->addCms(CMS_PHPBB, $version);
}
if ($this->checkVBulletin($version)) {
$this->addCms(CMS_VBULLETIN, $version);
}
if ($this->checkPhpShopScript($version)) {
$this->addCms(CMS_SHOPSCRIPT, $version);
}
}
function getCmsList() {
return $this->types;
}
function getCmsVersions() {
return $this->versions;
}
function getCmsNumber() {
return count($this->types);
}
function getCmsName($index = 0) {
return $this->types[$index];
}
function getCmsVersion($index = 0) {
return $this->versions[$index];
}
private function addCms($type, $version) {
$this->types[] = $type;
$this->versions[] = $version;
}
private function checkBitrix(&$version) {
$version = CMS_VERSION_UNDEFINED;
$res = false;
if (file_exists($this->root_path .'/bitrix')) {
$res = true;
$tmp_content = @implode('', @file($this->root_path .'/bitrix/modules/main/classes/general/version.php'));
if (preg_match('|define("SM_VERSION","(.+?)")|smi', $tmp_content, $tmp_ver)) {
$version = $tmp_ver[1];
}
}
return $res;
}
private function checkWordpress(&$version) {
$version = CMS_VERSION_UNDEFINED;
$res = false;
if (file_exists($this->root_path .'/wp-admin')) {
$res = true;
$tmp_content = @implode('', @file($this->root_path .'/wp-includes/version.php'));
if (preg_match('|$wp_versions*=s*'(.+?)'|smi', $tmp_content, $tmp_ver)) {
$version = $tmp_ver[1];
}
}
return $res;
}
private function checkJoomla(&$version) {
$version = CMS_VERSION_UNDEFINED;
$res = false;
if (file_exists($this->root_path .'/libraries/joomla')) {
$res = true;
// for 1.5.x
$tmp_content = @implode('', @file($this->root_path .'/libraries/joomla/version.php'));
if (preg_match('|vars+$RELEASEs*=s*'(.+?)'|smi', $tmp_content, $tmp_ver)) {
$version = $tmp_ver[1];
if (preg_match('|vars+$DEV_LEVELs*=s*'(.+?)'|smi', $tmp_content, $tmp_ver)) {
$version .= '.' . $tmp_ver[1];
}
}
// for 1.7.x
$tmp_content = @implode('', @file($this->root_path .'/includes/version.php'));
if (preg_match('|publics+$RELEASEs*=s*'(.+?)'|smi', $tmp_content, $tmp_ver)) {
$version = $tmp_ver[1];
if (preg_match('|publics+$DEV_LEVELs*=s*'(.+?)'|smi', $tmp_content, $tmp_ver)) {
$version .= '.' . $tmp_ver[1];
}
}
// for 2.5.x and 3.x
$tmp_content = @implode('', @file($this->root_path .'/libraries/cms/version/version.php'));
if (preg_match('|publics+$RELEASEs*=s*'(.+?)'|smi', $tmp_content, $tmp_ver)) {
$version = $tmp_ver[1];
if (preg_match('|publics+$DEV_LEVELs*=s*'(.+?)'|smi', $tmp_content, $tmp_ver)) {
$version .= '.' . $tmp_ver[1];
}
}
}
return $res;
}
private function checkDle(&$version) {
$version = CMS_VERSION_UNDEFINED;
$res = false;
if (file_exists($this->root_path .'/engine/engine.php')) {
$res = true;
$tmp_content = @implode('', @file($this->root_path .'/engine/data/config.php'));
if (preg_match('|'version_id's*=>s*"(.+?)"|smi', $tmp_content, $tmp_ver)) {
$version = $tmp_ver[1];
}
$tmp_content = @implode('', @file($this->root_path .'/install.php'));
if (preg_match('|'version_id's*=>s*"(.+?)"|smi', $tmp_content, $tmp_ver)) {
$version = $tmp_ver[1];
}
}
return $res;
}
private function checkIpb(&$version) {
$version = CMS_VERSION_UNDEFINED;
$res = false;
if (file_exists($this->root_path .'/ips_kernel')) {
$res = true;
$tmp_content = @implode('', @file($this->root_path .'/ips_kernel/class_xml.php'));
if (preg_match('|IP.Boards+v([0-9.]+)|si', $tmp_content, $tmp_ver)) {
$version = $tmp_ver[1];
}
}
return $res;
}
private function checkWebAsyst(&$version) {
$version = CMS_VERSION_UNDEFINED;
$res = false;
if (file_exists($this->root_path .'/wbs/installer')) {
$res = true;
$tmp_content = @implode('', @file($this->root_path .'/license.txt'));
if (preg_match('|v([0-9.]+)|si', $tmp_content, $tmp_ver)) {
$version = $tmp_ver[1];
}
}
return $res;
}
private function checkOsCommerce(&$version) {
$version = CMS_VERSION_UNDEFINED;
$res = false;
if (file_exists($this->root_path .'/includes/version.php')) {
$res = true;
$tmp_content = @implode('', @file($this->root_path .'/includes/version.php'));
if (preg_match('|([0-9.]+)|smi', $tmp_content, $tmp_ver)) {
$version = $tmp_ver[1];
}
}
return $res;
}
private function checkDrupal(&$version) {
$version = CMS_VERSION_UNDEFINED;
$res = false;
if (file_exists($this->root_path .'/sites/all')) {
$res = true;
$tmp_content = @implode('', @file($this->root_path .'/CHANGELOG.txt'));
if (preg_match('|Drupals+([0-9.]+)|smi', $tmp_content, $tmp_ver)) {
$version = $tmp_ver[1];
}
}
return $res;
}
private function checkMODX(&$version) {
$version = CMS_VERSION_UNDEFINED;
$res = false;
if (file_exists($this->root_path .'/manager/assets')) {
$res = true;
// no way to pick up version
}
return $res;
}
private function checkInstantCms(&$version) {
$version = CMS_VERSION_UNDEFINED;
$res = false;
if (file_exists($this->root_path .'/plugins/p_usertab')) {
$res = true;
$tmp_content = @implode('', @file($this->root_path .'/index.php'));
if (preg_match('|InstantCMSs+v([0-9.]+)|smi', $tmp_content, $tmp_ver)) {
$version = $tmp_ver[1];
}
}
return $res;
}
private function checkPhpBb(&$version) {
$version = CMS_VERSION_UNDEFINED;
$res = false;
if (file_exists($this->root_path .'/includes/acp')) {
$res = true;
$tmp_content = @implode('', @file($this->root_path .'/config.php'));
if (preg_match('|phpBBs+([0-9.x]+)|smi', $tmp_content, $tmp_ver)) {
$version = $tmp_ver[1];
}
}
return $res;
}
private function checkVBulletin(&$version) {
$version = CMS_VERSION_UNDEFINED;
$res = false;
if (file_exists($this->root_path .'/core/admincp')) {
$res = true;
$tmp_content = @implode('', @file($this->root_path .'/core/api.php'));
if (preg_match('|vBulletins+([0-9.x]+)|smi', $tmp_content, $tmp_ver)) {
$version = $tmp_ver[1];
}
}
return $res;
}
private function checkPhpShopScript(&$version) {
$version = CMS_VERSION_UNDEFINED;
$res = false;
if (file_exists($this->root_path .'/install/consts.php')) {
$res = true;
$tmp_content = @implode('', @file($this->root_path .'/install/consts.php'));
if (preg_match('|STRING_VERSION',s*'(.+?)'|smi', $tmp_content, $tmp_ver)) {
$version = $tmp_ver[1];
}
}
return $res;
}
}
/**
* 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 myCheckSum($str) {
return str_replace('-', 'x', crc32($str));
}
/*
*
*/
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)
{
global $g_CriticalPHP, $g_Base64, $g_Phishing, $g_CriticalJS, $g_Iframer;
$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) : '') . '] [Mlw:' . (count($g_CriticalPHP) + count($g_Base64)) . '|' . (count($g_CriticalJS) + count($g_Iframer) + count($g_Phishing)) . ']';
}
}
$l_FN = substr($par_File, -60);
$text = "[$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:',
'l:' => 'list:',
'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']}
-j, --file=FILE Specified path and filename to scan the only file
-l, --list=FILE Full path and filename to create plain text file with a list of found malware
-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/EMAILS
Full path to create report or email address to send report to.
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
* Mandatory arguments listed below are required for both full and short way of usage.
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['list']) AND !empty($options['list']) AND ($file = $options['list']) !== false)
OR (isset($options['l']) AND !empty($options['l']) AND ($file = $options['l']) !== false)
)
{
define('PLAIN_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;
}
}
if (!defined('PLAIN_FILE')) { define('PLAIN_FILE', ''); }
// 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" title="currentStyle">
@import "http://www.revisium.com/extra/media/css/demo_page.css";
@import "http://www.revisium.com/extra/media/css/jquery.dataTables.css";
</style>
<script type="text/javascript" language="javascript" src="http://yandex.st/jquery/2.1.0/jquery.min.js"></script>
<script type="text/javascript" language="javascript" src="https://datatables.net/download/build/jquery.dataTables.js"></script>
<style type="text/css">
body {
font-family: Georgia;
color: #303030;
background: #FFFFF0;
font-size: 12px;
margin: 20px;
padding: 0;
}
.hidd {
display: none;
}
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: 20px;
top: 54px;
background: #E06060;
color: white;
font-size: 11px;
font-family: Arial;
padding: 15px 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';
}
function hsig(id) {
var divs = document.getElementsByTagName("tr");
for(var i = 0; i < divs.length; i++){
if (divs[i].getAttribute('o') == id) {
divs[i].innerHTML = '';
}
}
return false;
}
</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 == 0) {
$l_Result .= '<div class="updateinfo">' . AI_STR_057 . '</div>';
} else {
$l_Result .= '<div style="font-size: 8px; color: #909090; margin: 10px 0 10px 0;">MODE=' . AI_EXPERT . '</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, $par_SigId = null, $par_TableName = null) {
global $g_Structure;
if ($par_TableName == null) {
$par_TableName = 'table_' . rand(1000000,9000000);
}
$l_Result = '';
$l_Result .= "<div class="flist"><table cellspacing=1 cellpadding=4 border=0 id="" . $par_TableName . "">";
$l_Result .= "<thead><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 .= "<th width=0></th>";
$l_Result .= "<th width=0></th>";
$l_Result .= "<th width=0></th>";
$l_Result .= "</tr></thead><tbody>";
for ($i = 0; $i < count($par_List); $i++) {
if ($par_SigId != null) {
$l_SigId = 'id_' . $par_SigId[$i];
} else {
$l_SigId = 'id_z' . rand(1000000,9000000);
}
$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_WithMarker = preg_replace('|@AI_MARKER@|smi', '<span class="marker">|</span>', $par_Details[$i]);
$l_Body = '<div class="details">';
if ($par_SigId != null) {
$l_Body .= '<a href="#" onclick="return hsig('' . $l_SigId . '')">[x]</a> ';
}
$l_Body .= $l_WithMarker . '</div>';
} else {
$l_Body = '';
}
$l_Result .= '<tr class="tbg' . ( $i % 2 ). '" o="' . $l_SigId .'">';
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 .= '<td class="hidd"><div class="hidd">' . $g_Structure['c'][$l_Pos] . '</div></td>';
$l_Result .= '<td class="hidd"><div class="hidd">' . $g_Structure['m'][$l_Pos] . '</div></td>';
$l_Result .= '<td class="hidd"><div class="hidd">' . $l_SigId . '</div></td>';
$l_Result .= '</tr>';
}
$l_Result .= "</tbody></table></div>";
return $l_Result;
}
///////////////////////////////////////////////////////////////////////////
function printPlainList($par_List, $par_Details = null, $par_NeedIgnore = false, $par_SigId = null, $par_TableName = null) {
global $g_Structure;
// $l_Result = "n#n";
$l_Src = array('"', '<', '>', '&');
$l_Dst = array('"', '<', '>', '&');
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;
}
}
if ($par_Details != null) {
$l_Body = preg_replace('|(Ld+).+@AI_MARKER@|smi', '$1: ...', $par_Details[$i]);
$l_Body = preg_replace('/[^x21-x7F]/', '.', $l_Body);
$l_Body = str_replace($l_Src, $l_Dst, $l_Body);
} else {
$l_Body = '';
}
if (is_file($g_Structure['n'][$l_Pos])) {
$l_Result .= $g_Structure['n'][$l_Pos] . "ttt" . $l_Body . "n";
} else {
$l_Result .= $g_Structure['n'][$par_List[$i]] . "n";
}
}
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("n" . date('H:i:s') . ': ' . $par_Str . $l_MemInfo . "n");
}
///////////////////////////////////////////////////////////////////////////
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_FoundStart = substr($par_Content, 0, $par_Pos);
$l_FoundStart = str_replace("r", '', $l_FoundStart);
$l_LineNo = strlen($l_FoundStart) - strlen(str_replace("n", '', $l_FoundStart)) + 1;
$l_Res = 'L' . $l_LineNo . " " . ($l_MinPos > 0 ? '...' : '') . 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 _utf8_decode($string)
{
$tmp = $string;
$count = 0;
while (detect_utf_encoding($tmp) !== false )
{
$tmp = utf8_decode($tmp);
$count++;
}
for ($i = 0; $i < $count-1 ; $i++)
{
$string = utf8_decode($string);
}
return $string;
}
///////////////////////////////////////////////////////////////////////////
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;
}
///////////////////////////////////////////////////////////////////////////
// Unicode BOM is U+FEFF, but after encoded, it will look like this.
define ('UTF32_BIG_ENDIAN_BOM' , chr(0x00) . chr(0x00) . chr(0xFE) . chr(0xFF));
define ('UTF32_LITTLE_ENDIAN_BOM', chr(0xFF) . chr(0xFE) . chr(0x00) . chr(0x00));
define ('UTF16_BIG_ENDIAN_BOM' , chr(0xFE) . chr(0xFF));
define ('UTF16_LITTLE_ENDIAN_BOM', chr(0xFF) . chr(0xFE));
define ('UTF8_BOM' , chr(0xEF) . chr(0xBB) . chr(0xBF));
function detect_utf_encoding($text) {
$first2 = substr($text, 0, 2);
$first3 = substr($text, 0, 3);
$first4 = substr($text, 0, 3);
if ($first3 == UTF8_BOM) return 'UTF-8';
elseif ($first4 == UTF32_BIG_ENDIAN_BOM) return 'UTF-32BE';
elseif ($first4 == UTF32_LITTLE_ENDIAN_BOM) return 'UTF-32LE';
elseif ($first2 == UTF16_BIG_ENDIAN_BOM) return 'UTF-16BE';
elseif ($first2 == UTF16_LITTLE_ENDIAN_BOM) return 'UTF-16LE';
return false;
}
///////////////////////////////////////////////////////////////////////////
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("/(<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_HeuristicType, $g_HeuristicDetected, $g_TotalFolder, $g_TotalFiles, $g_WarningPHP, $g_AdwareList,
$g_CriticalPHP, $g_Phishing, $g_CriticalJS, $g_UrlIgnoreList, $g_CriticalJSFragment, $g_PHPCodeInside, $g_PHPCodeInsideFragment,
$g_NotRead, $g_WarningPHPFragment, $g_WarningPHPSig, $g_BigFiles, $g_RedirectPHPFragment, $g_EmptyLinkSrc, $g_CriticalPHPSig, $g_CriticalPHPFragment,
$g_Base64Fragment, $g_UnixExec, $g_PhishingSigFragment, $g_PhishingFragment, $g_PhishingSig, $g_CriticalJSSig, $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);
$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 (detect_utf_encoding($l_Content) !== false) {
if (function_exists('mb_convert_encoding')) {
$l_Unwrapped = mb_convert_encoding($l_Unwrapped, "CP1251");
} else {
$g_NotRead[] = $i;
}
}
// ignore itself
if (strpos($l_Content, 'OI87547623YUIOIUYIOYHJW') !== false) {
continue;
}
// warnings
$l_Pos = '';
if (WarningPHP($l_Filename, $l_Unwrapped, $l_Pos, $l_SigId))
{ $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);
$g_WarningPHPSig[] = $l_SigId;
}
// 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, $l_SigId))
{
$g_CriticalPHP[] = $i;
$g_CriticalPHPFragment[] = getFragment($l_Unwrapped, $l_Pos);
$g_CriticalPHPSig[] = $l_SigId;
$g_SkipNextCheck = true;
} else {
if (CriticalPHP($l_Filename, $i, $l_Content, $l_Pos, $l_SigId))
{
$g_CriticalPHP[] = $i;
$g_CriticalPHPFragment[] = getFragment($l_Content, $l_Pos);
$g_CriticalPHPSig[] = $l_SigId;
$g_SkipNextCheck = true;
}
}
// critical without comments
$l_NoComments = preg_replace('|/*.*?*/|smiu', '', $l_Unwrapped);
if ($l_NoComments == $l_Unwrapped) {
$g_SkipNextCheck = true;
}
if ((!$g_SkipNextCheck) && CriticalPHP($l_Filename, $i, $l_NoComments, $l_Pos, $l_SigId))
{
$g_CriticalPHP[] = $i;
$g_CriticalPHPFragment[] = getFragment($l_Unwrapped, $l_Pos);
$g_CriticalPHPSig[] = $l_SigId;
}
$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, $l_SigId);
if ($l_Pos !== false)
{
$g_CriticalJS[] = $i;
$g_CriticalJSFragment[] = getFragment($l_Unwrapped, $l_Pos);
$g_CriticalJSSig[] = $l_SigId;
}
// phishing
$l_Pos = Phishing($l_Filename, $i, $l_Unwrapped, $l_SigId);
if ($l_Pos !== false)
{
$g_Phishing[] = $i;
$g_PhishingFragment[] = getFragment($l_Unwrapped, $l_Pos);
$g_PhishingSigFragment[] = $l_SigId;
}
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, &$l_SigId)
{
global $g_SusDB;
$l_Res = false;
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];
$l_SigId = myCheckSum($l_Item);
return true;
}
}
}
return $l_Res;
}
///////////////////////////////////////////////////////////////////////////
function Adware($l_FN, $l_Content, &$l_Pos)
{
global $g_AdwareSig;
$l_Res = false;
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];
return true;
}
}
}
return $l_Res;
}
///////////////////////////////////////////////////////////////////////////
function CheckException(&$l_Content, &$l_Found) {
global $g_ExceptFlex, $gX_FlexDBShe, $gXX_FlexDBShe, $g_FlexDBShe, $gX_DBShe, $g_DBShe, $g_Base64, $g_Base64Fragment;
$l_FoundStrPlus = substr($l_Content, max($l_Found[0][1] - 10, 0), 70);
foreach ($g_ExceptFlex as $l_ExceptItem) {
if (preg_match('#(' . $l_ExceptItem . ')#smi', $l_FoundStrPlus, $l_Detected)) {
$l_Exception = true;
return true;
}
}
return false;
}
///////////////////////////////////////////////////////////////////////////
function Phishing($l_FN, $l_Index, $l_Content, &$l_SigId)
{
global $g_PhishingSig;
$l_Res = false;
foreach ($g_PhishingSig 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];
$l_SigId = myCheckSum($l_Item);
if (DEBUG_MODE) {
echo "Phis: $l_FN matched [$l_Item] in $l_Posn";
}
return $l_Pos;
}
}
}
return $l_Res;
}
///////////////////////////////////////////////////////////////////////////
function CriticalJS($l_FN, $l_Index, $l_Content, &$l_SigId)
{
global $g_JSVirSig, $gX_JSVirSig;
$l_Res = false;
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];
$l_SigId = myCheckSum($l_Item);
if (DEBUG_MODE) {
echo "JS: $l_FN matched [$l_Item] in $l_Posn";
}
return $l_Pos;
}
}
}
if (AI_EXPERT > 1) {
foreach ($gX_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];
$l_SigId = myCheckSum($l_Item);
if (DEBUG_MODE) {
echo "JS PARA: $l_FN matched [$l_Item] in $l_Posn";
}
return $l_Pos;
}
}
}
}
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, &$l_SigId)
{
global $g_ExceptFlex, $gXX_FlexDBShe, $gX_FlexDBShe, $g_FlexDBShe, $gX_DBShe, $g_DBShe, $g_Base64, $g_Base64Fragment;
// OI87547623YUIOIUYIOYHJW
foreach ($g_FlexDBShe 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];
$l_SigId = myCheckSum($l_Item);
if (DEBUG_MODE) {
echo "CRIT 1: $l_FN matched [$l_Item] in $l_Posn";
}
return true;
}
}
}
if (AI_EXPERT > 1) {
foreach ($gXX_FlexDBShe 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];
$l_SigId = myCheckSum($l_Item);
if (DEBUG_MODE) {
echo "CRIT 2: $l_FN matched [$l_Item] in $l_Posn";
}
return true;
}
}
}
}
if (AI_EXPERT > 0) {
foreach ($gX_FlexDBShe 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];
$l_SigId = myCheckSum($l_Item);
if (DEBUG_MODE) {
echo "CRIT 3: $l_FN matched [$l_Item] in $l_Posn";
}
return true;
}
}
}
}
foreach ($g_DBShe as $l_Item) {
$l_Pos = stripos($l_Content, $l_Item);
if ($l_Pos !== false) {
$l_SigId = myCheckSum($l_Item);
if (DEBUG_MODE) {
echo "CRIT 4: $l_FN matched [$l_Item] in $l_Posn";
}
return true;
}
}
if (AI_EXPERT) {
foreach ($gX_DBShe as $l_Item) {
$l_Pos = stripos($l_Content, $l_Item);
if ($l_Pos !== false) {
$l_SigId = myCheckSum($l_Item);
if (DEBUG_MODE) {
echo "CRIT 5: $l_FN matched [$l_Item] in $l_Posn";
}
return true;
}
}
if ((strpos($l_FN, '.ph') !== false) && (AI_EXPERT > 1)) {
// for php only
$g_Specials = array(');#');
foreach ($g_Specials as $l_Item) {
$l_Pos = stripos($l_Content, $l_Item);
if ($l_Pos !== false) {
$l_SigId = myCheckSum($l_Item);
return true;
}
}
}
}
if ((strpos($l_Content, 'GIF89') === 0) && (strpos($l_FN, '.php') !== false )) {
$l_Pos = 0;
if (DEBUG_MODE) {
echo "CRIT 6: $l_FN matched [$l_Item] in $l_Posn";
}
return true;
}
if (strpos($l_FN, '.php.') !== false ) {
$g_Base64[] = $l_Index;
$g_Base64Fragment[] = '".php."';
$l_Pos = 0;
if (DEBUG_MODE) {
echo "CRIT 7: $l_FN matched [$l_Item] in $l_Posn";
}
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);
if (DEBUG_MODE) {
echo "CRIT 8: $l_FN matchedn";
}
}
// detect base64 suspicious
if (preg_match('|([A-Za-z0-9+/]{' . BASE64_LENGTH . ',})|smi', $l_Content, $l_Found, PREG_OFFSET_CAPTURE)) {
if (preg_match('#base64_decodes*(#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 (DEBUG_MODE) {
echo "CRIT 9: $l_FN matchedn";
}
}
}
}
// 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'));
if (DEBUG_MODE) {
echo "CRIT 10: $l_FN matchedn";
}
}
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();
$g_AiBolitAbsolutePath = dirname(__FILE__);
$l_IgnoreFilename = $g_AiBolitAbsolutePath . '/.aignore';
$l_DirIgnoreFilename = $g_AiBolitAbsolutePath . '/.adirignore';
$l_UrlIgnoreFilename = $g_AiBolitAbsolutePath . '/.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]);
}
}
$g_AiBolitAbsolutePathKnownFiles = dirname($g_AiBolitAbsolutePath) . '/known_files';
$g_AiBolitKnownFilesDirs = array('.');
if ($l_DIRH = opendir($g_AiBolitAbsolutePathKnownFiles))
{
while (($l_FileName = readdir($l_DIRH)) !== false)
{
if ($l_FileName == '.' || $l_FileName == '..') continue;
array_push($g_AiBolitKnownFilesDirs, $l_FileName);
}
closedir($l_DIRH);
}
foreach ($g_AiBolitKnownFilesDirs as $l_PathKnownFiles)
{
if ($l_PathKnownFiles != '.') {
$l_AbsolutePathKnownFiles = $g_AiBolitAbsolutePathKnownFiles . '/' . $l_PathKnownFiles;
} else {
$l_AbsolutePathKnownFiles = $l_PathKnownFiles;
}
if ($l_DIRH = opendir($l_AbsolutePathKnownFiles))
{
while (($l_FileName = readdir($l_DIRH)) !== false)
{
if ($l_FileName == '.' || $l_FileName == '..') continue;
if (strpos($l_FileName, $l_KnownFilename) !== false) {
$g_KnownListTmp = file($l_AbsolutePathKnownFiles . '/' . $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_FHList = fopen(DOUBLECHECK_FILE, "r");
while(!feof($l_FHList)) {
$l_FN = trim(fgets($l_FHList));
if (file_exists($l_FN)) {
QCR_ScanFile($l_FN);
}
}
fclose($l_FHList);
} else {
// scan whole file system
stdOut("Start scanning '" . ROOT_PATH . "'.");
QCR_ScanDirectories(ROOT_PATH);
}
}
$g_FoundTotalFiles = count($g_Structure['n']);
QCR_Debug();
stdOut("Found $g_FoundTotalFiles files in $g_FoundTotalDirs directories.");
stdOut(str_repeat(' ', 160),false);
$g_FoundTotalFiles = count($g_Structure['n']);
// detect version CMS
$l_CmsListDetector = new CmsVersionDetector('.');
$l_CmsDetectedNum = $l_CmsListDetector->getCmsNumber();
for ($tt = 0; $tt < $l_CmsDetectedNum; $tt++) {
$g_CMS[] = $l_CmsListDetector->getCmsName($tt) . ' v' . $l_CmsListDetector->getCmsVersion($tt);
}
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_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 (function_exists("gethostname") && is_callable("gethostname")) {
$l_HostName = gethostname();
} else {
$l_HostName = '???';
}
$l_PlainResult = "# Malware list detected by AI-Bolit (http://revisium.com/ai/) on " . date("d/m/Y H:i:s", time()) . " " . $l_HostName . "nn";
if (count($g_CriticalPHP) > 0) {
$l_Result .= '<div class="vir"><b>' . AI_STR_016 . '</b> (' . count($g_CriticalPHP) . ')';
$l_Result .= printList($g_CriticalPHP, $g_CriticalPHPFragment, true, $g_CriticalPHPSig, 'table_crit');
$l_PlainResult .= printPlainList($g_CriticalPHP, $g_CriticalPHPFragment, true, $g_CriticalPHPSig, 'table_crit');
$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> (' . count($g_CriticalJS) . ')';
$l_Result .= printList($g_CriticalJS, $g_CriticalJSFragment, true, $g_CriticalJSSig, 'table_vir');
$l_PlainResult .= printPlainList($g_CriticalJS, $g_CriticalJSFragment, true, $g_CriticalJSSig, 'table_vir');
$l_Result .= "</div>";
$l_ShowOffer = true;
}
stdOut("Building phishing pages " . count($g_Phishing));
if (count($g_Phishing) > 0) {
$l_Result .= '<div class="vir"><b>' . AI_STR_058 . '</b> (' . count($g_Phishing) . ')';
$l_Result .= printList($g_Phishing, $g_PhishingFragment, true, $g_PhishingSigFragment, 'table_vir');
$l_PlainResult .= printPlainList($g_Phishing, $g_PhishingFragment, true, $g_PhishingSigFragment, 'table_vir');
$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> (" . count($g_UnixExec) . ')';
$l_Result .= printList($g_UnixExec, '', true);
$l_PlainResult .= printPlainList($g_UnixExec, '', true);
$l_Result .= "</div>";
$l_ShowOffer = true;
}
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> (" . count($g_Iframer) . ')';
$l_Result .= printList($g_Iframer, $g_IframerFragment, true);
$l_Result .= "</div>";
}
stdOut("Building list of base64s " . count($g_Base64));
if (count($g_Base64) > 0) {
$l_ShowOffer = true;
$l_Result .= "<div class="warn"><b>" . AI_STR_020 ."</b> (" . count($g_Base64) . ')';
$l_Result .= printList($g_Base64, $g_Base64Fragment, true);
$l_PlainResult .= printPlainList($g_Base64, $g_Base64Fragment, 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 unread files " . count($g_NotRead));
if (count($g_NotRead) > 0) {
$l_ShowOffer = true;
$l_Result .= "<div class="vir"><b>" . AI_STR_030 . ":</b>";
$l_Result .= printList($g_NotRead);
$l_Result .= "</div>";
}
stdOut("Building list of symlinks " . count($g_SymLinks));
if (count($g_SymLinks) > 0) {
$l_Result .= "<div class="warn"><b>" . AI_STR_022 . "</b> (" . count($g_SymLinks) .")<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> (" . count($g_HiddenFiles) . ")<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 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, $g_WarningPHPSig, 'table_warn');
}
$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 .= 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 .= '<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>';
}
$l_Result .=<<<ENDING
</body>
<script language="javascript">
$(document).ready(function(){
$('#table_crit').dataTable({
"aLengthMenu": [[100 , 500, -1], [100, 500, "All"]],
"aoColumns": [
{"iDataSort": 7},
{"iDataSort": 5},
{"iDataSort": 6},
{"bSortable": true},
{"bSortable": true},
{"bVisible": false},
{"bVisible": false},
{"bVisible": false}
],
"iDisplayLength": 500,
"oLanguage": {
"sLengthMenu": "Отображать по _MENU_ записей",
"sZeroRecords": "Ничего не найдено",
"sInfo": "Отображается c _START_ по _END_ из _TOTAL_ файлов",
"sInfoEmpty": "Нет файлов",
"sInfoFiltered": "(всего записей _MAX_)",
"sSearch": "Поиск:",
"sUrl": "",
"oPaginate": {
"sFirst": "Первая",
"sPrevious": "Предыдущая",
"sNext": "Следующая",
"sLast": "Последняя"
},
"oAria": {
"sSortAscending": ": активировать для сортировки столбца по возрастанию",
"sSortDescending": ": активировать для сортировки столбцов по убыванию"
}
}
} );
});
$(document).ready(function(){
$('#table_vir').dataTable({
"aLengthMenu": [[100 , 500, -1], [100, 500, "All"]],
"aoColumns": [
{"iDataSort": 7},
{"iDataSort": 5},
{"iDataSort": 6},
{"bSortable": true},
{"bSortable": true},
{"bVisible": false},
{"bVisible": false},
{"bVisible": false}
],
"iDisplayLength": 500,
"oLanguage": {
"sLengthMenu": "Отображать по _MENU_ записей",
"sZeroRecords": "Ничего не найдено",
"sInfo": "Отображается c _START_ по _END_ из _TOTAL_ файлов",
"sInfoEmpty": "Нет файлов",
"sInfoFiltered": "(всего записей _MAX_)",
"sSearch": "Поиск:",
"sUrl": "",
"oPaginate": {
"sFirst": "Первая",
"sPrevious": "Предыдущая",
"sNext": "Следующая",
"sLast": "Последняя"
},
"oAria": {
"sSortAscending": ": активировать для сортировки столбца по возрастанию",
"sSortDescending": ": активировать для сортировки столбцов по убыванию"
}
},
} );
});
$('#table_warn').dataTable({
"aLengthMenu": [[100 , 500, -1], [100, 500, "All"]],
"aoColumns": [
{"iDataSort": 7},
{"iDataSort": 5},
{"iDataSort": 6},
{"bSortable": true},
{"bSortable": true},
{"bVisible": false},
{"bVisible": false},
{"bVisible": false}
],
"iDisplayLength": 500,
"oLanguage": {
"sLengthMenu": "Отображать по _MENU_ записей",
"sZeroRecords": "Ничего не найдено",
"sInfo": "Отображается c _START_ по _END_ из _TOTAL_ файлов",
"sInfoEmpty": "Нет файлов",
"sInfoFiltered": "(всего записей _MAX_)",
"sSearch": "Поиск:",
"sUrl": "",
"oPaginate": {
"sFirst": "Первая",
"sPrevious": "Предыдущая",
"sNext": "Следующая",
"sLast": "Последняя"
},
"oAria": {
"sSortAscending": ": активировать для сортировки столбца по возрастанию",
"sSortDescending": ": активировать для сортировки столбцов по убыванию"
}
}
} );
</script>
</html>
ENDING;
////////////////////////////////////////////////////////////////////////////
if (!isCli())
{
echo $l_Result;
exit;
}
if (!defined('REPORT') OR REPORT === '')
{
die('Report not written.');
}
// write plain text result
if (PLAIN_FILE != '') {
if ($l_FH = fopen(PLAIN_FILE, "w")) {
fputs($l_FH, $l_PlainResult);
fclose($l_FH);
}
}
$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();
?>