diff options
Diffstat (limited to 'lib/private')
-rw-r--r-- | lib/private/Accounts/AccountManager.php | 28 |
1 files changed, 26 insertions, 2 deletions
diff --git a/lib/private/Accounts/AccountManager.php b/lib/private/Accounts/AccountManager.php index 4d75c94346b..ddc4e7c2fb0 100644 --- a/lib/private/Accounts/AccountManager.php +++ b/lib/private/Accounts/AccountManager.php @@ -39,6 +39,7 @@ use libphonenumber\PhoneNumberUtil; use OCA\Settings\BackgroundJobs\VerifyUserData; use OCP\Accounts\IAccount; use OCP\Accounts\IAccountManager; +use OCP\Accounts\IAccountPropertyCollection; use OCP\BackgroundJob\IJobList; use OCP\DB\QueryBuilder\IQueryBuilder; use OCP\IConfig; @@ -400,10 +401,13 @@ class AccountManager implements IAccountManager { */ protected function addMissingDefaultValues(array $userData) { foreach ($userData as $key => $value) { - if (!isset($userData[$key]['verified'])) { + if (!isset($userData[$key]['verified']) && !$this->isCollection($key)) { $userData[$key]['verified'] = self::NOT_VERIFIED; } } + if (!isset($userData[IAccountManager::COLLECTION_EMAIL])) { + $userData[IAccountManager::COLLECTION_EMAIL] = []; + } return $userData; } @@ -582,13 +586,33 @@ class AccountManager implements IAccountManager { 'scope' => self::SCOPE_LOCAL, 'verified' => self::NOT_VERIFIED, ], + self::COLLECTION_EMAIL => [], ]; } + private function arrayDataToCollection(string $collectionName, array $data): IAccountPropertyCollection { + $collection = new AccountPropertyCollection($collectionName); + foreach ($data as $propertyData) { + $p = new AccountProperty( + $collectionName, + $propertyData['value'] ?? '', + $propertyData['scope'] ?? self::SCOPE_LOCAL, + $propertyData['verified'] ?? self::NOT_VERIFIED, + '' + ); + $collection->addProperty($p); + } + return $collection; + } + private function parseAccountData(IUser $user, $data): Account { $account = new Account($user); foreach ($data as $property => $accountData) { - $account->setProperty($property, $accountData['value'] ?? '', $accountData['scope'] ?? self::SCOPE_LOCAL, $accountData['verified'] ?? self::NOT_VERIFIED); + if ($this->isCollection($property)) { + $account->setPropertyCollection($this->arrayDataToCollection($property, $accountData)); + } else { + $account->setProperty($property, $accountData['value'] ?? '', $accountData['scope'] ?? self::SCOPE_LOCAL, $accountData['verified'] ?? self::NOT_VERIFIED); + } } return $account; } |