get rid of old code, use actions for 'version' and 'file'

This commit is contained in:
Uwe Steinmann 2022-08-05 13:32:46 +02:00
parent 014bcc009d
commit e31c532c68
2 changed files with 87 additions and 120 deletions

View File

@ -22,96 +22,91 @@
*/ */
class SeedDMS_Controller_Preview extends SeedDMS_Controller_Common { class SeedDMS_Controller_Preview extends SeedDMS_Controller_Common {
public function run() { public function version() {
global $theme;
$dms = $this->params['dms']; $dms = $this->params['dms'];
$type = $this->params['type'];
$settings = $this->params['settings']; $settings = $this->params['settings'];
$conversionmgr = $this->params['conversionmgr']; $conversionmgr = $this->params['conversionmgr'];
switch($type) { $version = $this->params['version'];
case "version": $document = $this->params['document'];
$version = $this->params['version']; $width = $this->params['width'];
$document = $this->params['document']; if($version < 1) {
$width = $this->params['width']; $content = $this->callHook('documentLatestContent', $document);
if($version < 1) { if($content === null)
$content = $this->callHook('documentLatestContent', $document); $content = $document->getLatestContent();
if($content === null) } else {
$content = $document->getLatestContent(); $content = $this->callHook('documentContent', $document, $version);
} else { if($content === null)
$content = $this->callHook('documentContent', $document, $version); $content = $document->getContentByVersion($version);
if($content === null)
$content = $document->getContentByVersion($version);
}
if (!is_object($content)) {
$this->errormsg = 'invalid_version';
return false;
}
/* set params['content'] for compatiblity with older extensions which
* expect the content in the controller
*/
$this->params['content'] = $content;
if(null === $this->callHook('version')) {
if($width)
$previewer = new SeedDMS_Preview_Previewer($settings->_cacheDir, $width, $settings->_cmdTimeout);
else
$previewer = new SeedDMS_Preview_Previewer($settings->_cacheDir);
if($conversionmgr)
$previewer->setConversionMgr($conversionmgr);
else
$previewer->setConverters($settings->_converters['preview']);
$previewer->setXsendfile($settings->_enableXsendfile);
if(!$previewer->hasPreview($content)) {
add_log_line("");
if(!$previewer->createPreview($content)) {
add_log_line("", PEAR_LOG_ERR);
}
}
if(!$previewer->hasPreview($content)) {
header('Content-Type: image/svg+xml');
readfile('../views/'.$theme.'/images/empty.svg');
exit;
}
header('Content-Type: image/png');
$previewer->getPreview($content);
}
break;
case "file":
$object = $this->params['object'];
$document = $this->params['document'];
$width = $this->params['width'];
if (!is_object($object)) {
$this->errormsg = 'invalid_version';
return false;
}
if(null === $this->callHook('file')) {
if($width)
$previewer = new SeedDMS_Preview_Previewer($settings->_cacheDir, $width, $settings->_cmdTimeout);
else
$previewer = new SeedDMS_Preview_Previewer($settings->_cacheDir);
if($conversionmgr)
$previewer->setConversionMgr($conversionmgr);
else
$previewer->setConverters($settings->_converters['preview']);
$previewer->setXsendfile($settings->_enableXsendfile);
if(!$previewer->hasPreview($object)) {
add_log_line("");
if(!$previewer->createPreview($object)) {
add_log_line("", PEAR_LOG_ERR);
}
}
if(!$previewer->hasPreview($object)) {
header('Content-Type: image/svg+xml');
readfile('../views/'.$theme.'/images/empty.svg');
exit;
}
header('Content-Type: image/png');
$previewer->getPreview($object);
}
break;
} }
return true; if (!is_object($content)) {
} $this->errormsg = 'invalid_version';
return false;
}
/* set params['content'] for compatiblity with older extensions which
* expect the content in the controller
*/
$this->params['content'] = $content;
if(null === $this->callHook('version')) {
if($width)
$previewer = new SeedDMS_Preview_Previewer($settings->_cacheDir, $width, $settings->_cmdTimeout);
else
$previewer = new SeedDMS_Preview_Previewer($settings->_cacheDir);
if($conversionmgr)
$previewer->setConversionMgr($conversionmgr);
else
$previewer->setConverters($settings->_converters['preview']);
$previewer->setXsendfile($settings->_enableXsendfile);
if(!$previewer->hasPreview($content)) {
add_log_line("");
if(!$previewer->createPreview($content)) {
add_log_line("", PEAR_LOG_ERR);
}
}
if(!$previewer->hasPreview($content)) {
return false;
}
header('Content-Type: image/png');
$previewer->getPreview($content);
}
} /* }}} */
public function file() {
$dms = $this->params['dms'];
$settings = $this->params['settings'];
$conversionmgr = $this->params['conversionmgr'];
$object = $this->params['object'];
$document = $this->params['document'];
$width = $this->params['width'];
if (!is_object($object)) {
$this->errormsg = 'invalid_version';
return false;
}
if(null === $this->callHook('file')) {
if($width)
$previewer = new SeedDMS_Preview_Previewer($settings->_cacheDir, $width, $settings->_cmdTimeout);
else
$previewer = new SeedDMS_Preview_Previewer($settings->_cacheDir);
if($conversionmgr)
$previewer->setConversionMgr($conversionmgr);
else
$previewer->setConverters($settings->_converters['preview']);
$previewer->setXsendfile($settings->_enableXsendfile);
if(!$previewer->hasPreview($object)) {
add_log_line("");
if(!$previewer->createPreview($object)) {
add_log_line("", PEAR_LOG_ERR);
}
}
if(!$previewer->hasPreview($object)) {
return false;
}
header('Content-Type: image/png');
$previewer->getPreview($object);
}
} /* }}} */
} }

View File

@ -55,15 +55,15 @@ if ($document->getAccessMode($user) < M_READ) {
} }
$controller->setParam('conversionmgr', $conversionmgr); $controller->setParam('conversionmgr', $conversionmgr);
$controller->setParam('width', !empty($_GET["width"]) ? $_GET["width"] : null);
$controller->setParam('document', $document);
if(isset($_GET['version'])) { if(isset($_GET['version'])) {
$version = $_GET["version"]; $version = $_GET["version"];
if (!is_numeric($version)) if (!is_numeric($version))
exit; exit;
$controller->setParam('width', !empty($_GET["width"]) ? $_GET["width"] : null); $controller->setParam('action', 'version');
$controller->setParam('document', $document);
$controller->setParam('version', $version); $controller->setParam('version', $version);
$controller->setParam('type', 'version');
if(!$controller()) { if(!$controller()) {
header('Content-Type: image/svg+xml'); header('Content-Type: image/svg+xml');
readfile('../views/'.$theme.'/images/empty.svg'); readfile('../views/'.$theme.'/images/empty.svg');
@ -75,11 +75,9 @@ if(isset($_GET['version'])) {
if (!is_numeric($file) || intval($file)<1) if (!is_numeric($file) || intval($file)<1)
exit; exit;
$object = $document->getDocumentFile($file); $object = $document->getDocumentFile($file);
$controller->setParam('width', !empty($_GET["width"]) ? $_GET["width"] : null); $controller->setParam('action', 'file');
$controller->setParam('document', $document);
$controller->setParam('object', $object); $controller->setParam('object', $object);
$controller->setParam('type', 'file'); if(!$controller()) {
if(!$controller->run()) {
header('Content-Type: image/svg+xml'); header('Content-Type: image/svg+xml');
readfile('../views/'.$theme.'/images/empty.svg'); readfile('../views/'.$theme.'/images/empty.svg');
exit; exit;
@ -88,29 +86,3 @@ if(isset($_GET['version'])) {
} else { } else {
exit; exit;
} }
/* From here on old code which isn't used anymore
if (!is_object($object)) {
exit;
}
if(!empty($_GET["width"]))
$previewer = new SeedDMS_Preview_Previewer($settings->_cacheDir, $_GET["width"]);
else
$previewer = new SeedDMS_Preview_Previewer($settings->_cacheDir);
$previewer->setConverters($settings->_converters['preview']);
$previewer->setXsendfile($settings->_enableXsendfile);
if(!$previewer->hasPreview($object)) {
add_log_line("");
if(!$previewer->createPreview($object)) {
}
}
if(!$previewer->hasPreview($object)) {
header('Content-Type: image/svg+xml');
readfile('../views/'.$theme.'/images/empty.svg');
exit;
}
header('Content-Type: image/png');
$previewer->getPreview($object);
*/
?>