diff options
author | Joas Schilling <coding@schilljs.com> | 2019-09-17 11:15:59 +0200 |
---|---|---|
committer | Joas Schilling <coding@schilljs.com> | 2019-09-17 11:15:59 +0200 |
commit | a4ba2113b2e083ea8cf358d683b1b0a370cca385 (patch) | |
tree | 1fd7aee990f7b51c00a4fa4f04e1b4b8d3dd5ce4 /lib/private | |
parent | d43a478840ace4cf827643f3254288b66eb75a8a (diff) | |
download | nextcloud-server-a4ba2113b2e083ea8cf358d683b1b0a370cca385.tar.gz nextcloud-server-a4ba2113b2e083ea8cf358d683b1b0a370cca385.zip |
Fix getById for files in appdata and the root mount
In case the path we are currently in is inside the appdata_* folder,
the original getById method does not work, because it can only look inside
the user's mount points. But the user has no mount point for the root storage.
So in that case we directly check the mount of the root if it contains
the id. If it does we check if the path is inside the path we are working
in.
Signed-off-by: Joas Schilling <coding@schilljs.com>
Diffstat (limited to 'lib/private')
-rw-r--r-- | lib/private/Files/Node/Folder.php | 44 |
1 files changed, 44 insertions, 0 deletions
diff --git a/lib/private/Files/Node/Folder.php b/lib/private/Files/Node/Folder.php index 8b2a93ffdc2..4a134cdcdbf 100644 --- a/lib/private/Files/Node/Folder.php +++ b/lib/private/Files/Node/Folder.php @@ -299,6 +299,9 @@ class Folder extends Node implements \OCP\Files\Folder { })); if (count($mountsContainingFile) === 0) { + if ($user === $this->getAppDataDirectoryName()) { + return $this->getByIdInRootMount((int) $id); + } return []; } @@ -327,6 +330,47 @@ class Folder extends Node implements \OCP\Files\Folder { }); } + protected function getAppDataDirectoryName(): string { + $instanceId = \OC::$server->getConfig()->getSystemValueString('instanceid'); + return 'appdata_' . $instanceId; + } + + /** + * In case the path we are currently in is inside the appdata_* folder, + * the original getById method does not work, because it can only look inside + * the user's mount points. But the user has no mount point for the root storage. + * + * So in that case we directly check the mount of the root if it contains + * the id. If it does we check if the path is inside the path we are working + * in. + * + * @param int $id + * @return array + */ + protected function getByIdInRootMount(int $id): array { + $mount = $this->root->getMount(''); + $cacheEntry = $mount->getStorage()->getCache($this->path)->get($id); + if (!$cacheEntry) { + return []; + } + + $absolutePath = '/' . ltrim($cacheEntry->getPath(), '/'); + $currentPath = rtrim($this->path, '/') . '/'; + + if (strpos($absolutePath, $currentPath) !== 0) { + return []; + } + + return [$this->root->createNode( + $absolutePath, new \OC\Files\FileInfo( + $absolutePath, + $mount->getStorage(), + $cacheEntry->getPath(), + $cacheEntry, + $mount + ))]; + } + public function getFreeSpace() { return $this->view->free_space($this->path); } |