diff options
author | Christoph Wurst <christoph@owncloud.com> | 2016-04-28 10:52:28 +0200 |
---|---|---|
committer | Thomas Müller <thomas.mueller@tmit.eu> | 2016-05-11 13:36:46 +0200 |
commit | 8cc5f6036f6ff1377077da0eed1cf4350db4b7e6 (patch) | |
tree | a6458b7630ae73d0029ff1ff23505e46794af49a /lib | |
parent | aafd660b9777bd4e3434dd1894ce61717fb541fc (diff) | |
download | nextcloud-server-8cc5f6036f6ff1377077da0eed1cf4350db4b7e6.tar.gz nextcloud-server-8cc5f6036f6ff1377077da0eed1cf4350db4b7e6.zip |
Fix existing tests
Diffstat (limited to 'lib')
-rw-r--r-- | lib/private/Files/Filesystem.php | 2 | ||||
-rw-r--r-- | lib/private/User/Session.php | 44 |
2 files changed, 24 insertions, 22 deletions
diff --git a/lib/private/Files/Filesystem.php b/lib/private/Files/Filesystem.php index 99c123ad1a1..89b8547aa52 100644 --- a/lib/private/Files/Filesystem.php +++ b/lib/private/Files/Filesystem.php @@ -404,7 +404,7 @@ class Filesystem { if (is_null($userObject)) { \OCP\Util::writeLog('files', ' Backends provided no user object for ' . $user, \OCP\Util::ERROR); - throw new \OC\User\NoUserException('Backends provided no user object for ' . $user); + throw new \OC\User\NoUserException('Backend provided no user object for ' . $user); } self::$usersSetup[$user] = true; diff --git a/lib/private/User/Session.php b/lib/private/User/Session.php index 262174ab172..972f59fc001 100644 --- a/lib/private/User/Session.php +++ b/lib/private/User/Session.php @@ -184,30 +184,27 @@ class Session implements IUserSession, Emitter { if (OC_User::isIncognitoMode()) { return null; } - if ($this->activeUser) { - return $this->activeUser; - } else { + if (is_null($this->activeUser)) { $uid = $this->session->get('user_id'); - if ($uid !== null && $this->isValidSession($uid)) { - return $this->activeUser; - } else { + if (is_null($uid)) { + return null; + } + $this->activeUser = $this->manager->get($uid); + if (is_null($this->activeUser)) { return null; } + $this->validateSession($this->activeUser); } + return $this->activeUser; } - private function isValidSession($uid) { - $this->activeUser = $this->manager->get($uid); - if (is_null($this->activeUser)) { - // User does not exist - return false; - } + protected function validateSession(IUser $user) { // TODO: use ISession::getId(), https://github.com/owncloud/core/pull/24229 $sessionId = session_id(); try { $token = $this->tokenProvider->getToken($sessionId); } catch (InvalidTokenException $ex) { - // Session was inalidated + // Session was invalidated $this->logout(); return false; } @@ -217,7 +214,7 @@ class Session implements IUserSession, Emitter { $lastCheck = $this->session->get('last_login_check') ? : 0; if ($lastCheck < (time() - 60 * 5)) { $pwd = $this->tokenProvider->getPassword($token, $sessionId); - if ($this->manager->checkPassword($uid, $pwd) === false) { + if ($this->manager->checkPassword($user->getUID(), $pwd) === false) { // Password has changed -> log user out $this->logout(); return false; @@ -303,13 +300,7 @@ class Session implements IUserSession, Emitter { $this->setLoginName($uid); $this->manager->emit('\OC\User', 'postLogin', array($user, $password)); if ($this->isLoggedIn()) { - // Refresh the token - \OC::$server->getCsrfTokenManager()->refreshToken(); - //we need to pass the user name, which may differ from login name - $user = $this->getUser()->getUID(); - \OC_Util::setupFS($user); - //trigger creation of user home and /files folder - \OC::$server->getUserFolder($user); + $this->prepareUserLogin(); return true; } else { // injecting l10n does not work - there is a circular dependency between session and \OCP\L10N\IFactory @@ -326,6 +317,17 @@ class Session implements IUserSession, Emitter { return false; } + protected function prepareUserLogin() { + // TODO: mock/inject/use non-static + // Refresh the token + \OC::$server->getCsrfTokenManager()->refreshToken(); + //we need to pass the user name, which may differ from login name + $user = $this->getUser()->getUID(); + \OC_Util::setupFS($user); + //trigger creation of user home and /files folder + \OC::$server->getUserFolder($user); + } + /** * Tries to login the user with HTTP Basic Authentication * @return boolean if the login was successful |