From 5eccf4b0f81544b10c23c1546c33b02106b87316 Mon Sep 17 00:00:00 2001 From: Bastian Waidelich Date: Fri, 20 Dec 2024 11:39:45 +0100 Subject: [PATCH] TASK: `NeosUserRole` enum to reduce amount of magic strings --- .../Classes/Service/EventMigrationService.php | 7 +++--- .../Classes/Domain/Model/NeosUserRole.php | 22 +++++++++++++++++++ .../Domain/Model/WorkspaceRoleAssignments.php | 6 ++--- .../Classes/Domain/Service/UserService.php | 9 ++++---- .../ContentRepositoryAuthorizationService.php | 5 ++--- 5 files changed, 36 insertions(+), 13 deletions(-) create mode 100644 Neos.Neos/Classes/Domain/Model/NeosUserRole.php diff --git a/Neos.ContentRepositoryRegistry/Classes/Service/EventMigrationService.php b/Neos.ContentRepositoryRegistry/Classes/Service/EventMigrationService.php index e1b3b4dae8e..654e014cf0f 100644 --- a/Neos.ContentRepositoryRegistry/Classes/Service/EventMigrationService.php +++ b/Neos.ContentRepositoryRegistry/Classes/Service/EventMigrationService.php @@ -47,6 +47,7 @@ use Neos\EventStore\Model\EventStream\EventStreamFilter; use Neos\EventStore\Model\EventStream\ExpectedVersion; use Neos\EventStore\Model\EventStream\VirtualStreamName; +use Neos\Neos\Domain\Model\NeosUserRole; use Neos\Neos\Domain\Model\WorkspaceClassification; use Neos\Neos\Domain\Model\WorkspaceRole; use Neos\Neos\Domain\Model\WorkspaceRoleSubjectType; @@ -719,18 +720,18 @@ public function migrateWorkspaceMetadataToWorkspaceService(\Closure $outputFn): if ($workspaceName->isLive()) { $roleAssignments[] = [ 'subject_type' => WorkspaceRoleSubjectType::GROUP->value, - 'subject' => 'Neos.Neos:LivePublisher', + 'subject' => NeosUserRole::LIVE_PUBLISHER->value, 'role' => WorkspaceRole::COLLABORATOR->value, ]; $roleAssignments[] = [ 'subject_type' => WorkspaceRoleSubjectType::GROUP->value, - 'subject' => 'Neos.Flow:Everybody', + 'subject' => NeosUserRole::EVERYBODY->value, 'role' => WorkspaceRole::VIEWER->value, ]; } elseif ($isInternalWorkspace) { $roleAssignments[] = [ 'subject_type' => WorkspaceRoleSubjectType::GROUP->value, - 'subject' => 'Neos.Neos:AbstractEditor', + 'subject' => NeosUserRole::ABSTRACT_EDITOR->value, 'role' => WorkspaceRole::COLLABORATOR->value, ]; } elseif ($isPrivateWorkspace) { diff --git a/Neos.Neos/Classes/Domain/Model/NeosUserRole.php b/Neos.Neos/Classes/Domain/Model/NeosUserRole.php new file mode 100644 index 00000000000..23a2af5f094 --- /dev/null +++ b/Neos.Neos/Classes/Domain/Model/NeosUserRole.php @@ -0,0 +1,22 @@ +value, WorkspaceRole::COLLABORATOR ), WorkspaceRoleAssignment::createForGroup( - 'Neos.Flow:Everybody', + NeosUserRole::EVERYBODY->value, WorkspaceRole::VIEWER ) ); @@ -76,7 +76,7 @@ public static function createForSharedWorkspace(UserId $userId): self WorkspaceRole::MANAGER, ), WorkspaceRoleAssignment::createForGroup( - 'Neos.Neos:AbstractEditor', + NeosUserRole::ABSTRACT_EDITOR->value, WorkspaceRole::COLLABORATOR, ) ); diff --git a/Neos.Neos/Classes/Domain/Service/UserService.php b/Neos.Neos/Classes/Domain/Service/UserService.php index dfa1616d003..29e7254a9b1 100644 --- a/Neos.Neos/Classes/Domain/Service/UserService.php +++ b/Neos.Neos/Classes/Domain/Service/UserService.php @@ -37,6 +37,7 @@ use Neos\Flow\Session\SessionManager; use Neos\Flow\Utility\Now; use Neos\Neos\Domain\Exception; +use Neos\Neos\Domain\Model\NeosUserRole; use Neos\Neos\Domain\Model\User; use Neos\Neos\Domain\Model\UserId; use Neos\Neos\Domain\Repository\UserRepository; @@ -321,7 +322,7 @@ public function addUser( $authenticationProviderName = null ) { if ($roleIdentifiers === null) { - $roleIdentifiers = ['Neos.Neos:Editor']; + $roleIdentifiers = [NeosUserRole::EDITOR->value]; } $roleIdentifiers = $this->normalizeRoleIdentifiers($roleIdentifiers); $account = $this->accountFactory->createAccountWithPassword( @@ -663,7 +664,7 @@ public function deactivateUser(User $user): void */ public function currentUserIsAdministrator(): bool { - return $this->securityContext->hasRole('Neos.Neos:Administrator'); + return $this->securityContext->hasRole(NeosUserRole::ADMINISTRATOR->value); } /** @@ -736,8 +737,8 @@ protected function normalizeRoleIdentifier($roleIdentifier) public function getAllRoles(User $user): array { $roles = [ - 'Neos.Flow:Everybody' => $this->policyService->getRole('Neos.Flow:Everybody'), - 'Neos.Flow:AuthenticatedUser' => $this->policyService->getRole('Neos.Flow:AuthenticatedUser') + NeosUserRole::EVERYBODY->value => $this->policyService->getRole(NeosUserRole::EVERYBODY->value), + NeosUserRole::AUTHENTICATED_USER->value => $this->policyService->getRole(NeosUserRole::AUTHENTICATED_USER->value) ]; /** @var Account $account */ diff --git a/Neos.Neos/Classes/Security/Authorization/ContentRepositoryAuthorizationService.php b/Neos.Neos/Classes/Security/Authorization/ContentRepositoryAuthorizationService.php index b187e63f7a6..d657175357a 100644 --- a/Neos.Neos/Classes/Security/Authorization/ContentRepositoryAuthorizationService.php +++ b/Neos.Neos/Classes/Security/Authorization/ContentRepositoryAuthorizationService.php @@ -14,6 +14,7 @@ use Neos\Flow\Security\Context; use Neos\Flow\Security\Policy\PolicyService; use Neos\Flow\Security\Policy\Role; +use Neos\Neos\Domain\Model\NeosUserRole; use Neos\Neos\Domain\Model\NodePermissions; use Neos\Neos\Domain\Model\UserId; use Neos\Neos\Domain\Model\WorkspacePermissions; @@ -33,8 +34,6 @@ #[Flow\Scope('singleton')] final readonly class ContentRepositoryAuthorizationService { - private const ROLE_NEOS_ADMINISTRATOR = 'Neos.Neos:Administrator'; - public function __construct( private WorkspaceMetadataAndRoleRepository $metadataAndRoleRepository, private PolicyService $policyService, @@ -63,7 +62,7 @@ public function getWorkspacePermissions(ContentRepositoryId $contentRepositoryId * We hardcode the check against administrators to always grant manage permissions. This is done to allow administrators to fix permissions of all workspaces. * We don't allow all rights like read and write. Admins should be able to grant themselves permissions to write to other personal workspaces, but they should not have this permission automagically. */ - $userIsAdministrator = in_array(self::ROLE_NEOS_ADMINISTRATOR, $roleIdentifiers, true); + $userIsAdministrator = in_array(NeosUserRole::ADMINISTRATOR->value, $roleIdentifiers, true); $userWorkspaceRole = $this->metadataAndRoleRepository->getMostPrivilegedWorkspaceRoleForSubjects($contentRepositoryId, $workspaceName, WorkspaceRoleSubjects::fromArray($subjects)); if ($userWorkspaceRole === null) { if ($userIsAdministrator) {