X-Git-Url: https://git.nubati.net/cgi-bin/gitweb.cgi?p=phpfspot.git;a=blobdiff_plain;f=phpfspot_img.php;h=8251b8e1c757bde355dc8e614d3eb8f702ede046;hp=052a45f4099c686bdc0cd561cf482ce6ee8ded90;hb=1b98418fc7f31d2d10364a60bc798ee85ef7add1;hpb=81e72e043165fe488f3db1a86e7d0d8eb3e6057f diff --git a/phpfspot_img.php b/phpfspot_img.php index 052a45f..8251b8e 100644 --- a/phpfspot_img.php +++ b/phpfspot_img.php @@ -1,5 +1,26 @@ parent = new PHPFSPOT; @@ -14,37 +38,57 @@ class PHPFSPOT_IMG { } // __construct() + /** + * PHPFSPOT_IMG class destructor + */ public function __destruct() { } // __desctruct() + /** + * 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) { + if($idx == 'rand') + $idx = $this->parent->get_random_photo(); + $details = $this->parent->get_photo_details($idx); if(!$details) { - $this->parent->showTextImage("The image you requested is unknown"); + $this->parent->showTextImage("The image (". $idx .") you requested is unknown"); return; } - /* show original photo */ + /* no width specified - show photo in its original size */ if($width == 0) { - $fullpath = $this->parent->translate_path($details['directory_path']) ."/". $details['name']; + $fullpath = $this->parent->translate_path($this->parent->parse_uri($details['uri'], 'fullpath')); } /* show thumbnail */ else { - $fullpath = $this->parent->cfg->base_path ."/thumbs/". $width ."_". $this->parent->getMD5($idx); - if(!file_exists($fullpath)) - $this->parent->gen_thumb($idx, 0, 1); + /* 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->get_thumb_path($width, $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 ". $fullpath ." does not exist"); + $this->parent->showTextImage("File ". basename($fullpath) ." does not exist"); return; } if(!is_readable($fullpath)) { - $this->parent->showTextImage("File ". $fullpath ." is not readable. Check the permissions"); + $this->parent->showTextImage("File ". basename($fullpath) ." is not readable. Check the permissions"); return; } @@ -58,11 +102,15 @@ class PHPFSPOT_IMG { Header("Content-Type: ". $mime); Header("Content-Length: ". filesize($fullpath)); - Header("Content-Transfer-Encoding: binary\n"); - Header("Content-Disposition: inline; filename=\"". $details['name'] ."\""); - Header("Accept-Ranges: bytes"); - Header("Connection: close"); - + Header("Content-Transfer-Encoding: binary\n"); + Header("Content-Disposition: inline; filename=\"". $this->parent->parse_uri($details['uri'], 'filename') ."\""); + Header("Content-Description: ". $this->parent->parse_uri($details['uri'], 'filename')); + Header("Accept-Ranges: bytes"); + Header("Connection: close"); + Header("Expires: Mon, 26 Jul 1997 05:00:00 GMT"); + Header("Cache-Control: no-cache"); + Header("Pragma: no-cache"); + $file = fopen($fullpath, "rb"); fpassthru($file); @fclose($file); @@ -71,15 +119,14 @@ class PHPFSPOT_IMG { } -if(isset($_GET['idx']) && is_numeric($_GET['idx'])) { +if(isset($_GET['idx']) && (is_numeric($_GET['idx']) || $_GET['idx'] == 'rand')) { + + $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']); } ?>