Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

TASK: Properly re-remove obsolete legacy userInformation.personalWorkspaceName in policy for workspaces #5418

Open
wants to merge 2 commits into
base: 9.0
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
30 changes: 0 additions & 30 deletions Neos.ContentRepository.NodeAccess/Configuration/Policy.yaml

This file was deleted.

12 changes: 12 additions & 0 deletions Neos.Neos/Classes/Service/UserService.php
Original file line number Diff line number Diff line change
Expand Up @@ -59,6 +59,18 @@ public function getBackendUser()
return $this->userDomainService->getCurrentUser();
}

/**
* 8.3 behaviour: Returns the name of the currently logged in user's personal workspace
* (even if that might not exist at that time).
* If no user is logged in this method returns null.
*
* @deprecated and not implemented with Neos 9.0 - can be removed any time, just for the 8.3 upgrade phase
*/
public function getPersonalWorkspaceName(): ?string
{
throw new \LogicException('`userInformation.personalWorkspaceName` was removed in Neos 9.0 see https://github.com/neos/neos-development-collection/pull/5418');
}

/**
* Returns the stored preferences of a user
*
Expand Down
30 changes: 0 additions & 30 deletions Neos.Neos/Configuration/Policy.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -43,27 +43,10 @@ privilegeTargets:
label: Access to content service APIs
matcher: 'method(Neos\Neos\Controller\Backend\SchemaController->(nodeTypeSchema)Action()) || method(Neos\Neos\Controller\Backend\SettingsController->editPreviewAction())'

'Neos.Neos:Backend.PersonalWorkspaceReadAccess.NodeConverter':
label: Access to own personal workspace
matcher: 'method(Neos\Neos\TypeConverter\NodeConverter->prepareContextProperties(workspaceName === current.userInformation.personalWorkspaceName))'

# No role should have this privilege assigned:
'Neos.Neos:Backend.OtherUsersPersonalWorkspaceAccess':
label: Access to other users personal workspace
matcher: 'method(Neos\ContentRepository\Domain\Service\Context->validateWorkspace()) && evaluate(this.workspace.owner !== current.userInformation.backendUser, this.workspace.personalWorkspace === true)'

'Neos.Neos:Backend.EditContent':
label: General access to content editing
matcher: 'method(Neos\Neos\Service\Controller\NodeController->(show|getPrimaryChildNode|getChildNodesForTree|filterChildNodesForTree|getChildNodes|getChildNodesFromParent|create|createAndRender|createNodeForTheTree|move|moveBefore|moveAfter|moveInto|moveAndRender|copy|copyBefore|copyAfter|copyInto|copyAndRender|update|updateAndRender|delete|searchPage|error)Action()) || method(Neos\Neos\Controller\Backend\ContentController->(uploadAsset|assetsWithMetadata|imageWithMetadata|createImageVariant|error)Action()) || method(Neos\Neos\Controller\Service\AssetProxiesController->(index|show|import|error)Action()) || method(Neos\Neos\Controller\Service\AssetsController->(index|show|error)Action()) || method(Neos\Neos\Controller\Service\NodesController->(index|show|create|error)Action())'

'Neos.Neos:Backend.PublishOwnWorkspaceContent':
label: Allowed to publish own personal workspace
matcher: 'method(Neos\Neos\Service\Controller\WorkspaceController->(publishNode|publishNodes|error)Action()) || method(Neos\Neos\Service\Controller\WorkspaceController->publishAllAction(workspaceName = current.userInformation.personalWorkspaceName)) || method(Neos\Neos\Service\Controller\WorkspaceController->getWorkspaceWideUnpublishedNodesAction(workspace.name = current.userInformation.personalWorkspaceName))'

'Neos.Neos:Backend.DiscardOwnWorkspaceContent':
label: Allowed to discard changes in own workspace
matcher: 'method(Neos\Neos\Service\Controller\WorkspaceController->(discardNode|discardNodes|error)Action()) || method(Neos\Neos\Service\Controller\WorkspaceController->discardAllAction(workspace.name === current.userInformation.personalWorkspaceName))'

#
# User management and user settings
#
Expand Down Expand Up @@ -173,7 +156,6 @@ roles:
'Neos.Neos:AbstractEditor':
# This group is assigned conventionally for new shared workspaces as collaborator. See WorkspaceService::assignWorkspaceRole
abstract: true
parentRoles: ['Neos.ContentRepository:Administrator']
privileges:
-
privilegeTarget: 'Neos.Neos:Backend.GeneralAccess'
Expand All @@ -183,22 +165,10 @@ roles:
privilegeTarget: 'Neos.Neos:ContentPreview'
permission: GRANT

-
privilegeTarget: 'Neos.Neos:Backend.PersonalWorkspaceReadAccess.NodeConverter'
permission: GRANT

-
privilegeTarget: 'Neos.Neos:Backend.EditContent'
permission: GRANT

-
privilegeTarget: 'Neos.Neos:Backend.PublishOwnWorkspaceContent'
permission: GRANT

-
privilegeTarget: 'Neos.Neos:Backend.DiscardOwnWorkspaceContent'
permission: GRANT

-
privilegeTarget: 'Neos.Neos:Backend.ContentDimensions'
permission: GRANT
Expand Down
36 changes: 0 additions & 36 deletions Neos.Workspace.Ui/Configuration/Policy.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -2,58 +2,22 @@ privilegeTargets:

'Neos\Flow\Security\Authorization\Privilege\Method\MethodPrivilege':

'Neos.Workspace.Ui:Backend.PublishAllToLiveWorkspace':
label: Allowed to publish to the live workspace
matcher: 'method(Neos\Workspace\Ui\Controller\WorkspaceController->publishWorkspaceAction(workspace.baseWorkspace.name === "live"))'

'Neos.Workspace.Ui:Backend.CreateWorkspaces':
label: Allowed to create a workspace
matcher: 'method(Neos\Workspace\Ui\Controller\WorkspaceController->(create|new)Action())'

'Neos.Workspace.Ui:Backend.Module.Management.Workspace.ManageOwnWorkspaces':
label: Allowed to manage own workspaces
matcher: 'method(Neos\Workspace\Ui\Controller\WorkspaceController->(publishWorkspace|discardWorkspace|edit|update|delete)Action(workspace.owner === current.userInformation.backendUser))'

'Neos.Workspace.Ui:Backend.Module.Management.Workspace.ManageInternalWorkspaces':
label: Manage internal workspaces
matcher: 'method(Neos\Workspace\Ui\Controller\WorkspaceController->(publishWorkspace|discardWorkspace|edit|update|delete)Action(workspace.owner === null))'

'Neos.Workspace.Ui:Backend.Module.Management.Workspace.ManageAllPrivateWorkspaces':
label: Manage all private workspaces
matcher: 'method(Neos\Workspace\Ui\Controller\WorkspaceController->(publishWorkspace|discardWorkspace|edit|update|delete)Action()) && evaluate(this.workspace.owner !== current.userInformation.backendUser, this.workspace.personalWorkspace === false)'

'Neos\Neos\Security\Authorization\Privilege\ModulePrivilege':
'Neos.Workspace.Ui:Backend.Module.Management.Workspace':
label: General access to the workspace module
matcher: 'management/workspace'

roles:
'Neos.Neos:LivePublisher':
privileges:
-
privilegeTarget: 'Neos.Workspace.Ui:Backend.PublishAllToLiveWorkspace'
permission: GRANT

'Neos.Neos:AbstractEditor':
privileges:
-
privilegeTarget: 'Neos.Workspace.Ui:Backend.CreateWorkspaces'
permission: GRANT

-
privilegeTarget: 'Neos.Workspace.Ui:Backend.Module.Management.Workspace.ManageOwnWorkspaces'
permission: GRANT

-
privilegeTarget: 'Neos.Workspace.Ui:Backend.Module.Management.Workspace'
permission: GRANT

'Neos.Neos:Administrator':
privileges:
-
privilegeTarget: 'Neos.Workspace.Ui:Backend.Module.Management.Workspace.ManageInternalWorkspaces'
permission: GRANT

-
privilegeTarget: 'Neos.Workspace.Ui:Backend.Module.Management.Workspace.ManageAllPrivateWorkspaces'
permission: GRANT
20 changes: 0 additions & 20 deletions Neos.Workspace.Ui/Migrations/Code/Version20240603134000.php
Original file line number Diff line number Diff line change
Expand Up @@ -26,31 +26,11 @@ public function getIdentifier(): string

public function up(): void
{
$this->searchAndReplace(
'Neos.Neos:Backend.PublishAllToLiveWorkspace',
'Neos.Workspace.Ui:Backend.PublishAllToLiveWorkspace',
['yaml', 'html', 'php']
);
$this->searchAndReplace(
'Neos.Neos:Backend.CreateWorkspaces',
'Neos.Workspace.Ui:Backend.CreateWorkspaces',
['yaml', 'html', 'php']
);
$this->searchAndReplace(
'Neos.Neos:Backend.Module.Management.Workspaces.ManageOwnWorkspaces',
'Neos.Workspace.Ui:Backend.Module.Management.Workspace.ManageOwnWorkspaces',
['yaml', 'html', 'php']
);
$this->searchAndReplace(
'Neos.Neos:Backend.Module.Management.Workspaces.ManageInternalWorkspaces',
'Neos.Workspace.Ui:Backend.Module.Management.Workspace.ManageInternalWorkspaces',
['yaml', 'html', 'php']
);
$this->searchAndReplace(
'Neos.Neos:Backend.Module.Management.Workspaces.ManageAllPrivateWorkspaces',
'Neos.Workspace.Ui:Backend.Module.Management.Workspace.ManageAllPrivateWorkspaces',
['yaml', 'html', 'php']
);
$this->searchAndReplace(
'Neos.Neos:Backend.Module.Management.Workspaces',
'Neos.Workspace.Ui:Backend.Module.Management.Workspace',
Expand Down
Loading