From 92e7b5d56f7bc4a5a726f0c85cb1dff6e2be7612 Mon Sep 17 00:00:00 2001 From: Ronak Patel Date: Fri, 6 Oct 2023 00:23:54 -0700 Subject: [PATCH 1/3] Another system config: allow_user_to_change_email_address --- .../lib/Controller/UsersController.php | 11 ++++++-- .../tests/Controller/UsersControllerTest.php | 20 ++++++++++++++- .../lib/Controller/UsersController.php | 9 +++++-- .../lib/Settings/Personal/PersonalInfo.php | 1 + .../EmailSection/EmailSection.vue | 6 ++--- .../tests/Controller/UsersControllerTest.php | 8 +++++- config/config.sample.php | 6 +++++ lib/private/User/Backend.php | 3 ++- lib/private/User/LazyUser.php | 4 +++ lib/private/User/User.php | 12 +++++++++ lib/public/IUser.php | 8 ++++++ tests/lib/User/UserTest.php | 25 +++++++++++++++++++ 12 files changed, 103 insertions(+), 10 deletions(-) diff --git a/apps/provisioning_api/lib/Controller/UsersController.php b/apps/provisioning_api/lib/Controller/UsersController.php index b7e9b5d0de086..f9e56290bf335 100644 --- a/apps/provisioning_api/lib/Controller/UsersController.php +++ b/apps/provisioning_api/lib/Controller/UsersController.php @@ -638,7 +638,7 @@ public function getEditableFieldsForUser(string $userId): DataResponse { $targetUser = $currentLoggedInUser; } - // Editing self (display, email) + // Editing self (display) if ($this->config->getSystemValue('allow_user_to_change_display_name', true) !== false) { if ( $targetUser->getBackend() instanceof ISetDisplayNameBackend @@ -646,6 +646,9 @@ public function getEditableFieldsForUser(string $userId): DataResponse { ) { $permittedFields[] = IAccountManager::PROPERTY_DISPLAYNAME; } + } + // Editing self (email) + if ($this->config->getSystemValue('allow_user_to_change_email_address', true) !== false) { $permittedFields[] = IAccountManager::PROPERTY_EMAIL; } @@ -792,7 +795,7 @@ public function editUser(string $userId, string $key, string $value): DataRespon $permittedFields = []; if ($targetUser->getUID() === $currentLoggedInUser->getUID()) { - // Editing self (display, email) + // Editing self (display) if ($this->config->getSystemValue('allow_user_to_change_display_name', true) !== false) { if ( $targetUser->getBackend() instanceof ISetDisplayNameBackend @@ -801,8 +804,12 @@ public function editUser(string $userId, string $key, string $value): DataRespon $permittedFields[] = self::USER_FIELD_DISPLAYNAME; $permittedFields[] = IAccountManager::PROPERTY_DISPLAYNAME; } + } + // Editing self (email) + if ($this->config->getSystemValue('allow_user_to_change_email_address', true) !== false) { $permittedFields[] = IAccountManager::PROPERTY_EMAIL; } + $permittedFields[] = IAccountManager::PROPERTY_DISPLAYNAME . self::SCOPE_SUFFIX; $permittedFields[] = IAccountManager::PROPERTY_EMAIL . self::SCOPE_SUFFIX; diff --git a/apps/provisioning_api/tests/Controller/UsersControllerTest.php b/apps/provisioning_api/tests/Controller/UsersControllerTest.php index a48461c0a27b5..0a5682312382c 100644 --- a/apps/provisioning_api/tests/Controller/UsersControllerTest.php +++ b/apps/provisioning_api/tests/Controller/UsersControllerTest.php @@ -2134,6 +2134,12 @@ public function testEditUserSelfEditChangeLanguage() { ['allow_user_to_change_display_name', true, true], ['force_language', false, false], ]); + $this->config->expects($this->any()) + ->method('getSystemValue') + ->willReturnMap([ + ['allow_user_to_change_email_address', true, true], + ['force_language', false, false], + ]); $loggedInUser = $this->createMock(IUser::class); $loggedInUser @@ -2191,7 +2197,13 @@ public function testEditUserSelfEditChangeLanguageButForced($forced) { ['allow_user_to_change_display_name', true, true], ['force_language', false, $forced], ]); - + $this->config->expects($this->any()) + ->method('getSystemValue') + ->willReturnMap([ + ['allow_user_to_change_email_address', true, true], + ['force_language', false, $forced], + ]); + $loggedInUser = $this->createMock(IUser::class); $loggedInUser ->expects($this->any()) @@ -4180,6 +4192,12 @@ public function testGetEditableFields(bool $allowedToChangeDisplayName, string $ $this->equalTo('allow_user_to_change_display_name'), $this->anything() )->willReturn($allowedToChangeDisplayName); + $this->config + ->method('getSystemValue') + ->with( + $this->equalTo('allow_user_to_change_email_address'), + $this->anything() + )->willReturn($allowedToChangeDisplayName); $user = $this->createMock(IUser::class); $this->userSession->method('getUser') diff --git a/apps/settings/lib/Controller/UsersController.php b/apps/settings/lib/Controller/UsersController.php index 13a91ab45ad97..753dee74626b5 100644 --- a/apps/settings/lib/Controller/UsersController.php +++ b/apps/settings/lib/Controller/UsersController.php @@ -422,9 +422,14 @@ public function setUserSettings(?string $avatarScope = null, IAccountManager::PROPERTY_FEDIVERSE => ['value' => $fediverse, 'scope' => $fediverseScope], ]; $allowUserToChangeDisplayName = $this->config->getSystemValueBool('allow_user_to_change_display_name', true); + $allowUserToChangeEmailAddress = $this->config->getSystemValueBool('allow_user_to_change_email_address', true); foreach ($updatable as $property => $data) { if ($allowUserToChangeDisplayName === false - && in_array($property, [IAccountManager::PROPERTY_DISPLAYNAME, IAccountManager::PROPERTY_EMAIL], true)) { + && in_array($property, [IAccountManager::PROPERTY_DISPLAYNAME], true)) { + continue; + } + if ($allowUserToChangeEmailAddress === false + && in_array($property, [IAccountManager::PROPERTY_EMAIL], true)) { continue; } $property = $userAccount->getProperty($property); @@ -497,7 +502,7 @@ protected function saveUserSettings(IAccount $userAccount): void { if ($oldEmailAddress !== strtolower($userAccount->getProperty(IAccountManager::PROPERTY_EMAIL)->getValue())) { // this is the only permission a backend provides and is also used // for the permission of setting a email address - if (!$userAccount->getUser()->canChangeDisplayName()) { + if (!$userAccount->getUser()->canChangeEmailAddress()) { throw new ForbiddenException($this->l10n->t('Unable to change email address')); } $userAccount->getUser()->setSystemEMailAddress($userAccount->getProperty(IAccountManager::PROPERTY_EMAIL)->getValue()); diff --git a/apps/settings/lib/Settings/Personal/PersonalInfo.php b/apps/settings/lib/Settings/Personal/PersonalInfo.php index 9fbee6ef62fa5..d24d5f4bd1ba9 100644 --- a/apps/settings/lib/Settings/Personal/PersonalInfo.php +++ b/apps/settings/lib/Settings/Personal/PersonalInfo.php @@ -172,6 +172,7 @@ public function getForm(): TemplateResponse { $accountParameters = [ 'avatarChangeSupported' => $user->canChangeAvatar(), 'displayNameChangeSupported' => $user->canChangeDisplayName(), + 'emailAddressChangeSupported' => $user->canChangeEmailAddress(), 'federationEnabled' => $federationEnabled, 'lookupServerUploadEnabled' => $lookupServerUploadEnabled, ]; diff --git a/apps/settings/src/components/PersonalInfo/EmailSection/EmailSection.vue b/apps/settings/src/components/PersonalInfo/EmailSection/EmailSection.vue index 980af3e62b0cb..7e4fd0e08d182 100644 --- a/apps/settings/src/components/PersonalInfo/EmailSection/EmailSection.vue +++ b/apps/settings/src/components/PersonalInfo/EmailSection/EmailSection.vue @@ -31,7 +31,7 @@ :scope.sync="primaryEmail.scope" @add-additional="onAddAdditionalEmail" /> -