summaryrefslogtreecommitdiffstats
path: root/lib
diff options
context:
space:
mode:
authorMichael Gapczynski <mtgap@owncloud.com>2013-05-29 18:08:18 -0400
committerMichael Gapczynski <mtgap@owncloud.com>2013-05-29 18:08:18 -0400
commitdbbf195727d698a5ba46d7cfee06eb9ea7916d96 (patch)
tree383d2e96375b9579cb5b51507459485f9d0be87e /lib
parent44d217c42529c3f4a0df0a56255887450d37e00b (diff)
downloadnextcloud-server-dbbf195727d698a5ba46d7cfee06eb9ea7916d96.tar.gz
nextcloud-server-dbbf195727d698a5ba46d7cfee06eb9ea7916d96.zip
Only retrieve the current user's permissions
Diffstat (limited to 'lib')
-rw-r--r--lib/files/cache/permissions.php9
-rw-r--r--lib/files/view.php2
2 files changed, 6 insertions, 5 deletions
diff --git a/lib/files/cache/permissions.php b/lib/files/cache/permissions.php
index 73473142c74..29c30b0f36c 100644
--- a/lib/files/cache/permissions.php
+++ b/lib/files/cache/permissions.php
@@ -89,14 +89,15 @@ class Permissions {
* get the permissions for all files in a folder
*
* @param int $parentId
+ * @param string $user
* @return int[]
*/
- public function getDirectoryPermissions($parentId) {
+ public function getDirectoryPermissions($parentId, $user) {
$query = \OC_DB::prepare('SELECT `*PREFIX*permissions`.`fileid`, `permissions`
- FROM `*PREFIX*permissions` INNER JOIN `*PREFIX*filecache` ON `*PREFIX*permissions`.fileid = `*PREFIX*filecache`.fileid
- WHERE `*PREFIX*filecache`.parent = ?');
+ FROM `*PREFIX*permissions` INNER JOIN `*PREFIX*filecache` ON `*PREFIX*permissions`.`fileid` = `*PREFIX*filecache`.`fileid`
+ WHERE `*PREFIX*filecache`.`parent` = ? AND `*PREFIX*permissions`.`user` = ?');
- $result = $query->execute(array($parentId));
+ $result = $query->execute(array($parentId, $user));
$filePermissions = array();
while ($row = $result->fetchRow()) {
$filePermissions[$row['fileid']] = $row['permissions'];
diff --git a/lib/files/view.php b/lib/files/view.php
index ffe0e155c6c..ecb0f30400a 100644
--- a/lib/files/view.php
+++ b/lib/files/view.php
@@ -797,7 +797,7 @@ class View {
}
$files = $cache->getFolderContents($internalPath); //TODO: mimetype_filter
- $permissions = $permissionsCache->getDirectoryPermissions($cache->getId($internalPath));
+ $permissions = $permissionsCache->getDirectoryPermissions($cache->getId($internalPath), $user);
$ids = array();
foreach ($files as $i => $file) {