X-Git-Url: http://git.roojs.org/?a=blobdiff_plain;f=DataObjects%2FImages.php;h=5e3999cf525dee0b73ab2334408eb6d6559a615c;hb=d3ee3d94ce786b01a60019a73fd502c278e9881d;hp=4a0ba4b24abd6c445dab2b01771b448ef980c258;hpb=ce0d62ed3657a466fc0addf946317f123042dc33;p=Pman.Core diff --git a/DataObjects/Images.php b/DataObjects/Images.php index 4a0ba4b2..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'); @@ -790,40 +792,51 @@ class Pman_Core_DataObjects_Images extends DB_DataObject return $base64; } - function getNumberOfPages() + function getNumberOfPages($file) { - $ret = false; - 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' : - $file = $this->getStoreName(); + $pdfinfo = System::which('pdfinfo'); - if(!file_exists($file)){ + if (empty($pdfinfo)) { return false; } - $pdftk = System::which('pdftk'); + $cmd = "{$pdfinfo} {$file}"; - if (empty($pdftk)) { - return false; - } - - $cmd = "{$pdftk} {$file} dump_data"; - - $test = `$cmd`; + $info = `$cmd`; - print_R($test);exit; + $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 $ret; + return; } }