X-Git-Url: http://git.shiar.net/minimedit.git/blobdiff_plain/4486f69521f03fe56549394f13f7c529f57fa962..HEAD:/thumb/index.php diff --git a/thumb/index.php b/thumb/index.php index bd08d88..9232b33 100644 --- a/thumb/index.php +++ b/thumb/index.php @@ -1,22 +1,28 @@ api) return; $imgpath = ltrim($Page->path, '/'); if (!preg_match('{^[0-9x]+/}', $imgpath)) { return; } list ($size, $imgpath) = explode('/', $imgpath, 2); $imgpath = preg_replace('{^(?=[0-9]+/)}', 'data/', $imgpath, 1); +$ext = ''; # explicit file type request -if (!file_exists($imgpath)) { +if (preg_match('/(.*)(\.jpg)$/', $imgpath, $imgpart) and file_exists($imgpart[1])) { + # source file without requested thumb extension + list (, $imgpath, $ext) = $imgpart; +} +elseif (!file_exists($imgpath)) { http_response_code(404); $imgpath = '404.png'; if (!file_exists($imgpath)) { exit; } } +$target = "thumb/$size/$imgpath$ext"; try { - $target = mkthumb($imgpath, $size); + mkthumb($imgpath, $size, $target); } catch (Throwable $e) { http_response_code($e->getCode() ?: 500); @@ -32,11 +38,12 @@ catch (Throwable $e) { } header('Cache-Control: max-age=2628000'); -header('Content-type: '.mime_content_type($target)); +header('Content-Type: '.mime_content_type($target)); +header('Content-Length: '.filesize($target)); readfile($target); exit; -function mkthumb($source, $size) +function mkthumb($source, $size, $target) { if (strpos($size, 'x') !== FALSE) { list ($width, $height) = explode('x', $size); @@ -50,7 +57,6 @@ function mkthumb($source, $size) if (empty($width)) { $width = $height * 4; } - $target = "thumb/$size/$source"; if (isset($_GET['backend'])) { $backend = $_GET['backend'];