Файл: 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();
?>