aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJohn Molakvoæ (skjnldsv) <skjnldsv@protonmail.com>2023-09-19 21:00:21 +0200
committerJohn Molakvoæ <skjnldsv@protonmail.com>2023-10-04 11:29:05 +0200
commitb05719c8e900268a50412756c38ee19a87e67093 (patch)
tree662588950fbf9621e5e25a31e0996144219ee43c
parent529bce24b44f7c10673e619fe062baeea5b5c3d5 (diff)
downloadnextcloud-server-b05719c8e900268a50412756c38ee19a87e67093.tar.gz
nextcloud-server-b05719c8e900268a50412756c38ee19a87e67093.zip
fix: redirect to proper directory if file not found
Signed-off-by: John Molakvoæ (skjnldsv) <skjnldsv@protonmail.com>
-rw-r--r--apps/files/lib/Controller/ViewController.php15
1 files changed, 14 insertions, 1 deletions
diff --git a/apps/files/lib/Controller/ViewController.php b/apps/files/lib/Controller/ViewController.php
index d4a75b514eb..88d9a32039b 100644
--- a/apps/files/lib/Controller/ViewController.php
+++ b/apps/files/lib/Controller/ViewController.php
@@ -231,6 +231,19 @@ class ViewController extends Controller {
$favElements['folders'] = [];
}
+ // If the file doesn't exists in the folder and
+ // exists in only one occurrence, redirect to that file
+ // in the correct folder
+ if ($fileid && $dir !== '') {
+ $baseFolder = $this->rootFolder->getUserFolder($userId);
+ $nodes = $baseFolder->getById((int) $fileid);
+ $relativePath = dirname($baseFolder->getRelativePath($nodes[0]->getPath()));
+ // If the requested path is different from the file path
+ if (count($nodes) === 1 && $relativePath !== $dir) {
+ return $this->redirectToFile((int) $fileid);
+ }
+ }
+
try {
// If view is files, we use the directory, otherwise we use the root storage
$storageInfo = $this->getStorageInfo(($view === 'files' && $dir) ? $dir : '/');
@@ -380,7 +393,7 @@ class ViewController extends Controller {
$uid = $this->userSession->getUser()->getUID();
$baseFolder = $this->rootFolder->getUserFolder($uid);
$nodes = $baseFolder->getById($fileId);
- $params = [];
+ $params = ['view' => 'files'];
try {
$this->redirectToFileIfInTrashbin($fileId);