login/pass: error messages below page title
[minimedit.git] / thumb / index.php
index a6b5bd7d66cce6d27560b120955a3fae695aaaa1..9232b3332be5de1c33370705b4ea41e273b427d3 100644 (file)
@@ -1,18 +1,28 @@
 <?php
-if (!$User) return;
-list ($size, $imgpath) = explode('/', ltrim($Page->path, '/'), 2);
+if ($Page->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);
@@ -28,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);
@@ -46,7 +57,6 @@ function mkthumb($source, $size)
        if (empty($width)) {
                $width = $height * 4;
        }
-       $target = "thumb/$size/$source";
 
        if (isset($_GET['backend'])) {
                $backend = $_GET['backend'];
@@ -95,7 +105,7 @@ function mkthumb_exec($source, $target, $width, $height)
                '-interlace', 'plane', # progressive
                '-strip', '-taint', # omit metadata
                '-sampling-factor', '4:2:0', '-colorspace', 'sRGB', # half chroma
-               '-resize', "${width}x${height}",
+               '-resize', "${width}x${height}>",
                '-quality', '85%',
                $source, "jpg:$target"
        ]));