diff options
| author | Jan-Hendrik Willms <tleilax+studip@gmail.com> | 2024-06-17 08:21:04 +0000 |
|---|---|---|
| committer | David Siegfried <david.siegfried@uni-vechta.de> | 2024-06-17 08:21:04 +0000 |
| commit | f2dd56afd93cae70a7462cfc6336b89dfeee7fb5 (patch) | |
| tree | c7697b9438bf039c704d2cd41aa1a18438e6389b /lib/classes | |
| parent | 0850b4ce0be34ac6cae3077293e04059ba8324aa (diff) | |
fixes #4277
Closes #4277
Merge request studip/studip!3116
Diffstat (limited to 'lib/classes')
| -rw-r--r-- | lib/classes/JsonApi/Routes/Files/SubfoldersIndex.php | 23 |
1 files changed, 17 insertions, 6 deletions
diff --git a/lib/classes/JsonApi/Routes/Files/SubfoldersIndex.php b/lib/classes/JsonApi/Routes/Files/SubfoldersIndex.php index e8f4d13..f0ad18c 100644 --- a/lib/classes/JsonApi/Routes/Files/SubfoldersIndex.php +++ b/lib/classes/JsonApi/Routes/Files/SubfoldersIndex.php @@ -19,20 +19,31 @@ class SubfoldersIndex extends JsonApiController */ public function __invoke(Request $request, Response $response, $args) { - if (!$folder = \FileManager::getTypedFolder($args['id'])) { + $folder = \FileManager::getTypedFolder($args['id']); + if (!$folder) { throw new RecordNotFoundException(); } - if (!Authority::canShowFolder($this->getUser($request), $folder)) { + $user = $this->getUser($request); + + if (!Authority::canShowFolder($user, $folder)) { throw new AuthorizationFailedException(); } - $subfolders = array_map( - function ($subfolder) { - return $subfolder->getTypedFolder(); + $subfolders = array_reduce( + $folder->subfolders->getArrayCopy(), + function ($result, $subfolder) use ($user) { + $folder = $subfolder->getTypedFolder(); + + if (Authority::canShowFolder($user, $folder)) { + $result[] = $folder; + } + + return $result; }, - $folder->subfolders->getArrayCopy() + [] ); + list($offset, $limit) = $this->getOffsetAndLimit(); return $this->getPaginatedContentResponse( |
