X-Git-Url: https://git.nubati.net/cgi-bin/gitweb.cgi?p=phpfspot.git;a=blobdiff_plain;f=phpfspot_img.php;h=194b534ba63e61d9258ea0a1ce621d35673581f4;hp=0afdd7b2d8dc5f728492d0dffd32b8ff405bd143;hb=350ffa92282e6b5adf3dc2b854fbb2255c845b8e;hpb=97515e0f70a469982927f9e617fff8e60c9593d3;ds=sidebyside diff --git a/phpfspot_img.php b/phpfspot_img.php index 0afdd7b..194b534 100644 --- a/phpfspot_img.php +++ b/phpfspot_img.php @@ -1,6 +1,26 @@ parent = new PHPFSPOT; @@ -15,33 +38,71 @@ class PHPFSPOT_IMG { } // __construct() + /** + * PHPFSPOT_IMG class destructor + */ public function __destruct() { } // __desctruct() - public function show($idx, $width = "") + /** + * sends the specified image to the browser + * + * this function will send the specified image to + * the client - in the specified width. it also try's + * to create on-the-fly missing thumbnails via PHPFSPOT + * gen_thumbs function. + */ + public function show($idx, $width = 0) { - $this->parent->gen_thumbs($idx); - $details = $this->parent->get_photo_details($idx); + + if(!$details) { + $this->parent->showTextImage("The image you requested is unknown"); + return; + } - if($width == "") + /* no width specified - show photo in its original size */ + if($width == 0) { $fullpath = $this->parent->translate_path($details['directory_path']) ."/". $details['name']; - else - $fullpath = $this->parent->translate_path($details['directory_path']) ."/thumbs/". $width ."_". $details['name']; - + } + /* show thumbnail */ + else { + /* if no entry for this photo is yet in the database, create thumb */ + if(!$this->parent->getMD5($idx)) { + $this->parent->gen_thumb($idx); + } + $fullpath = $this->parent->cfg->base_path ."/thumbs/". $width ."_". $this->parent->getMD5($idx); + /* if the thumb file does not exist, create it */ + if(!file_exists($fullpath)) { + $this->parent->gen_thumb($idx); + } + } + + if(!file_exists($fullpath)) { + $this->parent->showTextImage("File ". basename($fullpath) ." does not exist"); + return; + } + if(!is_readable($fullpath)) { + $this->parent->showTextImage("File ". basename($fullpath) ." is not readable. Check the permissions"); + return; + } $tmp = getimagesize($fullpath); $mime = $tmp['mime']; + if(!$this->parent->checkifImageSupported($mime)) { + $this->parent->showTextImage("Unsupported Image Type"); + return; + } + Header("Content-Type: ". $mime); Header("Content-Length: ". filesize($fullpath)); - Header("Content-Transfer-Encoding: binary\n"); - $user_agent = strtolower ($_SERVER["HTTP_USER_AGENT"]); + Header("Content-Transfer-Encoding: binary\n"); Header("Content-Disposition: inline; filename=\"". $details['name'] ."\""); - Header("Accept-Ranges: bytes"); - Header("Connection: close"); + Header("Accept-Ranges: bytes"); + Header("Connection: close"); $file = fopen($fullpath, "rb"); fpassthru($file); @@ -53,13 +114,12 @@ class PHPFSPOT_IMG { if(isset($_GET['idx']) && is_numeric($_GET['idx'])) { + $img = new PHPFSPOT_IMG; + if(isset($_GET['width']) && is_numeric($_GET['width'])) - $width = $_GET['width']; + $img->show($_GET['idx'], $_GET['width']); else - $width = ""; - - $img = new PHPFSPOT_IMG; - $img->show($_GET['idx'], $width); + $img->show($_GET['idx']); } ?>