diff options
author | Bjoern Schiessle <schiessle@owncloud.com> | 2015-03-31 12:01:51 +0200 |
---|---|---|
committer | Thomas Müller <thomas.mueller@tmit.eu> | 2015-04-07 13:30:28 +0200 |
commit | 4843e5ce301c4ac1e4cccf21b7d33e5e2a2b3042 (patch) | |
tree | 3196f9d642f73a1d62c874cc02241427777f9280 /apps/encryption/lib | |
parent | 0f28d538a0af769220bcba120f0a7340dd0aba5f (diff) | |
download | nextcloud-server-4843e5ce301c4ac1e4cccf21b7d33e5e2a2b3042.tar.gz nextcloud-server-4843e5ce301c4ac1e4cccf21b7d33e5e2a2b3042.zip |
use password change logic to userhooks to avoid recursions
Diffstat (limited to 'apps/encryption/lib')
-rw-r--r-- | apps/encryption/lib/keymanager.php | 75 | ||||
-rw-r--r-- | apps/encryption/lib/session.php | 11 |
2 files changed, 13 insertions, 73 deletions
diff --git a/apps/encryption/lib/keymanager.php b/apps/encryption/lib/keymanager.php index 6c5f2348027..87b19fe35ea 100644 --- a/apps/encryption/lib/keymanager.php +++ b/apps/encryption/lib/keymanager.php @@ -23,7 +23,7 @@ namespace OCA\Encryption; use OC\Encryption\Exceptions\DecryptionFailedException; -use OC\Encryption\Exceptions\PrivateKeyMissingException; +use OCA\Encryption\Exceptions\PrivateKeyMissingException; use OC\Encryption\Exceptions\PublicKeyMissingException; use OCA\Encryption\Crypto\Crypt; use OCP\Encryption\Keys\IStorage; @@ -92,7 +92,6 @@ class KeyManager { * @param IUserSession $userSession * @param Session $session * @param ILogger $log - * @param Recovery $recovery */ public function __construct( IStorage $keyStorage, @@ -100,8 +99,7 @@ class KeyManager { IConfig $config, IUserSession $userSession, Session $session, - ILogger $log, - Recovery $recovery + ILogger $log ) { $this->session = $session; @@ -141,7 +139,6 @@ class KeyManager { $this->keyId = $userSession && $userSession->isLoggedIn() ? $userSession->getUser()->getUID() : false; $this->log = $log; - $this->recovery = $recovery; } /** @@ -330,74 +327,6 @@ class KeyManager { } /** - * Change a user's encryption passphrase - * - * @param array $params keys: uid, password - * @param IUserSession $user - * @param Util $util - * @return bool - */ - public function setPassphrase($params, IUserSession $user, Util $util) { - - // Get existing decrypted private key - $privateKey = $this->session->getPrivateKey(); - - if ($params['uid'] === $user->getUser()->getUID() && $privateKey) { - - // Encrypt private key with new user pwd as passphrase - $encryptedPrivateKey = $this->crypt->symmetricEncryptFileContent($privateKey, - $params['password']); - - // Save private key - if ($encryptedPrivateKey) { - $this->setPrivateKey($user->getUser()->getUID(), - $encryptedPrivateKey); - } else { - $this->log->error('Encryption could not update users encryption password'); - } - - // NOTE: Session does not need to be updated as the - // private key has not changed, only the passphrase - // used to decrypt it has changed - } else { // admin changed the password for a different user, create new keys and reencrypt file keys - $user = $params['uid']; - $recoveryPassword = isset($params['recoveryPassword']) ? $params['recoveryPassword'] : null; - - // we generate new keys if... - // ...we have a recovery password and the user enabled the recovery key - // ...encryption was activated for the first time (no keys exists) - // ...the user doesn't have any files - if (($util->recoveryEnabledForUser() && $recoveryPassword) || !$this->userHasKeys($user) || !$util->userHasFiles($user) - ) { - - // backup old keys - $this->backupAllKeys('recovery'); - - $newUserPassword = $params['password']; - - $keyPair = $this->crypt->createKeyPair(); - - // Save public key - $this->setPublicKey($user, $keyPair['publicKey']); - - // Encrypt private key with new password - $encryptedKey = $this->crypt->symmetricEncryptFileContent($keyPair['privateKey'], - $newUserPassword); - - if ($encryptedKey) { - $this->setPrivateKey($user, $encryptedKey); - - if ($recoveryPassword) { // if recovery key is set we can re-encrypt the key files - $this->recovery->recoverUsersFiles($recoveryPassword); - } - } else { - $this->log->error('Encryption Could not update users encryption password'); - } - } - } - } - - /** * @param $userId * @return bool */ diff --git a/apps/encryption/lib/session.php b/apps/encryption/lib/session.php index e049a8fe403..8da11e522ce 100644 --- a/apps/encryption/lib/session.php +++ b/apps/encryption/lib/session.php @@ -100,4 +100,15 @@ class Session { $this->session->set('privateKey', $key); } + + /** + * remove keys from session + */ + public function clear() { + $this->session->remove('publicSharePrivateKey'); + $this->session->remove('privateKey'); + $this->session->remove('encryptionInitialized'); + + } + }
\ No newline at end of file |