2018-04-02 08:29:19 +02:00
|
|
|
<?php
|
|
|
|
|
|
|
|
$config = include 'config/config.php';
|
|
|
|
|
|
|
|
require_once 'include/utils.php';
|
|
|
|
|
|
|
|
if ($_SESSION['RF']["verify"] != "RESPONSIVEfilemanager")
|
|
|
|
{
|
|
|
|
response(trans('forbiden').AddErrorLocation())->send();
|
|
|
|
exit;
|
|
|
|
}
|
|
|
|
$languages = include 'lang/languages.php';
|
|
|
|
|
|
|
|
if (isset($_SESSION['RF']['language']) && file_exists('lang/' . basename($_SESSION['RF']['language']) . '.php'))
|
|
|
|
{
|
|
|
|
if(array_key_exists($_SESSION['RF']['language'],$languages)){
|
|
|
|
include 'lang/' . basename($_SESSION['RF']['language']) . '.php';
|
|
|
|
}else{
|
|
|
|
response(trans('Lang_Not_Found').AddErrorLocation())->send();
|
|
|
|
exit;
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
response(trans('Lang_Not_Found').AddErrorLocation())->send();
|
|
|
|
exit;
|
|
|
|
}
|
2019-01-11 09:59:01 +01:00
|
|
|
|
|
|
|
|
|
|
|
//check $_GET['file']
|
|
|
|
if(isset($_GET['file']) && !checkRelativePath($_GET['file'])) {
|
|
|
|
response(trans('wrong path').AddErrorLocation())->send();
|
|
|
|
exit;
|
|
|
|
}
|
|
|
|
|
|
|
|
//check $_POST['file']
|
|
|
|
if(isset($_POST['path']) && !checkRelativePath($_POST['path'])) {
|
|
|
|
response(trans('wrong path').AddErrorLocation())->send();
|
|
|
|
exit;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2018-04-02 08:29:19 +02:00
|
|
|
$ftp = ftp_con($config);
|
|
|
|
|
|
|
|
if(isset($_GET['action']))
|
|
|
|
{
|
|
|
|
switch($_GET['action'])
|
|
|
|
{
|
|
|
|
case 'new_file_form':
|
|
|
|
echo trans('Filename') . ': <input type="text" id="create_text_file_name" style="height:30px"> <select id="create_text_file_extension" style="margin:0;width:100px;">';
|
|
|
|
foreach($config['editable_text_file_exts'] as $ext){
|
|
|
|
echo '<option value=".'.$ext.'">.'.$ext.'</option>';
|
|
|
|
}
|
|
|
|
echo '</select><br><hr><textarea id="textfile_create_area" style="width:100%;height:150px;"></textarea>';
|
|
|
|
break;
|
|
|
|
case 'view':
|
|
|
|
if(isset($_GET['type']))
|
|
|
|
{
|
|
|
|
$_SESSION['RF']["view_type"] = $_GET['type'];
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
response(trans('view type number missing').AddErrorLocation())->send();
|
|
|
|
exit;
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case 'filter':
|
|
|
|
if (isset($_GET['type']))
|
|
|
|
{
|
2019-01-11 09:59:01 +01:00
|
|
|
if (isset($config['remember_text_filter']) && $config['remember_text_filter'])
|
2018-04-02 08:29:19 +02:00
|
|
|
{
|
|
|
|
$_SESSION['RF']["filter"] = $_GET['type'];
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
response(trans('view type number missing').AddErrorLocation())->send();
|
|
|
|
exit;
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case 'sort':
|
|
|
|
if (isset($_GET['sort_by']))
|
|
|
|
{
|
|
|
|
$_SESSION['RF']["sort_by"] = $_GET['sort_by'];
|
|
|
|
}
|
|
|
|
|
|
|
|
if (isset($_GET['descending']))
|
|
|
|
{
|
|
|
|
$_SESSION['RF']["descending"] = $_GET['descending'];
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case 'save_img':
|
|
|
|
$info = pathinfo($_POST['name']);
|
|
|
|
|
2019-01-11 09:59:01 +01:00
|
|
|
if ((strpos($_POST['url'], 'http://s3.amazonaws.com/feather') !== 0 && strpos($_POST['url'], 'https://s3.amazonaws.com/feather') !== 0)
|
2018-04-02 08:29:19 +02:00
|
|
|
|| $_POST['name'] != fix_filename($_POST['name'], $config)
|
|
|
|
|| ! in_array(strtolower($info['extension']), array( 'jpg', 'jpeg', 'png' ))
|
|
|
|
)
|
|
|
|
{
|
|
|
|
response(trans('wrong data').AddErrorLocation())->send();
|
|
|
|
exit;
|
|
|
|
}
|
|
|
|
$image_data = get_file_by_url($_POST['url']);
|
|
|
|
if ($image_data === false)
|
|
|
|
{
|
|
|
|
response(trans('Aviary_No_Save').AddErrorLocation())->send();
|
|
|
|
exit;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!checkresultingsize(strlen($image_data))) {
|
2019-01-11 09:59:01 +01:00
|
|
|
response(sprintf(trans('max_size_reached'),$config['MaxSizeTotal']).AddErrorLocation())->send();
|
2018-04-02 08:29:19 +02:00
|
|
|
exit;
|
|
|
|
}
|
|
|
|
if($ftp){
|
|
|
|
|
|
|
|
$temp = tempnam('/tmp','RF');
|
|
|
|
unlink($temp);
|
|
|
|
$temp .=".".substr(strrchr($_POST['url'],'.'),1);
|
|
|
|
file_put_contents($temp,$image_data);
|
|
|
|
|
2019-01-11 09:59:01 +01:00
|
|
|
$ftp->put($config['ftp_base_folder'].$config['upload_dir'] . $_POST['path'] . $_POST['name'], $temp, FTP_BINARY);
|
2018-04-02 08:29:19 +02:00
|
|
|
|
|
|
|
create_img($temp,$temp,122,91);
|
2019-01-11 09:59:01 +01:00
|
|
|
$ftp->put($config['ftp_base_folder'].$config['ftp_thumbs_dir']. $_POST['path'] . $_POST['name'], $temp, FTP_BINARY);
|
2018-04-02 08:29:19 +02:00
|
|
|
|
|
|
|
unlink($temp);
|
|
|
|
}else{
|
|
|
|
|
2019-01-11 09:59:01 +01:00
|
|
|
file_put_contents($config['current_path'] . $_POST['path'] . $_POST['name'],$image_data);
|
|
|
|
create_img($config['current_path'] . $_POST['path'] . $_POST['name'], $config['thumbs_base_path'].$_POST['path'].$_POST['name'], 122, 91);
|
2018-04-02 08:29:19 +02:00
|
|
|
// TODO something with this function cause its blowing my mind
|
|
|
|
new_thumbnails_creation(
|
2019-01-11 09:59:01 +01:00
|
|
|
$config['current_path'].$_POST['path'],
|
|
|
|
$config['current_path'].$_POST['path'].$_POST['name'],
|
2018-04-02 08:29:19 +02:00
|
|
|
$_POST['name'],
|
2019-01-11 09:59:01 +01:00
|
|
|
$config['current_path'],
|
2018-04-02 08:29:19 +02:00
|
|
|
$config
|
|
|
|
);
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case 'extract':
|
2019-01-11 09:59:01 +01:00
|
|
|
if(!$config['extract_files']){
|
|
|
|
response(trans('wrong action').AddErrorLocation())->send();
|
2018-04-02 08:29:19 +02:00
|
|
|
}
|
|
|
|
if($ftp){
|
2019-01-11 09:59:01 +01:00
|
|
|
$path = $config['ftp_base_url'].$config['upload_dir'] . $_POST['path'];
|
|
|
|
$base_folder = $config['ftp_base_url'].$config['upload_dir'] . fix_dirname($_POST['path']) . "/";
|
2018-04-02 08:29:19 +02:00
|
|
|
}else{
|
2019-01-11 09:59:01 +01:00
|
|
|
$path = $config['current_path'] . $_POST['path'];
|
|
|
|
$base_folder = $config['current_path'] . fix_dirname($_POST['path']) . "/";
|
2018-04-02 08:29:19 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
$info = pathinfo($path);
|
|
|
|
|
|
|
|
if($ftp){
|
|
|
|
$tempDir = tempdir();
|
|
|
|
$temp = tempnam($tempDir,'RF');
|
|
|
|
unlink($temp);
|
|
|
|
$temp .=".".$info['extension'];
|
|
|
|
$handle = fopen($temp, "w");
|
|
|
|
fwrite($handle, file_get_contents($path));
|
|
|
|
fclose($handle);
|
|
|
|
$path = $temp;
|
|
|
|
$base_folder = $tempDir."/";
|
|
|
|
}
|
|
|
|
|
|
|
|
$info = pathinfo($path);
|
|
|
|
|
|
|
|
switch ($info['extension'])
|
|
|
|
{
|
|
|
|
case "zip":
|
|
|
|
$zip = new ZipArchive;
|
|
|
|
if ($zip->open($path) === true)
|
|
|
|
{
|
|
|
|
//get total size
|
|
|
|
$sizeTotalFinal = 0;
|
|
|
|
for ($i = 0; $i < $zip->numFiles; $i++)
|
|
|
|
{
|
|
|
|
$aStat = $zip->statIndex($i);
|
|
|
|
$sizeTotalFinal += $aStat['size'];
|
|
|
|
}
|
|
|
|
if (!checkresultingsize($sizeTotalFinal)) {
|
2019-01-11 09:59:01 +01:00
|
|
|
response(sprintf(trans('max_size_reached'),$config['MaxSizeTotal']).AddErrorLocation())->send();
|
2018-04-02 08:29:19 +02:00
|
|
|
exit;
|
|
|
|
}
|
|
|
|
|
2019-01-11 09:59:01 +01:00
|
|
|
//make all the folders and unzip into the folders
|
2018-04-02 08:29:19 +02:00
|
|
|
for ($i = 0; $i < $zip->numFiles; $i++)
|
|
|
|
{
|
|
|
|
$FullFileName = $zip->statIndex($i);
|
|
|
|
|
2019-01-11 09:59:01 +01:00
|
|
|
if(checkRelativePath($FullFileName['name'])){
|
|
|
|
if (substr($FullFileName['name'], -1, 1) == "/")
|
2018-04-02 08:29:19 +02:00
|
|
|
{
|
2019-01-11 09:59:01 +01:00
|
|
|
create_folder($base_folder . $FullFileName['name']);
|
|
|
|
}
|
|
|
|
|
|
|
|
if ( ! (substr($FullFileName['name'], -1, 1) == "/"))
|
|
|
|
{
|
|
|
|
$fileinfo = pathinfo($FullFileName['name']);
|
|
|
|
if (in_array(strtolower($fileinfo['extension']), $config['ext']))
|
|
|
|
{
|
2019-11-15 22:11:05 +01:00
|
|
|
//copy('zip://' . $path . '#' . $FullFileName['name'], $base_folder . $FullFileName['name']);
|
|
|
|
$zip->extractTo($base_folder , $FullFileName['name']);
|
2019-01-11 09:59:01 +01:00
|
|
|
}
|
2018-04-02 08:29:19 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
$zip->close();
|
|
|
|
} else {
|
|
|
|
response(trans('Zip_No_Extract').AddErrorLocation())->send();
|
|
|
|
exit;
|
|
|
|
}
|
|
|
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
case "gz":
|
|
|
|
// No resulting size pre-control available
|
|
|
|
$p = new PharData($path);
|
|
|
|
$p->decompress(); // creates files.tar
|
|
|
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
case "tar":
|
|
|
|
// No resulting size pre-control available
|
|
|
|
// unarchive from the tar
|
|
|
|
$phar = new PharData($path);
|
|
|
|
$phar->decompressFiles();
|
|
|
|
$files = array();
|
2019-01-11 09:59:01 +01:00
|
|
|
check_files_extensions_on_phar($phar, $files, '', $config);
|
2018-04-02 08:29:19 +02:00
|
|
|
$phar->extractTo($base_folder, $files, true);
|
|
|
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
default:
|
|
|
|
response(trans('Zip_Invalid').AddErrorLocation())->send();
|
|
|
|
exit;
|
|
|
|
}
|
|
|
|
|
|
|
|
if($ftp){
|
|
|
|
unlink($path);
|
2019-01-11 09:59:01 +01:00
|
|
|
$ftp->putAll($base_folder, "/".$config['ftp_base_folder'] . $config['upload_dir'] . fix_dirname($_POST['path']), FTP_BINARY);
|
2018-04-02 08:29:19 +02:00
|
|
|
deleteDir($base_folder);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
break;
|
|
|
|
case 'media_preview':
|
2019-01-11 09:59:01 +01:00
|
|
|
if(isset($_GET['file'])){
|
|
|
|
$_GET['file'] = sanitize($_GET['file']);
|
|
|
|
}
|
|
|
|
if(isset($_GET['title'])){
|
|
|
|
$_GET['title'] = sanitize($_GET['title']);
|
|
|
|
}
|
2018-04-02 08:29:19 +02:00
|
|
|
if($ftp){
|
2019-01-11 09:59:01 +01:00
|
|
|
$preview_file = $config['ftp_base_url'].$config['upload_dir'] . $_GET['file'];
|
2018-04-02 08:29:19 +02:00
|
|
|
}else{
|
2019-01-11 09:59:01 +01:00
|
|
|
$preview_file = $config['current_path'] . $_GET["file"];
|
2018-04-02 08:29:19 +02:00
|
|
|
}
|
|
|
|
$info = pathinfo($preview_file);
|
|
|
|
ob_start();
|
|
|
|
?>
|
2019-01-11 09:59:01 +01:00
|
|
|
<div id="jp_container_1" class="jp-video" style="margin:0 auto;">
|
2018-04-02 08:29:19 +02:00
|
|
|
<div class="jp-type-single">
|
|
|
|
<div id="jquery_jplayer_1" class="jp-jplayer"></div>
|
|
|
|
<div class="jp-gui">
|
|
|
|
<div class="jp-video-play">
|
|
|
|
<a href="javascript:;" class="jp-video-play-icon" tabindex="1">play</a>
|
|
|
|
</div>
|
|
|
|
<div class="jp-interface">
|
|
|
|
<div class="jp-progress">
|
|
|
|
<div class="jp-seek-bar">
|
|
|
|
<div class="jp-play-bar"></div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
<div class="jp-current-time"></div>
|
|
|
|
<div class="jp-duration"></div>
|
|
|
|
<div class="jp-controls-holder">
|
|
|
|
<ul class="jp-controls">
|
|
|
|
<li><a href="javascript:;" class="jp-play" tabindex="1">play</a></li>
|
|
|
|
<li><a href="javascript:;" class="jp-pause" tabindex="1">pause</a></li>
|
|
|
|
<li><a href="javascript:;" class="jp-stop" tabindex="1">stop</a></li>
|
|
|
|
<li><a href="javascript:;" class="jp-mute" tabindex="1" title="mute">mute</a></li>
|
|
|
|
<li><a href="javascript:;" class="jp-unmute" tabindex="1" title="unmute">unmute</a></li>
|
|
|
|
<li><a href="javascript:;" class="jp-volume-max" tabindex="1" title="max volume">max volume</a></li>
|
|
|
|
</ul>
|
|
|
|
<div class="jp-volume-bar">
|
|
|
|
<div class="jp-volume-bar-value"></div>
|
|
|
|
</div>
|
|
|
|
<ul class="jp-toggles">
|
|
|
|
<li><a href="javascript:;" class="jp-full-screen" tabindex="1" title="full screen">full screen</a></li>
|
|
|
|
<li><a href="javascript:;" class="jp-restore-screen" tabindex="1" title="restore screen">restore screen</a></li>
|
|
|
|
<li><a href="javascript:;" class="jp-repeat" tabindex="1" title="repeat">repeat</a></li>
|
|
|
|
<li><a href="javascript:;" class="jp-repeat-off" tabindex="1" title="repeat off">repeat off</a></li>
|
|
|
|
</ul>
|
|
|
|
</div>
|
|
|
|
<div class="jp-title" style="display:none;">
|
|
|
|
<ul>
|
|
|
|
<li></li>
|
|
|
|
</ul>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
<div class="jp-no-solution">
|
|
|
|
<span>Update Required</span>
|
|
|
|
To play the media you will need to either update your browser to a recent version or update your <a href="https://get.adobe.com/flashplayer/" target="_blank">Flash plugin</a>.
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
2019-01-11 09:59:01 +01:00
|
|
|
<?php if(in_array(strtolower($info['extension']), $config['ext_music'])): ?>
|
2018-04-02 08:29:19 +02:00
|
|
|
|
|
|
|
<script type="text/javascript">
|
|
|
|
$(document).ready(function(){
|
|
|
|
|
|
|
|
$("#jquery_jplayer_1").jPlayer({
|
|
|
|
ready: function () {
|
|
|
|
$(this).jPlayer("setMedia", {
|
|
|
|
title:"<?php $_GET['title']; ?>",
|
|
|
|
mp3: "<?php echo $preview_file; ?>",
|
|
|
|
m4a: "<?php echo $preview_file; ?>",
|
|
|
|
oga: "<?php echo $preview_file; ?>",
|
|
|
|
wav: "<?php echo $preview_file; ?>"
|
|
|
|
});
|
|
|
|
},
|
|
|
|
swfPath: "js",
|
|
|
|
solution:"html,flash",
|
|
|
|
supplied: "mp3, m4a, midi, mid, oga,webma, ogg, wav",
|
|
|
|
smoothPlayBar: true,
|
|
|
|
keyEnabled: false
|
|
|
|
});
|
|
|
|
});
|
|
|
|
</script>
|
|
|
|
|
2019-01-11 09:59:01 +01:00
|
|
|
<?php elseif(in_array(strtolower($info['extension']), $config['ext_video'])): ?>
|
2018-04-02 08:29:19 +02:00
|
|
|
|
|
|
|
<script type="text/javascript">
|
|
|
|
$(document).ready(function(){
|
|
|
|
|
|
|
|
$("#jquery_jplayer_1").jPlayer({
|
|
|
|
ready: function () {
|
|
|
|
$(this).jPlayer("setMedia", {
|
|
|
|
title:"<?php $_GET['title']; ?>",
|
|
|
|
m4v: "<?php echo $preview_file; ?>",
|
|
|
|
ogv: "<?php echo $preview_file; ?>",
|
|
|
|
flv: "<?php echo $preview_file; ?>"
|
|
|
|
});
|
|
|
|
},
|
|
|
|
swfPath: "js",
|
|
|
|
solution:"html,flash",
|
|
|
|
supplied: "mp4, m4v, ogv, flv, webmv, webm",
|
|
|
|
smoothPlayBar: true,
|
|
|
|
keyEnabled: false
|
|
|
|
});
|
|
|
|
|
|
|
|
});
|
|
|
|
</script>
|
|
|
|
|
|
|
|
<?php endif;
|
|
|
|
|
|
|
|
$content = ob_get_clean();
|
|
|
|
|
|
|
|
response($content)->send();
|
|
|
|
exit;
|
|
|
|
|
|
|
|
break;
|
|
|
|
case 'copy_cut':
|
|
|
|
if ($_POST['sub_action'] != 'copy' && $_POST['sub_action'] != 'cut')
|
|
|
|
{
|
|
|
|
response(trans('wrong sub-action').AddErrorLocation())->send();
|
|
|
|
exit;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (trim($_POST['path']) == '')
|
|
|
|
{
|
|
|
|
response(trans('no path').AddErrorLocation())->send();
|
|
|
|
exit;
|
|
|
|
}
|
|
|
|
|
|
|
|
$msg_sub_action = ($_POST['sub_action'] == 'copy' ? trans('Copy') : trans('Cut'));
|
2019-01-11 09:59:01 +01:00
|
|
|
$path = $config['current_path'] . $_POST['path'];
|
2018-04-02 08:29:19 +02:00
|
|
|
|
|
|
|
if (is_dir($path))
|
|
|
|
{
|
|
|
|
// can't copy/cut dirs
|
2019-01-11 09:59:01 +01:00
|
|
|
if ($config['copy_cut_dirs'] === false)
|
2018-04-02 08:29:19 +02:00
|
|
|
{
|
|
|
|
response(sprintf(trans('Copy_Cut_Not_Allowed'), $msg_sub_action, trans('Folders')).AddErrorLocation())->send();
|
|
|
|
exit;
|
|
|
|
}
|
|
|
|
|
|
|
|
list($sizeFolderToCopy,$fileNum,$foldersCount) = folder_info($path,false);
|
|
|
|
// size over limit
|
2019-01-11 09:59:01 +01:00
|
|
|
if ($config['copy_cut_max_size'] !== false && is_int($config['copy_cut_max_size'])) {
|
|
|
|
if (($config['copy_cut_max_size'] * 1024 * 1024) < $sizeFolderToCopy) {
|
|
|
|
response(sprintf(trans('Copy_Cut_Size_Limit'), $msg_sub_action, $config['copy_cut_max_size']).AddErrorLocation())->send();
|
2018-04-02 08:29:19 +02:00
|
|
|
exit;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// file count over limit
|
2019-01-11 09:59:01 +01:00
|
|
|
if ($config['copy_cut_max_count'] !== false && is_int($config['copy_cut_max_count']))
|
2018-04-02 08:29:19 +02:00
|
|
|
{
|
2019-01-11 09:59:01 +01:00
|
|
|
if ($config['copy_cut_max_count'] < $fileNum)
|
2018-04-02 08:29:19 +02:00
|
|
|
{
|
2019-01-11 09:59:01 +01:00
|
|
|
response(sprintf(trans('Copy_Cut_Count_Limit'), $msg_sub_action, $config['copy_cut_max_count']).AddErrorLocation())->send();
|
2018-04-02 08:29:19 +02:00
|
|
|
exit;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!checkresultingsize($sizeFolderToCopy)) {
|
2019-01-11 09:59:01 +01:00
|
|
|
response(sprintf(trans('max_size_reached'),$config['MaxSizeTotal']).AddErrorLocation())->send();
|
2018-04-02 08:29:19 +02:00
|
|
|
exit;
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
// can't copy/cut files
|
2019-01-11 09:59:01 +01:00
|
|
|
if ($config['copy_cut_files'] === false)
|
2018-04-02 08:29:19 +02:00
|
|
|
{
|
|
|
|
response(sprintf(trans('Copy_Cut_Not_Allowed'), $msg_sub_action, trans('Files')).AddErrorLocation())->send();
|
|
|
|
exit;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
$_SESSION['RF']['clipboard']['path'] = $_POST['path'];
|
|
|
|
$_SESSION['RF']['clipboard_action'] = $_POST['sub_action'];
|
|
|
|
break;
|
|
|
|
case 'clear_clipboard':
|
|
|
|
$_SESSION['RF']['clipboard'] = null;
|
|
|
|
$_SESSION['RF']['clipboard_action'] = null;
|
|
|
|
break;
|
|
|
|
case 'chmod':
|
|
|
|
if($ftp){
|
2019-01-11 09:59:01 +01:00
|
|
|
$path = $config['ftp_base_url'] . $config['upload_dir'] . $_POST['path'];
|
2018-04-02 08:29:19 +02:00
|
|
|
if (
|
2019-01-11 09:59:01 +01:00
|
|
|
($_POST['folder']==1 && $config['chmod_dirs'] === false)
|
|
|
|
|| ($_POST['folder']==0 && $config['chmod_files'] === false)
|
2018-04-02 08:29:19 +02:00
|
|
|
|| (is_function_callable("chmod") === false) )
|
|
|
|
{
|
|
|
|
response(sprintf(trans('File_Permission_Not_Allowed'), (is_dir($path) ? trans('Folders') : trans('Files')), 403).AddErrorLocation())->send();
|
|
|
|
exit;
|
|
|
|
}
|
|
|
|
$info = $_POST['permissions'];
|
|
|
|
}else{
|
2019-01-11 09:59:01 +01:00
|
|
|
$path = $config['current_path'] . $_POST['path'];
|
2018-04-02 08:29:19 +02:00
|
|
|
if (
|
2019-01-11 09:59:01 +01:00
|
|
|
(is_dir($path) && $config['chmod_dirs'] === false)
|
|
|
|
|| (is_file($path) && $config['chmod_files'] === false)
|
2018-04-02 08:29:19 +02:00
|
|
|
|| (is_function_callable("chmod") === false) )
|
|
|
|
{
|
|
|
|
response(sprintf(trans('File_Permission_Not_Allowed'), (is_dir($path) ? trans('Folders') : trans('Files')), 403).AddErrorLocation())->send();
|
|
|
|
exit;
|
|
|
|
}
|
|
|
|
|
|
|
|
$perms = fileperms($path) & 0777;
|
|
|
|
|
|
|
|
$info = '-';
|
|
|
|
|
|
|
|
// 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' : '-'));
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
$ret = '<div id="files_permission_start">
|
|
|
|
<form id="chmod_form">
|
|
|
|
<table class="table file-perms-table">
|
|
|
|
<thead>
|
|
|
|
<tr>
|
|
|
|
<td></td>
|
|
|
|
<td>r </td>
|
|
|
|
<td>w </td>
|
|
|
|
<td>x </td>
|
|
|
|
</tr>
|
|
|
|
</thead>
|
|
|
|
<tbody>
|
|
|
|
<tr>
|
|
|
|
<td>'.trans('User').'</td>
|
|
|
|
<td><input id="u_4" type="checkbox" data-value="4" data-group="user" '.(substr($info, 1,1)=='r' ? " checked" : "").'></td>
|
|
|
|
<td><input id="u_2" type="checkbox" data-value="2" data-group="user" '.(substr($info, 2,1)=='w' ? " checked" : "").'></td>
|
|
|
|
<td><input id="u_1" type="checkbox" data-value="1" data-group="user" '.(substr($info, 3,1)=='x' ? " checked" : "").'></td>
|
|
|
|
</tr>
|
|
|
|
<tr>
|
|
|
|
<td>'.trans('Group').'</td>
|
|
|
|
<td><input id="g_4" type="checkbox" data-value="4" data-group="group" '.(substr($info, 4,1)=='r' ? " checked" : "").'></td>
|
|
|
|
<td><input id="g_2" type="checkbox" data-value="2" data-group="group" '.(substr($info, 5,1)=='w' ? " checked" : "").'></td>
|
|
|
|
<td><input id="g_1" type="checkbox" data-value="1" data-group="group" '.(substr($info, 6,1)=='x' ? " checked" : "").'></td>
|
|
|
|
</tr>
|
|
|
|
<tr>
|
|
|
|
<td>'.trans('All').'</td>
|
|
|
|
<td><input id="a_4" type="checkbox" data-value="4" data-group="all" '.(substr($info, 7,1)=='r' ? " checked" : "").'></td>
|
|
|
|
<td><input id="a_2" type="checkbox" data-value="2" data-group="all" '.(substr($info, 8,1)=='w' ? " checked" : "").'></td>
|
|
|
|
<td><input id="a_1" type="checkbox" data-value="1" data-group="all" '.(substr($info, 9,1)=='x' ? " checked" : "").'></td>
|
|
|
|
</tr>
|
|
|
|
<tr>
|
|
|
|
<td></td>
|
|
|
|
<td colspan="3"><input type="text" class="input-block-level" name="chmod_value" id="chmod_value" value="" data-def-value=""></td>
|
|
|
|
</tr>
|
|
|
|
</tbody>
|
|
|
|
</table>';
|
|
|
|
|
|
|
|
if ((!$ftp && is_dir($path)) )
|
|
|
|
{
|
|
|
|
$ret .= '<div class="hero-unit" style="padding:10px;">'.trans('File_Permission_Recursive').'<br/><br/>
|
|
|
|
<ul class="unstyled">
|
|
|
|
<li><label class="radio"><input value="none" name="apply_recursive" type="radio" checked> '.trans('No').'</label></li>
|
|
|
|
<li><label class="radio"><input value="files" name="apply_recursive" type="radio"> '.trans('Files').'</label></li>
|
|
|
|
<li><label class="radio"><input value="folders" name="apply_recursive" type="radio"> '.trans('Folders').'</label></li>
|
|
|
|
<li><label class="radio"><input value="both" name="apply_recursive" type="radio"> '.trans('Files').' & '.trans('Folders').'</label></li>
|
|
|
|
</ul>
|
|
|
|
</div>';
|
|
|
|
}
|
|
|
|
|
|
|
|
$ret .= '</form></div>';
|
|
|
|
|
|
|
|
response($ret)->send();
|
|
|
|
exit;
|
|
|
|
|
|
|
|
break;
|
|
|
|
case 'get_lang':
|
|
|
|
if ( ! file_exists('lang/languages.php'))
|
|
|
|
{
|
|
|
|
response(trans('Lang_Not_Found').AddErrorLocation())->send();
|
|
|
|
exit;
|
|
|
|
}
|
|
|
|
|
|
|
|
$languages = include 'lang/languages.php';
|
|
|
|
if ( ! isset($languages) || ! is_array($languages))
|
|
|
|
{
|
|
|
|
response(trans('Lang_Not_Found').AddErrorLocation())->send();
|
|
|
|
exit;
|
|
|
|
}
|
|
|
|
|
|
|
|
$curr = $_SESSION['RF']['language'];
|
|
|
|
|
|
|
|
$ret = '<select id="new_lang_select">';
|
|
|
|
foreach ($languages as $code => $name)
|
|
|
|
{
|
|
|
|
$ret .= '<option value="' . $code . '"' . ($code == $curr ? ' selected' : '') . '>' . $name . '</option>';
|
|
|
|
}
|
|
|
|
$ret .= '</select>';
|
|
|
|
|
|
|
|
response($ret)->send();
|
|
|
|
exit;
|
|
|
|
|
|
|
|
break;
|
|
|
|
case 'change_lang':
|
|
|
|
$choosen_lang = (!empty($_POST['choosen_lang']))? $_POST['choosen_lang']:"en_EN";
|
|
|
|
|
|
|
|
if(array_key_exists($choosen_lang,$languages)){
|
|
|
|
if ( ! file_exists('lang/' . $choosen_lang . '.php'))
|
|
|
|
{
|
|
|
|
response(trans('Lang_Not_Found').AddErrorLocation())->send();
|
|
|
|
exit;
|
|
|
|
}else{
|
|
|
|
$_SESSION['RF']['language'] = $choosen_lang;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
break;
|
|
|
|
case 'cad_preview':
|
|
|
|
if($ftp){
|
2019-01-11 09:59:01 +01:00
|
|
|
$selected_file = $config['ftp_base_url'].$config['upload_dir'] . $_GET['file'];
|
2018-04-02 08:29:19 +02:00
|
|
|
}else{
|
2019-01-11 09:59:01 +01:00
|
|
|
$selected_file = $config['current_path'] . $_GET['file'];
|
2018-04-02 08:29:19 +02:00
|
|
|
|
|
|
|
if ( ! file_exists($selected_file))
|
|
|
|
{
|
|
|
|
response(trans('File_Not_Found').AddErrorLocation())->send();
|
|
|
|
exit;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if($ftp){
|
|
|
|
$url_file = $selected_file;
|
|
|
|
}else{
|
2019-01-11 09:59:01 +01:00
|
|
|
$url_file = $config['base_url'] . $config['upload_dir'] . str_replace($config['current_path'], '', $_GET["file"]);
|
2018-04-02 08:29:19 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
$cad_url = urlencode($url_file);
|
|
|
|
$cad_html = "<iframe src=\"//sharecad.org/cadframe/load?url=" . $url_file . "\" class=\"google-iframe\" scrolling=\"no\"></iframe>";
|
|
|
|
$ret = $cad_html;
|
|
|
|
response($ret)->send();
|
|
|
|
break;
|
|
|
|
case 'get_file': // preview or edit
|
|
|
|
$sub_action = $_GET['sub_action'];
|
|
|
|
$preview_mode = $_GET["preview_mode"];
|
|
|
|
|
|
|
|
if ($sub_action != 'preview' && $sub_action != 'edit')
|
|
|
|
{
|
|
|
|
response(trans('wrong action').AddErrorLocation())->send();
|
|
|
|
exit;
|
|
|
|
}
|
|
|
|
|
|
|
|
if($ftp){
|
2019-01-11 09:59:01 +01:00
|
|
|
$selected_file = ($sub_action == 'preview' ? $config['ftp_base_url'].$config['upload_dir'] . $_GET['file'] : $config['ftp_base_url'].$config['upload_dir'] . $_POST['path']);
|
2018-04-02 08:29:19 +02:00
|
|
|
}else{
|
2019-01-11 09:59:01 +01:00
|
|
|
$selected_file = ($sub_action == 'preview' ? $config['current_path'] . $_GET['file'] : $config['current_path'] . $_POST['path']);
|
2018-04-02 08:29:19 +02:00
|
|
|
|
|
|
|
if ( ! file_exists($selected_file))
|
|
|
|
{
|
|
|
|
response(trans('File_Not_Found').AddErrorLocation())->send();
|
|
|
|
exit;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
$info = pathinfo($selected_file);
|
|
|
|
|
|
|
|
if ($preview_mode == 'text')
|
|
|
|
{
|
2019-01-11 09:59:01 +01:00
|
|
|
$is_allowed = ($sub_action == 'preview' ? $config['preview_text_files'] : $config['edit_text_files']);
|
|
|
|
$allowed_file_exts = ($sub_action == 'preview' ? $config['previewable_text_file_exts'] : $config['editable_text_file_exts']);
|
2018-04-02 08:29:19 +02:00
|
|
|
}elseif($preview_mode == 'google') {
|
2019-01-11 09:59:01 +01:00
|
|
|
$is_allowed = $config['googledoc_enabled'];
|
|
|
|
$allowed_file_exts = $config['googledoc_file_exts'];
|
2018-04-02 08:29:19 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
if ( ! isset($allowed_file_exts) || ! is_array($allowed_file_exts))
|
|
|
|
{
|
|
|
|
$allowed_file_exts = array();
|
|
|
|
}
|
|
|
|
|
2019-01-11 09:59:01 +01:00
|
|
|
if(!isset($info['extension'])){
|
|
|
|
$info['extension']='';
|
|
|
|
}
|
2018-04-02 08:29:19 +02:00
|
|
|
if ( ! in_array($info['extension'], $allowed_file_exts)
|
|
|
|
|| ! isset($is_allowed)
|
|
|
|
|| $is_allowed === false
|
|
|
|
|| (!$ftp && ! is_readable($selected_file))
|
|
|
|
)
|
|
|
|
{
|
|
|
|
response(sprintf(trans('File_Open_Edit_Not_Allowed'), ($sub_action == 'preview' ? strtolower(trans('Open')) : strtolower(trans('Edit')))).AddErrorLocation())->send();
|
|
|
|
exit;
|
|
|
|
}
|
|
|
|
if ($sub_action == 'preview')
|
|
|
|
{
|
|
|
|
if ($preview_mode == 'text')
|
|
|
|
{
|
|
|
|
// get and sanities
|
|
|
|
$data = file_get_contents($selected_file);
|
|
|
|
$data = htmlspecialchars(htmlspecialchars_decode($data));
|
|
|
|
$ret = '';
|
|
|
|
|
2019-01-11 09:59:01 +01:00
|
|
|
$ret .= '<script src="https://rawgit.com/google/code-prettify/master/loader/run_prettify.js?autoload=true&skin=sunburst"></script>';
|
|
|
|
$ret .= '<?prettify lang='.$info['extension'].' linenums=true?><pre class="prettyprint"><code class="language-'.$info['extension'].'">'.$data.'</code></pre>';
|
2018-04-02 08:29:19 +02:00
|
|
|
|
|
|
|
}
|
|
|
|
elseif ($preview_mode == 'google') {
|
|
|
|
if($ftp){
|
|
|
|
$url_file = $selected_file;
|
|
|
|
}else{
|
2019-01-11 09:59:01 +01:00
|
|
|
$url_file = $config['base_url'] . $config['upload_dir'] . str_replace($config['current_path'], '', $_GET["file"]);
|
2018-04-02 08:29:19 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
$googledoc_url = urlencode($url_file);
|
2019-01-11 09:59:01 +01:00
|
|
|
$ret = "<iframe src=\"https://docs.google.com/viewer?url=" . $url_file . "&embedded=true\" class=\"google-iframe\"></iframe>";
|
2018-04-02 08:29:19 +02:00
|
|
|
}
|
2019-01-11 09:59:01 +01:00
|
|
|
}else{
|
2018-04-02 08:29:19 +02:00
|
|
|
$data = stripslashes(htmlspecialchars(file_get_contents($selected_file)));
|
2019-01-11 09:59:01 +01:00
|
|
|
if(in_array($info['extension'],array('html','html'))){
|
|
|
|
$ret = '<script src="https://cdn.ckeditor.com/ckeditor5/11.1.1/classic/ckeditor.js"></script><textarea id="textfile_edit_area" style="width:100%;height:300px;">'.$data.'</textarea><script>setTimeout(function(){ ClassicEditor
|
|
|
|
.create( document.querySelector( "#textfile_edit_area" ),{ }).then( newEditor => { window.editor = newEditor; } ); }, 500);</script>';
|
|
|
|
}else{
|
|
|
|
$ret = '<textarea id="textfile_edit_area" style="width:100%;height:300px;">'.$data.'</textarea>';
|
|
|
|
}
|
|
|
|
|
2018-04-02 08:29:19 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
response($ret)->send();
|
|
|
|
exit;
|
|
|
|
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
response(trans('no action passed').AddErrorLocation())->send();
|
|
|
|
exit;
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
response(trans('no action passed').AddErrorLocation())->send();
|
|
|
|
exit;
|
|
|
|
}
|