* @author Clark Tomlinson * @author Lukas Reschke * @author Morris Jobke * @author Thomas Müller * * @copyright Copyright (c) 2015, ownCloud, Inc. * @license AGPL-3.0 * * This code is free software: you can redistribute it and/or modify * it under the terms of the GNU Affero General Public License, version 3, * as published by the Free Software Foundation. * * 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, version 3, * along with this program. If not, see * */ namespace OCA\Encryption\AppInfo; use OC\Files\View; use OCA\Encryption\Controller\RecoveryController; use OCA\Encryption\Controller\SettingsController; use OCA\Encryption\Controller\StatusController; use OCA\Encryption\Crypto\Crypt; use OCA\Encryption\Crypto\EncryptAll; use OCA\Encryption\Crypto\Encryption; use OCA\Encryption\HookManager; use OCA\Encryption\Hooks\UserHooks; use OCA\Encryption\KeyManager; use OCA\Encryption\Recovery; use OCA\Encryption\Session; use OCA\Encryption\Users\Setup; use OCA\Encryption\Util; use OCP\App; use OCP\AppFramework\IAppContainer; use OCP\Encryption\IManager; use OCP\IConfig; use Symfony\Component\Console\Helper\QuestionHelper; class Application extends \OCP\AppFramework\App { /** @var IManager */ private $encryptionManager; /** @var IConfig */ private $config; /** * @param array $urlParams * @param bool $encryptionSystemReady */ public function __construct($urlParams = array(), $encryptionSystemReady = true) { parent::__construct('encryption', $urlParams); $this->encryptionManager = \OC::$server->getEncryptionManager(); $this->config = \OC::$server->getConfig(); $this->registerServices(); if($encryptionSystemReady === false) { /** @var Session $session */ $session = $this->getContainer()->query('Session'); $session->setStatus(Session::RUN_MIGRATION); } } /** * register hooks */ public function registerHooks() { if (!$this->config->getSystemValue('maintenance', false)) { $container = $this->getContainer(); $server = $container->getServer(); // Register our hooks and fire them. $hookManager = new HookManager(); $hookManager->registerHook([ new UserHooks($container->query('KeyManager'), $server->getUserManager(), $server->getLogger(), $container->query('UserSetup'), $server->getUserSession(), $container->query('Util'), $container->query('Session'), $container->query('Crypt'), $container->query('Recovery')) ]); $hookManager->fireHooks(); } else { // Logout user if we are in maintenance to force re-login $this->getContainer()->getServer()->getUserSession()->logout(); } } public function registerEncryptionModule() { $container = $this->getContainer(); $this->encryptionManager->registerEncryptionModule( Encryption::ID, Encryption::DISPLAY_NAME, function() use ($container) { return new Encryption( $container->query('Crypt'), $container->query('KeyManager'), $container->query('Util'), $container->query('EncryptAll'), $container->getServer()->getLogger(), $container->getServer()->getL10N($container->getAppName()) ); }); } public function registerServices() { $container = $this->getContainer(); $container->registerService('Crypt', function (IAppContainer $c) { $server = $c->getServer(); return new Crypt($server->getLogger(), $server->getUserSession(), $server->getConfig()); }); $container->registerService('Session', function (IAppContainer $c) { $server = $c->getServer(); return new Session($server->getSession()); } ); $container->registerService('KeyManager', function (IAppContainer $c) { $server = $c->getServer(); return new KeyManager($server->getEncryptionKeyStorage(), $c->query('Crypt'), $server->getConfig(), $server->getUserSession(), new Session($server->getSession()), $server->getLogger(), $c->query('Util') ); }); $container->registerService('Recovery', function (IAppContainer $c) { $server = $c->getServer(); return new Recovery( $server->getUserSession(), $c->query('Crypt'), $server->getSecureRandom(), $c->query('KeyManager'), $server->getConfig(), $server->getEncryptionKeyStorage(), $server->getEncryptionFilesHelper(), new View()); }); $container->registerService('RecoveryController', function (IAppContainer $c) { $server = $c->getServer(); return new RecoveryController( $c->getAppName(), $server->getRequest(), $server->getConfig(), $server->getL10N($c->getAppName()), $c->query('Recovery')); }); $container->registerService('StatusController', function (IAppContainer $c) { $server = $c->getServer(); return new StatusController( $c->getAppName(), $server->getRequest(), $server->getL10N($c->getAppName()), $c->query('Session') ); }); $container->registerService('SettingsController', function (IAppContainer $c) { $server = $c->getServer(); return new SettingsController( $c->getAppName(), $server->getRequest(), $server->getL10N($c->getAppName()), $server->getUserManager(), $server->getUserSession(), $c->query('KeyManager'), $c->query('Crypt'), $c->query('Session'), $server->getSession() ); }); $container->registerService('UserSetup', function (IAppContainer $c) { $server = $c->getServer(); return new Setup($server->getLogger(), $server->getUserSession(), $c->query('Crypt'), $c->query('KeyManager')); }); $container->registerService('Util', function (IAppContainer $c) { $server = $c->getServer(); return new Util( new View(), $c->query('Crypt'), $server->getLogger(), $server->getUserSession(), $server->getConfig(), $server->getUserManager()); }); $container->registerService('EncryptAll', function (IAppContainer $c) { $server = $c->getServer(); return new EncryptAll( $c->query('UserSetup'), $c->getServer()->getUserManager(), new View(), $c->query('KeyManager'), $server->getConfig(), $server->getMailer(), $server->getL10N('encryption'), new QuestionHelper(), $server->getSecureRandom() ); } ); } public function registerSettings() { // Register settings scripts App::registerAdmin('encryption', 'settings/settings-admin'); App::registerPersonal('encryption', 'settings/settings-personal'); } }