aboutsummaryrefslogtreecommitdiffstats
path: root/lib
diff options
context:
space:
mode:
authorRobin Appelman <robin@icewind.nl>2024-04-24 14:50:13 +0200
committerRobin Appelman <robin@icewind.nl>2024-05-17 17:45:44 +0200
commit66d36bffa61f6c173e48680e6e000bbd16ff1614 (patch)
tree519b210cf38daea76ef81298d2c0c7dace23b7bb /lib
parent54afea4b01385106a241a5161b3894e669716107 (diff)
downloadnextcloud-server-66d36bffa61f6c173e48680e6e000bbd16ff1614.tar.gz
nextcloud-server-66d36bffa61f6c173e48680e6e000bbd16ff1614.zip
fix: forbid moving a folder into a subfolder of itself
Signed-off-by: Robin Appelman <robin@icewind.nl>
Diffstat (limited to 'lib')
-rw-r--r--lib/private/Files/View.php6
1 files changed, 6 insertions, 0 deletions
diff --git a/lib/private/Files/View.php b/lib/private/Files/View.php
index a6e57d775ed..b8a08052cc9 100644
--- a/lib/private/Files/View.php
+++ b/lib/private/Files/View.php
@@ -59,6 +59,7 @@ use OCP\Files\Cache\ICacheEntry;
use OCP\Files\ConnectionLostException;
use OCP\Files\EmptyFileNameException;
use OCP\Files\FileNameTooLongException;
+use OCP\Files\ForbiddenException;
use OCP\Files\InvalidCharacterInPathException;
use OCP\Files\InvalidDirectoryException;
use OCP\Files\InvalidPathException;
@@ -733,6 +734,11 @@ class View {
public function rename($source, $target) {
$absolutePath1 = Filesystem::normalizePath($this->getAbsolutePath($source));
$absolutePath2 = Filesystem::normalizePath($this->getAbsolutePath($target));
+
+ if (str_starts_with($absolutePath2, $absolutePath1 . '/')) {
+ throw new ForbiddenException("Moving a folder into a child folder is forbidden", false);
+ }
+
$targetParts = explode('/', $absolutePath2);
$targetUser = $targetParts[1] ?? null;
$result = false;