summaryrefslogtreecommitdiffstats
path: root/lib
diff options
context:
space:
mode:
authorArthur Schiwon <blizzz@arthur-schiwon.de>2021-06-22 13:41:48 +0200
committerbackportbot[bot] <backportbot[bot]@users.noreply.github.com>2021-06-30 05:15:49 +0000
commitb30ce04e15816ad52a3443252abbfc3287c1a4a6 (patch)
treecd8868977c946069f64a71c745821029e27c4690 /lib
parentbcedd4031d608c41f0c29f5461d71aa201266a74 (diff)
downloadnextcloud-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.php34
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);
}