Files

313 lines
14 KiB
PHP
Raw Permalink Normal View History

2019-09-17 10:16:07 +03:00
<?php
/**
* @package AutoIndex
*
2023-11-09 19:44:24 +02:00
* @copyright Copyright (C) 2002-2004 Justin Hagstrom, 2019-2023 Florin C Bodin aka orynider at github.com
2019-09-17 10:16:07 +03:00
* @license http://www.gnu.org/licenses/gpl.html GNU General Public License (GPL)
2023-11-25 23:46:57 +02:00
* @version $Id: FileItem.php, v 2.2.6 2023/11/15 08:08:08 orynider Exp $
2019-09-17 10:16:07 +03:00
* @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)
{
2023-11-09 19:44:24 +02:00
die('bad class init...');
2019-09-17 10:16:07 +03:00
}
/**
* Subclass of item that specifically represents a file.
*
* @author Justin Hagstrom <JustinHagstrom@yahoo.com>
* @version 1.0.1 (July 10, 2004)
* @package AutoIndex
*/
class FileItem extends Item
{
/**
* @param string $fn The filename
* @return string Everything after the list dot in the filename, not including the dot
*/
2023-11-09 19:44:24 +02:00
public static function ext($fn, $ext = true)
2019-09-17 10:16:07 +03:00
{
$fn = Item::get_basename($fn);
2023-11-09 19:44:24 +02:00
switch($ext)
{
case false:
2023-11-12 10:27:54 +02:00
return (strpos($fn, '.') ? substr($fn, 0, strrpos($fn, '.')) : $fn);
2023-11-09 19:44:24 +02:00
break;
default:
return (strpos($fn, '.') ? strtolower(substr(strrchr($fn, '.'), 1)) : '');
break;
}
2019-09-17 10:16:07 +03:00
}
/**
2023-11-09 19:44:24 +02:00
* @return string Returns the name of the filename
2019-09-17 10:16:07 +03:00
* @see FileItem::ext()
*/
2023-11-09 19:44:24 +02:00
public function file_name()
2019-09-17 10:16:07 +03:00
{
2023-11-09 19:44:24 +02:00
return self::ext($this->filename, false);
2019-09-17 10:16:07 +03:00
}
2023-11-09 19:44:24 +02:00
/**
* @return string Returns the extension of the filename
* @see FileItem::ext()
*/
public function file_ext()
{
return self::ext($this->filename);
}
2019-09-17 10:16:07 +03:00
/**
* @param string $parent_dir
* @param string $filename
*/
public function __construct($parent_dir, $filename)
{
parent::__construct($parent_dir, $filename);
2023-11-25 23:46:57 +02:00
if (!is_file($this->parent_dir . $filename))
2020-12-23 03:18:48 +02:00
{
2023-10-31 18:32:54 +02:00
throw new ExceptionDisplay('File <em>' . Url::html_output($this->parent_dir . $filename) . '</em> does not exist.');
2019-09-17 10:16:07 +03:00
}
2023-11-25 23:46:57 +02:00
global $config, $words, $downloads, $request;
2023-10-31 18:32:54 +02:00
$this->filename = $filename;
$this->size = new Size(filesize($this->parent_dir . $filename));
2019-09-17 10:16:07 +03:00
if (ICON_PATH)
{
$file_icon = new Icon($filename);
2023-11-25 23:46:57 +02:00
$this->icon = $file_icon->__toString();
2019-09-17 10:16:07 +03:00
}
2023-11-25 23:46:57 +02:00
$this->downloads = (DOWNLOAD_COUNT && $downloads->is_set($parent_dir . $filename) ? (int)($downloads->__get($parent_dir . $filename)) : 0);
$this->link = Url::html_output($request->server('PHP_SELF')) . '?dir=' . Url::translate_uri(substr($this->parent_dir, strlen($config->__get('base_dir')))) . '&amp;file=' . Url::translate_uri($filename);
2020-06-19 20:56:35 +03:00
if (THUMBNAIL_HEIGHT && in_array(self::ext($filename), array('png', 'jpg', 'jpeg', 'jfif', 'gif', 'bmp')))
2019-09-17 10:16:07 +03:00
{
2023-11-25 23:46:57 +02:00
$this->thumb_link = ' <img src="' . Url::html_output($request->server('PHP_SELF'))
2023-10-31 18:32:54 +02:00
. '?thumbnail='. Url::translate_uri($this->parent_dir . $filename) . '"'
2023-11-25 23:46:57 +02:00
. ' alt="' . $words->__get('thumbnail of') . ' ' . $filename . '"'
2020-06-19 20:56:35 +03:00
. ' />';
2023-11-25 23:46:57 +02:00
$this->thumb_link .= ' <a href="' . Url::html_output($request->server('PHP_SELF'))
. '?thm='. Url::translate_uri($this->parent_dir . $filename) . '"'
. ' alt="' . $words->__get('thumbnail of') . ' ' . $filename . '"'
. ' >' . $words->__get('view') . ' ' . $words->__get('file') . '</a>';
2019-09-17 10:16:07 +03:00
}
if (THUMBNAIL_HEIGHT && in_array(self::ext($filename), array('svg', 'SVG')))
{
$svgcontent = false;
$svgcontent = file_get_contents(Url::translate_uri($this->parent_dir . $filename));
$width = $height = '32';
//<svg xmlns="http://www.w3.org/2000/svg" width="16" height="16" viewBox="0 0 16 16" fill="context-fill">
$contentsvg = explode('<svg', $svgcontent);
//xmlns="http://www.w3.org/2000/svg" width="32" height="32" viewBox="0 0 32 32">
$content = explode('=', $contentsvg[1]);
//[0] => xmlns [1] => "http://www.w3.org/2000/svg" width [2] => "32" height [3] => "32" viewBox [4] => "0 0 32 32">
if(preg_match('/<svg\s[^>]*width=\"(.*)\"\/>/isU', '<svg '.$contentsvg[1], $width))
{
$width = explode('" ', $content[2]);
$width = !empty($width[0]) ? str_replace('"', '', $width[0]) : '32';
}
$svgcontent = ($width > '400') ? str_replace($width, $width/1.1, $svgcontent) : $svgcontent;
$svgcontent = ($width < '24') ? str_replace($width, $width*1.5*2, $svgcontent) : $svgcontent;
$svgcontent = ('edit.svg' === basename($filename)) ? str_replace($width, '200', $svgcontent) : $svgcontent;
if(preg_match_all('/<svg\s[^>]*height=\"(.*)\"\/>/isU', '<svg '.$contentsvg[1], $height))
{
$height = explode('" ', $content[3]);
$height = !empty($height[0]) ? str_replace('"', '', $height[0]) : '32';
}
$svgcontent = ($width > '400') ? str_replace($height, $height/1.1, $svgcontent) : $svgcontent;
$svgcontent = ($width < '24') ? str_replace($height, $height*1.5*2, $svgcontent) : $svgcontent;
$svgcontent = ('<edit.svg>' === basename($filename)) ? str_replace($height, '200', $svgcontent) : $svgcontent;
if(preg_match_all('/<svg\s[^>]*viewBox=\"(.*)\"\/>/isU', '<svg '.$contentsvg[1], $viewBox))
{
$viewBox = explode('" ', $content[4]);
$viewBox = str_replace('"', '', $viewBox[0]);
}
$this->thumb_link = '<a title="'.trim(basename($filename)).'" href="'.Url::html_output($this->parent_dir . $filename).'">'.$svgcontent.'</a>';
}
if (THUMBNAIL_HEIGHT && in_array(self::ext($filename), array('thm', 'thm')))
2021-01-05 22:00:42 +02:00
{
2023-11-25 23:46:57 +02:00
$this->thumb_link = ' <img src="' . Url::html_output($request->server('PHP_SELF'))
2023-10-31 18:32:54 +02:00
. '?thm='. Url::translate_uri($this->parent_dir . $filename) . '"'
2023-11-25 23:46:57 +02:00
. ' alt="' . $words->__get('thumbnail of') . ' ' . $filename . '"'
2021-01-05 22:00:42 +02:00
. ' />';
2023-11-25 23:46:57 +02:00
$this->thumb_link .= ' <a href="' . Url::html_output($request->server('PHP_SELF'))
. '?thm='. Url::translate_uri($this->parent_dir . $filename) . '"'
. ' alt="' . $words->__get('thumbnail of') . ' ' . $filename . '"'
. ' >' . $words->__get('view') . ' ' . $words->__get('file') . '</a>';
2021-01-05 22:00:42 +02:00
}
2023-10-31 18:32:54 +02:00
if (THUMBNAIL_HEIGHT && in_array(self::ext($filename), array('avi', 'divx', 'xvid', 'mkv', 'asf', 'mov', 'wmv', '3gp', 'mp3', 'mp4', 'mpv', 'ogg', 'ogv','mpg', 'mpeg', 'flv', 'FLV', 'flvjs')))
2020-12-23 03:18:48 +02:00
{
$mime = new MimeType($filename);
$finfo = finfo_open(FILEINFO_MIME_TYPE);
//Display correct headers for media file
2023-11-25 23:46:57 +02:00
$mimetype = finfo_file($finfo, $this->parent_dir . $filename);
$file_size = function_exists('getvideosize') ? getvideosize($this->parent_dir . $filename) : array();
$file_mime = function_exists('getvideosize') ? $file_size['mime'] : $mime->__toString();
$this->thumb_link = '';
2023-10-31 18:32:54 +02:00
if (function_exists('imagecreatefromavi') && in_array(self::ext($filename), array('avi', 'divx', 'xvid')))
2020-12-23 03:18:48 +02:00
{
2023-10-31 18:32:54 +02:00
$this->thumb_link .= ' <video controls="play" src="' . Url::translate_uri($this->parent_dir . $filename) . '"'
2023-11-25 23:46:57 +02:00
. ' poster="' . Url::html_output($request->server('PHP_SELF')) . '"'
. ' type="' . $file_mime . ', ' . $mimetype . ', video/' . self::ext($filename) .'"'
. ' />Your browser does not support the <code>video</code> element.'
2023-11-25 23:46:57 +02:00
. '<source src="' . Url::html_output($request->server('PHP_SELF')) . '" type="video/' . self::ext($filename) . '" />'
. '</video> ';
2023-11-25 23:46:57 +02:00
$this->thumb_link .= '</br><img src="' . Url::html_output($request->server('PHP_SELF'))
2023-10-31 18:32:54 +02:00
. '?thumbnail='. Url::translate_uri($this->parent_dir . $filename) . '"'
. ' alt="' . $words->__get('thumbnail of') . ' ' . $filename . '"'
. ' />';
}
2023-10-31 18:32:54 +02:00
elseif (in_array(self::ext($filename), array('avi', 'divx', 'xvid', 'mkv', 'asf', 'mov', 'wmv', '3gp', 'mp4', 'mpv', 'ogv', 'mpg', 'mpeg')))
{
2023-11-25 23:46:57 +02:00
$video_href = Url::html_output($request->server('PHP_SELF')) . '?thm='. Url::translate_uri($this->parent_dir . $filename);
$thumbnail = Url::html_output($request->server('PHP_SELF')) . '?thumbnail='. Url::translate_uri($this->parent_dir . $filename);
2023-10-31 18:32:54 +02:00
$this->thumb_link .= ' <video id="'.$filename.'" controls />'
. '<source src="' . $video_href . '" type="video/'. self::ext($filename) .'" />'
. '<p>Your user agent does not support the HTML5 Video element.</p></video>';
2023-10-31 18:32:54 +02:00
// if (in_array(self::ext($filename), array('avi', 'divx', 'mp4', 'mpg'))) {
$this->thumb_link .='<button type="button" onclick="vid_play_pause()">Play/Pause</button>
<script>
function vid_play_pause()
{
2023-10-31 18:32:54 +02:00
var myVideo = document.getElementById('.$filename.');
if (myVideo.paused)
{
myVideo.play();
}
else
{
myVideo.pause();
}
}
</script>';
2023-10-31 18:32:54 +02:00
//}
2023-11-25 23:46:57 +02:00
$this->thumb_link .= '</br><img src="' . Url::html_output($request->server('PHP_SELF'))
2023-10-31 18:32:54 +02:00
. '?thumbnail='. Url::translate_uri($this->parent_dir . $filename) . '"'
2023-11-25 23:46:57 +02:00
. ' alt="' . $words->__get('thumbnail of') . ' ' . $filename . '"'
2020-12-23 03:18:48 +02:00
. ' />';
2023-11-25 23:46:57 +02:00
$this->thumb_link .= ' <a href="' . Url::html_output($request->server('PHP_SELF'))
2023-10-31 18:32:54 +02:00
. '?thm='. Url::translate_uri($this->parent_dir . $filename) . '"'
. ' alt="' . $words->__get('thumbnail of') . ' ' . $filename . '"'
. ' >' . $words->__get('view') . ' ' . $words->__get('file') . '</a>';
}
elseif (in_array(self::ext($filename), array('flv', 'FLV', 'flvjs')))
{
2023-11-25 23:46:57 +02:00
$video_href = Url::html_output($request->server('PHP_SELF')) . '?thm='. Url::translate_uri($this->parent_dir . $filename);
$thumbnail = Url::html_output($request->server('PHP_SELF')) . '?thumbnail='. Url::translate_uri($this->parent_dir . $filename);
2023-10-31 18:32:54 +02:00
$this->thumb_link .= '<script src="'.$config->__get('assets_path').'/javascript/flv.min.js"></script>';
$this->thumb_link .='<VIDEO controls="play" type="video/flv" id="videoElement" src="'.$video_href.'" loop="false" allowfullscreen="true" quality="high" width="425" height="360" scale="noscale" salign="lt" name="flvPlayer" align="center" bgcolor="#E3F0FB">
<script>
if (flvjs.isSupported())
{
var videoElement = document.getElementById(videoElement);
var flvPlayer = flvjs.createPlayer({
type: flv,
url: '.$video_href.'
});
flvPlayer.attachMediaElement(videoElement);
flvPlayer.load();
flvPlayer.play();
}
</script>
<source src="' . $video_href . '" type="video/'. self::ext($filename) .'" />
</VIDEO>';
2023-11-25 23:46:57 +02:00
$this->thumb_link .= ' <a href="' . Url::html_output($request->server('PHP_SELF'))
2023-10-31 18:32:54 +02:00
. '?thm='. Url::translate_uri($this->parent_dir . $filename) . '"'
2023-11-25 23:46:57 +02:00
. ' alt="' . $words->__get('thumbnail of') . ' ' . $filename . '"'
. ' >' . $words->__get('view') . ' ' . $words->__get('file') . '</a>';
}
elseif (in_array(self::ext($filename), array('MP3', 'mp3', 'ogg')))
{
//<!-- audio tag starts here -->
2023-11-25 23:46:57 +02:00
$this->thumb_link .= ' <audio controls="play" src="' . Url::html_output($request->server('PHP_SELF'))
2023-10-31 18:32:54 +02:00
. '?thm='. Url::translate_uri($this->parent_dir . $filename) . '"'
2023-11-25 23:46:57 +02:00
. ' poster="' . Url::html_output($request->server('PHP_SELF')) . '"'
. ' type="' . $file_mime . ', ' . $mimetype . ', audio/' . self::ext($filename) .'"'
. ' />Your browser does not support the <code>audio</code> element.'
2023-11-25 23:46:57 +02:00
. '<source src="' . Url::html_output($request->server('PHP_SELF')) . '" type="audio/' . self::ext($filename) . '" />'
. '</audio> ';
//<!-- audio tag ends here -->
2020-12-23 03:18:48 +02:00
}
else
{
2023-11-25 23:46:57 +02:00
$this->thumb_link .= ' <video controls="play" src="' . Url::html_output($request->server('PHP_SELF'))
2023-10-31 18:32:54 +02:00
. '?thm='. Url::translate_uri($this->parent_dir . $filename) . '"'
2023-11-25 23:46:57 +02:00
. ' poster="' . Url::html_output($request->server('PHP_SELF')) . '"'
2020-12-23 03:18:48 +02:00
. ' type="' . $file_mime . ', ' . $mimetype . ', application/octet-stream"'
. ' />Your browser does not support the <code>video</code> element.</video> ';
2023-11-25 23:46:57 +02:00
$this->thumb_link .= ' <a href="' . Url::html_output($request->server('PHP_SELF'))
2023-10-31 18:32:54 +02:00
. '?thm='. Url::translate_uri($this->parent_dir . $filename) . '"'
2023-11-25 23:46:57 +02:00
. ' alt="' . $words->__get('thumbnail of') . ' ' . $filename . '"'
2023-10-31 18:32:54 +02:00
. ' >' . $words->__get('view') . ' ' . $words->__get('file') . '</a>';
2020-12-23 03:18:48 +02:00
}
}
/*
2020-06-19 20:56:35 +03:00
if (THUMBNAIL_HEIGHT && in_array(self::ext($filename), array('svg', 'xml')))
{
2023-10-31 18:32:54 +02:00
$icon_svg = ICON_PATH ? Url::translate_uri($config->__get('icon_path') . 'svg.png') : Url::translate_uri($this->parent_dir . $filename);
2020-06-19 20:56:35 +03:00
$heightwidth = in_array(self::ext($filename), array('svg', 'xml')) ? ' height="' . '150' . '" width="' . '150' . '" ' : ' ';
2023-11-25 23:46:57 +02:00
$this->thumb_link .= ' <img src="' . Url::html_output($request->server('PHP_SELF'))
. '?thumbnail='. Url::translate_uri($icon_svg) . '"'
2023-10-31 18:32:54 +02:00
. ' alt="' . $words->__get('thumbnail of') . ' ' . $filename . '"'
. ' />';
2020-06-19 20:56:35 +03:00
}
*/
2023-11-25 23:46:57 +02:00
$size = $this->size->__get('bytes');
if (MD5_SHOW && $size > 0 && $size / 1048576 <= $config->__get('md5_show'))
{
2023-11-25 23:46:57 +02:00
$this->md5_link = '<span class="autoindex_small">[<a class="autoindex_a" href="'
. Url::html_output($request->server('PHP_SELF')) . '?dir='
. Url::translate_uri(substr($this->parent_dir, strlen($config->__get('base_dir'))))
2019-09-17 10:16:07 +03:00
. '&amp;md5=' . Url::translate_uri($filename) . '">'
2023-11-25 23:46:57 +02:00
. $words->__get('calculate md5sum') . '</a>]</span>';
2019-09-17 10:16:07 +03:00
}
}
/**
* @param string $var The key to look for
* @return mixed The data stored at the key
*/
2020-12-23 03:18:48 +02:00
public function __get($var = '')
2019-09-17 10:16:07 +03:00
{
2023-11-12 10:27:54 +02:00
if (isset($this->$var))
2019-09-17 10:16:07 +03:00
{
2023-11-12 10:27:54 +02:00
return $this->$var;
2019-09-17 10:16:07 +03:00
}
2020-12-23 03:18:48 +02:00
throw new ExceptionDisplay('Variable <em>' . Url::html_output($var) . '</em> not set in FileItem class.');
2019-09-17 10:16:07 +03:00
}
}
?>