fix return value of getStorageInfo when 'quota_include_external_storage' is enabled

Signed-off-by: Robin Appelman <robin@icewind.nl>
This commit is contained in:
Robin Appelman 2021-05-20 13:55:49 +02:00 committed by backportbot[bot]
parent c87c3710f2
commit 4a5364a9b2
1 changed files with 15 additions and 6 deletions

View File

@ -44,6 +44,8 @@
*/ */
use bantu\IniGetWrapper\IniGetWrapper; use bantu\IniGetWrapper\IniGetWrapper;
use OCP\Files\Mount\IMountPoint;
use OCP\IUser;
use Symfony\Component\Process\ExecutableFinder; use Symfony\Component\Process\ExecutableFinder;
/** /**
@ -517,7 +519,7 @@ class OC_Helper {
$quota = OC_Util::getUserQuota($user); $quota = OC_Util::getUserQuota($user);
if ($quota !== \OCP\Files\FileInfo::SPACE_UNLIMITED) { if ($quota !== \OCP\Files\FileInfo::SPACE_UNLIMITED) {
// always get free space / total space from root + mount points // always get free space / total space from root + mount points
return self::getGlobalStorageInfo($quota); return self::getGlobalStorageInfo($quota, $user, $mount);
} }
} }
@ -569,11 +571,8 @@ class OC_Helper {
/** /**
* Get storage info including all mount points and quota * Get storage info including all mount points and quota
*
* @param int $quota
* @return array
*/ */
private static function getGlobalStorageInfo($quota) { private static function getGlobalStorageInfo(int $quota, IUser $user, IMountPoint $mount): array {
$rootInfo = \OC\Files\Filesystem::getFileInfo('', 'ext'); $rootInfo = \OC\Files\Filesystem::getFileInfo('', 'ext');
$used = $rootInfo['size']; $used = $rootInfo['size'];
if ($used < 0) { if ($used < 0) {
@ -593,12 +592,22 @@ class OC_Helper {
$relative = 0; $relative = 0;
} }
if (substr_count($mount->getMountPoint(), '/') < 3) {
$mountPoint = '';
} else {
[,,,$mountPoint] = explode('/', $mount->getMountPoint(), 4);
}
return [ return [
'free' => $free, 'free' => $free,
'used' => $used, 'used' => $used,
'total' => $total, 'total' => $total,
'relative' => $relative, 'relative' => $relative,
'quota' => $quota 'quota' => $quota,
'owner' => $user->getUID(),
'ownerDisplayName' => $user->getDisplayName(),
'mountType' => $mount->getMountType(),
'mountPoint' => trim($mountPoint, '/'),
]; ];
} }