diff options
author | Julius Härtl <jus@bitgrid.net> | 2023-09-06 20:09:50 +0200 |
---|---|---|
committer | Julius Härtl <jus@bitgrid.net> | 2023-09-13 10:28:28 +0200 |
commit | 7f958e81d3ead0c2c04303896e29ccc6bfbba3da (patch) | |
tree | b372ae3143eb4e26d02960c1eb05e9e04bb59bed /lib/private/Files/Node/Node.php | |
parent | c6e6ebb9992882ad2a2bcd49252bffe2248103c4 (diff) | |
download | nextcloud-server-7f958e81d3ead0c2c04303896e29ccc6bfbba3da.tar.gz nextcloud-server-7f958e81d3ead0c2c04303896e29ccc6bfbba3da.zip |
fix: Pass parent to NonExistingFile instances
Signed-off-by: Julius Härtl <jus@bitgrid.net>
Diffstat (limited to 'lib/private/Files/Node/Node.php')
-rw-r--r-- | lib/private/Files/Node/Node.php | 11 |
1 files changed, 10 insertions, 1 deletions
diff --git a/lib/private/Files/Node/Node.php b/lib/private/Files/Node/Node.php index 4b916bd9c1b..9729f79aae3 100644 --- a/lib/private/Files/Node/Node.php +++ b/lib/private/Files/Node/Node.php @@ -297,10 +297,19 @@ class Node implements INode { return $this->root; } + // Manually fetch the parent if the current node doesn't have a file info yet + try { + $fileInfo = $this->getFileInfo(); + } catch (NotFoundException) { + $this->parent = $this->root->get($newPath); + /** @var \OCP\Files\Folder $this->parent */ + return $this->parent; + } + // gather the metadata we already know about our parent $parentData = [ 'path' => $newPath, - 'fileid' => $this->getFileInfo()->getParentId(), + 'fileid' => $fileInfo->getParentId(), ]; // and create lazy folder with it instead of always querying |