summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorOlivier Paroz <oparoz@users.noreply.github.com>2014-09-02 22:56:39 +0200
committerOlivier Paroz <oparoz@users.noreply.github.com>2014-09-02 22:56:39 +0200
commitb559b21dc37228062ba8c3cccd842771d17132ce (patch)
tree620aae249fde4b4021ddcbc03f60aa95365fa0dd
parent1e600a0d36a074ce1e3d4c55a0f6461f5be16018 (diff)
downloadnextcloud-server-b559b21dc37228062ba8c3cccd842771d17132ce.tar.gz
nextcloud-server-b559b21dc37228062ba8c3cccd842771d17132ce.zip
Converts TIFF files to PNG
-rw-r--r--lib/private/preview/tiff.php48
1 files changed, 48 insertions, 0 deletions
diff --git a/lib/private/preview/tiff.php b/lib/private/preview/tiff.php
new file mode 100644
index 00000000000..52b53b00d1c
--- /dev/null
+++ b/lib/private/preview/tiff.php
@@ -0,0 +1,48 @@
+<?php
+/**
+ * Copyright (c) 2013-2014 Georg Ehrke georg@ownCloud.com
+ * This file is licensed under the Affero General Public License version 3 or
+ * later.
+ * See the COPYING-README file.
+ */
+namespace OC\Preview;
+
+use Imagick;
+
+if (extension_loaded('imagick')) {
+
+ $checkImagick = new Imagick();
+
+ if(count($checkImagick->queryFormats('TIFF')) === 1) {
+
+ class TIFF extends Provider {
+
+ public function getMimeType() {
+ return '/image\/tiff/';
+ }
+
+ public function getThumbnail($path, $maxX, $maxY, $scalingup, $fileview) {
+ $tmpPath = $fileview->toTmpFile($path);
+
+ //create imagick object from TIFF
+ try{
+ $tiff = new Imagick($tmpPath . '[0]');
+ $tiff->setImageFormat('png');
+ } catch (\Exception $e) {
+ \OC_Log::write('core', $e->getmessage(), \OC_Log::ERROR);
+ return false;
+ }
+
+ unlink($tmpPath);
+
+ //new image object
+ $image = new \OC_Image($tiff);
+ //check if image object is valid
+ return $image->valid() ? $image : false;
+ }
+
+ }
+
+ \OC\Preview::registerProvider('OC\Preview\TIFF');
+ }
+}