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.
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.
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.
This role can be used to give users the ability to review their own requests.
This role can be used to give users the ability to view the publication protocol.
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.
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.
- Each filter implements the
ReviewerFilterInterfaceand 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.
To create a custom reviewer filter:
- Create a class that implements
CodeQ\AdvancedPublish\Domain\Service\ReviewerFilterInterface - Implement the
checkFilterConditionsForUserAndNodemethod that returnstrueif the user is allowed to publish the node, orfalseotherwise - Register your filter in the Settings.yaml configuration:
CodeQ:
AdvancedPublish:
reviewers:
filterImplementations:
YourFilter: 'Your\Namespace\YourFilterClass'<?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');
}
}'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