Use magic DI as much as possible

Signed-off-by: Joas Schilling <coding@schilljs.com>
This commit is contained in:
Joas Schilling 2016-10-05 16:31:28 +02:00
parent 8b3deb00b3
commit 4db5b2a2c6
No known key found for this signature in database
GPG Key ID: E166FD8976B3BAC8
5 changed files with 68 additions and 217 deletions

View File

@ -30,18 +30,11 @@
namespace OC\Settings; namespace OC\Settings;
use OC\Files\View; use OC\Authentication\Token\IProvider;
use OC\Server;
use OC\Settings\Controller\AdminSettingsController;
use OC\Settings\Controller\AuthSettingsController;
use OC\Settings\Controller\CertificateController;
use OC\Settings\Controller\EncryptionController;
use OC\Settings\Controller\GroupsController;
use OC\Settings\Controller\MailSettingsController;
use OC\Settings\Controller\UsersController;
use OC\Settings\Middleware\SubadminMiddleware; use OC\Settings\Middleware\SubadminMiddleware;
use OCP\AppFramework\App; use OCP\AppFramework\App;
use OCP\IContainer; use OCP\IContainer;
use OCP\Settings\IManager;
use OCP\Util; use OCP\Util;
/** /**
@ -58,131 +51,19 @@ class Application extends App {
$container = $this->getContainer(); $container = $this->getContainer();
/** // Register Middleware
* Controllers $container->registerAlias('SubadminMiddleware', SubadminMiddleware::class);
*/ $container->registerMiddleWare('SubadminMiddleware');
$container->registerService('MailSettingsController', function(IContainer $c) {
return new MailSettingsController(
$c->query('AppName'),
$c->query('Request'),
$c->query('L10N'),
$c->query('Config'),
$c->query('UserSession'),
$c->query('Defaults'),
$c->query('Mailer'),
$c->query('DefaultMailAddress')
);
});
$container->registerService('EncryptionController', function(IContainer $c) {
return new EncryptionController(
$c->query('AppName'),
$c->query('Request'),
$c->query('L10N'),
$c->query('Config'),
$c->query('DatabaseConnection'),
$c->query('UserManager'),
new View(),
$c->query('Logger')
);
});
$container->registerService('AuthSettingsController', function(IContainer $c) {
return new AuthSettingsController(
$c->query('AppName'),
$c->query('Request'),
$c->query('ServerContainer')->query('OC\Authentication\Token\IProvider'),
$c->query('UserManager'),
$c->query('ServerContainer')->getSession(),
$c->query('ServerContainer')->getSecureRandom(),
$c->query('UserId')
);
});
$container->registerService('CertificateController', function(IContainer $c) {
return new CertificateController(
$c->query('AppName'),
$c->query('Request'),
$c->query('CertificateManager'),
$c->query('SystemCertificateManager'),
$c->query('L10N'),
$c->query('IAppManager')
);
});
$container->registerService('GroupsController', function(IContainer $c) {
return new GroupsController(
$c->query('AppName'),
$c->query('Request'),
$c->query('GroupManager'),
$c->query('UserSession'),
$c->query('IsAdmin'),
$c->query('L10N')
);
});
$container->registerService('UsersController', function(IContainer $c) {
return new UsersController(
$c->query('AppName'),
$c->query('Request'),
$c->query('UserManager'),
$c->query('GroupManager'),
$c->query('UserSession'),
$c->query('Config'),
$c->query('IsAdmin'),
$c->query('L10N'),
$c->query('Logger'),
$c->query('Defaults'),
$c->query('Mailer'),
$c->query('DefaultMailAddress'),
$c->query('URLGenerator'),
$c->query('OCP\\App\\IAppManager'),
$c->query('OCP\\IAvatarManager')
);
});
$container->registerService('AdminSettingsController', function(IContainer $c) {
return new AdminSettingsController(
$c->query('AppName'),
$c->query('Request'),
$c->query('INavigationManager'),
$c->query('SettingsManager')
);
});
/**
* Middleware
*/
$container->registerService('SubadminMiddleware', function(IContainer $c){
return new SubadminMiddleware(
$c->query('ControllerMethodReflector'),
$c->query('IsSubAdmin')
);
});
// Execute middlewares
$container->registerMiddleware('SubadminMiddleware');
/** /**
* Core class wrappers * Core class wrappers
*/ */
$container->registerService('Config', function(IContainer $c) {
return $c->query('ServerContainer')->getConfig();
});
$container->registerService('ICacheFactory', function(IContainer $c) {
return $c->query('ServerContainer')->getMemCacheFactory();
});
$container->registerService('L10N', function(IContainer $c) {
return $c->query('ServerContainer')->getL10N('settings');
});
$container->registerService('GroupManager', function(IContainer $c) {
return $c->query('ServerContainer')->getGroupManager();
});
$container->registerService('UserManager', function(IContainer $c) {
return $c->query('ServerContainer')->getUserManager();
});
$container->registerService('UserSession', function(IContainer $c) {
return $c->query('ServerContainer')->getUserSession();
});
/** FIXME: Remove once OC_User is non-static and mockable */ /** FIXME: Remove once OC_User is non-static and mockable */
$container->registerService('IsAdmin', function(IContainer $c) { $container->registerService('isAdmin', function() {
return \OC_User::isAdminUser(\OC_User::getUser()); return \OC_User::isAdminUser(\OC_User::getUser());
}); });
/** FIXME: Remove once OC_SubAdmin is non-static and mockable */ /** FIXME: Remove once OC_SubAdmin is non-static and mockable */
$container->registerService('IsSubAdmin', function(IContainer $c) { $container->registerService('isSubAdmin', function(IContainer $c) {
$userObject = \OC::$server->getUserSession()->getUser(); $userObject = \OC::$server->getUserSession()->getUser();
$isSubAdmin = false; $isSubAdmin = false;
if($userObject !== null) { if($userObject !== null) {
@ -190,57 +71,19 @@ class Application extends App {
} }
return $isSubAdmin; return $isSubAdmin;
}); });
$container->registerService('Mailer', function(IContainer $c) { $container->registerService('fromMailAddress', function() {
return $c->query('ServerContainer')->getMailer();
});
$container->registerService('Defaults', function(IContainer $c) {
return $c->query('ServerContainer')->getThemingDefaults();
});
$container->registerService('DefaultMailAddress', function(IContainer $c) {
return Util::getDefaultEmailAddress('no-reply'); return Util::getDefaultEmailAddress('no-reply');
}); });
$container->registerService('Logger', function(IContainer $c) { $container->registerService('userCertificateManager', function(IContainer $c) {
return $c->query('ServerContainer')->getLogger();
});
$container->registerService('URLGenerator', function(IContainer $c) {
return $c->query('ServerContainer')->getURLGenerator();
});
$container->registerService('ClientService', function(IContainer $c) {
return $c->query('ServerContainer')->getHTTPClientService();
});
$container->registerService('INavigationManager', function(IContainer $c) {
return $c->query('ServerContainer')->getNavigationManager();
});
$container->registerService('IAppManager', function(IContainer $c) {
return $c->query('ServerContainer')->getAppManager();
});
$container->registerService('OcsClient', function(IContainer $c) {
return $c->query('ServerContainer')->getOcsClient();
});
$container->registerService('Util', function(IContainer $c) {
return new \OC_Util();
});
$container->registerService('DatabaseConnection', function(IContainer $c) {
return $c->query('ServerContainer')->getDatabaseConnection();
});
$container->registerService('CertificateManager', function(IContainer $c){
return $c->query('ServerContainer')->getCertificateManager(); return $c->query('ServerContainer')->getCertificateManager();
}); }, false);
$container->registerService('SystemCertificateManager', function (IContainer $c) { $container->registerService('systemCertificateManager', function (IContainer $c) {
return $c->query('ServerContainer')->getCertificateManager(null); return $c->query('ServerContainer')->getCertificateManager(null);
}, false);
$container->registerService(IProvider::class, function (IContainer $c) {
return $c->query('ServerContainer')->query(IProvider::class);
}); });
$container->registerService('Checker', function(IContainer $c) { $container->registerService(IManager::class, function (IContainer $c) {
/** @var Server $server */
$server = $c->query('ServerContainer');
return $server->getIntegrityCodeChecker();
});
$container->registerService('EventDispatcher', function (IContainer $c) {
return $c->query('ServerContainer')->getEventDispatcher();
});
$container->registerService('EncryptionManager', function (IContainer $c) {
return $c->query('ServerContainer')->getEncryptionManager();
});
$container->registerService('SettingsManager', function (IContainer $c) {
return $c->query('ServerContainer')->getSettingsManager(); return $c->query('ServerContainer')->getSettingsManager();
}); });
} }

View File

@ -60,14 +60,14 @@ class AuthSettingsController extends Controller {
* @param IUserManager $userManager * @param IUserManager $userManager
* @param ISession $session * @param ISession $session
* @param ISecureRandom $random * @param ISecureRandom $random
* @param string $uid * @param string $userId
*/ */
public function __construct($appName, IRequest $request, IProvider $tokenProvider, IUserManager $userManager, public function __construct($appName, IRequest $request, IProvider $tokenProvider, IUserManager $userManager,
ISession $session, ISecureRandom $random, $uid) { ISession $session, ISecureRandom $random, $userId) {
parent::__construct($appName, $request); parent::__construct($appName, $request);
$this->tokenProvider = $tokenProvider; $this->tokenProvider = $tokenProvider;
$this->userManager = $userManager; $this->userManager = $userManager;
$this->uid = $uid; $this->uid = $userId;
$this->session = $session; $this->session = $session;
$this->random = $random; $this->random = $random;
} }

View File

@ -23,14 +23,15 @@
namespace OC\Settings\Controller; namespace OC\Settings\Controller;
use OC\Files\View; use OC\Files\View;
use OCA\Encryption\Migration; use OCA\Encryption\Migration;
use OCP\IDBConnection;
use OCP\IL10N; use OCP\IL10N;
use OCP\AppFramework\Controller; use OCP\AppFramework\Controller;
use OCP\ILogger; use OCP\ILogger;
use OCP\IRequest; use OCP\IRequest;
use OCP\IConfig; use OCP\IConfig;
use OC\DB\Connection;
use OCP\IUserManager; use OCP\IUserManager;
/** /**
@ -38,10 +39,10 @@ use OCP\IUserManager;
*/ */
class EncryptionController extends Controller { class EncryptionController extends Controller {
/** @var \OCP\IL10N */ /** @var IL10N */
private $l10n; private $l10n;
/** @var Connection */ /** @var IDBConnection */
private $connection; private $connection;
/** @var IConfig */ /** @var IConfig */
@ -53,15 +54,15 @@ class EncryptionController extends Controller {
/** @var View */ /** @var View */
private $view; private $view;
/** @var ILogger */ /** @var ILogger */
private $logger; private $logger;
/** /**
* @param string $appName * @param string $appName
* @param IRequest $request * @param IRequest $request
* @param \OCP\IL10N $l10n * @param IL10N $l10n
* @param \OCP\IConfig $config * @param IConfig $config
* @param \OC\DB\Connection $connection * @param IDBConnection $connection
* @param IUserManager $userManager * @param IUserManager $userManager
* @param View $view * @param View $view
* @param ILogger $logger * @param ILogger $logger
@ -70,7 +71,7 @@ class EncryptionController extends Controller {
IRequest $request, IRequest $request,
IL10N $l10n, IL10N $l10n,
IConfig $config, IConfig $config,
Connection $connection, IDBConnection $connection,
IUserManager $userManager, IUserManager $userManager,
View $view, View $view,
ILogger $logger) { ILogger $logger) {
@ -86,13 +87,13 @@ class EncryptionController extends Controller {
/** /**
* @param IConfig $config * @param IConfig $config
* @param View $view * @param View $view
* @param Connection $connection * @param IDBConnection $connection
* @param ILogger $logger * @param ILogger $logger
* @return Migration * @return Migration
*/ */
protected function getMigration(IConfig $config, protected function getMigration(IConfig $config,
View $view, View $view,
Connection $connection, IDBConnection $connection,
ILogger $logger) { ILogger $logger) {
return new Migration($config, $view, $connection, $logger); return new Migration($config, $view, $connection, $logger);
} }

View File

@ -24,11 +24,11 @@
namespace OC\Settings\Controller; namespace OC\Settings\Controller;
use OC\User\Session; use OCP\AppFramework\Controller;
use \OCP\AppFramework\Controller;
use OCP\IRequest; use OCP\IRequest;
use OCP\IL10N; use OCP\IL10N;
use OCP\IConfig; use OCP\IConfig;
use OCP\IUserSession;
use OCP\Mail\IMailer; use OCP\Mail\IMailer;
/** /**
@ -36,14 +36,12 @@ use OCP\Mail\IMailer;
*/ */
class MailSettingsController extends Controller { class MailSettingsController extends Controller {
/** @var \OCP\IL10N */ /** @var IL10N */
private $l10n; private $l10n;
/** @var \OCP\IConfig */ /** @var IConfig */
private $config; private $config;
/** @var Session */ /** @var IUserSession */
private $userSession; private $userSession;
/** @var \OC_Defaults */
private $defaults;
/** @var IMailer */ /** @var IMailer */
private $mailer; private $mailer;
/** @var string */ /** @var string */
@ -54,26 +52,23 @@ class MailSettingsController extends Controller {
* @param IRequest $request * @param IRequest $request
* @param IL10N $l10n * @param IL10N $l10n
* @param IConfig $config * @param IConfig $config
* @param Session $userSession * @param IUserSession $userSession
* @param \OC_Defaults $defaults
* @param IMailer $mailer * @param IMailer $mailer
* @param string $defaultMailAddress * @param string $fromMailAddress
*/ */
public function __construct($appName, public function __construct($appName,
IRequest $request, IRequest $request,
IL10N $l10n, IL10N $l10n,
IConfig $config, IConfig $config,
Session $userSession, IUserSession $userSession,
\OC_Defaults $defaults,
IMailer $mailer, IMailer $mailer,
$defaultMailAddress) { $fromMailAddress) {
parent::__construct($appName, $request); parent::__construct($appName, $request);
$this->l10n = $l10n; $this->l10n = $l10n;
$this->config = $config; $this->config = $config;
$this->userSession = $userSession; $this->userSession = $userSession;
$this->defaults = $defaults;
$this->mailer = $mailer; $this->mailer = $mailer;
$this->defaultMailAddress = $defaultMailAddress; $this->defaultMailAddress = $fromMailAddress;
} }
/** /**

View File

@ -25,6 +25,18 @@ namespace Tests\Settings;
use OC\Settings\Application; use OC\Settings\Application;
use OC\Settings\Controller\AdminSettingsController;
use OC\Settings\Controller\AppSettingsController;
use OC\Settings\Controller\AuthSettingsController;
use OC\Settings\Controller\CertificateController;
use OC\Settings\Controller\CheckSetupController;
use OC\Settings\Controller\EncryptionController;
use OC\Settings\Controller\GroupsController;
use OC\Settings\Controller\LogSettingsController;
use OC\Settings\Controller\MailSettingsController;
use OC\Settings\Controller\SecuritySettingsController;
use OC\Settings\Controller\UsersController;
use OC\Settings\Middleware\SubadminMiddleware;
use OCP\AppFramework\Controller; use OCP\AppFramework\Controller;
use OCP\AppFramework\Middleware; use OCP\AppFramework\Middleware;
use OCP\IUser; use OCP\IUser;
@ -56,21 +68,21 @@ class ApplicationTest extends TestCase {
} }
public function dataContainerQuery() { public function dataContainerQuery() {
return array( return [
array('AdminSettingsController', Controller::class), [AdminSettingsController::class, Controller::class],
array('AppSettingsController', Controller::class), [AppSettingsController::class, Controller::class],
array('AuthSettingsController', Controller::class), [AuthSettingsController::class, Controller::class],
// Needs session: array('CertificateController', Controller::class), // Needs session: [CertificateController::class, Controller::class],
array('CheckSetupController', Controller::class), [CheckSetupController::class, Controller::class],
array('EncryptionController', Controller::class), [EncryptionController::class, Controller::class],
array('GroupsController', Controller::class), [GroupsController::class, Controller::class],
array('LogSettingsController', Controller::class), [LogSettingsController::class, Controller::class],
array('MailSettingsController', Controller::class), [MailSettingsController::class, Controller::class],
array('SecuritySettingsController', Controller::class), [SecuritySettingsController::class, Controller::class],
array('UsersController', Controller::class), [UsersController::class, Controller::class],
array('SubadminMiddleware', Middleware::class), [SubadminMiddleware::class, Middleware::class],
); ];
} }
/** /**
@ -83,9 +95,9 @@ class ApplicationTest extends TestCase {
} }
public function dataContainerQueryRequiresSession() { public function dataContainerQueryRequiresSession() {
return array( return [
array('CertificateController', Controller::class), [CertificateController::class, Controller::class],
); ];
} }
/** /**