Skip to content

Commit

Permalink
feat(quota): provide storage info to PageController
Browse files Browse the repository at this point in the history
Signed-off-by: Franziska Bath <[email protected]>
  • Loading branch information
fracado committed Sep 9, 2024
1 parent 49ec2fd commit 4e84489
Show file tree
Hide file tree
Showing 2 changed files with 75 additions and 1 deletion.
17 changes: 17 additions & 0 deletions lib/Controller/PageController.php
Original file line number Diff line number Diff line change
Expand Up @@ -34,7 +34,9 @@
use OCP\AppFramework\Http\TemplateResponse;
use OCP\AppFramework\Services\IInitialState;
use OCP\Authentication\Exceptions\InvalidTokenException;
use OCP\Files\FileInfo;
use OCP\IConfig;
use OCP\IL10N;
use OCP\ISession;
use OCP\IUser;
use OCP\IUserManager;
Expand All @@ -49,6 +51,7 @@ class PageController extends Controller {
private IConfig $config;
private IUserManager $userManager;
private IFactory $l10nFactory;
private $l;
private IProvider $tokenProvider;
private IInitialState $initialState;
private IUserSession $userSession;
Expand All @@ -59,6 +62,7 @@ public function __construct(
IConfig $config,
IUserManager $userManager,
IFactory $l10nFactory,
IL10N $l,
IProvider $tokenProvider,
ISession $session,
IInitialState $initialState,
Expand All @@ -68,6 +72,7 @@ public function __construct(
$this->config = $config;
$this->userManager = $userManager;
$this->l10nFactory = $l10nFactory;
$this->l = $l;
$this->tokenProvider = $tokenProvider;
$this->session = $session;
$this->initialState = $initialState;
Expand All @@ -92,10 +97,22 @@ public function index(): TemplateResponse {

$user = $this->userManager->get($this->uid);

$storageInfo = \OC_Helper::getStorageInfo('/');
if ($storageInfo['quota'] !== FileInfo::SPACE_UNLIMITED) {
$totalSpace = $this->l->t('Unlimited');
} else {
$totalSpace = \OC_Helper::humanFileSize($storageInfo['total']);
}

$this->initialState->provideInitialState(
'personalInfoParameters',
[
'languageMap' => $this->getLanguageMap($user),
'quota' => $storageInfo['quota'],
'totalSpace' => $totalSpace,
'freeSpace' => \OC_Helper::humanFileSize($storageInfo['free']),
'usage' => \OC_Helper::humanFileSize($storageInfo['used']),
'usageRelative' => round($storageInfo['relative']),
]
);

Expand Down
59 changes: 58 additions & 1 deletion tests/Controller/PageControllerTest.php
Original file line number Diff line number Diff line change
Expand Up @@ -26,7 +26,9 @@
use OC\Authentication\Token\IProvider as IAuthTokenProvider;
use OC\Authentication\Token\IToken;
use OCP\AppFramework\Services\IInitialState;
use OCP\Files\FileInfo;
use OCP\IConfig;
use OCP\IL10N;
use OCP\ISession;
use OCP\IUser;
use OCP\IUserManager;
Expand All @@ -45,6 +47,7 @@ protected function setUp(): void {
$this->config = $this->createMock(IConfig::class);
$this->userManager = $this->createMock(IUserManager::class);
$this->l10nFactory = $this->createMock(IFactory::class);
$this->l = $this->createMock(IL10N::class);
$this->tokenProvider = $this->createMock(IAuthTokenProvider::class);
$this->session = $this->createMock(ISession::class);
$this->initialState = $this->createMock(IInitialState::class);
Expand All @@ -55,6 +58,7 @@ protected function setUp(): void {
$this->config,
$this->userManager,
$this->l10nFactory,
$this->l,
$this->tokenProvider,
$this->session,
$this->initialState,
Expand Down Expand Up @@ -205,7 +209,6 @@ private function createMockAppToken(int $id, array $serializedJson = []): IToken

return $token;
}

/**
* @throws Exception
*/
Expand Down Expand Up @@ -360,4 +363,58 @@ public function testIndexProvidesInitialStateWithCustomClientURLs() {

$this->controller->index();
}

public function testIndexProvidesInitialStateWithUnlimitedTotalSpace() {
$expectedStorageInfo = [
'quota' => FileInfo::SPACE_UNLIMITED,
'total' => 1000000000,
'free' => 500000000,
'used' => 500000000,
'relative' => 50,
];

$this->initialState->expects($this->exactly(4))
->method('provideInitialState')
->withConsecutive(
['app_tokens', $this->anything()],
['can_create_app_token', true],
['personalInfoParameters', [
'quota' => $expectedStorageInfo['quota'],
'totalSpace' => 'Unlimited',
'freeSpace' => \OC_Helper::humanFileSize($expectedStorageInfo['free']),
'usage' => \OC_Helper::humanFileSize($expectedStorageInfo['used']),
'usageRelative' => round($expectedStorageInfo['relative']),
]],
['customClientURL', $this->anything()]
);

$this->controller->index();
}

public function testIndexProvidesInitialStateWithLimitedTotalSpace() {
$expectedStorageInfo = [
'quota' => 1000000000,
'total' => 1000000000,
'free' => 500000000,
'used' => 500000000,
'relative' => 50,
];

$this->initialState->expects($this->exactly(4))
->method('provideInitialState')
->withConsecutive(
['app_tokens', $this->anything()],
['can_create_app_token', true],
['personalInfoParameters', [
'quota' => $expectedStorageInfo['quota'],
'totalSpace' => \OC_Helper::humanFileSize($expectedStorageInfo['total']),
'freeSpace' => \OC_Helper::humanFileSize($expectedStorageInfo['free']),
'usage' => \OC_Helper::humanFileSize($expectedStorageInfo['used']),
'usageRelative' => round($expectedStorageInfo['relative']),
]],
['customClientURL', $this->anything()]
);

$this->controller->index();
}
}

0 comments on commit 4e84489

Please sign in to comment.