issue43, fixed on-the-fly thumbnail generation
[phpfspot.git] / phpfspot_img.php
index 052a45f4099c686bdc0cd561cf482ce6ee8ded90..de677e558c56fe3ae76cbfcadd9d266520f17f11 100644 (file)
@@ -28,23 +28,29 @@ class PHPFSPOT_IMG {
          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'];
       }
       /* 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(!file_exists($fullpath)) 
-            $this->parent->gen_thumb($idx, 0, 1);
+         /* 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,10 +64,10 @@ class PHPFSPOT_IMG {
 
       Header("Content-Type: ". $mime);
       Header("Content-Length: ". filesize($fullpath));
-      Header("Content-Transfer-Encoding: binary\n");              
+      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);
@@ -73,13 +79,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']);
 }
 
 ?>