codeq / advancedpublish
The package adds a review workflow and change logs to the Neos publication function
Installs: 1 742
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 2
Forks: 0
Open Issues: 0
Type:neos-package
Requires
- neos/neos: ^7 || ^8
- neosidekick/revisions: *
- sandstorm/templatemailer: ^2
Suggests
- ext-bz2: Install bz2 extension to compress changes content
- ext-igbinary: Install igbinary for better serialization
README
This package enforces a four-eyes-principle for publishing changes. For that reasons, every user gets an additional workspace, on which changes staged for publication are parked. The user then can request a review from an authorized user, who can then publish the changes to the live workspace. The reviewer can also reject the changes, whereupon the editor can revise the changes and request a new review.
Roles
CodeQ.AdvancedPublish:AbstractReviewer
This role can be used to give users the ability to review changes.
Using this role aims at not being fully able to publish changes,
but to be restricted later using custom filters in the CodeQ.AdvancedPublish.reviewers.filterImplementations
setting.
CodeQ.AdvancedPublish:CanReview
This role can be used to give users the ability to review changes with the aim to be able to publish changes across the site without any restriction.
CodeQ.AdvancedPublish:CanReviewOwnRequests
This role can be used to give users the ability to review their own requests.
CodeQ.AdvancedPublish:CanViewProtocol
This role can be used to give users the ability to view the publication protocol.
CodeQ.AdvancedPublish:SuperEditor
This role is allowed to see the original workspace dropdown in the Neos UI and to switch workspaces. Other users only see a simplified publish button without the option to switch workspaces.
Reviewer Filters
The package provides a flexible system to control which reviewers are allowed to publish specific content. This is implemented through reviewer filters that check if a user has the necessary permissions to publish a node.
How Reviewer Filters Work
- Each filter implements the
ReviewerFilterInterface
and returns a boolean value. - If at least one filter returns
true
, the reviewer is allowed to publish the content. - If all filters return
false
, the reviewer is not allowed to publish the content.
Implementing Custom Reviewer Filters
To create a custom reviewer filter:
- Create a class that implements
CodeQ\AdvancedPublish\Domain\Service\ReviewerFilterInterface
- Implement the
checkFilterConditionsForUserAndNode
method that returnstrue
if the user is allowed to publish the node, orfalse
otherwise - Register your filter in the Settings.yaml configuration:
CodeQ: AdvancedPublish: reviewers: filterImplementations: YourFilter: 'Your\Namespace\YourFilterClass'
Example Filter Implementation
<?php namespace Your\Namespace; use CodeQ\AdvancedPublish\Domain\Service\ReviewerFilterInterface; use CodeQ\AdvancedPublish\Domain\Service\UserService; use CodeQ\AdvancedPublish\Utility\RolesUtility; use Neos\ContentRepository\Domain\Model\NodeInterface; use Neos\Neos\Domain\Model\User; class YourFilterClass implements ReviewerFilterInterface { public function checkFilterConditionsForUserAndNode(User $user, NodeInterface $node): bool { $neosBackendAccount = UserService::findNeosBackendAccount($user); // Your custom logic to determine if the user can publish the node // Return true if allowed, false otherwise return $someCondition && RolesUtility::containsRole($neosBackendAccount->getRoles(), 'Your.Package:YourRole'); } }
Suggested project changes
Deny live publishing and manipulation of workspaces
'Neos.Flow:Everybody': privileges: - privilegeTarget: 'Neos.Neos:Backend.PublishToLiveWorkspace' permission: DENY - privilegeTarget: 'Neos.Neos:Backend.PublishAllToLiveWorkspace' permission: DENY - privilegeTarget: 'Neos.Neos:Backend.CreateWorkspaces' permission: DENY - privilegeTarget: 'Neos.Neos:Backend.Module.Management.Workspaces.ManageOwnWorkspaces' permission: DENY - privilegeTarget: 'Neos.Neos:Backend.Module.Management.Workspaces.ManageInternalWorkspaces' permission: DENY - privilegeTarget: 'Neos.Neos:Backend.Module.Management.Workspaces.ManageAllPrivateWorkspaces' permission: DENY