* * @author Alexey Pyltsyn * @author Janis Köhr * @author John Molakvoæ (skjnldsv) * @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\Accessibility\AppInfo; use OCP\AppFramework\App; use OCP\AppFramework\Bootstrap\IBootContext; use OCP\AppFramework\Bootstrap\IBootstrap; use OCP\AppFramework\Bootstrap\IRegistrationContext; use OCP\IConfig; use OCP\IServerContainer; use OCP\IURLGenerator; use OCP\IUserSession; use function count; use function implode; use function md5; class Application extends App implements IBootstrap { /** @var string */ public const APP_ID = 'accessibility'; /** @var IConfig */ private $config; /** @var IUserSession */ private $userSession; /** @var IURLGenerator */ private $urlGenerator; public function __construct() { parent::__construct(self::APP_ID); } public function register(IRegistrationContext $context): void { } public function boot(IBootContext $context): void { $this->injectCss( $context->getAppContainer()->query(IUserSession::class), $context->getAppContainer()->query(IConfig::class), $context->getAppContainer()->query(IURLGenerator::class) ); $this->injectJavascript( $context->getAppContainer()->query(IURLGenerator::class), $context->getAppContainer()->query(IConfig::class), $context->getServerContainer() ); } private function injectCss(IUserSession $userSession, IConfig $config, IURLGenerator $urlGenerator) { // Inject the fake css on all pages if enabled and user is logged $loggedUser = $userSession->getUser(); if ($loggedUser !== null) { $userValues = $config->getUserKeys($loggedUser->getUID(), self::APP_ID); // we want to check if any theme or font is enabled. if (count($userValues) > 0) { $hash = $config->getUserValue($loggedUser->getUID(), self::APP_ID, 'icons-css', md5(implode('-', $userValues))); $linkToCSS = $urlGenerator->linkToRoute(self::APP_ID . '.accessibility.getCss', ['md5' => $hash]); \OCP\Util::addHeader('link', ['rel' => 'stylesheet', 'href' => $linkToCSS]); } } } private function injectJavascript(IURLGenerator $urlGenerator, IConfig $config, IServerContainer $serverContainer) { $linkToJs = $urlGenerator->linkToRoute( self::APP_ID . '.accessibility.getJavascript', [ 'v' => $config->getAppValue(self::APP_ID, 'cachebuster', '0'), ] ); \OCP\Util::addHeader( 'script', [ 'src' => $linkToJs, 'nonce' => $serverContainer->getContentSecurityPolicyNonceManager()->getNonce() ], '' ); } }