* * @author Arthur Schiwon * @author Bjoern Schiessle * @author Christoph Wurst * @author Julius Härtl * @author Lukas Reschke * @author Roeland Jago Douma * * @license GNU AGPL version 3 or any later version * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Affero General Public License as * published by the Free Software Foundation, either version 3 of the * License, or (at your option) any later version. * * This program 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 program. If not, see . * */ namespace OCA\Theming\Settings; use OCA\Theming\AppInfo\Application; use OCA\Theming\Controller\ThemingController; use OCA\Theming\ImageManager; use OCA\Theming\ThemingDefaults; use OCP\AppFramework\Http\TemplateResponse; use OCP\AppFramework\Services\IInitialState; use OCP\IConfig; use OCP\IL10N; use OCP\IURLGenerator; use OCP\Settings\IDelegatedSettings; use OCP\Util; class Admin implements IDelegatedSettings { public function __construct( private string $appName, private IConfig $config, private IL10N $l, private ThemingDefaults $themingDefaults, private IInitialState $initialState, private IURLGenerator $urlGenerator, private ImageManager $imageManager, ) { } /** * @return TemplateResponse */ public function getForm(): TemplateResponse { $themable = true; $errorMessage = ''; $theme = $this->config->getSystemValue('theme', ''); if ($theme !== '') { $themable = false; $errorMessage = $this->l->t('You are already using a custom theme. Theming app settings might be overwritten by that.'); } $allowedMimeTypes = array_reduce(ThemingController::VALID_UPLOAD_KEYS, function ($carry, $key) { $carry[$key] = $this->imageManager->getSupportedUploadImageFormats($key); return $carry; }, []); $this->initialState->provideInitialState('adminThemingParameters', [ 'isThemable' => $themable, 'notThemableErrorMessage' => $errorMessage, 'name' => $this->themingDefaults->getEntity(), 'url' => $this->themingDefaults->getBaseUrl(), 'slogan' => $this->themingDefaults->getSlogan(), 'color' => $this->themingDefaults->getDefaultColorPrimary(), 'logoMime' => $this->config->getAppValue(Application::APP_ID, 'logoMime', ''), 'allowedMimeTypes' => $allowedMimeTypes, 'backgroundMime' => $this->config->getAppValue(Application::APP_ID, 'backgroundMime', ''), 'logoheaderMime' => $this->config->getAppValue(Application::APP_ID, 'logoheaderMime', ''), 'faviconMime' => $this->config->getAppValue(Application::APP_ID, 'faviconMime', ''), 'legalNoticeUrl' => $this->themingDefaults->getImprintUrl(), 'privacyPolicyUrl' => $this->themingDefaults->getPrivacyUrl(), 'docUrl' => $this->urlGenerator->linkToDocs('admin-theming'), 'docUrlIcons' => $this->urlGenerator->linkToDocs('admin-theming-icons'), 'canThemeIcons' => $this->imageManager->shouldReplaceIcons(), 'userThemingDisabled' => $this->themingDefaults->isUserThemingDisabled(), 'defaultApps' => array_filter(explode(',', $this->config->getSystemValueString('defaultapp', ''))), ]); Util::addScript($this->appName, 'admin-theming'); return new TemplateResponse($this->appName, 'settings-admin'); } /** * @return string the section ID, e.g. 'sharing' */ public function getSection(): string { return $this->appName; } /** * @return int whether the form should be rather on the top or bottom of * the admin section. The forms are arranged in ascending order of the * priority values. It is required to return a value between 0 and 100. * * E.g.: 70 */ public function getPriority(): int { return 5; } public function getName(): ?string { return null; // Only one setting in this section } public function getAuthorizedAppConfig(): array { return [ $this->appName => '/.*/', ]; } }