X-Git-Url: http://git.shiar.net/minimedit.git/blobdiff_plain/31de5ab9716df36202127e9b1657ace23d499c4c..v3.2-15-gf08646f0f4:/thumb/index.php?ds=sidebyside diff --git a/thumb/index.php b/thumb/index.php index e8b3bcb..2849bb5 100644 --- a/thumb/index.php +++ b/thumb/index.php @@ -7,36 +7,50 @@ $imgpath = preg_replace('{^(?=[0-9]+/)}', 'data/', $imgpath, 1); if (!file_exists($imgpath)) { http_response_code(404); - exit; + $imgpath = '404.png'; + if (!file_exists($imgpath)) { + exit; + } } -$target = "thumb/$height/$imgpath"; -if (!file_exists($target)) { - try { - mkthumb($imgpath, $target, $width, $height); - } - catch (Exception $e) { - http_response_code($e->getCode() ?: 500); - $target = '500.png'; - if (file_exists($target)) { - header("X-Error: ".$e->getMessage()); - header('Content-type: '.mime_content_type($target)); - readfile($target); - exit; - } - trigger_error("thumbnail creation failed: ".$e->getMessage(), E_USER_WARNING); +try { + $target = mkthumb($imgpath, $width, $height); +} +catch (Exception $e) { + http_response_code($e->getCode() ?: 500); + $target = '500.png'; + if (file_exists($target)) { + header("X-Error: ".$e->getMessage()); + header('Content-type: '.mime_content_type($target)); + readfile($target); exit; } + trigger_error("thumbnail creation failed: ".$e->getMessage(), E_USER_WARNING); + exit; } header('Content-type: '.mime_content_type($target)); readfile($target); exit; -function mkthumb($source, $target, $width, $height) +function mkthumb($source, $width, $height) { + $target = "thumb/$height/$source"; + + if (isset($_GET['backend'])) { + $backend = $_GET['backend']; + } + elseif (file_exists($target)) { + return; + } + else { + $backend = 'exec'; + } + $backend = "mkthumb_$backend"; + @mkdir(dirname($target), 0777, TRUE); - return mkthumb_exec($source, $target, $width, $height); + $backend($source, $target, $width, $height); + return $target; } function mkthumb_exec($source, $target, $width, $height)