summaryrefslogtreecommitdiffstats
path: root/lib/private/Files
diff options
context:
space:
mode:
authorJoas Schilling <coding@schilljs.com>2019-11-29 11:04:20 +0100
committerJoas Schilling <coding@schilljs.com>2019-12-10 09:11:42 +0100
commitda44c2a414129047c256e5e86c1aa3f0dddb22ef (patch)
tree0aaf09eafbd795002f1a693bca7914ed4e76d832 /lib/private/Files
parent1336dedd5d7946c74d1bfedc17e3510fcb744be7 (diff)
downloadnextcloud-server-da44c2a414129047c256e5e86c1aa3f0dddb22ef.tar.gz
nextcloud-server-da44c2a414129047c256e5e86c1aa3f0dddb22ef.zip
Some more fixes in detecting the mimetype from the content
Signed-off-by: Joas Schilling <coding@schilljs.com>
Diffstat (limited to 'lib/private/Files')
-rw-r--r--lib/private/Files/Type/Detection.php32
1 files changed, 17 insertions, 15 deletions
diff --git a/lib/private/Files/Type/Detection.php b/lib/private/Files/Type/Detection.php
index 7d4c3408c86..d1193b7a36b 100644
--- a/lib/private/Files/Type/Detection.php
+++ b/lib/private/Files/Type/Detection.php
@@ -200,7 +200,7 @@ class Detection implements IMimeTypeDetector {
if (strpos($fileName, '.') > 0) {
// remove versioning extension: name.v1508946057 and transfer extension: name.ocTransferId2057600214.part
- $fileName = preg_replace('!((\.v\d+)|((.ocTransferId\d+)?.part))$!', '', $fileName);
+ $fileName = preg_replace('!((\.v\d+)|((\.ocTransferId\d+)?\.part))$!', '', $fileName);
//try to guess the type by the file extension
$extension = strtolower(strrchr($fileName, '.'));
@@ -225,45 +225,47 @@ class Detection implements IMimeTypeDetector {
return 'httpd/unix-directory';
}
- $mimeType = 'application/octet-stream';
if (function_exists('finfo_open')
&& function_exists('finfo_file')
&& $finfo = finfo_open(FILEINFO_MIME)) {
- $info = @strtolower(finfo_file($finfo, $path));
+ $info = @finfo_file($finfo, $path);
finfo_close($finfo);
if ($info) {
+ $info = strtolower($info);
$mimeType = strpos($info, ';') !== false ? substr($info, 0, strpos($info, ';')) : $info;
- return empty($mimeType) ? 'application/octet-stream' : $mimeType;
+ return $this->getSecureMimeType($mimeType);
}
-
}
if (strpos($path, '://') !== false && strpos($path, 'file://') === 0) {
// Is the file wrapped in a stream?
- return $mimeType;
+ return 'application/octet-stream';
}
if (function_exists('mime_content_type')) {
// use mime magic extension if available
$mimeType = mime_content_type($path);
+ if ($mimeType !== false) {
+ return $this->getSecureMimeType($mimeType);
+ }
}
- if ($mimeType === 'application/octet-stream' && \OC_Helper::canExecute('file')) {
+
+ if (\OC_Helper::canExecute('file')) {
// it looks like we have a 'file' command,
// lets see if it does have mime support
$path = escapeshellarg($path);
- $fp = popen("file -b --mime-type $path 2>/dev/null", 'r');
- $reply = fgets($fp);
+ $fp = popen("test -f $path && file -b --mime-type $path", 'r');
+ $mimeType = fgets($fp);
pclose($fp);
- //trim the newline
- $mimeType = trim($reply);
-
- if (empty($mimeType)) {
- $mimeType = 'application/octet-stream';
+ if ($mimeType !== false) {
+ //trim the newline
+ $mimeType = trim($mimeType);
+ return $this->getSecureMimeType($mimeType);
}
}
- return $mimeType;
+ return 'application/octet-stream';
}
/**