diff options
author | Arthur Schiwon <blizzz@arthur-schiwon.de> | 2021-06-22 13:41:48 +0200 |
---|---|---|
committer | backportbot[bot] <backportbot[bot]@users.noreply.github.com> | 2021-06-30 05:15:49 +0000 |
commit | b30ce04e15816ad52a3443252abbfc3287c1a4a6 (patch) | |
tree | cd8868977c946069f64a71c745821029e27c4690 /lib | |
parent | bcedd4031d608c41f0c29f5461d71aa201266a74 (diff) | |
download | nextcloud-server-b30ce04e15816ad52a3443252abbfc3287c1a4a6.tar.gz nextcloud-server-b30ce04e15816ad52a3443252abbfc3287c1a4a6.zip |
adjust email verification checker
Signed-off-by: Arthur Schiwon <blizzz@arthur-schiwon.de>
Diffstat (limited to 'lib')
-rw-r--r-- | lib/private/Accounts/AccountManager.php | 34 |
1 files changed, 18 insertions, 16 deletions
diff --git a/lib/private/Accounts/AccountManager.php b/lib/private/Accounts/AccountManager.php index 20f596e3a90..651663a57cc 100644 --- a/lib/private/Accounts/AccountManager.php +++ b/lib/private/Accounts/AccountManager.php @@ -228,7 +228,7 @@ class AccountManager implements IAccountManager { $updated = true; if ($userData !== $data) { - $data = $this->checkEmailVerification($userData, $data, $user); + $this->updateExistingUser($user, $data); } else { // nothing needs to be done if new and old data set are the same @@ -340,30 +340,31 @@ class AccountManager implements IAccountManager { /** * check if we need to ask the server for email verification, if yes we create a cronjob - * - * @param $oldData - * @param $newData - * @param IUser $user - * @return array - */ - protected function checkEmailVerification($oldData, $newData, IUser $user): array { - if ($oldData[self::PROPERTY_EMAIL]['value'] !== $newData[self::PROPERTY_EMAIL]['value']) { + */ + protected function checkEmailVerification(IAccount $updatedAccount, array $oldData): void { + try { + $property = $updatedAccount->getProperty(self::PROPERTY_EMAIL); + } catch (PropertyDoesNotExistException $e) { + return; + } + if ($oldData[self::PROPERTY_EMAIL]['value'] !== $property->getValue()) { $this->jobList->add(VerifyUserData::class, [ 'verificationCode' => '', - 'data' => $newData[self::PROPERTY_EMAIL]['value'], + 'data' => $property->getValue(), 'type' => self::PROPERTY_EMAIL, - 'uid' => $user->getUID(), + 'uid' => $updatedAccount->getUser()->getUID(), 'try' => 0, 'lastRun' => time() ] ); - $newData[self::PROPERTY_EMAIL]['verified'] = self::VERIFICATION_IN_PROGRESS; - } - return $newData; + + + $property->setVerified(self::VERIFICATION_IN_PROGRESS); + } } /** @@ -639,8 +640,9 @@ class AccountManager implements IAccountManager { $this->testPropertyScope($property, $allowedScopes, true); } - $this->updateVerificationStatus($account, $this->getUser($account->getUser(), false)); - + $oldData = $this->getUser($account->getUser(), false); + $this->updateVerificationStatus($account, $oldData); + $this->checkEmailVerification($account, $oldData); $this->updateUser($account->getUser(), $data, true); } |