options.php 18 KB
 <?php
 // don't load directly 
if ( !defined('ABSPATH') ) 
	die('-1');	
 
 	//Set dir
	if (ini_get('open_basedir')) {
		foreach (explode(PATH_SEPARATOR,str_replace('\\','/',ini_get('open_basedir'))) as $basedirs) {
			$opdenbasedirs[]=trailingslashit($basedirs);
		}
	} else {
		if (function_exists('posix_getpwuid'))
			$opdenbasedirs=array('/');
		else 
			$opdenbasedirs=array('A:/','B:/','C:/','D:/','E:/','F:/','G:/','H:/','I:/','J:/','K:/','L:/','M:/','N:/','O:/','P:/','Q:/','R:/','S:/','T:/','U:/','V:/','W:/','X:/','Y:/','Z:/');
	}
	$opdenbasedirs=array_unique($opdenbasedirs);
	sort($opdenbasedirs);
	
	$folder=trailingslashit($gotofolder);
	if (!empty($_GET['gotofolder']))
		$folder=trailingslashit(str_replace('\\','/',realpath($_GET['gotofolder']))); //dirchange
		


	//get files and folder
	$dirs=array();
	if ( $dir = @opendir( $folder ) ) {
		while (false !== ($file = readdir($dir))) {
			if ($file=='.' or $file=='..')
				continue;
			if (@is_dir($folder.$file))
				$dirs[]=$folder.$file;
		}
		@closedir( $dir );
		sort($dirs);
	}
	$files=array();
	if ( $dir = @opendir( $folder ) ) {
		while (false !== ($file = readdir($dir))) {
			if ($file=='.' or $file=='..')
				continue;
			if (!@is_dir($folder.$file))
				$files[]=$folder.$file;
		}
		@closedir( $dir );
		sort($files);
	}
	$files=array_merge($dirs,$files);		

 ?>
<div class="wrap">
	<div id="icon-tools" class="icon32"><br /></div>
<h2><?php _e("FileBrowser", "filebrowser"); ?>&nbsp;<a href="<?PHP echo wp_nonce_url('admin.php?page=FileBrowser&action=new&gotofolder='.$folder, 'filebrowser'); ?>" class="button add-new-h2"><?php esc_html_e('Add New'); ?></a></h2>

<form id="filebrowser" action="" method="post" enctype="multipart/form-data">
<?php wp_nonce_field('filebrowser'); ?>
<input type="hidden" name="page" value="FileBrowser" />
<div class="tablenav"> 
 
<div class="alignleft actions"> 
<select name="action" class="select-action"> 
<option value="-1" selected="selected"><?PHP _e('Bulk Actions','filebrowser'); ?></option> 
<option value="delete"><?PHP _e('Delete','filebrowser'); ?></option>
<option value="copy"><?PHP _e('Copy','filebrowser'); ?></option> 
<option value="move"><?PHP _e('Move','filebrowser'); ?></option>
<option value="zip"><?PHP _e('Zip','filebrowser'); ?></option> 
</select> 
<input type="submit" value="<?PHP _e('Apply','filebrowser'); ?>" name="doaction" id="doaction" class="button-secondary action" /> 

<?php
if (count($opdenbasedirs)>1) {
	echo '<select name="root">';
	foreach ($opdenbasedirs as $roots) {
		echo '<option value="'.esc_attr($roots).'"'.selected(substr($folder,0,strlen($roots)),$roots,false).'>'.$roots.'</option>';
		if (substr($folder,0,strlen($roots))==$roots) 
			$folderrest=substr($folder,strlen($roots));
	}
	echo '</select>';
} else {
	foreach ($opdenbasedirs as $roots) {
		echo '<input type="hidden" name="root" value="'.esc_attr($roots).'" />';
		echo '<big>'.$roots.'</big>';
		$folderrest=substr($folder,strlen($roots));
	}
}
echo '<input type="hidden" name="oldusedfolder" value="'.esc_attr($folder).'" />';
?>
<input type="text" size="45" name="newfolder" value="<?php echo $folderrest; ?>" />
<input type="submit" value="<?PHP _e('Go','filebrowser'); ?>" name="doactiongo" id="doactiongo" class="button-secondary action" />
&nbsp;
<?PHP if (!in_array($folder,$opdenbasedirs)) { ?>
	<a href="admin.php?page=FileBrowser&amp;gotofolder=<?PHP echo $folder.'..'; if (!empty($_GET['copyfiles'])) echo '&amp;copyfiles='.esc_attr($_GET['copyfiles']); if (!empty($_GET['movefiles'])) echo '&amp;movefiles='.esc_attr($_GET['movefiles']);?>"><img src="<?PHP echo plugins_url('',__FILE__); ?>/icons/arrow_undo.png" border="0" title="<?PHP _e('..','filebrowser');?>" alt="<?PHP _e('..','filebrowser');?>" /></a>&nbsp;
<?PHP } ?>
<a href="admin.php?page=FileBrowser&amp;gotofolder=<?PHP echo $folder; if (!empty($_GET['copyfiles'])) echo '&amp;copyfiles='.esc_attr($_GET['copyfiles']); if (!empty($_GET['movefiles'])) echo '&amp;movefiles='.esc_attr($_GET['movefiles']);?>"><img src="<?PHP echo plugins_url('',__FILE__); ?>/icons/arrow_refresh.png" border="0" title="<?PHP _e('Refresh','filebrowser');?>" alt="<?PHP _e('Refresh','filebrowser');?>" /></a>&nbsp;
<?PHP if (!empty($_GET['copyfiles'])) { ?>
	<a href="<?PHP echo wp_nonce_url('admin.php?page=FileBrowser&action=copynow&copyfiles='.esc_attr($_GET['copyfiles']).'&copyto='.esc_attr($folder), 'filebrowser'); ?>"><img src="<?PHP echo plugins_url('',__FILE__); ?>/icons/arrow_in.png" border="0" title="<?PHP _e('Copy to','filebrowser');?>" alt="<?PHP _e('Copy to','filebrowser');?>" /></a>&nbsp;
<?PHP } ?>
<?PHP if (!empty($_GET['movefiles'])) { ?>
	<a href="<?PHP echo wp_nonce_url('admin.php?page=FileBrowser&action=movenow&movefiles='.esc_attr($_GET['movefiles']).'&moveto='.esc_attr($folder), 'filebrowser'); ?>"><img src="<?PHP echo plugins_url('',__FILE__); ?>/icons/arrow_in.png" border="0" title="<?PHP _e('Move to','filebrowser');?>" alt="<?PHP _e('Move to','filebrowser');?>" /></a>&nbsp;
<?PHP } ?>

</div> 
 
<br class="clear" />
</div>

<div class="clear"></div>

<table class="widefat" cellspacing="0">
	<thead>
	<tr>
<?php print_column_headers($page_hook); ?>
	</tr>
	</thead>
	
	<tfoot>
	<tr>
<?php print_column_headers($page_hook, false); ?>
	</tr>
	</tfoot>	
 
	<tbody id="the-list" class="list:post"> 
	
	<?PHP 
	if ($_GET['action']=='new') {  //make new files
	?>
	<tr id="file-new" class="alternate status-inherit" valign="top"> 
		<th scope="row" class="check-column">&nbsp;</th> 
		<td class="name column-name">
			<img src="<?PHP echo plugins_url('',__FILE__).'/icons/file.png'; ?>" height="16" width="16" border="0" title="<?PHP _e('Create empty','filebrowser'); ?>" alt="<?PHP _e('Create empty','filebrowser'); ?>" />&nbsp;
			<input type="text" class="regular-text" name="newname" size="30" value="" />
			<select name="type"><option value="dir"><?PHP _e('Folder','filebrowser');?></option><option value="file"><?PHP _e('File','filebrowser');?></option></select><br />
			<input type="hidden" name="dir" value="<?PHP echo esc_attr($folder);?>" />
			<img src="<?PHP echo plugins_url('',__FILE__).'/icons/disk.png'; ?>" height="16" width="16" border="0" title="<?PHP _e('Upload file','filebrowser'); ?>" alt="<?PHP _e('Upload file','filebrowser'); ?>" />&nbsp;<input name="uplodfile" type="file" size="40" class="file"> <?PHP echo _e('Max size:','filebrowser').' '.ini_get('upload_max_filesize');?><br />
			<img src="<?PHP echo plugins_url('',__FILE__).'/icons/connect.png'; ?>" height="16" width="16" border="0" title="<?PHP _e('Copy file from URL','filebrowser'); ?>" alt="<?PHP _e('Copy file from URL','filebrowser'); ?>" />&nbsp;<input type="text" class="regular-text" size="40" name="copyfile" value="" />&nbsp;
			<input type="submit" value="<?PHP _e('Create','filebrowser'); ?>" name="doactionnew" id="doactionnew" class="button-secondary action" />
		</td>
		<td class="column-size">&nbsp;</td> 
		<td class="column-mdate">&nbsp;</td>
		<td class="column-premissions">&nbsp;</td>
		</td> 
	</tr>
	<?PHP 
	}
	
	if ($_GET['action']=='zip' or $_POST['action']=='zip' or $_POST['action2']=='zip') {  //Make zip file
	?>
	<tr id="file-zip" class="alternate status-inherit" valign="top"> 
		<th scope="row" class="check-column">&nbsp;</th> 
		<td class="name column-name">
			<img src="<?PHP echo plugins_url('',__FILE__).'/icons/zip.png'; ?>" height="16" width="16" border="0" title="<?PHP _e('Zip file name','filebrowser'); ?>" alt="<?PHP _e('Zip file name','filebrowser'); ?>" />&nbsp;
			<input type="text" class="regular-text" name="zipname" value=".zip" />
			<input type="hidden" name="folder" value="<?PHP echo esc_attr($folder);?>" />
			<?PHP
			if(is_array($_POST['selfiles'])) {
				$zipfiles=implode(';',$_POST['selfiles']);
			} else {
				$zipfiles=$_GET['selfiles'];
			}		
			?>
			<input type="hidden" name="zipfiles" value="<?PHP echo esc_attr($zipfiles);?>" />
			<input type="submit" value="<?PHP _e('Create Zip','filebrowser'); ?>" name="doactionzip" id="doactionzip" class="button-secondary action" />
		</td>
		<td class="column-size">&nbsp;</td> 
		<td class="column-mdate">&nbsp;</td>
		<td class="column-premissions">&nbsp;</td>
		</td> 
	</tr>
	<?PHP 
	}

	
	$item_columns = get_column_headers($page_hook);
	$hidden = get_hidden_columns($page_hook);
	
	if (is_array($files)) { 
		foreach ($files as $file) {
			if (!($filestats=@stat($file)))
				unset($filestats);
		?><tr id="file-<?PHP echo $file;?>" valign="top"><?PHP 
		foreach($item_columns as $column_name=>$column_display_name) {
			$class = "class=\"column-$column_name\"";

			$style = '';
			if ( in_array($column_name, $hidden) )
				$style = ' style="display:none;"';

			$attributes = "$class$style";
			
			switch($column_name) {
				case 'cb':
					echo '<th scope="row" class="check-column"><input type="checkbox" name="selfiles[]" value="'. esc_attr($file) .'" /></th>';
					break;	
				case 'name':
					if (@is_dir($file)) {
						echo "<td $attributes>"; ?>
						<img src="<?PHP echo filebrowser_fileicon($file); ?>" height="16" width="16" border="0" alt="<?PHP _e('Folder','filebrowser'); ?>" />&nbsp;
						<?PHP if ($_GET['action']=='rename' and $_GET['filerename']==$file) {?>
							<input type="text" class="regular-text" name="newname" value="<?PHP echo basename($file);?>" /><input type="hidden" name="oldfile" value="<?PHP echo esc_attr($file);?>" /><input type="submit" value="<?PHP _e('Rename','filebrowser'); ?>" name="doactionrename" class="button-secondary action" />
						<?PHP } else { ?>
							<strong><a href="admin.php?page=FileBrowser&amp;gotofolder=<?PHP echo esc_attr($file); if (!empty($_GET['copyfiles'])) echo '&amp;copyfiles='.esc_attr($_GET['copyfiles']); if (!empty($_GET['movefiles'])) echo '&amp;movefiles='.esc_attr($_GET['movefiles']);?>"><?PHP echo basename($file);?></a></strong>
						<?PHP } ?>
						<div class="row-actions">
							<?PHP if (is_writable($file)) {?>
								<span class="delete"><a class="submitdelete" href="<?PHP echo wp_nonce_url('admin.php?page=FileBrowser&action=delete&selfiles='.esc_attr($file), 'filebrowser'); ?>" onclick="if ( confirm('<?PHP echo esc_js(__("You are about to delete this File/Dir. \n  'Cancel' to stop, 'OK' to delete.","filebrowser")) ?>') ){return true;}return false;"><?PHP _e('Delete','filebrowser'); ?></a> | </span>
							<?PHP } ?>
							<span class="copy"><a href="<?PHP echo wp_nonce_url('admin.php?page=FileBrowser&action=copy&selfiles='.esc_attr($file), 'filebrowser'); ?>"><?PHP _e('Copy','filebrowser'); ?></a> | </span>
							<span class="move"><a href="<?PHP echo wp_nonce_url('admin.php?page=FileBrowser&action=move&selfiles='.esc_attr($file), 'filebrowser'); ?>"><?PHP _e('Move','filebrowser'); ?></a> | </span>
							<span class="rename"><a href="<?PHP echo wp_nonce_url('admin.php?page=FileBrowser&action=rename&filerename='.esc_attr($file).'&gotofolder='.esc_attr(dirname($file)), 'rename-file_'.esc_attr($file)); ?>"><?PHP _e('Rename','filebrowser'); ?></a> | </span>
							<?PHP if (function_exists('posix_getpwuid') and function_exists('posix_getgrgid')) {?>
								<span class="premissions"><a href="<?PHP echo wp_nonce_url('admin.php?page=FileBrowser&action=premissions&filepremissions='.esc_attr($file).'&gotofolder='.esc_attr(dirname($file)), 'filebrowser'); ?>"><?PHP _e('Permissions','filebrowser'); ?></a> | </span>
							<?PHP } ?>
							<span class="zip"><a href="<?PHP echo wp_nonce_url('admin.php?page=FileBrowser&action=zip&selfiles='.esc_attr($file).'&gotofolder='.esc_attr($file.'/..'), 'filebrowser'); ?>"><?PHP _e('Zip','filebrowser'); ?></a></span>
						</div><?PHP 
						echo '</td>';
					} else {
						echo "<td $attributes>"; ?>
						<img src="<?PHP echo filebrowser_fileicon($file); ?>" height="16" width="16" border="0" alt="<?PHP echo pathinfo($file,PATHINFO_EXTENSION); ?>" />&nbsp;
						<?PHP if ($_GET['action']=='rename' and $_GET['filerename']==$file) {?>
							<input type="text" class="regular-text" name="newname" value="<?PHP echo basename($file);?>" /><input type="hidden" name="oldfile" value="<?PHP echo esc_attr($file);?>" /><input type="submit" value="<?PHP _e('Rename','filebrowser'); ?>" name="doactionrename" class="button-secondary action" />
						<?PHP } else { ?>
							<strong><a href="<?PHP echo wp_nonce_url('admin.php?page=FileBrowser&action=download&selfile='.esc_attr($file), 'download-file_'.esc_attr($file)); ?>"><?PHP echo basename($file);?></a></strong>
						<?PHP } ?>
						<div class="row-actions">
							<?PHP if (is_writable($file) and in_array(strtolower(pathinfo($file,PATHINFO_EXTENSION)),array('php','txt','log','html','htm','php3','css','js','ini','nfo','sh','cmd','bat','htaccess','xml'))) {?>
								<span class="edit"><a href="<?PHP echo wp_nonce_url('admin.php?page=FileBrowser&action=edit&selfile='.esc_attr($file), 'edit-file'); ?>"><?PHP _e('Edit','filebrowser'); ?></a> | </span>
							<?PHP } ?>
							<?PHP if (is_writable($file)) {?>
								<span class="delete"><a class="submitdelete" href="<?PHP echo wp_nonce_url('admin.php?page=FileBrowser&action=delete&selfiles='.esc_attr($file), 'filebrowser'); ?>" onclick="if ( confirm('<?PHP echo esc_js(__("You are about to delete this File/Dir. \n  'Cancel' to stop, 'OK' to delete.","filebrowser")) ?>') ){return true;}return false;"><?PHP _e('Delete','filebrowser'); ?></a> | </span>
							<?PHP } ?>
							<span class="copy"><a href="<?PHP echo wp_nonce_url('admin.php?page=FileBrowser&action=copy&selfiles='.esc_attr($file), 'filebrowser'); ?>"><?PHP _e('Copy','filebrowser'); ?></a> | </span>
							<span class="move"><a href="<?PHP echo wp_nonce_url('admin.php?page=FileBrowser&action=move&selfiles='.esc_attr($file), 'filebrowser'); ?>"><?PHP _e('Move','filebrowser'); ?></a> | </span>
							<span class="rename"><a href="<?PHP echo wp_nonce_url('admin.php?page=FileBrowser&action=rename&filerename='.esc_attr($file).'&gotofolder='.esc_attr(dirname($file)), 'rename-file_'.esc_attr($file)); ?>"><?PHP _e('Rename','filebrowser'); ?></a> | </span>
							<?PHP if (function_exists('posix_getpwuid')) {?>
								<span class="premissions"><a href="<?PHP echo wp_nonce_url('admin.php?page=FileBrowser&action=premissions&filepremissions='.esc_attr($file).'&gotofolder='.esc_attr(dirname($file)), 'filebrowser'); ?>"><?PHP _e('Permissions','filebrowser'); ?></a> | </span>
							<?PHP }
							if (strtolower(pathinfo($file,PATHINFO_EXTENSION))=="zip") {?>
								<span class="zip"><a href="<?PHP echo wp_nonce_url('admin.php?page=FileBrowser&action=unzip&selfiles='.esc_attr($file), 'filebrowser'); ?>"><?PHP _e('UnZip here','filebrowser'); ?></a></span>
							<?PHP } else { ?>
								<span class="zip"><a href="<?PHP echo wp_nonce_url('admin.php?page=FileBrowser&action=zip&selfiles='.esc_attr($file).'&folder='.esc_attr(dirname($file)), 'filebrowser'); ?>"><?PHP _e('Zip','filebrowser'); ?></a></span>
							<?PHP } ?>
						</div><?PHP 
						echo '</td>';
					}
					break;	
				case 'size':
					echo "<td $attributes>";
					if (is_dir($file))
						echo '-';
					else
						echo filebrowser_formatBytes($filestats['size']); 
					echo "</td>";
					break;	
				case 'mdate':
					echo "<td $attributes>";
					if (is_array($filestats)) 
						echo date(get_option('date_format'),$filestats['mtime']).' '.date(get_option('time_format'),$filestats['mtime']);
					echo "</td>";
					break;	
				case 'premissions':
					echo "<td $attributes>";
					if (function_exists('posix_getpwuid')) { //only on unix systems
						$owner=posix_getpwuid($filestats['uid']);
						$grp=posix_getgrgid($filestats['gid']);
					}
					if ($_GET['action']=='premissions' and $_GET['filepremissions']==$file) {
						$prem=filebrowser_premissions($file);
						echo __('Own:','filebrowser').' <input class="checkbox" value="400" type="checkbox"'.checked(substr($prem,1,1),'r',false).' name="prems[]" />r <input class="checkbox" value="200" type="checkbox"'.checked(substr($prem,2,1),'w',false).' name="prems[]" />w <input class="checkbox" value="100" type="checkbox"'.checked(substr($prem,3,1),'x',false).' name="prems[]" />x<br />';
						echo __('Grp:','filebrowser').' <input class="checkbox" value="40" type="checkbox"'.checked(substr($prem,4,1),'r',false).' name="prems[]" />r <input class="checkbox" value="20" type="checkbox"'.checked(substr($prem,5,1),'w',false).' name="prems[]" />w <input class="checkbox" value="10" type="checkbox"'.checked(substr($prem,6,1),'x',false).' name="prems[]" />x<br />';
						echo __('Pub:','filebrowser').' <input class="checkbox" value="4" type="checkbox"'.checked(substr($prem,7,1),'r',false).' name="prems[]" />r <input class="checkbox" value="2" type="checkbox"'.checked(substr($prem,8,1),'w',false).' name="prems[]" />w <input class="checkbox" value="1" type="checkbox"'.checked(substr($prem,9,1),'x',false).' name="prems[]" />x<br />';
						if (function_exists('posix_getpwuid')) { //only on unix systems
							echo __('Own:','filebrowser').' <input class="small-text" value="'.esc_attr($owner['name']).'" type="text" name="owner" /><br />';
							echo __('Grp:','filebrowser').' <input class="small-text" value="'.esc_attr($grp['name']).'" type="text" name="group" /><br />';
						}
						echo '<input type="hidden" name="changefile" value="'.esc_attr($file).'" /><input type="submit" value="'.__('Change','filebrowser').'" name="doactionpremissions" class="button-secondary action" />';
					} else {
						if (is_array($filestats)) {
							echo filebrowser_premissions($file).'<br />';
							if (function_exists('posix_getpwuid')) { //only on unix systems
								echo $owner['name'].' ';
								echo $grp['name'];
							}
						}
					}
					echo "</td>";
					break;	
			}
		}
		echo "\n    </tr>\n";
		}
	}
	?></tbody> 
</table> 	
  
<div class="tablenav"> 
<div class="alignleft actions"> 
<select name="action2" class="select-action"> 
<option value="-1" selected="selected"><?PHP _e('Bulk Actions','backwpup'); ?></option> 
<option value="delete"><?PHP _e('Delete','filebrowser'); ?></option>
<option value="copy"><?PHP _e('Copy','filebrowser'); ?></option> 
<option value="move"><?PHP _e('Move','filebrowser'); ?></option>
<option value="zip"><?PHP _e('Zip','filebrowser'); ?></option>
</select> 
<input type="submit" value="<?PHP _e('Apply','backwpup'); ?>" name="doaction2" id="doaction2" class="button-secondary action" /> 
</div> 
 
<br class="clear" /> 
</div> 
</form> 
<br class="clear" /> 
 
</div>