X-Git-Url: http://git.roojs.org/?a=blobdiff_plain;f=DataObjects%2FImages.php;h=ad85ff99c1cc6a831108f8592096f7a1f15a9ccd;hb=811d438bfed9c36044f370aa8cf8cdc3f148cf82;hp=c23f56f7ddc3ba800f22a32fbcc75b32361f3330;hpb=2ce8484aea363c14597504cbd4ba9c1779a64357;p=Pman.Core diff --git a/DataObjects/Images.php b/DataObjects/Images.php index c23f56f7..ad85ff99 100644 --- a/DataObjects/Images.php +++ b/DataObjects/Images.php @@ -132,7 +132,7 @@ class Pman_Core_DataObjects_Images extends DB_DataObject } if($this->mimetype == 'application/pdf'){ - $this->no_of_pages = $this->getNumberOfPage($file); + $this->no_of_pages = $this->getPdfPages($file); } $this->filesize = filesize($file); @@ -185,6 +185,9 @@ class Pman_Core_DataObjects_Images extends DB_DataObject { $opts = HTML_FlexyFramework::get()->Pman; $fn = preg_replace('/[^a-z0-9\.]+/i', '_', $this->filename); + $opts = HTML_FlexyFramework::get()->Coba; + + print_r($opts);exit; return implode( '/', array( $opts['storedir'], '_images_', date('Y/m', strtotime($this->created)), $this->id . '-'. $fn )); @@ -769,6 +772,10 @@ class Pman_Core_DataObjects_Images extends DB_DataObject $this->filesize = filesize($f); + if($this->mimetype == 'application/pdf'){ + $this->no_of_pages = $this->getPdfPages($f); + } + $this->update($o); return true; @@ -794,4 +801,34 @@ class Pman_Core_DataObjects_Images extends DB_DataObject return $base64; } + function getPdfPages($file) + { + require_once 'System.php'; + + $page = 0; + + $pdfinfo = System::which('pdfinfo'); + + if (!file_exists($file) || empty($pdfinfo)) { + return $page; + } + + $cmd = "{$pdfinfo} {$file}"; + + $ret = `$cmd`; + + $info = explode("\n", $ret); + + foreach ($info as $i){ + + if(!preg_match('/^Pages:[\s]*([0-9]+)/', $i, $matches)){ + continue; + } + + $page = (empty($matches[1])) ? 0 : $matches[1]; + } + + return $page; + } + }