Files
Autoindex-2.2.4/classes/DirectoryListDetailed.php
2019-09-28 04:55:48 +02:00

237 lines
6.1 KiB
PHP
Executable File

<?php
/**
* @package AutoIndex
*
* @copyright Copyright (C) 2002-2006 Justin Hagstrom
* @license http://www.gnu.org/licenses/gpl.html GNU General Public License (GPL)
*
* @link http://autoindex.sourceforge.net
*/
/*
AutoIndex PHP Script is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation; either version 2 of the License, or
(at your option) any later version.
AutoIndex PHP Script is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program; if not, write to the Free Software
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
*/
if (!defined('IN_AUTOINDEX') || !IN_AUTOINDEX)
{
die();
}
/**
* Subclass of DirectoryList that uses the Item class to represent each
* file/folder in the directory. Each entry in the list is an object of
* the Item class.
*
* @author Justin Hagstrom <JustinHagstrom@yahoo.com>
* @version 1.1.0 (January 01, 2006)
* @package AutoIndex
*/
class DirectoryListDetailed extends DirectoryList
{
/**
* @var string The HTML text that makes up the path navigation links
*/
protected $path_nav;
/**
* @var int Total number of files in this directory
*/
protected $total_files;
/**
* @var int Total number of folders in this directory
*/
protected $total_folders;
/**
* @var int Total number of folders in this directory (including parent)
*/
protected $raw_total_folders;
/**
* @var int Total number of downloads of files in this directory
*/
protected $total_downloads;
/**
* @var Size Total size of this directory (recursive)
*/
protected $total_size;
/**
* @return string The HTML text that makes up the path navigation
*/
private function set_path_nav()
{
global $config, $subdir;
$exploded = explode('/', $subdir);
$c = count($exploded) - 1;
$temp = '<a class="autoindex_a" href="' . Url::html_output($_SERVER['PHP_SELF']) . '?dir=">'
. Url::html_output(substr(str_replace('/', ' / ', $config -> __get('base_dir')), 0, -2)) . '</a>/ ';
for ($i = 0; $i < $c; $i++)
{
$temp .= '<a class="autoindex_a" href="' . Url::html_output($_SERVER['PHP_SELF'])
. '?dir=';
for ($j = 0; $j <= $i; $j++)
{
$temp .= Url::translate_uri($exploded[$j]) . '/';
}
$temp .= '">' . Url::html_output($exploded[$i]) . '</a> / ';
}
return $temp;
}
/**
* Returns -1 if $a < $b or 1 if $a > $b
*
* @param Item $a
* @param Item $b
* @return int
*/
private static function callback_sort(Item $a, Item $b)
{
if ($a -> __get('is_parent_dir'))
{
return -1;
}
if ($b -> __get('is_parent_dir'))
{
return 1;
}
$sort = strtolower($_SESSION['sort']);
if ($sort === 'size')
{
$val = (($a -> __get('size') -> __get('bytes') <
$b -> __get('size') -> __get('bytes')) ? -1 : 1);
}
else
{
if (!$a -> is_set($sort))
{
$_SESSION['sort'] = 'filename'; //so the "continue" link will work
throw new ExceptionDisplay('Invalid sort mode.');
}
if (is_string($a -> __get($sort)))
{
$val = strnatcasecmp($a -> __get($sort), $b -> __get($sort));
}
else
{
$val = (($a -> __get($sort) < $b -> __get($sort)) ? -1 : 1);
}
}
return ((strtolower($_SESSION['sort_mode']) === 'd') ? -$val : $val);
}
/**
* @param array $list The array to be sorted with the callback_sort function
*/
protected static function sort_list(&$list)
{
usort($list, array('self', 'callback_sort'));
}
/**
* @return int The total number of files and folders (including the parent folder)
*/
public function total_items()
{
return $this -> raw_total_folders + $this -> total_files;
}
/**
* @param string $path The directory to read the files from
* @param int $page The number of files to skip (used for pagination)
*/
public function __construct($path, $page = 1)
{
$path = Item::make_sure_slash($path);
parent::__construct($path);
$subtract_parent = false;
$this -> total_downloads = $total_size = 0;
$dirs = $files = array();
foreach ($this as $t)
{
if (@is_dir($path . $t))
{
$temp = new DirItem($path, $t);
if ($temp -> __get('is_parent_dir'))
{
$dirs[] = $temp;
$subtract_parent = true;
}
else if ($temp -> __get('filename') !== false)
{
$dirs[] = $temp;
if ($temp -> __get('size') -> __get('bytes') !== false)
{
$total_size += $temp -> __get('size') -> __get('bytes');
}
}
}
else if (@is_file($path . $t))
{
$temp = new FileItem($path, $t);
if ($temp -> __get('filename') !== false)
{
$files[] = $temp;
$this -> total_downloads += $temp -> __get('downloads');
$total_size += $temp -> __get('size') -> __get('bytes');
}
}
}
self::sort_list($dirs);
self::sort_list($files);
$this -> contents = array_merge($dirs, $files);
$this -> total_size = new Size($total_size);
$this -> total_files = count($files);
$this -> raw_total_folders = $this -> total_folders = count($dirs);
if ($subtract_parent)
{
$this -> total_folders--;
}
$this -> path_nav = $this -> set_path_nav();
//Paginate the files
if (ENTRIES_PER_PAGE)
{
if ($page < 1)
{
throw new ExceptionDisplay('Invalid page number.');
}
global $config;
$num_per_page = $config -> __get('entries_per_page');
if (($page - 1) * $num_per_page >= $this -> total_items())
{
throw new ExceptionDisplay('Invalid page number.');
}
$this -> contents = array_slice($this -> contents, ($page - 1) * $num_per_page, $num_per_page);
}
}
/**
* @return string The HTML text of the directory list, using the template system
*/
public function __toString()
{
$head = new TemplateInfo(TABLE_HEADER, $this);
$main = new TemplateFiles(EACH_FILE, $this);
$foot = new TemplateInfo(TABLE_FOOTER, $this);
return $head -> __toString() . $main -> __toString() . $foot -> __toString();
}
}
?>