]> source.dussan.org Git - nextcloud-server.git/commitdiff
Check if the file isReadable() before sending a (cached) preview 1184/head
authorJoas Schilling <coding@schilljs.com>
Fri, 26 Aug 2016 13:51:18 +0000 (15:51 +0200)
committerJoas Schilling <coding@schilljs.com>
Tue, 30 Aug 2016 08:24:01 +0000 (10:24 +0200)
core/ajax/preview.php
lib/private/Preview.php

index 2894efdc8e3826a2b3939d90f5907c4e918cb593..6cfba6aef30320dc89eaf47fbf978385d0c19fab 100644 (file)
@@ -53,6 +53,8 @@ $info = \OC\Files\Filesystem::getFileInfo($file);
 
 if (!$info instanceof OCP\Files\FileInfo || !$always && !\OC::$server->getPreviewManager()->isAvailable($info)) {
        \OC_Response::setStatus(404);
+} else if (!$info->isReadable()) {
+       \OC_Response::setStatus(403);
 } else {
        $preview = new \OC\Preview(\OC_User::getUser(), 'files');
        $preview->setFile($file, $info);
index 70b000a30ee3af4bfe7d35c3e4b9fafc14b6479a..67838a8d4a318b0a1f019d72b39885f79bf27d07 100644 (file)
@@ -763,7 +763,7 @@ class Preview {
 
                $this->preview = null;
                $fileInfo = $this->getFileInfo();
-               if ($fileInfo === null || $fileInfo === false) {
+               if ($fileInfo === null || $fileInfo === false || !$fileInfo->isReadable()) {
                        return new \OC_Image();
                }