mirror of
https://github.com/avecms/AVE.cms.git
synced 2025-01-22 15:30:07 +00:00
351 lines
8.6 KiB
PHP
351 lines
8.6 KiB
PHP
<?php
|
||
|
||
/**
|
||
* AVE.cms
|
||
*
|
||
* @package AVE.cms
|
||
* @version 3.x
|
||
* @filesource
|
||
* @copyright © 2007-2014 AVE.cms, http://www.ave-cms.ru
|
||
*
|
||
* @license GPL v.2
|
||
*/
|
||
|
||
if(! defined('BASE_DIR'))
|
||
define('BASE_DIR', str_replace("\\", "/", dirname(dirname(__FILE__))));
|
||
|
||
|
||
if (! function_exists('iptc_make_tag'))
|
||
{
|
||
function iptc_make_tag($rec, $data, $value)
|
||
{
|
||
$length = strlen($value);
|
||
$retval = chr(0x1C) . chr($rec) . chr($data);
|
||
|
||
if($length < 0x8000)
|
||
{
|
||
$retval .= chr($length >> 8) . chr($length & 0xFF);
|
||
}
|
||
else
|
||
{
|
||
$retval .= chr(0x80) .
|
||
chr(0x04) .
|
||
chr(($length >> 24) & 0xFF) .
|
||
chr(($length >> 16) & 0xFF) .
|
||
chr(($length >> 8) & 0xFF) .
|
||
chr($length & 0xFF);
|
||
}
|
||
|
||
return $retval . $value;
|
||
}
|
||
}
|
||
|
||
/**
|
||
* Creates directory
|
||
*
|
||
* @param string $path Path to create
|
||
* @param integer $mode Optional permissions
|
||
* @return boolean Success
|
||
*/
|
||
function _mkdir($path, $mode = 0777)
|
||
{
|
||
$old = umask(0);
|
||
$res = @mkdir($path, $mode);
|
||
umask($old);
|
||
|
||
return $res;
|
||
}
|
||
|
||
/**
|
||
* Creates directories recursively
|
||
*
|
||
* @param string $path Path to create
|
||
* @param integer $mode Optional permissions
|
||
* @return boolean Success
|
||
*/
|
||
function rmkdir($path, $mode = 0777)
|
||
{
|
||
return is_dir($path) || (mkdir(dirname($path), $mode) && _mkdir($path, $mode));
|
||
}
|
||
|
||
//-- Подгружаем настройки системы
|
||
require (dirname(__FILE__) . '/config.php');
|
||
|
||
//-- Подгружаем функции логирования
|
||
require_once BASE_DIR . '/functions/func.logs.php';
|
||
|
||
//-- Разрешенные расширения файлов
|
||
$allowedExt = array('jpg', 'jpeg', 'png', 'gif', 'JPG', 'JPEG', 'PNG', 'GIF');
|
||
|
||
//-- Разрешенные размеры миниатюр
|
||
$allowedSize = (defined(THUMBNAIL_SIZES) && THUMBNAIL_SIZES != '')
|
||
? explode(',', trim(THUMBNAIL_SIZES))
|
||
: array();
|
||
|
||
//-- Разрешения для админпанели
|
||
$allowedAdmin = array(
|
||
't128x128',
|
||
'f128x128'
|
||
);
|
||
|
||
//-- Ссылка на файл
|
||
$imagefile = urldecode($_SERVER['REQUEST_URI']);
|
||
|
||
//-- Вызов чере $_GET параметры
|
||
//-- ToDo
|
||
if (! empty($_REQUEST['thumb']))
|
||
{
|
||
$imagefile = '/'.
|
||
rtrim(
|
||
dirname($_REQUEST['thumb'])
|
||
. '/' . THUMBNAIL_DIR . '/'
|
||
. (str_replace(
|
||
'.',
|
||
(empty($_REQUEST['mode'])
|
||
? '-t'
|
||
: '-' . $_REQUEST['mode']) . ((empty($_REQUEST['width']) && empty($_REQUEST['height']))
|
||
? '128'
|
||
: intval(@$_REQUEST['width'])) . 'x' . ((empty($_REQUEST['width']) && empty($_REQUEST['height']))
|
||
? '128'
|
||
: intval(@$_REQUEST['height'])) . '.',
|
||
basename($_REQUEST['thumb'])
|
||
)
|
||
),
|
||
'/');
|
||
}
|
||
|
||
//-- Если пришел прямой вызов файла, то сразу отрубаем его
|
||
if ($_SERVER['REQUEST_URI'] == '/inc/thumb.php')
|
||
die('No image');
|
||
|
||
//-- Базовая папка
|
||
$baseDir = str_replace('\\', '/', dirname(dirname(__FILE__)));
|
||
|
||
//-- Если файл существует, показываем его
|
||
if (file_exists($baseDir . $imagefile))
|
||
{
|
||
$img_data = @getimagesize($baseDir . $imagefile);
|
||
|
||
header('Content-Type:' . $img_data['mime'], true);
|
||
header("Last-Modified: " . gmdate("D, d M Y H:i:s" . filemtime($baseDir . $imagefile)) . " GMT");
|
||
header("Content-Length: " . (string) filesize($baseDir . $imagefile), true);
|
||
readfile($baseDir . $imagefile);
|
||
|
||
exit;
|
||
}
|
||
|
||
list(, $thumbPath) = explode('/' . UPLOAD_DIR . '/', dirname($imagefile), 2);
|
||
|
||
$lenThumbDir = strlen(THUMBNAIL_DIR);
|
||
|
||
// --
|
||
if ($lenThumbDir && substr($thumbPath, -$lenThumbDir) != THUMBNAIL_DIR)
|
||
{
|
||
if (! file_exists($baseDir . $imagefile))
|
||
{
|
||
report404();
|
||
|
||
header($_SERVER['SERVER_PROTOCOL'] . ' 404 Not Found');
|
||
}
|
||
exit(0);
|
||
}
|
||
|
||
$thumbPath = $baseDir . '/' . UPLOAD_DIR . '/' . $thumbPath;
|
||
$imagePath = $lenThumbDir ? dirname($thumbPath) : $thumbPath;
|
||
|
||
$thumbName = basename($imagefile);
|
||
$nameParts = explode('.', $thumbName);
|
||
$countParts = count($nameParts);
|
||
|
||
if ($countParts < 2 || ! in_array(strtolower(end($nameParts)), $allowedExt))
|
||
exit(0);
|
||
|
||
$matches = array();
|
||
|
||
//-- Смотрим переданные параметры
|
||
preg_match('/-(r|c|f|t|s)(\d+)x(\d+)(r)*$/i', $nameParts[$countParts-2], $matches);
|
||
|
||
//-- Если нет параметров, отдаем 404
|
||
if (! isset($matches[0]))
|
||
{
|
||
report404();
|
||
|
||
header($_SERVER['SERVER_PROTOCOL'] . ' 404 Not Found');
|
||
exit(0);
|
||
}
|
||
|
||
$check = ltrim($matches[0], '-');
|
||
|
||
//-- Проверяем разрешен ли данный размер для миниатюры
|
||
if (! empty($allowedSize) && ! in_array($check, $allowedSize))
|
||
{
|
||
if (! in_array($check, $allowedAdmin))
|
||
{
|
||
report404();
|
||
|
||
header($_SERVER['SERVER_PROTOCOL'] . ' 404 Not Found');
|
||
exit(0);
|
||
}
|
||
}
|
||
|
||
//-- Если есть параметр rotate
|
||
if (isset($matches[4]))
|
||
{
|
||
list ($size, $method, $width, $height, $rotate) = $matches;
|
||
}
|
||
//-- Иначе
|
||
else
|
||
{
|
||
list ($size, $method, $width, $height) = $matches;
|
||
$rotate = false;
|
||
}
|
||
|
||
$nameParts[$countParts-2] = substr($nameParts[$countParts-2], 0, -strlen($size));
|
||
$imageName = implode('.', $nameParts);
|
||
|
||
$save = true;
|
||
|
||
if (! file_exists("$imagePath/$imageName"))
|
||
{
|
||
$l = "$imagePath/$imageName";
|
||
|
||
if (file_exists($l . '.tmp'))
|
||
{
|
||
include_once (BASE_DIR . '/functions/func.common.php');
|
||
|
||
$abs_path = dirname((!strstr($_SERVER['PHP_SELF'], $_SERVER['SCRIPT_NAME']) && (@php_sapi_name() == 'cgi'))
|
||
? $_SERVER['PHP_SELF']
|
||
: $_SERVER['SCRIPT_NAME']);
|
||
|
||
define('ABS_PATH', rtrim(str_replace("\\", "/", $abs_path), '/') . '/');
|
||
|
||
$url = trim(file_get_contents($l . '.tmp'), ABS_PATH);
|
||
|
||
$img = CURL_file_get_contents($url);
|
||
|
||
if ($img)
|
||
{
|
||
file_put_contents("$imagePath/$imageName", $img);
|
||
|
||
setEXIFF("$imagePath/$imageName");
|
||
|
||
$save = true;
|
||
}
|
||
|
||
@unlink($l . '.tmp');
|
||
}
|
||
}
|
||
|
||
if (! file_exists("$imagePath/$imageName"))
|
||
{
|
||
header($_SERVER['SERVER_PROTOCOL'] . ' 404 Not Found');
|
||
|
||
report404();
|
||
|
||
$imageName = 'noimage.png';
|
||
|
||
if (! file_exists("$imagePath/$imageName"))
|
||
$imagePath = $baseDir . '/' . UPLOAD_DIR . '/images';
|
||
|
||
if (! file_exists("$imagePath/$imageName"))
|
||
exit(0);
|
||
|
||
$save = false;
|
||
}
|
||
|
||
require $baseDir . '/class/class.thumbnail.php';
|
||
|
||
$thumb = new Image_Toolbox("$imagePath/$imageName");
|
||
|
||
//-- Методы генерации миниатюр
|
||
switch ($method)
|
||
{
|
||
case 'r':
|
||
$thumb->newOutputSize((int)$width, (int)$height, 0, (boolean)$rotate);
|
||
break;
|
||
|
||
case 'c':
|
||
$thumb->newOutputSize((int)$width, (int)$height, 1, (boolean)$rotate);
|
||
break;
|
||
|
||
case 'f':
|
||
$thumb->newOutputSize((int)$width, (int)$height, 2, false, '#ffffff');
|
||
break;
|
||
|
||
case 't':
|
||
$thumb->newOutputSize((int)$width, (int)$height, 3, false);
|
||
break;
|
||
|
||
case 's':
|
||
$thumb->newOutputSize((int)$width, (int)$height, 4, (boolean)$rotate);
|
||
break;
|
||
}
|
||
|
||
//Blend
|
||
//$thumb->addImage(BASE_DIR . '/' . 'uploads/gallery/watermark.gif');
|
||
//$thumb->blend('right -10', 'bottom -10', IMAGE_TOOLBOX_BLEND_COPY, 70);
|
||
|
||
//Text
|
||
//$thumb->addText('Мой текст', BASE_DIR . '/inc/fonts/ft16.ttf', 16, '#709536', 'right -10', 'bottom -10');
|
||
//if ($width > 200){
|
||
// $thumb->addImage(BASE_DIR . '/' . 'uploads/gallery/watermark.gif');
|
||
// $thumb->blend('right -10', 'bottom -10', IMAGE_TOOLBOX_BLEND_COPY, 70);
|
||
//}
|
||
|
||
$thumb->output();
|
||
|
||
//-- Если можно сохранять миниатюру
|
||
if ($save)
|
||
{
|
||
if (! file_exists($thumbPath) && ! mkdir($thumbPath, 0777, true))
|
||
exit(0);
|
||
|
||
if ($thumb->save("$thumbPath/$thumbName"))
|
||
{
|
||
$old = umask(0);
|
||
chmod("$thumbPath/$thumbName", 0777);
|
||
umask($old);
|
||
}
|
||
|
||
if ($thumb->_img['main']['type']==2)
|
||
{
|
||
$image = getimagesize("$thumbPath/$thumbName", $info);
|
||
|
||
if (! isset($info['APP13']))
|
||
{
|
||
//-- Если в настройках разрешена генерация IPTC тегов для миниатюр
|
||
if (THUMBNAIL_IPTC)
|
||
{
|
||
if (! isset($AVE_DB))
|
||
{
|
||
@require(BASE_DIR . '/class/class.database.php');
|
||
$sitename= @$AVE_DB->Query("SELECT site_name FROM " . PREFIX . "_settings LIMIT 1")->GetCell();
|
||
}
|
||
|
||
// установка IPTC тэгов
|
||
$iptc = array(
|
||
'2#120' => iconv("UTF-8", "WINDOWS-1251", $sitename),
|
||
'2#116' => "http://" . $_SERVER['SERVER_NAME']
|
||
);
|
||
|
||
// Преобразование IPTC тэгов в двоичный код
|
||
$data = '';
|
||
|
||
foreach($iptc as $tag => $string)
|
||
{
|
||
$tag = substr($tag, 2);
|
||
$data .= iptc_make_tag(2, $tag, $string);
|
||
}
|
||
|
||
// Встраивание IPTC данных
|
||
$content = iptcembed($data, "$thumbPath/$thumbName");
|
||
|
||
// запись нового изображения в файл
|
||
$fp = fopen("$thumbPath/$thumbName", "wb");
|
||
fwrite($fp, $content);
|
||
fclose($fp);
|
||
}
|
||
}
|
||
}
|
||
}
|
||
?>
|