'$2y$10$HNSzIP6lfXutPzV/YkLIoOKk4YssqqEchrsLHJXQMqV7pf5qMhEwK',);$g=array('user');$h=false;$j=array();$m=true;$n='vs';$o=true;$q='Etc/UTC';$r=$_SERVER['DOCUMENT_ROOT'];$s='';$t=$_SERVER['HTTP_HOST'];$u='UTF-8';$w='m/d/Y g:i A';$y='';$z='';$aa='';$bb=array();$cc='google';$dd=true;$ee=5000000000;$ff=2000000;$gg='OFF';$hh=true;$jj=array('127.0.0.1','::1');$kk=array('0.0.0.0','::');$ll=array('css-bootstrap'=>'','css-dropzone'=>'','css-font-awesome'=>'','css-highlightjs'=>'','js-ace'=>'','js-bootstrap'=>'','js-dropzone'=>'','js-jquery'=>'','js-jquery-datatables'=>'','js-highlightjs'=>'','pre-jsdelivr'=>'','pre-cloudflare'=>'');$mm=__DIR__.'/config.php';if(is_readable($mm)){@include($mm);}define('MAX_UPLOAD_SIZE',$ee);define('UPLOAD_CHUNK_SIZE',$ff);if(!defined('FM_SESSION_ID')){define('FM_SESSION_ID','filemanager');}$nn=new FM_Config();$oo=isset($nn->data['lang'])?$nn->data['lang']:'en';$pp=isset($nn->data['show_hidden'])?$nn->data['show_hidden']:true;$qq=isset($nn->data['error_reporting'])?$nn->data['error_reporting']:true;$rr=isset($nn->data['hide_Cols'])?$nn->data['hide_Cols']:true;$ss=isset($nn->data['theme'])?$nn->data['theme']:'light';define('FM_THEME',$ss);$tt=array('en'=>'English');if($qq==true){@ini_set('error_reporting',E_ALL);@ini_set('display_errors',1);}else{@ini_set('error_reporting',E_ALL);@ini_set('display_errors',0);}if(defined('FM_EMBED')){$c=false;$dd=false;}else{@set_time_limit(600);date_default_timezone_set($q);ini_set('default_charset','UTF-8');if(version_compare(PHP_VERSION,'5.6.0','<')&&function_exists('mb_internal_encoding')){mb_internal_encoding('UTF-8');}if(function_exists('mb_regex_encoding')){mb_regex_encoding('UTF-8');}session_cache_limiter('');session_name(FM_SESSION_ID);function session_error_handling_function($uu,$vv,$ww,$xx){if($uu==2){session_abort();session_id(session_create_id());@session_start();}}set_error_handler('session_error_handling_function');session_start();restore_error_handler();}if(empty($_SESSION['token'])){$_SESSION['token']=bin2hex(random_bytes(32));}if(empty($d)){$c=false;}$yy=isset($_SERVER['HTTPS'])&&($_SERVER['HTTPS']=='on'||$_SERVER['HTTPS']==1)||isset($_SERVER['HTTP_X_FORWARDED_PROTO'])&&$_SERVER['HTTP_X_FORWARDED_PROTO']=='https';if(isset($_SESSION[FM_SESSION_ID]['logged'])&&!empty($j[$_SESSION[FM_SESSION_ID]['logged']])){$zz=fm_clean_path(dirname($_SERVER['PHP_SELF']));$s=$s.$zz.DIRECTORY_SEPARATOR.$j[$_SESSION[FM_SESSION_ID]['logged']];}$s=fm_clean_path($s);defined('FM_ROOT_URL')||define('FM_ROOT_URL',($yy?'https':'http').'://'.$t.(!empty($s)?'/'.$s:''));defined('FM_SELF_URL')||define('FM_SELF_URL',($yy?'https':'http').'://'.$t.$_SERVER['PHP_SELF']);if(isset($_GET['logout'])){unset($_SESSION[FM_SESSION_ID]['logged']);unset($_SESSION['token']);fm_redirect(FM_SELF_URL);}if($gg!='OFF'){function getClientIP(){if(array_key_exists('HTTP_CF_CONNECTING_IP',$_SERVER)){return $_SERVER["HTTP_CF_CONNECTING_IP"];}else if(array_key_exists('HTTP_X_FORWARDED_FOR',$_SERVER)){return $_SERVER["HTTP_X_FORWARDED_FOR"];}else if(array_key_exists('REMOTE_ADDR',$_SERVER)){return $_SERVER['REMOTE_ADDR'];}else if(array_key_exists('HTTP_CLIENT_IP',$_SERVER)){return $_SERVER['HTTP_CLIENT_IP'];}return'';}$aaa=getClientIP();$bbb=false;$ccc=in_array($aaa,$jj);$ddd=in_array($aaa,$kk);if($gg=='AND'){if($ccc==true&&$ddd==false){$bbb=true;}}else if($gg=='OR'){if($ccc==true||$ddd==false){$bbb=true;}}if($bbb==false){trigger_error('User connection denied from: '.$aaa,E_USER_WARNING);if($hh==false){fm_set_msg(lng('Access denied. IP restriction applicable'),'error');fm_show_header_login();fm_show_message();}exit();}}if($c){if(isset($_SESSION[FM_SESSION_ID]['logged'],$d[$_SESSION[FM_SESSION_ID]['logged']])){}elseif(isset($_POST['fm_usr'],$_POST['fm_pwd'],$_POST['token'])){sleep(1);if(function_exists('password_verify')){if(isset($d[$_POST['fm_usr']])&&isset($_POST['fm_pwd'])&&password_verify($_POST['fm_pwd'],$d[$_POST['fm_usr']])&&verifyToken($_POST['token'])){$_SESSION[FM_SESSION_ID]['logged']=$_POST['fm_usr'];fm_set_msg(lng('You are logged in'));fm_redirect(FM_ROOT_URL);}else{unset($_SESSION[FM_SESSION_ID]['logged']);fm_set_msg(lng('Login failed. Invalid username or password'),'error');fm_redirect(FM_ROOT_URL);}}else{fm_set_msg(lng('password_hash not supported, Upgrade PHP version'),'error');;}}else{unset($_SESSION[FM_SESSION_ID]['logged']);fm_show_header_login();?>
".lng('Root path')." \"{$r}\" ".lng('not found!')." ";exit;}defined('FM_SHOW_HIDDEN')||define('FM_SHOW_HIDDEN',$pp);defined('FM_ROOT_PATH')||define('FM_ROOT_PATH',$r);defined('FM_LANG')||define('FM_LANG',$oo);defined('FM_FILE_EXTENSION')||define('FM_FILE_EXTENSION',$y);defined('FM_UPLOAD_EXTENSION')||define('FM_UPLOAD_EXTENSION',$z);defined('FM_EXCLUDE_ITEMS')||define('FM_EXCLUDE_ITEMS',(version_compare(PHP_VERSION,'7.0.0','<')?serialize($bb):$bb));defined('FM_DOC_VIEWER')||define('FM_DOC_VIEWER',$cc);define('FM_READONLY',$h||($c&&!empty($g)&&isset($_SESSION[FM_SESSION_ID]['logged'])&&in_array($_SESSION[FM_SESSION_ID]['logged'],$g)));define('FM_IS_WIN',DIRECTORY_SEPARATOR=='\\');if(!isset($_GET['p'])&&empty($_FILES)){fm_redirect(FM_SELF_URL.'?p=');}$eee=isset($_GET['p'])?$_GET['p']:(isset($_POST['p'])?$_POST['p']:'');$eee=fm_clean_path($eee);$fff=file_get_contents('php://input');$_POST=(strpos($fff,'ajax')!=FALSE&&strpos($fff,'save')!=FALSE)?json_decode($fff,true):$_POST;define('FM_PATH',$eee);define('FM_USE_AUTH',$c);define('FM_EDIT_FILE',$o);defined('FM_ICONV_INPUT_ENC')||define('FM_ICONV_INPUT_ENC',$u);defined('FM_USE_HIGHLIGHTJS')||define('FM_USE_HIGHLIGHTJS',$m);defined('FM_HIGHLIGHTJS_STYLE')||define('FM_HIGHLIGHTJS_STYLE',$n);defined('FM_DATETIME_FORMAT')||define('FM_DATETIME_FORMAT',$w);unset($eee,$c,$u,$m,$n);if((isset($_SESSION[FM_SESSION_ID]['logged'],$d[$_SESSION[FM_SESSION_ID]['logged']])||!FM_USE_AUTH)&&isset($_POST['ajax'],$_POST['token'])&&!FM_READONLY){if(!verifyToken($_POST['token'])){header('HTTP/1.0 401 Unauthorized');die("Invalid Token.");}if(isset($_POST['type'])&&$_POST['type']=="search"){$ggg=$_POST['path']=="."?'':$_POST['path'];$hhh=scan(fm_clean_path($ggg),$_POST['content']);echo json_encode($hhh);exit();}if(isset($_POST['type'])&&$_POST['type']=="save"){$iii=FM_ROOT_PATH;if(FM_PATH!=''){$iii.='/'.FM_PATH;}if(!is_dir($iii)){fm_redirect(FM_SELF_URL.'?p=');}$ww=$_GET['edit'];$ww=fm_clean_path($ww);$ww=str_replace('/','',$ww);if($ww==''||!is_file($iii.'/'.$ww)){fm_set_msg(lng('File not found'),'error');$jjj=FM_PATH;fm_redirect(FM_SELF_URL.'?p='.urlencode($jjj));}header('X-XSS-Protection:0');$kkk=$iii.'/'.$ww;$lll=$_POST['content'];$mmm=fopen($kkk,"w");$nnn=@fwrite($mmm,$lll);fclose($mmm);if($nnn===false){header("HTTP/1.1 500 Internal Server Error");die("Could Not Write File! - Check Permissions / Ownership");}die(true);}if(isset($_POST['type'])&&$_POST['type']=="backup"&&!empty($_POST['file'])){$ooo=fm_clean_path($_POST['file']);$ppp=FM_ROOT_PATH.'/';if(!empty($_POST['path'])){$qqq=fm_clean_path($_POST['path']);$ppp.="{$qqq}/";}$rrr=date("dMy-His");$sss="{$ooo}-{$rrr}.bak";$ttt=$ppp.$ooo;try{if(!file_exists($ttt)){throw new Exception("File {$ooo} not found");}if(copy($ttt,$ppp.$sss)){echo"Backup {$sss} created";}else{throw new Exception("Could not copy file {$ooo}");}}catch(Exception $uuu){echo $uuu->getMessage();}}if(isset($_POST['type'])&&$_POST['type']=="settings"){global $nn,$oo,$qq,$pp,$tt,$rr,$ss;$vvv=$_POST['js-language'];fm_get_translations([]);if(!array_key_exists($vvv,$tt)){$vvv='en';}$www=isset($_POST['js-error-report'])&&$_POST['js-error-report']=="true"?true:false;$xxx=isset($_POST['js-show-hidden'])&&$_POST['js-show-hidden']=="true"?true:false;$yyy=isset($_POST['js-hide-cols'])&&$_POST['js-hide-cols']=="true"?true:false;$zzz=$_POST['js-theme-3'];if($nn->data['lang']!=$vvv){$nn->data['lang']=$vvv;$oo=$vvv;}if($nn->data['error_reporting']!=$www){$nn->data['error_reporting']=$www;$qq=$www;}if($nn->data['show_hidden']!=$xxx){$nn->data['show_hidden']=$xxx;$pp=$xxx;}if($nn->data['show_hidden']!=$xxx){$nn->data['show_hidden']=$xxx;$pp=$xxx;}if($nn->data['hide_Cols']!=$yyy){$nn->data['hide_Cols']=$yyy;$rr=$yyy;}if($nn->data['theme']!=$zzz){$nn->data['theme']=$zzz;$ss=$zzz;}$nn->save();echo true;}if(isset($_POST['type'])&&$_POST['type']=="pwdhash"){$aaaa=isset($_POST['inputPassword2'])&&!empty($_POST['inputPassword2'])?password_hash($_POST['inputPassword2'],PASSWORD_DEFAULT):'';echo $aaaa;}if(isset($_POST['type'])&&$_POST['type']=="upload"&&!empty($_REQUEST["uploadurl"])){$iii=FM_ROOT_PATH;if(FM_PATH!=''){$iii.='/'.FM_PATH;}function event_callback($bbbb){global $cccc;echo json_encode($bbbb);}function get_file_path(){global $iii,$dddd,$eeee;return $iii."/".basename($dddd->name);}$ffff=!empty($_REQUEST["uploadurl"])&&preg_match("|^http(s)?://.+$|",stripslashes($_REQUEST["uploadurl"]))?stripslashes($_REQUEST["uploadurl"]):null;$gggg=parse_url($ffff,PHP_URL_HOST);$hhhh=parse_url($ffff,PHP_URL_PORT);$iiii=[22,23,25,3306];if(preg_match("/^localhost$|^127(?:\.[0-9]+){0,2}\.[0-9]+$|^(?:0*\:)*?:?0*1$/i",$gggg)||in_array($hhhh,$iiii)){$jjjj=array("message"=>"URL is not allowed");event_callback(array("fail"=>$jjjj));exit();}$kkkk=false;$eeee=tempnam(sys_get_temp_dir(),"upload-");$dddd=new stdClass();$dddd->name=trim(basename($ffff),".\x00..\x20");$llll=(FM_UPLOAD_EXTENSION)?explode(',',FM_UPLOAD_EXTENSION):false;$mmmm=strtolower(pathinfo($dddd->name,PATHINFO_EXTENSION));$nnnn=($llll)?in_array($mmmm,$llll):true;$jjjj=false;if(!$nnnn){$jjjj=array("message"=>"File extension is not allowed");event_callback(array("fail"=>$jjjj));exit();}if(!$ffff){$oooo=false;}else if($kkkk){@$pppp=fopen($eeee,"w");@$qqqq=curl_init($ffff);curl_setopt($qqqq,CURLOPT_NOPROGRESS,false);curl_setopt($qqqq,CURLOPT_FOLLOWLOCATION,true);curl_setopt($qqqq,CURLOPT_FILE,$pppp);@$oooo=curl_exec($qqqq);$rrrr=curl_getinfo($qqqq);if(!$oooo){$jjjj=array("message"=>curl_error($qqqq));}@curl_close($qqqq);fclose($pppp);$dddd->size=$rrrr["size_download"];$dddd->type=$rrrr["content_type"];}else{$ssss=stream_context_create();@$oooo=copy($ffff,$eeee,$ssss);if(!$oooo){$jjjj=error_get_last();}}if($oooo){$oooo=rename($eeee,strtok(get_file_path(),'?'));}if($oooo){event_callback(array("done"=>$dddd));}else{unlink($eeee);if(!$jjjj){$jjjj=array("message"=>"Invalid url parameter");}event_callback(array("fail"=>$jjjj));}}exit();}if(isset($_GET['del'],$_POST['token'])&&!FM_READONLY){$tttt=str_replace('/','',fm_clean_path($_GET['del']));if($tttt!=''&&$tttt!='..'&&$tttt!='.'&&verifyToken($_POST['token'])){$iii=FM_ROOT_PATH;if(FM_PATH!=''){$iii.='/'.FM_PATH;}$uuuu=is_dir($iii.'/'.$tttt);if(fm_rdelete($iii.'/'.$tttt)){$vv=$uuuu?lng('Folder').' %s '.lng('Deleted'):lng('File').' %s '.lng('Deleted');fm_set_msg(sprintf($vv,fm_enc($tttt)));}else{$vv=$uuuu?lng('Folder').' %s '.lng('not deleted'):lng('File').' %s '.lng('not deleted');fm_set_msg(sprintf($vv,fm_enc($tttt)),'error');}}else{fm_set_msg(lng('Invalid file or folder name'),'error');}$jjj=FM_PATH;fm_redirect(FM_SELF_URL.'?p='.urlencode($jjj));}if(isset($_POST['newfilename'],$_POST['newfile'],$_POST['token'])&&!FM_READONLY){$vvvv=urldecode($_POST['newfile']);$wwww=str_replace('/','',fm_clean_path(strip_tags($_POST['newfilename'])));if(fm_isvalid_filename($wwww)&&$wwww!=''&&$wwww!='..'&&$wwww!='.'&&verifyToken($_POST['token'])){$iii=FM_ROOT_PATH;if(FM_PATH!=''){$iii.='/'.FM_PATH;}if($vvvv=="file"){if(!file_exists($iii.'/'.$wwww)){if(fm_is_valid_ext($wwww)){@fopen($iii.'/'.$wwww,'w')or die('Cannot open file: '.$wwww);fm_set_msg(sprintf(lng('File').' %s '.lng('Created'),fm_enc($wwww)));}else{fm_set_msg(lng('File extension is not allowed'),'error');}}else{fm_set_msg(sprintf(lng('File').' %s '.lng('already exists'),fm_enc($wwww)),'alert');}}else{if(fm_mkdir($iii.'/'.$wwww,false)===true){fm_set_msg(sprintf(lng('Folder').' %s '.lng('Created'),$wwww));}elseif(fm_mkdir($iii.'/'.$wwww,false)===$iii.'/'.$wwww){fm_set_msg(sprintf(lng('Folder').' %s '.lng('already exists'),fm_enc($wwww)),'alert');}else{fm_set_msg(sprintf(lng('Folder').' %s '.lng('not created'),fm_enc($wwww)),'error');}}}else{fm_set_msg(lng('Invalid characters in file or folder name'),'error');}$jjj=FM_PATH;fm_redirect(FM_SELF_URL.'?p='.urlencode($jjj));}if(isset($_GET['copy'],$_GET['finish'])&&!FM_READONLY){$xxxx=urldecode($_GET['copy']);$xxxx=fm_clean_path($xxxx);if($xxxx==''){fm_set_msg(lng('Source path not defined'),'error');$jjj=FM_PATH;fm_redirect(FM_SELF_URL.'?p='.urlencode($jjj));}$yyyy=FM_ROOT_PATH.'/'.$xxxx;$zzzz=FM_ROOT_PATH;if(FM_PATH!=''){$zzzz.='/'.FM_PATH;}$zzzz.='/'.basename($yyyy);$aaaaa=isset($_GET['move']);$aaaaa=fm_clean_path(urldecode($aaaaa));if($yyyy!=$zzzz){$bbbbb=trim(FM_PATH.'/'.basename($yyyy),'/');if($aaaaa){$ccccc=fm_rename($yyyy,$zzzz);if($ccccc){fm_set_msg(sprintf(lng('Moved from').' %s '.lng('to').' %s',fm_enc($xxxx),fm_enc($bbbbb)));}elseif($ccccc===null){fm_set_msg(lng('File or folder with this path already exists'),'alert');}else{fm_set_msg(sprintf(lng('Error while moving from').' %s '.lng('to').' %s',fm_enc($xxxx),fm_enc($bbbbb)),'error');}}else{if(fm_rcopy($yyyy,$zzzz)){fm_set_msg(sprintf(lng('Copied from').' %s '.lng('to').' %s',fm_enc($xxxx),fm_enc($bbbbb)));}else{fm_set_msg(sprintf(lng('Error while copying from').' %s '.lng('to').' %s',fm_enc($xxxx),fm_enc($bbbbb)),'error');}}}else{if(!$aaaaa){$bbbbb=trim(FM_PATH.'/'.basename($yyyy),'/');$ddddd=pathinfo($yyyy);$eeeee='';if(!is_dir($yyyy)){$eeeee='.'.$ddddd['extension'];}$fffff=$ddddd['dirname'].'/'.$ddddd['filename'].'-'.date('YmdHis').$eeeee;$ggggg=0;$hhhhh=1000;while(file_exists($fffff)&$ggggg<$hhhhh){$ddddd=pathinfo($fffff);$fffff=$ddddd['dirname'].'/'.$ddddd['filename'].'-copy'.$eeeee;$ggggg++;}if(fm_rcopy($yyyy,$fffff,False)){fm_set_msg(sprintf('Copyied from %s to %s',fm_enc($xxxx),fm_enc($fffff)));}else{fm_set_msg(sprintf('Error while copying from %s to %s',fm_enc($xxxx),fm_enc($fffff)),'error');}}else{fm_set_msg(lng('Paths must be not equal'),'alert');}}$jjj=FM_PATH;fm_redirect(FM_SELF_URL.'?p='.urlencode($jjj));}if(isset($_POST['file'],$_POST['copy_to'],$_POST['finish'],$_POST['token'])&&!FM_READONLY){if(!verifyToken($_POST['token'])){fm_set_msg(lng('Invalid Token.'),'error');}$iii=FM_ROOT_PATH;if(FM_PATH!=''){$iii.='/'.FM_PATH;}$iiiii=FM_ROOT_PATH;$jjjjj=fm_clean_path($_POST['copy_to']);if($jjjjj!=''){$iiiii.='/'.$jjjjj;}if($iii==$iiiii){fm_set_msg(lng('Paths must be not equal'),'alert');$jjj=FM_PATH;fm_redirect(FM_SELF_URL.'?p='.urlencode($jjj));}if(!is_dir($iiiii)){if(!fm_mkdir($iiiii,true)){fm_set_msg('Unable to create destination folder','error');$jjj=FM_PATH;fm_redirect(FM_SELF_URL.'?p='.urlencode($jjj));}}$aaaaa=isset($_POST['move']);$kkkkk=0;$lllll=$_POST['file'];if(is_array($lllll)&&count($lllll)){foreach($lllll as $mmmmm){if($mmmmm!=''){$mmmmm=fm_clean_path($mmmmm);$yyyy=$iii.'/'.$mmmmm;$zzzz=$iiiii.'/'.$mmmmm;if($aaaaa){$ccccc=fm_rename($yyyy,$zzzz);if($ccccc===false){$kkkkk++;}}else{if(!fm_rcopy($yyyy,$zzzz)){$kkkkk++;}}}}if($kkkkk==0){$vv=$aaaaa?'Selected files and folders moved':'Selected files and folders copied';fm_set_msg($vv);}else{$vv=$aaaaa?'Error while moving items':'Error while copying items';fm_set_msg($vv,'error');}}else{fm_set_msg(lng('Nothing selected'),'alert');}$jjj=FM_PATH;fm_redirect(FM_SELF_URL.'?p='.urlencode($jjj));}if(isset($_POST['rename_from'],$_POST['rename_to'],$_POST['token'])&&!FM_READONLY){if(!verifyToken($_POST['token'])){fm_set_msg("Invalid Token.",'error');}$nnnnn=urldecode($_POST['rename_from']);$nnnnn=fm_clean_path($nnnnn);$nnnnn=str_replace('/','',$nnnnn);$wwww=urldecode($_POST['rename_to']);$wwww=fm_clean_path(strip_tags($wwww));$wwww=str_replace('/','',$wwww);$iii=FM_ROOT_PATH;if(FM_PATH!=''){$iii.='/'.FM_PATH;}if(fm_isvalid_filename($wwww)&&$nnnnn!=''&&$wwww!=''){if(fm_rename($iii.'/'.$nnnnn,$iii.'/'.$wwww)){fm_set_msg(sprintf(lng('Renamed from').' %s '.lng('to').' %s',fm_enc($nnnnn),fm_enc($wwww)));}else{fm_set_msg(sprintf(lng('Error while renaming from').' %s '.lng('to').' %s',fm_enc($nnnnn),fm_enc($wwww)),'error');}}else{fm_set_msg(lng('Invalid characters in file name'),'error');}$jjj=FM_PATH;fm_redirect(FM_SELF_URL.'?p='.urlencode($jjj));}if(isset($_GET['dl'],$_POST['token'])){if(!verifyToken($_POST['token'])){fm_set_msg("Invalid Token.",'error');}$ooooo=urldecode($_GET['dl']);$ooooo=fm_clean_path($ooooo);$ooooo=str_replace('/','',$ooooo);$iii=FM_ROOT_PATH;if(FM_PATH!=''){$iii.='/'.FM_PATH;}if($ooooo!=''&&is_file($iii.'/'.$ooooo)){fm_download_file($iii.'/'.$ooooo,$ooooo,1024);exit;}else{fm_set_msg(lng('File not found'),'error');$jjj=FM_PATH;fm_redirect(FM_SELF_URL.'?p='.urlencode($jjj));}}if(!empty($_FILES)&&!FM_READONLY){if(isset($_POST['token'])){if(!verifyToken($_POST['token'])){$hhh=array('status'=>'error','info'=>"Invalid Token.");echo json_encode($hhh);exit();}}else{$hhh=array('status'=>'error','info'=>"Token Missing.");echo json_encode($hhh);exit();}$ppppp=false;$qqqqq=$_POST['dzchunkindex'];$rrrrr=$_POST['dztotalchunkcount'];$sssss=fm_clean_path($_REQUEST['fullpath']);$mmmmm=$_FILES;$iii=FM_ROOT_PATH;$ttttt=DIRECTORY_SEPARATOR;if(FM_PATH!=''){$iii.='/'.FM_PATH;}$kkkkk=0;$uuuuu=0;$llll=(FM_UPLOAD_EXTENSION)?explode(',',FM_UPLOAD_EXTENSION):false;$hhh=array('status'=>'error','info'=>'Oops! Try again');$vvvvv=$mmmmm['file']['name'];$wwwww=$mmmmm['file']['tmp_name'];$mmmm=pathinfo($vvvvv,PATHINFO_FILENAME)!=''?strtolower(pathinfo($vvvvv,PATHINFO_EXTENSION)):'';$nnnn=($llll)?in_array($mmmm,$llll):true;if(!fm_isvalid_filename($vvvvv)&&!fm_isvalid_filename($sssss)){$hhh=array('status'=>'error','info'=>"Invalid File name!",);echo json_encode($hhh);exit();}$xxxxx=$iii.$ttttt;if(is_writable($xxxxx)){$ppp=$iii.'/'.basename($sssss);$yyyyy=substr($ppp,0,strrpos($ppp,"/"));if(file_exists($ppp)&&!$ppppp&&!$zzzzz){$aaaaaa=$mmmm?'.'.$mmmm:'';$ppp=$iii.'/'.basename($sssss,$aaaaaa).'_'.date('ymdHis').$aaaaaa;}if(!is_dir($yyyyy)){$nnnnn=umask(0);mkdir($yyyyy,0777,true);umask($nnnnn);}if(empty($mmmmm['file']['error'])&&!empty($wwwww)&&$wwwww!='none'&&$nnnn){if($rrrrr){$bbbbbb=@fopen("{$ppp}.part",$qqqqq==0?"wb":"ab");if($bbbbbb){$cccccc=@fopen($wwwww,"rb");if($cccccc){while($dddddd=fread($cccccc,4096)){fwrite($bbbbbb,$dddddd);}$hhh=array('status'=>'success','info'=>"file upload successful");}else{$hhh=array('status'=>'error','info'=>"failed to open output stream",'errorDetails'=>error_get_last());}@fclose($cccccc);@fclose($bbbbbb);@unlink($wwwww);$hhh=array('status'=>'success','info'=>"file upload successful");}else{$hhh=array('status'=>'error','info'=>"failed to open output stream");}if($qqqqq==$rrrrr-1){rename("{$ppp}.part",$ppp);}}else if(move_uploaded_file($wwwww,$ppp)){if(file_exists($ppp)){$hhh=array('status'=>'success','info'=>"file upload successful");}else{$hhh=array('status'=>'error','info'=>'Couldn\'t upload the requested file.');}}else{$hhh=array('status'=>'error','info'=>"Error while uploading files. Uploaded files $uuuuu",);}}}else{$hhh=array('status'=>'error','info'=>'The specified folder for upload isn\'t writeable.');}echo json_encode($hhh);exit();}if(isset($_POST['group'],$_POST['delete'],$_POST['token'])&&!FM_READONLY){if(!verifyToken($_POST['token'])){fm_set_msg(lng("Invalid Token."),'error');}$iii=FM_ROOT_PATH;if(FM_PATH!=''){$iii.='/'.FM_PATH;}$kkkkk=0;$lllll=$_POST['file'];if(is_array($lllll)&&count($lllll)){foreach($lllll as $mmmmm){if($mmmmm!=''){$eeeeee=$iii.'/'.$mmmmm;if(!fm_rdelete($eeeeee)){$kkkkk++;}}}if($kkkkk==0){fm_set_msg(lng('Selected files and folder deleted'));}else{fm_set_msg(lng('Error while deleting items'),'error');}}else{fm_set_msg(lng('Nothing selected'),'alert');}$jjj=FM_PATH;fm_redirect(FM_SELF_URL.'?p='.urlencode($jjj));}if(isset($_POST['group'],$_POST['token'])&&(isset($_POST['zip'])||isset($_POST['tar']))&&!FM_READONLY){if(!verifyToken($_POST['token'])){fm_set_msg(lng("Invalid Token."),'error');}$iii=FM_ROOT_PATH;$mmmm='zip';if(FM_PATH!=''){$iii.='/'.FM_PATH;}$mmmm=isset($_POST['tar'])?'tar':'zip';if(($mmmm=="zip"&&!class_exists('ZipArchive'))||($mmmm=="tar"&&!class_exists('PharData'))){fm_set_msg(lng('Operations with archives are not available'),'error');$jjj=FM_PATH;fm_redirect(FM_SELF_URL.'?p='.urlencode($jjj));}$lllll=$_POST['file'];$ffffff=array();foreach($lllll as $ww){array_push($ffffff,fm_clean_path($ww));}$lllll=$ffffff;if(!empty($lllll)){chdir($iii);if(count($lllll)==1){$gggggg=reset($lllll);$gggggg=basename($gggggg);$hhhhhh=$gggggg.'_'.date('ymd_His').'.'.$mmmm;}else{$hhhhhh='archive_'.date('ymd_His').'.'.$mmmm;}if($mmmm=='zip'){$iiiiii=new FM_Zipper();$aaaa=$iiiiii->create($hhhhhh,$lllll);}elseif($mmmm=='tar'){$jjjjjj=new FM_Zipper_Tar();$aaaa=$jjjjjj->create($hhhhhh,$lllll);}if($aaaa){fm_set_msg(sprintf(lng('Archive').' %s '.lng('Created'),fm_enc($hhhhhh)));}else{fm_set_msg(lng('Archive not created'),'error');}}else{fm_set_msg(lng('Nothing selected'),'alert');}$jjj=FM_PATH;fm_redirect(FM_SELF_URL.'?p='.urlencode($jjj));}if(isset($_POST['unzip'],$_POST['token'])&&!FM_READONLY){if(!verifyToken($_POST['token'])){fm_set_msg(lng("Invalid Token."),'error');}$kkkkkk=urldecode($_POST['unzip']);$kkkkkk=fm_clean_path($kkkkkk);$kkkkkk=str_replace('/','',$kkkkkk);$llllll=false;$iii=FM_ROOT_PATH;if(FM_PATH!=''){$iii.='/'.FM_PATH;}if($kkkkkk!=''&&is_file($iii.'/'.$kkkkkk)){$mmmmmm=$iii.'/'.$kkkkkk;$mmmm=pathinfo($mmmmmm,PATHINFO_EXTENSION);$llllll=true;}else{fm_set_msg(lng('File not found'),'error');}if(($mmmm=="zip"&&!class_exists('ZipArchive'))||($mmmm=="tar"&&!class_exists('PharData'))){fm_set_msg(lng('Operations with archives are not available'),'error');$jjj=FM_PATH;fm_redirect(FM_SELF_URL.'?p='.urlencode($jjj));}if($llllll){$nnnnnn='';if(isset($_POST['tofolder'])){$nnnnnn=pathinfo($mmmmmm,PATHINFO_FILENAME);if(fm_mkdir($iii.'/'.$nnnnnn,true)){$iii.='/'.$nnnnnn;}}if($mmmm=="zip"){$iiiiii=new FM_Zipper();$aaaa=$iiiiii->unzip($mmmmmm,$iii);}elseif($mmmm=="tar"){try{$oooooo=new PharData($mmmmmm);if(@$oooooo->extractTo($iii,null,true)){$aaaa=true;}else{$aaaa=false;}}catch(Exception $uuu){$aaaa=true;}}if($aaaa){fm_set_msg(lng('Archive unpacked'));}else{fm_set_msg(lng('Archive not unpacked'),'error');}}else{fm_set_msg(lng('File not found'),'error');}$jjj=FM_PATH;fm_redirect(FM_SELF_URL.'?p='.urlencode($jjj));}if(isset($_POST['chmod'],$_POST['token'])&&!FM_READONLY&&!FM_IS_WIN){if(!verifyToken($_POST['token'])){fm_set_msg(lng("Invalid Token."),'error');}$iii=FM_ROOT_PATH;if(FM_PATH!=''){$iii.='/'.FM_PATH;}$ww=$_POST['chmod'];$ww=fm_clean_path($ww);$ww=str_replace('/','',$ww);if($ww==''||(!is_file($iii.'/'.$ww)&&!is_dir($iii.'/'.$ww))){fm_set_msg(lng('File not found'),'error');$jjj=FM_PATH;fm_redirect(FM_SELF_URL.'?p='.urlencode($jjj));}$pppppp=0;if(!empty($_POST['ur'])){$pppppp|=0400;}if(!empty($_POST['uw'])){$pppppp|=0200;}if(!empty($_POST['ux'])){$pppppp|=0100;}if(!empty($_POST['gr'])){$pppppp|=0040;}if(!empty($_POST['gw'])){$pppppp|=0020;}if(!empty($_POST['gx'])){$pppppp|=0010;}if(!empty($_POST['or'])){$pppppp|=0004;}if(!empty($_POST['ow'])){$pppppp|=0002;}if(!empty($_POST['ox'])){$pppppp|=0001;}if(@chmod($iii.'/'.$ww,$pppppp)){fm_set_msg(lng('Permissions changed'));}else{fm_set_msg(lng('Permissions not changed'),'error');}$jjj=FM_PATH;fm_redirect(FM_SELF_URL.'?p='.urlencode($jjj));}$iii=FM_ROOT_PATH;if(FM_PATH!=''){$iii.='/'.FM_PATH;}if(!is_dir($iii)){fm_redirect(FM_SELF_URL.'?p=');}$qqqqqq=fm_get_parent_path(FM_PATH);$rrrrrr=is_readable($iii)?scandir($iii):array();$ssssss=array();$lllll=array();$tttttt=array_slice(explode("/",$iii),-1)[0];if(is_array($rrrrrr)&&fm_is_exclude_items($tttttt)){foreach($rrrrrr as $ww){if($ww=='.'||$ww=='..'){continue;}if(!FM_SHOW_HIDDEN&&substr($ww,0,1)==='.'){continue;}$eeeeee=$iii.'/'.$ww;if(@is_file($eeeeee)&&fm_is_exclude_items($ww)){$lllll[]=$ww;}elseif(@is_dir($eeeeee)&&$ww!='.'&&$ww!='..'&&fm_is_exclude_items($ww)){$ssssss[]=$ww;}}}if(!empty($lllll)){natcasesort($lllll);}if(!empty($ssssss)){natcasesort($ssssss);}if(isset($_GET['upload'])&&!FM_READONLY){fm_show_header();fm_show_nav_path(FM_PATH);function getUploadExt(){$uuuuuu=explode(',',FM_UPLOAD_EXTENSION);if(FM_UPLOAD_EXTENSION&&$uuuuuu){array_walk($uuuuuu,function(&$vvvvvv){$vvvvvv=".$vvvvvv";});return implode(',',$uuuuuu);}return'';}?>