123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167 |
- <?php
- /**
- * SPDX-FileCopyrightText: 2023 Nextcloud GmbH and Nextcloud contributors
- * SPDX-License-Identifier: AGPL-3.0-or-later
- */
- namespace OCA\Files\Service;
- use OCA\Files\AppInfo\Application;
- use OCP\IConfig;
- use OCP\IUser;
- use OCP\IUserSession;
- class ViewConfig {
- public const CONFIG_KEY = 'files_views_configs';
- public const ALLOWED_CONFIGS = [
- [
- // The default sorting key for the files list view
- 'key' => 'sorting_mode',
- // null by default as views can provide default sorting key
- // and will fallback to it if user hasn't change it
- 'default' => null,
- ],
- [
- // The default sorting direction for the files list view
- 'key' => 'sorting_direction',
- 'default' => 'asc',
- 'allowed' => ['asc', 'desc'],
- ],
- [
- // If the navigation entry for this view is expanded or not
- 'key' => 'expanded',
- 'default' => true,
- 'allowed' => [true, false],
- ],
- ];
- protected ?IUser $user = null;
- public function __construct(
- protected IConfig $config,
- IUserSession $userSession,
- ) {
- $this->user = $userSession->getUser();
- }
- /**
- * Get the list of all allowed user config keys
- * @return string[]
- */
- public function getAllowedConfigKeys(): array {
- return array_map(function ($config) {
- return $config['key'];
- }, self::ALLOWED_CONFIGS);
- }
- /**
- * Get the list of allowed config values for a given key
- *
- * @param string $key a valid config key
- * @return array
- */
- private function getAllowedConfigValues(string $key): array {
- foreach (self::ALLOWED_CONFIGS as $config) {
- if ($config['key'] === $key) {
- return $config['allowed'] ?? [];
- }
- }
- return [];
- }
- /**
- * Get the default config value for a given key
- *
- * @param string $key a valid config key
- * @return string|bool|null
- */
- private function getDefaultConfigValue(string $key) {
- foreach (self::ALLOWED_CONFIGS as $config) {
- if ($config['key'] === $key) {
- return $config['default'];
- }
- }
- return '';
- }
- /**
- * Set a user config
- *
- * @param string $view
- * @param string $key
- * @param string|bool $value
- * @throws \Exception
- * @throws \InvalidArgumentException
- */
- public function setConfig(string $view, string $key, $value): void {
- if ($this->user === null) {
- throw new \Exception('No user logged in');
- }
- if (!$view) {
- throw new \Exception('Unknown view');
- }
- if (!in_array($key, $this->getAllowedConfigKeys())) {
- throw new \InvalidArgumentException('Unknown config key');
- }
-
- if (!in_array($value, $this->getAllowedConfigValues($key))
- && !empty($this->getAllowedConfigValues($key))) {
- throw new \InvalidArgumentException('Invalid config value');
- }
- // Cast boolean values
- if (is_bool($this->getDefaultConfigValue($key))) {
- $value = $value === '1';
- }
- $config = $this->getConfigs();
- $config[$view][$key] = $value;
- $this->config->setUserValue($this->user->getUID(), Application::APP_ID, self::CONFIG_KEY, json_encode($config));
- }
- /**
- * Get the current user configs array for a given view
- *
- * @return array
- */
- public function getConfig(string $view): array {
- if ($this->user === null) {
- throw new \Exception('No user logged in');
- }
- $userId = $this->user->getUID();
- $configs = json_decode($this->config->getUserValue($userId, Application::APP_ID, self::CONFIG_KEY, '[]'), true);
-
- if (!isset($configs[$view])) {
- $configs[$view] = [];
- }
- // Extend undefined values with defaults
- return array_reduce(self::ALLOWED_CONFIGS, function ($carry, $config) use ($view, $configs) {
- $key = $config['key'];
- $carry[$key] = $configs[$view][$key] ?? $this->getDefaultConfigValue($key);
- return $carry;
- }, []);
- }
- /**
- * Get the current user configs array
- *
- * @return array
- */
- public function getConfigs(): array {
- if ($this->user === null) {
- throw new \Exception('No user logged in');
- }
- $userId = $this->user->getUID();
- $configs = json_decode($this->config->getUserValue($userId, Application::APP_ID, self::CONFIG_KEY, '[]'), true);
- $views = array_keys($configs);
-
- return array_reduce($views, function ($carry, $view) use ($configs) {
- $carry[$view] = $this->getConfig($view);
- return $carry;
- }, []);
- }
- }
|