DataObjects/Images.php
[Pman.Core] / DataObjects / Images.php
index 70fb7e7..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 
 {
@@ -131,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');
          
@@ -241,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();
@@ -286,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)) {
@@ -302,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();
             }
@@ -629,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;
@@ -640,6 +648,11 @@ class Pman_Core_DataObjects_Images extends DB_DataObject
          
     }
     
+    function addEvent($ar, $roo)
+    {
+        $roo->addEvent("ADD", $this, $this->toEventString());
+    }
+    
     function toEventString()
     {
         
@@ -661,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();
         }
         
@@ -678,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();
             }
@@ -756,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;
+    }
+    
  }