From 141a0f0f476a6675c0db9044afc7447342197f45 Mon Sep 17 00:00:00 2001
From: Roeland Jago Douma <roeland@famdouma.nl>
Date: Tue, 14 Jul 2015 08:43:14 +0200
Subject: Move mimetypedetection to files/type/detection

---
 lib/private/files/type/detection.php | 127 ++++++++++++-----------------------
 lib/private/helper.php               |  90 +++----------------------
 lib/private/server.php               |  11 ++-
 3 files changed, 60 insertions(+), 168 deletions(-)

(limited to 'lib')

diff --git a/lib/private/files/type/detection.php b/lib/private/files/type/detection.php
index 571062061df..35348c41a65 100644
--- a/lib/private/files/type/detection.php
+++ b/lib/private/files/type/detection.php
@@ -27,6 +27,7 @@
 namespace OC\Files\Type;
 
 use OCP\Files\IMimeTypeDetector;
+use OCP\IURLGenerator;
 
 /**
  * Class Detection
@@ -41,78 +42,17 @@ class Detection implements IMimeTypeDetector {
 
 	protected $mimetypeIcons = [];
 	/** @var string[] */
-	protected $mimeTypeAlias = [
-		'application/octet-stream' => 'file', // use file icon as fallback
+	protected $mimeTypeAlias = [];
 
-		'application/illustrator' => 'image/vector',
-		'application/postscript' => 'image/vector',
-		'image/svg+xml' => 'image/vector',
-
-		'application/coreldraw' => 'image',
-		'application/x-gimp' => 'image',
-		'application/x-photoshop' => 'image',
-		'application/x-dcraw' => 'image',
-
-		'application/font-sfnt' => 'font',
-		'application/x-font' => 'font',
-		'application/font-woff' => 'font',
-		'application/vnd.ms-fontobject' => 'font',
-
-		'application/json' => 'text/code',
-		'application/x-perl' => 'text/code',
-		'application/x-php' => 'text/code',
-		'text/x-shellscript' => 'text/code',
-		'application/yaml' => 'text/code',
-		'application/xml' => 'text/html',
-		'text/css' => 'text/code',
-		'application/x-tex' => 'text',
-
-		'application/x-compressed' => 'package/x-generic',
-		'application/x-7z-compressed' => 'package/x-generic',
-		'application/x-deb' => 'package/x-generic',
-		'application/x-gzip' => 'package/x-generic',
-		'application/x-rar-compressed' => 'package/x-generic',
-		'application/x-tar' => 'package/x-generic',
-		'application/vnd.android.package-archive' => 'package/x-generic',
-		'application/zip' => 'package/x-generic',
-
-		'application/msword' => 'x-office/document',
-		'application/vnd.openxmlformats-officedocument.wordprocessingml.document' => 'x-office/document',
-		'application/vnd.openxmlformats-officedocument.wordprocessingml.template' => 'x-office/document',
-		'application/vnd.ms-word.document.macroEnabled.12' => 'x-office/document',
-		'application/vnd.ms-word.template.macroEnabled.12' => 'x-office/document',
-		'application/vnd.oasis.opendocument.text' => 'x-office/document',
-		'application/vnd.oasis.opendocument.text-template' => 'x-office/document',
-		'application/vnd.oasis.opendocument.text-web' => 'x-office/document',
-		'application/vnd.oasis.opendocument.text-master' => 'x-office/document',
-
-		'application/mspowerpoint' => 'x-office/presentation',
-		'application/vnd.ms-powerpoint' => 'x-office/presentation',
-		'application/vnd.openxmlformats-officedocument.presentationml.presentation' => 'x-office/presentation',
-		'application/vnd.openxmlformats-officedocument.presentationml.template' => 'x-office/presentation',
-		'application/vnd.openxmlformats-officedocument.presentationml.slideshow' => 'x-office/presentation',
-		'application/vnd.ms-powerpoint.addin.macroEnabled.12' => 'x-office/presentation',
-		'application/vnd.ms-powerpoint.presentation.macroEnabled.12' => 'x-office/presentation',
-		'application/vnd.ms-powerpoint.template.macroEnabled.12' => 'x-office/presentation',
-		'application/vnd.ms-powerpoint.slideshow.macroEnabled.12' => 'x-office/presentation',
-		'application/vnd.oasis.opendocument.presentation' => 'x-office/presentation',
-		'application/vnd.oasis.opendocument.presentation-template' => 'x-office/presentation',
-
-		'application/msexcel' => 'x-office/spreadsheet',
-		'application/vnd.ms-excel' => 'x-office/spreadsheet',
-		'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet' => 'x-office/spreadsheet',
-		'application/vnd.openxmlformats-officedocument.spreadsheetml.template' => 'x-office/spreadsheet',
-		'application/vnd.ms-excel.sheet.macroEnabled.12' => 'x-office/spreadsheet',
-		'application/vnd.ms-excel.template.macroEnabled.12' => 'x-office/spreadsheet',
-		'application/vnd.ms-excel.addin.macroEnabled.12' => 'x-office/spreadsheet',
-		'application/vnd.ms-excel.sheet.binary.macroEnabled.12' => 'x-office/spreadsheet',
-		'application/vnd.oasis.opendocument.spreadsheet' => 'x-office/spreadsheet',
-		'application/vnd.oasis.opendocument.spreadsheet-template' => 'x-office/spreadsheet',
-		'text/csv' => 'x-office/spreadsheet',
-
-		'application/msaccess' => 'database',
-	];
+	/** @var IURLGenerator */
+	private $urlGenerator;
 
+	/**
+	 * @param IURLGenerator $urlGenerator
+	 */
+	public function __construct(IURLGenerator $urlGenerator) {
+		$this->urlGenerator = $urlGenerator;
+	}
 
 	/**
 	 * Add an extension -> mimetype mapping
@@ -255,44 +195,61 @@ class Detection implements IMimeTypeDetector {
 	 * @return string the url
 	 */
 	public function mimeTypeIcon($mimetype) {
+		// On first access load the list of mimetype aliases
+		if (empty($this->mimeTypeAlias)) {
+			$file = file_get_contents(\OC::$configDir . '/mimetypealiases.dist.json');
+			$this->mimeTypeAlias = get_object_vars(json_decode($file));
+
+			if (file_exists(\OC::$configDir . '/mimetypealiases.json')) {
+				$custom = get_object_vars(json_decode(file_get_contents(\OC::$configDir . '/mimetypealiases.json')));
+				$this->mimeTypeAlias = array_merge($this->mimeTypeAlias, $custom);
+			}
+		}
+
 		if (isset($this->mimeTypeAlias[$mimetype])) {
 			$mimetype = $this->mimeTypeAlias[$mimetype];
 		}
 		if (isset($this->mimetypeIcons[$mimetype])) {
 			return $this->mimetypeIcons[$mimetype];
 		}
+
 		// Replace slash and backslash with a minus
 		$icon = str_replace('/', '-', $mimetype);
 		$icon = str_replace('\\', '-', $icon);
 
 		// Is it a dir?
 		if ($mimetype === 'dir') {
-			$this->mimetypeIcons[$mimetype] = OC::$WEBROOT . '/core/img/filetypes/folder.png';
-			return OC::$WEBROOT . '/core/img/filetypes/folder.png';
+			$this->mimetypeIcons[$mimetype] = $this->urlGenerator->imagePath('core', 'filetypes/folder.png');
+			return $this->mimetypeIcons[$mimetype];
 		}
 		if ($mimetype === 'dir-shared') {
-			$this->mimetypeIcons[$mimetype] = OC::$WEBROOT . '/core/img/filetypes/folder-shared.png';
-			return OC::$WEBROOT . '/core/img/filetypes/folder-shared.png';
+			$this->mimetypeIcons[$mimetype] = $this->urlGenerator->imagePath('core', 'filetypes/folder-shared.png');
+			return $this->mimetypeIcons[$mimetype];
 		}
 		if ($mimetype === 'dir-external') {
-			$this->mimetypeIcons[$mimetype] = OC::$WEBROOT . '/core/img/filetypes/folder-external.png';
-			return OC::$WEBROOT . '/core/img/filetypes/folder-external.png';
+			$this->mimetypeIcons[$mimetype] = $this->urlGenerator->imagePath('core', 'filetypes/folder-external.
+png');
+			return $this->mimetypeIcons[$mimetype];
 		}
 
 		// Icon exists?
-		if (file_exists(OC::$SERVERROOT . '/core/img/filetypes/' . $icon . '.png')) {
-			$this->mimetypeIcons[$mimetype] = OC::$WEBROOT . '/core/img/filetypes/' . $icon . '.png';
-			return OC::$WEBROOT . '/core/img/filetypes/' . $icon . '.png';
+		try {
+			$this->mimetypeIcons[$mimetype] = $this->urlGenerator->imagePath('core', 'filetypes/' . $icon . '.png');
+			return $this->mimetypeIcons[$mimetype];
+		} catch (\RuntimeException $e) {
+			// Specified image not found
 		}
 
 		// Try only the first part of the filetype
 		$mimePart = substr($icon, 0, strpos($icon, '-'));
-		if (file_exists(OC::$SERVERROOT . '/core/img/filetypes/' . $mimePart . '.png')) {
-			$this->mimetypeIcons[$mimetype] = OC::$WEBROOT . '/core/img/filetypes/' . $mimePart . '.png';
-			return OC::$WEBROOT . '/core/img/filetypes/' . $mimePart . '.png';
-		} else {
-			$this->mimetypeIcons[$mimetype] = OC::$WEBROOT . '/core/img/filetypes/file.png';
-			return OC::$WEBROOT . '/core/img/filetypes/file.png';
+		try {
+			$this->mimetypeIcons[$mimetype] = $this->urlGenerator->imagePath('core', 'filetypes/' . $mimePart . '.png');
+			return $this->mimetypeIcons[$mimetype];
+		} catch (\RuntimeException $e) {
+			// Image for the first part of the mimetype not found
 		}
+
+		$this->mimetypeIcons[$mimetype] = $this->urlGenerator->imagePath('core', 'filetypes/file.png');
+		return $this->mimetypeIcons[$mimetype];
 	}
 }
diff --git a/lib/private/helper.php b/lib/private/helper.php
index 09f0ba1da3c..c30c11dc840 100644
--- a/lib/private/helper.php
+++ b/lib/private/helper.php
@@ -50,11 +50,7 @@ use Symfony\Component\Process\ExecutableFinder;
  * Collection of useful functions
  */
 class OC_Helper {
-	private static $mimetypeIcons = array();
-	private static $mimetypeDetector;
 	private static $templateManager;
-	/** @var string[] */
-	private static $mimeTypeAlias = [];
 
 	/**
 	 * Creates an url using a defined route
@@ -183,65 +179,10 @@ class OC_Helper {
 	 * @return string the url
 	 *
 	 * Returns the path to the image of this file type.
-	 * @deprecated Use \OC::$server->getMimeTypeDetector()->mimeTypeIcon($mimetype)
+	 * @deprecated 8.2.0 Use \OC::$server->getMimeTypeDetector()->mimeTypeIcon($mimetype)
 	 */
 	public static function mimetypeIcon($mimetype) {
-
-		// On first access load the list of mimetype aliases
-		if (empty(self::$mimeTypeAlias)) {
-			$file = file_get_contents(OC::$SERVERROOT . '/config/mimetypealiases.dist.json');
-			self::$mimeTypeAlias = get_object_vars(json_decode($file));
-
-			if (file_exists(\OC::$SERVERROOT . '/config/mimetypealiases.json')) {
-				$custom = get_object_vars(json_decode(file_get_contents(\OC::$SERVERROOT . '/config/mimetypealiases.json')));
-				self::$mimeTypeAlias = array_merge(self::$mimeTypeAlias, $custom);
-			}
-		}
-
-		if (isset(self::$mimeTypeAlias[$mimetype])) {
-			$mimetype = self::$mimeTypeAlias[$mimetype];
-		}
-		if (isset(self::$mimetypeIcons[$mimetype])) {
-			return self::$mimetypeIcons[$mimetype];
-		}
-
-		// Replace slash and backslash with a minus
-		$icon = str_replace('/', '-', $mimetype);
-		$icon = str_replace('\\', '-', $icon);
-
-		// Is it a dir?
-		if ($mimetype === 'dir') {
-			self::$mimetypeIcons[$mimetype] = \OC::$server->getURLGenerator()->imagePath('core', 'filetypes/folder.png');
-			return self::$mimetypeIcons[$mimetype];
-		}
-		if ($mimetype === 'dir-shared') {
-			self::$mimetypeIcons[$mimetype] = \OC::$server->getURLGenerator()->imagePath('core', 'filetypes/folder-shared.png');
-			return self::$mimetypeIcons[$mimetype];
-		}
-		if ($mimetype === 'dir-external') {
-			self::$mimetypeIcons[$mimetype] = \OC::$server->getURLGenerator()->imagePath('core', 'filetypes/folder-external.png');
-			return self::$mimetypeIcons[$mimetype];
-		}
-
-		// Icon exists?
-		try {
-			self::$mimetypeIcons[$mimetype] = \OC::$server->getURLGenerator()->imagePath('core', 'filetypes/' . $icon . '.png');
-			return self::$mimetypeIcons[$mimetype];
-		} catch (\RuntimeException $e) {
-			// Specified image not found
-		}
-
-		// Try only the first part of the filetype
-		$mimePart = substr($icon, 0, strpos($icon, '-'));
-		try {
-			self::$mimetypeIcons[$mimetype] = \OC::$server->getURLGenerator()->imagePath('core', 'filetypes/' . $mimePart . '.png');
-			return self::$mimetypeIcons[$mimetype];
-		} catch (\RuntimeException $e) {
-			// Image for the first part of the mimetype not found
-		}
-
-		self::$mimetypeIcons[$mimetype] = \OC::$server->getURLGenerator()->imagePath('core', 'filetypes/file.png');
-		return self::$mimetypeIcons[$mimetype];
+		return \OC::$server->getMimeTypeDetector()->mimeTypeIcon($mimetype);
 	}
 
 	/**
@@ -432,23 +373,10 @@ class OC_Helper {
 
 	/**
 	 * @return \OC\Files\Type\Detection
+	 * @deprecated 8.2.0 use \OC::$server->getMimeTypeDetector()
 	 */
 	static public function getMimetypeDetector() {
-		if (!self::$mimetypeDetector) {
-			$dist = file_get_contents(OC::$configDir . '/mimetypemapping.dist.json');
-			$mimetypemapping = get_object_vars(json_decode($dist));
-
-			//Check if need to load custom mappings
-			if (file_exists(OC::$configDir . '/mimetypemapping.json')) {
-				$custom = file_get_contents(OC::$configDir . '/mimetypemapping.json');
-				$custom_mapping = get_object_vars(json_decode($custom));
-				$mimetypemapping = array_merge($mimetypemapping, $custom_mapping);
-			}
-
-			self::$mimetypeDetector = new \OC\Files\Type\Detection();
-			self::$mimetypeDetector->registerTypeArray($mimetypemapping);
-		}
-		return self::$mimetypeDetector;
+		return \OC::$server->getMimeTypeDetector();
 	}
 
 	/**
@@ -469,7 +397,7 @@ class OC_Helper {
 	 * @deprecated Use \OC::$server->getMimeTypeDetector()->detectPath($path)
 	 */
 	static public function getFileNameMimeType($path) {
-		return self::getMimetypeDetector()->detectPath($path);
+		return \OC::$server->getMimeTypeDetector()->detectPath($path);
 	}
 
 	/**
@@ -481,7 +409,7 @@ class OC_Helper {
 	 * @deprecated Use \OC::$server->getMimeTypeDetector()->detect($path)
 	 */
 	static function getMimeType($path) {
-		return self::getMimetypeDetector()->detect($path);
+		return \OC::$server->getMimeTypeDetector()->detect($path);
 	}
 
 	/**
@@ -492,7 +420,7 @@ class OC_Helper {
 	 * @deprecated Use \OC::$server->getMimeTypeDetector()->getSecureMimeType($mimeType)
 	 */
 	static function getSecureMimeType($mimeType) {
-		return self::getMimetypeDetector()->getSecureMimeType($mimeType);
+		return \OC::$server->getMimeTypeDetector()->getSecureMimeType($mimeType);
 	}
 
 	/**
@@ -500,10 +428,10 @@ class OC_Helper {
 	 *
 	 * @param string $data
 	 * @return string
-	 * @deprecated Use \OC::$server->getMimeTypeDetector->detectString($data)
+	 * @deprecated Use \OC::$server->getMimeTypeDetector()->detectString($data)
 	 */
 	static function getStringMimeType($data) {
-		return self::getMimetypeDetector()->detectString($data);
+		return \OC::$server->getMimeTypeDetector()->detectString($data);
 	}
 
 	/**
diff --git a/lib/private/server.php b/lib/private/server.php
index 7aa331884b6..b835fbd4cbf 100644
--- a/lib/private/server.php
+++ b/lib/private/server.php
@@ -59,7 +59,6 @@ use OC\Security\SecureRandom;
 use OC\Security\TrustedDomainHelper;
 use OC\Tagging\TagMapper;
 use OCP\IServerContainer;
-use OC\Files\Type\Detection;
 
 /**
  * Class Server
@@ -446,9 +445,17 @@ class Server extends SimpleContainer implements IServerContainer {
 			return new \OC\Files\Mount\Manager();
 		});
 		$this->registerService('MimeTypeDetector', function(Server $c) {
-			$mimeTypeDetector = new Detection();
+			$mimeTypeDetector = new \OC\Files\Type\Detection($c->getURLGenerator());
 			$dist = file_get_contents(\OC::$configDir . '/mimetypemapping.dist.json');
 			$mimetypemapping = get_object_vars(json_decode($dist));
+
+			//Check if need to load custom mappings
+			if (file_exists(\OC::$configDir . '/mimetypemapping.json')) {
+				$custom = file_get_contents(\OC::$configDir . '/mimetypemapping.json');
+				$custom_mapping = get_object_vars(json_decode($custom));
+				$mimetypemapping = array_merge($mimetypemapping, $custom_mapping);
+			}
+
 			$mimeTypeDetector->registerTypeArray($mimetypemapping);
 			return $mimeTypeDetector;
 		});
-- 
cgit v1.2.3