Skip to content

Commit

Permalink
fix: don't skip scanner users filesystem if they have a mountpoint at…
Browse files Browse the repository at this point in the history
… /<user>/files/

Signed-off-by: Robin Appelman <robin@icewind.nl>
  • Loading branch information
icewind1991 committed Dec 16, 2024
1 parent 53c9cda commit c0112fd
Showing 1 changed file with 6 additions and 2 deletions.
8 changes: 6 additions & 2 deletions lib/private/Files/Utils/Scanner.php
Original file line number Diff line number Diff line change
Expand Up @@ -85,7 +85,7 @@ public function __construct($user, $db, IEventDispatcher $dispatcher, LoggerInte
* get all storages for $dir
*
* @param string $dir
* @return \OC\Files\Mount\MountPoint[]
* @return array{string, \OC\Files\Mount\MountPoint}
*/
protected function getMounts($dir) {
//TODO: move to the node based fileapi once that's done
Expand All @@ -96,8 +96,9 @@ protected function getMounts($dir) {
$mounts = $mountManager->findIn($dir);
$mounts[] = $mountManager->find($dir);
$mounts = array_reverse($mounts); //start with the mount of $dir
$mountPoints = array_map(fn ($mount) => $mount->getMountPoint(), $mounts);

return $mounts;
return array_combine($mountPoints, $mounts);
}

/**
Expand Down Expand Up @@ -210,6 +211,9 @@ public function scan($dir = '', $recursive = \OC\Files\Cache\Scanner::SCAN_RECUR
$owner = $owner['name'] ?? $ownerUid;
$permissions = decoct(fileperms($fullPath));
throw new ForbiddenException("User folder $fullPath is not writable, folders is owned by $owner and has mode $permissions");
} elseif (isset($mounts[$mount->getMountPoint() . $path . '/'])) {

Check failure on line 214 in lib/private/Files/Utils/Scanner.php

View workflow job for this annotation

GitHub Actions / static-code-analysis

InvalidArrayOffset

lib/private/Files/Utils/Scanner.php:214:23: InvalidArrayOffset: Cannot access value on variable $mounts using a non-falsy-string offset, expecting int<0, 1> (see https://psalm.dev/115)
// /<user>/files is overwritten by a mountpoint, so this check is irrelevant
break;
} else {
// if the root exists in neither the cache nor the storage the user isn't setup yet
break 2;
Expand Down

0 comments on commit c0112fd

Please sign in to comment.