summaryrefslogtreecommitdiffstats
path: root/lib
diff options
context:
space:
mode:
authorGeorg Ehrke <developer@georgehrke.com>2014-06-10 22:08:12 +0200
committerGeorg Ehrke <developer@georgehrke.com>2014-06-10 22:08:27 +0200
commit7396e5f455b0e723e9c7ef41bfb34a17de0569cf (patch)
treeff392450fbe26e7c924fa36a58d5aae17daec40f /lib
parentecc41fe0c3375022d2455fd563f91b2691bdd857 (diff)
downloadnextcloud-server-7396e5f455b0e723e9c7ef41bfb34a17de0569cf.tar.gz
nextcloud-server-7396e5f455b0e723e9c7ef41bfb34a17de0569cf.zip
movie previews: use file directly when it's stored locally and encryption is not enabled, fixes #7756
Diffstat (limited to 'lib')
-rw-r--r--lib/private/preview/movies.php25
1 files changed, 17 insertions, 8 deletions
diff --git a/lib/private/preview/movies.php b/lib/private/preview/movies.php
index 72ccfadc6e9..2a23c2141c1 100644
--- a/lib/private/preview/movies.php
+++ b/lib/private/preview/movies.php
@@ -41,14 +41,22 @@ if (!\OC_Util::runningOnWindows()) {
public function getThumbnail($path, $maxX, $maxY, $scalingup, $fileview) {
// TODO: use proc_open() and stream the source file ?
- $absPath = \OC_Helper::tmpFile();
- $handle = $fileview->fopen($path, 'rb');
+ $fileInfo = $fileview->getFileInfo($path);
+ $useFileDirectly = (!$fileInfo->isEncrypted() && !$fileInfo->isMounted());
- // we better use 5MB (1024 * 1024 * 5 = 5242880) instead of 1MB.
- // in some cases 1MB was no enough to generate thumbnail
- $firstmb = stream_get_contents($handle, 5242880);
- file_put_contents($absPath, $firstmb);
+ if ($useFileDirectly) {
+ $absPath = $fileview->getLocalFile($path);
+ } else {
+ $absPath = \OC_Helper::tmpFile();
+
+ $handle = $fileview->fopen($path, 'rb');
+
+ // we better use 5MB (1024 * 1024 * 5 = 5242880) instead of 1MB.
+ // in some cases 1MB was no enough to generate thumbnail
+ $firstmb = stream_get_contents($handle, 5242880);
+ file_put_contents($absPath, $firstmb);
+ }
$result = $this->generateThumbNail($maxX, $maxY, $absPath, 5);
if ($result === false) {
@@ -58,8 +66,9 @@ if (!\OC_Util::runningOnWindows()) {
}
}
- unlink($absPath);
-
+ if (!$useFileDirectly) {
+ unlink($absPath);
+ }
return $result;
}