DataObjects/Images.php
[Pman.Core] / DataObjects / Images.php
index 88a957c..5e3999c 100644 (file)
@@ -2,7 +2,7 @@
 /**
  * Table Definition for Images
  */
-require_once 'DB/DataObject.php';
+class_exists('DB_DataObject') ? '' : require_once 'DB/DataObject.php';
 
 class Pman_Core_DataObjects_Images extends DB_DataObject 
 {
@@ -53,8 +53,6 @@ class Pman_Core_DataObjects_Images extends DB_DataObject
     
     function beforeInsert($q, $roo) 
     {
-        print_r('beforeInsert');exit;
-        
         if (isset($q['_remote_upload'])) {
             require_once 'System.php';
             
@@ -106,7 +104,6 @@ class Pman_Core_DataObjects_Images extends DB_DataObject
      */
     function createFrom($file, $filename=false)
     {
-        print_r('createFrom');exit;
         // copy the file into the storage area..
         if (!file_exists($file) || !filesize($file)) {
             $this->err = "File $file did not exist or is 0 size";
@@ -134,6 +131,8 @@ class Pman_Core_DataObjects_Images extends DB_DataObject
             }
         }
         
+        $this->getNumberOfPages($file);
+        
         $this->filesize = filesize($file);
         $this->created = date('Y-m-d H:i:s');
          
@@ -244,6 +243,8 @@ class Pman_Core_DataObjects_Images extends DB_DataObject
             return false;
         }
         if ($tbl->$fld) {
+            HTML_FlexyFramework::get()->page->jerr("updating images is disabled");
+            exit;
             $image = DB_DataObject::factory('Images');
             $image->get($tbl->$fld);
             $image->beforeDelete();
@@ -269,7 +270,6 @@ class Pman_Core_DataObjects_Images extends DB_DataObject
     /// ctrl not used??
     function onUpload($roo)
     {
-            print_r('onUpload');exit;
         //print_r($_FILES); echo $_FILES['imageUpload']['type'];exit;
         if (empty($_FILES['imageUpload']['tmp_name']) || 
             empty($_FILES['imageUpload']['name']) || 
@@ -290,6 +290,8 @@ class Pman_Core_DataObjects_Images extends DB_DataObject
         }
         
         if ($this->id) {
+            HTML_FlexyFramework::get()->page->jerr("updating images is disabled");
+            exit;
             $this->beforeDelete();
         }
         if ( empty($this->ontable)) {
@@ -306,6 +308,8 @@ class Pman_Core_DataObjects_Images extends DB_DataObject
             
             $img->find();
             while ($img->fetch()) {
+                HTML_FlexyFramework::get()->page->jerr("updating images is disabled");
+                exit;
                 $img->beforeDelete();
                 $img->delete();
             }
@@ -573,7 +577,6 @@ class Pman_Core_DataObjects_Images extends DB_DataObject
     
     function setFromRoo($ar, $roo)
     {
-        print_r('setFromRoo');exit;
         // not sure why we do this.. 
         
         // if imgtype starts with '-' ? then we set the 'old' (probably to delete later)
@@ -634,7 +637,7 @@ class Pman_Core_DataObjects_Images extends DB_DataObject
             $roo->jerr("File upload failed : error = ". (!empty($this->err) ? $this->err : ''));
         }
         
-        $roo->addEvent("ADD", $this, $this->toEventString());
+        $this->addEvent($ar, $roo);
         
         $r = DB_DataObject::factory($this->tableName());
         $r->id = $this->id;
@@ -645,6 +648,11 @@ class Pman_Core_DataObjects_Images extends DB_DataObject
          
     }
     
+    function addEvent($ar, $roo)
+    {
+        $roo->addEvent("ADD", $this, $this->toEventString());
+    }
+    
     function toEventString()
     {
         
@@ -666,6 +674,8 @@ class Pman_Core_DataObjects_Images extends DB_DataObject
         }
         
         if ($this->id) {
+            HTML_FlexyFramework::get()->page->jerr("updating images is disabled");
+            exit;
             $this->beforeDelete();
         }
         
@@ -683,6 +693,8 @@ class Pman_Core_DataObjects_Images extends DB_DataObject
             
             $img->find();
             while ($img->fetch()) {
+                HTML_FlexyFramework::get()->page->jerr("updating images is disabled");
+                exit;
                 $img->beforeDelete();
                 $img->delete();
             }
@@ -761,4 +773,70 @@ class Pman_Core_DataObjects_Images extends DB_DataObject
         
     }
     
+    function toBase64()
+    {
+        if(!preg_match('/^image\//', $this->mimetype)){
+            return false;
+        }
+        
+        $file = $this->getStoreName();
+        
+        if(!file_exists($file)){
+            return false;
+        }
+        
+        $data = file_get_contents($file);
+        
+        $base64 = 'data:' . $this->mimetype . ';base64,' . base64_encode($data);
+        
+        return $base64;
+    }
+    
+    function getNumberOfPages($file)
+    {
+        require_once 'System.php';
+        
+        $this->no_of_pages = 0;
+          
+        if(!file_exists($file)){
+            return;
+        }
+        
+        /*
+         * We handle pdf only at present
+         */
+        switch ($this->mimetype) {
+            
+            case 'application/pdf' :
+                
+                $pdfinfo = System::which('pdfinfo');
+                
+                if (empty($pdfinfo)) {
+                    return false;
+                }
+                
+                $cmd = "{$pdfinfo} {$file}";
+                
+                $info = `$cmd`;
+                
+                $infos = explode("\n", $info);
+
+                foreach ($infos as $i){
+                    
+                    if(!preg_match('/^Pages:[\s]?([0-9]+)/', $i, $matches)){
+                        continue;
+                    }
+                    print_R($matches);exit;
+                    $ret = (empty($matches[1])) ? false : $matches[1];
+                    break;
+                }
+                
+                break;
+            default :
+                break;
+        }
+        
+        return;
+    }
+    
  }