X-Git-Url: http://git.roojs.org/?a=blobdiff_plain;f=DataObjects%2FImages.php;h=d9d53008f0c31bbd2bf50e11ade1ee733b012099;hb=6376efd4af86923fec4987504b9a08c460d0a0d0;hp=cc51a13e980223992663b03184f4f19993c4c5ea;hpb=90d19c6f75132149e6b62504f7ed953b0fb4f6ea;p=Pman.Core diff --git a/DataObjects/Images.php b/DataObjects/Images.php index cc51a13e..d9d53008 100644 --- a/DataObjects/Images.php +++ b/DataObjects/Images.php @@ -29,6 +29,19 @@ class Pman_Core_DataObjects_Images extends DB_DataObject /* the code above is auto generated do not remove the tag below */ ###END_AUTOCODE + function applyFilters($q, $au, $roo) + { + $tn = $this->tableName(); + + if(!empty($q['search']['filename'])){ + echo "$tn.filename LIKE '%{$this->escape($q['search']['filename'])}%'"; die; + $this->whereAdd(" + $tn.filename LIKE '%{$this->escape($q['search']['filename'])}%' + "); + } + + + } function checkPerm($lvl, $au) { @@ -118,9 +131,10 @@ class Pman_Core_DataObjects_Images extends DB_DataObject $this->mimetype = $y->fromFilename($filename); } - $this->mimetype= strtolower($this->mimetype); + $this->mimetype = strtolower($this->mimetype); - if (array_shift(explode('/', $this->mimetype)) == 'image') { + $mta = explode('/', $this->mimetype); + if (array_shift($mta) == 'image') { $imgs = @getimagesize($file); @@ -131,6 +145,10 @@ class Pman_Core_DataObjects_Images extends DB_DataObject } } + if($this->mimetype == 'application/pdf'){ + $this->no_of_pages = $this->getPdfPages($file); + } + $this->filesize = filesize($file); $this->created = date('Y-m-d H:i:s'); @@ -192,21 +210,42 @@ class Pman_Core_DataObjects_Images extends DB_DataObject * * */ - function beforeDelete() + function beforeDelete($dependants_array, $roo) { + + $opts = HTML_FlexyFramework::get()->Pman; + $deldir = $opts['storedir']. '/_deleted_images_'; + if (!file_exists( $deldir )) { + mkdir($deldir, 0755); + } + $fn = $this->getStoreName(); + $b = basename($fn); if (file_exists($fn)) { - unlink($fn); + + if (file_exists($deldir . '/'. $b)) { + unlink($fn); + } else { + rename($fn, $deldir .'/'. $b); + } + + } // delete thumbs.. - $b = basename($fn); + $d = dirname($fn); if (file_exists($d)) { $dh = opendir($d); while (false !== ($fn = readdir($dh))) { if (substr($fn, 0, strlen($b)) == $b) { - unlink($d. '/'. $fn); + + if (file_exists($deldir . '/'. $fn)) { + unlink($d. '/'. $fn); + continue; + } + rename($d. '/'. $fn, $deldir .'/'. $fn); + } } } @@ -765,6 +804,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; @@ -790,50 +833,34 @@ class Pman_Core_DataObjects_Images extends DB_DataObject return $base64; } - function getNumberOfPages() + function getPdfPages($file) { - $ret = false; - require_once 'System.php'; - $file = $this->getStoreName(); - - if(!file_exists($file)){ - return false; + $page = 0; + + $pdfinfo = System::which('pdfinfo'); + + if (!file_exists($file) || empty($pdfinfo)) { + return $page; } - - switch ($this->mimetype) { - - case 'application/pdf' : - - $pdftk = System::which('pdftk'); - - if (empty($pdftk)) { - return false; - } - - $cmd = "{$pdftk} {$file} dump_data"; - - $info = `$cmd`; - - $infos = explode("\n", $info); + + $cmd = "{$pdfinfo} {$file}"; - foreach ($infos as $i){ - - if(!preg_match('/^NumberOfPages: ([0-9]+)/', $i, $matches)){ - continue; - } - - $ret = (empty($matches[1])) ? false : $matches[1]; - break; - } - - break; - default : - break; + $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 $ret; + return $page; } }