* * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU AFFERO GENERAL PUBLIC LICENSE * License as published by the Free Software Foundation; either * version 3 of the License, or any later version. * * This library is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU AFFERO GENERAL PUBLIC LICENSE for more details. * * You should have received a copy of the GNU Affero General Public * License along with this library. If not, see . * */ namespace OCA\Privacy\Settings; use OC; use OCA\Theming\ThemingDefaults; use OCP\AppFramework\Http\TemplateResponse; use OCP\IConfig; use OCP\Encryption\IManager as IEncryptionManager; use OCP\IInitialStateService; use OCP\Settings\ISettings; /** * Class WhoHasAccessSettings * * @package OCA\Privacy\Settings */ class WhoHasAccessSettings implements ISettings { /** @var IConfig */ private $config; /** @var IEncryptionManager */ private $encryptionManager; /** @var IInitialStateService */ private $initialStateService; /** * WhoHasAccessSettings constructor. * * @param IConfig $config * @param IEncryptionManager $manager * @param IInitialStateService $initialStateService */ public function __construct(IConfig $config, IEncryptionManager $manager, IInitialStateService $initialStateService) { $this->config = $config; $this->encryptionManager = $manager; $this->initialStateService = $initialStateService; } /** * @return TemplateResponse */ public function getForm():TemplateResponse { $themingDefaults = OC::$server->getThemingDefaults(); if ($themingDefaults instanceof ThemingDefaults) { $privacyPolicyUrl = $themingDefaults->getPrivacyUrl(); } else { $privacyPolicyUrl = null; } $this->initialStateService->provideInitialState('privacy', 'privacyPolicyUrl', $privacyPolicyUrl); $this->initialStateService->provideInitialState('privacy', 'fullDiskEncryptionEnabled', $this->config->getAppValue('privacy', 'fullDiskEncryptionEnabled', '0') === '1'); $this->initialStateService->provideInitialState('privacy', 'serverSideEncryptionEnabled', $this->encryptionManager->isEnabled()); return new TemplateResponse('privacy', 'who-has-access'); } /** * @return string */ public function getSection():string { return 'privacy'; } /** * @return int */ public function getPriority():int { return 10; } }