Merge pull request #26391 from nextcloud/backport/26386/stable21

[stable21] Also check the default phone region when the number has no country code
This commit is contained in:
Morris Jobke 2021-04-01 09:32:57 +02:00 committed by GitHub
commit 052c9abfdf
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
1 changed files with 15 additions and 0 deletions

View File

@ -233,6 +233,7 @@ class UsersController extends AUserData {
/** @var IUser $user */ /** @var IUser $user */
$user = $this->userSession->getUser(); $user = $this->userSession->getUser();
$knownTo = $user->getUID(); $knownTo = $user->getUID();
$defaultPhoneRegion = $this->config->getSystemValueString('default_phone_region');
$normalizedNumberToKey = []; $normalizedNumberToKey = [];
foreach ($search as $key => $phoneNumbers) { foreach ($search as $key => $phoneNumbers) {
@ -245,6 +246,20 @@ class UsersController extends AUserData {
} }
} catch (NumberParseException $e) { } catch (NumberParseException $e) {
} }
if ($defaultPhoneRegion !== '' && $defaultPhoneRegion !== $location && strpos($phone, '0') === 0) {
// If the number has a leading zero (no country code),
// we also check the default phone region of the instance,
// when it's different to the user's given region.
try {
$phoneNumber = $phoneUtil->parse($phone, $defaultPhoneRegion);
if ($phoneNumber instanceof PhoneNumber && $phoneUtil->isValidNumber($phoneNumber)) {
$normalizedNumber = $phoneUtil->format($phoneNumber, PhoneNumberFormat::E164);
$normalizedNumberToKey[$normalizedNumber] = (string) $key;
}
} catch (NumberParseException $e) {
}
}
} }
} }