Skip to content

Commit

Permalink
allow reusing known folder info when getting directory contents
Browse files Browse the repository at this point in the history
Signed-off-by: Robin Appelman <robin@icewind.nl>
  • Loading branch information
icewind1991 committed Apr 6, 2022
1 parent 9b1abd6 commit 151c800
Show file tree
Hide file tree
Showing 5 changed files with 29 additions and 16 deletions.
4 changes: 2 additions & 2 deletions apps/dav/lib/Connector/Sabre/Directory.php
Original file line number Diff line number Diff line change
Expand Up @@ -236,7 +236,7 @@ public function getChild($name, $info = null) {
throw new \Sabre\DAV\Exception\NotFound('File with name ' . $path . ' could not be located');
}

if ($info['mimetype'] === 'httpd/unix-directory') {
if ($info->getMimeType() === FileInfo::MIMETYPE_FOLDER) {
$node = new \OCA\DAV\Connector\Sabre\Directory($this->fileView, $info, $this->tree, $this->shareManager);
} else {
$node = new \OCA\DAV\Connector\Sabre\File($this->fileView, $info, $this->shareManager);
Expand Down Expand Up @@ -264,7 +264,7 @@ public function getChildren() {
// the caller believe that the collection itself does not exist
throw new Forbidden('No read permissions');
}
$folderContent = $this->fileView->getDirectoryContent($this->path);
$folderContent = $this->getNode()->getDirectoryListing();
} catch (LockedException $e) {
throw new Locked();
}
Expand Down
14 changes: 9 additions & 5 deletions apps/dav/lib/Connector/Sabre/Node.php
Original file line number Diff line number Diff line change
Expand Up @@ -78,7 +78,7 @@ abstract class Node implements \Sabre\DAV\INode {
*/
protected $shareManager;

protected \OC\Files\Node\Node $node;
protected \OCP\Files\Node $node;

/**
* Sets up the node, expects a full path name
Expand All @@ -96,11 +96,15 @@ public function __construct(View $view, FileInfo $info, IManager $shareManager =
} else {
$this->shareManager = \OC::$server->getShareManager();
}
$root = \OC::$server->get(IRootFolder::class);
if ($info->getType()=== FileInfo::TYPE_FOLDER) {
$this->node = new Folder($root, $view, $this->path, $info);
if ($info instanceof Folder || $info instanceof File) {
$this->node = $info;
} else {
$this->node = new File($root, $view, $this->path, $info);
$root = \OC::$server->get(IRootFolder::class);
if ($info->getType() === FileInfo::TYPE_FOLDER) {
$this->node = new Folder($root, $view, $this->path, $info);
} else {
$this->node = new File($root, $view, $this->path, $info);
}
}
}

Expand Down
4 changes: 2 additions & 2 deletions lib/private/Files/Node/Folder.php
Original file line number Diff line number Diff line change
Expand Up @@ -97,10 +97,10 @@ public function isSubNode($node) {
* @throws \OCP\Files\NotFoundException
*/
public function getDirectoryListing() {
$folderContent = $this->view->getDirectoryContent($this->path);
$folderContent = $this->view->getDirectoryContent($this->path, '', $this->getFileInfo());

return array_map(function (FileInfo $info) {
if ($info->getMimetype() === 'httpd/unix-directory') {
if ($info->getMimetype() === FileInfo::MIMETYPE_FOLDER) {
return new Folder($this->root, $this->view, $info->getPath(), $info);
} else {
return new File($this->root, $this->view, $info->getPath(), $info);
Expand Down
21 changes: 14 additions & 7 deletions lib/private/Files/View.php
Original file line number Diff line number Diff line change
Expand Up @@ -1431,7 +1431,7 @@ public function getFileInfo($path, $includeMountPoints = true) {
* @param string $mimetype_filter limit returned content to this mimetype or mimepart
* @return FileInfo[]
*/
public function getDirectoryContent($directory, $mimetype_filter = '') {
public function getDirectoryContent($directory, $mimetype_filter = '', \OCP\Files\FileInfo $directoryInfo = null) {
$this->assertPathLength($directory);
if (!Filesystem::isValidPath($directory)) {
return [];
Expand All @@ -1449,14 +1449,21 @@ public function getDirectoryContent($directory, $mimetype_filter = '') {
$cache = $storage->getCache($internalPath);
$user = \OC_User::getUser();

$data = $this->getCacheEntry($storage, $internalPath, $directory);
if (!$directoryInfo) {
$data = $this->getCacheEntry($storage, $internalPath, $directory);
if (!$data instanceof ICacheEntry || !isset($data['fileid'])) {
return [];
}
} else {
$data = $directoryInfo;
}

if (!$data instanceof ICacheEntry || !isset($data['fileid']) || !($data->getPermissions() & Constants::PERMISSION_READ)) {
return [];
}
if (!($data->getPermissions() & Constants::PERMISSION_READ)) {
return [];
}

$folderId = $data['fileid'];
$contents = $cache->getFolderContentsById($folderId); //TODO: mimetype_filter
$folderId = $data->getId();
$contents = $cache->getFolderContentsById($folderId); //TODO: mimetype_filter

$sharingDisabled = \OCP\Util::isSharingDisabledForUser();

Expand Down
2 changes: 2 additions & 0 deletions tests/lib/Files/Node/FolderTest.php
Original file line number Diff line number Diff line change
Expand Up @@ -78,6 +78,8 @@ public function testGetDirectoryContent() {
new FileInfo('/bar/foo/asd', null, 'foo/asd', ['fileid' => 2, 'path' => '/bar/foo/asd', 'name' => 'asd', 'size' => 100, 'mtime' => 50, 'mimetype' => 'text/plain'], null),
new FileInfo('/bar/foo/qwerty', null, 'foo/qwerty', ['fileid' => 3, 'path' => '/bar/foo/qwerty', 'name' => 'qwerty', 'size' => 200, 'mtime' => 55, 'mimetype' => 'httpd/unix-directory'], null),
]);
$view->method('getFileInfo')
->willReturn($this->createMock(FileInfo::class));

$node = new Folder($root, $view, '/bar/foo');
$children = $node->getDirectoryListing();
Expand Down

0 comments on commit 151c800

Please sign in to comment.