diff options
Diffstat (limited to 'apps/dashboard/lib')
-rw-r--r-- | apps/dashboard/lib/Controller/DashboardController.php | 7 | ||||
-rw-r--r-- | apps/dashboard/lib/Service/BackgroundService.php | 35 |
2 files changed, 29 insertions, 13 deletions
diff --git a/apps/dashboard/lib/Controller/DashboardController.php b/apps/dashboard/lib/Controller/DashboardController.php index 95656b260e8..5d9f886f0c1 100644 --- a/apps/dashboard/lib/Controller/DashboardController.php +++ b/apps/dashboard/lib/Controller/DashboardController.php @@ -39,7 +39,6 @@ use OCP\Dashboard\IManager; use OCP\Dashboard\IWidget; use OCP\Dashboard\RegisterWidgetEvent; use OCP\EventDispatcher\IEventDispatcher; -use OCP\Files\NotFoundException; use OCP\IConfig; use OCP\IInitialStateService; use OCP\IRequest; @@ -128,8 +127,8 @@ class DashboardController extends Controller { /** * @NoAdminRequired */ - public function setBackground(string $type = 'default', $value): JSONResponse { - $currentVersion = $this->config->getUserValue($this->userId, 'dashboard', 'backgroundVersion', 0); + public function setBackground(string $type, string $value): JSONResponse { + $currentVersion = (int)$this->config->getUserValue($this->userId, 'dashboard', 'backgroundVersion', 0); try { switch ($type) { case 'shipped': @@ -149,6 +148,8 @@ class DashboardController extends Controller { } } catch (\InvalidArgumentException $e) { return new JSONResponse(['error' => $e->getMessage()], Http::STATUS_BAD_REQUEST); + } catch (\Throwable $e) { + return new JSONResponse(['error' => $e->getMessage()], Http::STATUS_INTERNAL_SERVER_ERROR); } $currentVersion++; $this->config->setUserValue($this->userId, 'dashboard', 'backgroundVersion', $currentVersion); diff --git a/apps/dashboard/lib/Service/BackgroundService.php b/apps/dashboard/lib/Service/BackgroundService.php index da0de6117e6..ab5f58b6cb7 100644 --- a/apps/dashboard/lib/Service/BackgroundService.php +++ b/apps/dashboard/lib/Service/BackgroundService.php @@ -26,8 +26,6 @@ declare(strict_types=1); namespace OCA\Dashboard\Service; - -use OCP\Files\File; use OCP\Files\IAppData; use OCP\Files\IRootFolder; use OCP\Files\NotFoundException; @@ -35,7 +33,6 @@ use OCP\Files\SimpleFS\ISimpleFile; use OCP\IConfig; class BackgroundService { - public const THEMING_MODE_DARK = 'dark'; public const SHIPPED_BACKGROUNDS = [ @@ -81,6 +78,19 @@ class BackgroundService { 'attribution_url' => '', ] ]; + /** + * @var \OCP\Files\Folder + */ + private $userFolder; + /** + * @var \OCP\Files\SimpleFS\ISimpleFolder + */ + private $dashboardUserFolder; + /** + * @var IConfig + */ + private $config; + private $userId; public function __construct(IRootFolder $rootFolder, IAppData $appData, IConfig $config, $userId) { if ($userId === null) { @@ -96,31 +106,37 @@ class BackgroundService { $this->userId = $userId; } - public function setDefaultBackground() { + public function setDefaultBackground(): void { $this->config->deleteUserValue($this->userId, 'dashboard', 'background'); } - public function setFileBackground($path) { + /** + * @param $path + * @throws NotFoundException + * @throws \OCP\Files\NotPermittedException + * @throws \OCP\PreConditionNotMetException + */ + public function setFileBackground($path): void { $this->config->setUserValue($this->userId, 'dashboard', 'background', 'custom'); $file = $this->userFolder->get($path); - $newFile = $this->dashboardUserFolder->newFile('background.jpg', $file->fopen('r')); + $this->dashboardUserFolder->newFile('background.jpg', $file->fopen('r')); } - public function setShippedBackground($fileName) { + public function setShippedBackground($fileName): void { if (!array_key_exists($fileName, self::SHIPPED_BACKGROUNDS)) { throw new \InvalidArgumentException('The given file name is invalid'); } $this->config->setUserValue($this->userId, 'dashboard', 'background', $fileName); } - public function setColorBackground(string $color) { + public function setColorBackground(string $color): void { if (!preg_match('/^\#([0-9a-f]{3}|[0-9a-f]{6})$/i', $color)) { throw new \InvalidArgumentException('The given color is invalid'); } $this->config->setUserValue($this->userId, 'dashboard', 'background', $color); } - public function getBackground() { + public function getBackground(): ?ISimpleFile { $background = $this->config->getUserValue($this->userId, 'dashboard', 'background', 'default'); if ($background === 'custom') { try { @@ -130,5 +146,4 @@ class BackgroundService { } return null; } - } |