X-Git-Url: http://git.roojs.org/?a=blobdiff_plain;f=DataObjects%2FImages.php;h=5e3999cf525dee0b73ab2334408eb6d6559a615c;hb=d3ee3d94ce786b01a60019a73fd502c278e9881d;hp=73e87aed996219f736403636e01a7cccd66795af;hpb=ba29dd6c1d38107f03eb85e8b10aeeeab901b8bb;p=Pman.Core diff --git a/DataObjects/Images.php b/DataObjects/Images.php index 73e87aed..5e3999cf 100644 --- a/DataObjects/Images.php +++ b/DataObjects/Images.php @@ -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'); @@ -242,6 +244,7 @@ class Pman_Core_DataObjects_Images extends DB_DataObject } if ($tbl->$fld) { HTML_FlexyFramework::get()->page->jerr("updating images is disabled"); + exit; $image = DB_DataObject::factory('Images'); $image->get($tbl->$fld); $image->beforeDelete(); @@ -287,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)) { @@ -303,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(); } @@ -630,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; @@ -641,6 +648,11 @@ class Pman_Core_DataObjects_Images extends DB_DataObject } + function addEvent($ar, $roo) + { + $roo->addEvent("ADD", $this, $this->toEventString()); + } + function toEventString() { @@ -662,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(); } @@ -679,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(); } @@ -757,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; + } + }