From 06860b629b92b6060465ef6768862e42bffff900 Mon Sep 17 00:00:00 2001 From: Bartek Wajda Date: Tue, 7 Nov 2023 17:05:59 +0100 Subject: [PATCH 1/3] IBX-6592: Allowed `Location` to be a part of permission check for Object State assignment --- .../Controller/ObjectStateController.php | 13 +++-- src/bundle/Resources/config/routing.yaml | 2 +- .../admin/content/tab/details.html.twig | 3 +- .../ContentObjectStateUpdateData.php | 53 +++++++------------ .../ContentObjectStateUpdateType.php | 25 +++++---- src/lib/Tab/LocationView/DetailsTab.php | 20 +++---- src/lib/UI/Dataset/ObjectStatesDataset.php | 17 ++---- src/lib/UI/Value/ValueFactory.php | 15 +++--- 8 files changed, 71 insertions(+), 77 deletions(-) diff --git a/src/bundle/Controller/ObjectStateController.php b/src/bundle/Controller/ObjectStateController.php index e816001cb3..b06ebcec8e 100644 --- a/src/bundle/Controller/ObjectStateController.php +++ b/src/bundle/Controller/ObjectStateController.php @@ -307,7 +307,8 @@ public function updateAction(Request $request, ObjectState $objectState): Respon public function updateContentStateAction( Request $request, ContentInfo $contentInfo, - ObjectStateGroup $objectStateGroup + ObjectStateGroup $objectStateGroup, + Location $location ): Response { if (!$this->permissionResolver->hasAccess('state', 'assign')) { $exception = $this->createAccessDeniedException(); @@ -319,7 +320,7 @@ public function updateContentStateAction( $form = $this->formFactory->create( ContentObjectStateUpdateType::class, - new ContentObjectStateUpdateData($contentInfo, $objectStateGroup) + new ContentObjectStateUpdateData($contentInfo, $objectStateGroup, null, $location) ); $form->handleRequest($request); @@ -328,7 +329,13 @@ public function updateContentStateAction( $contentInfo = $data->getContentInfo(); $objectStateGroup = $data->getObjectStateGroup(); $objectState = $data->getObjectState(); - $this->objectStateService->setContentState($contentInfo, $objectStateGroup, $objectState); + $location = $data->getLocation(); + $this->objectStateService->setContentState( + $contentInfo, + $objectStateGroup, + $objectState, + $location + ); $this->notificationHandler->success( /** @Desc("Content item's Object state changed to '%name%'.") */ diff --git a/src/bundle/Resources/config/routing.yaml b/src/bundle/Resources/config/routing.yaml index 682891d70d..b1c22cd69c 100644 --- a/src/bundle/Resources/config/routing.yaml +++ b/src/bundle/Resources/config/routing.yaml @@ -821,7 +821,7 @@ ezplatform.object_state.state.bulk_delete: _controller: 'EzSystems\EzPlatformAdminUiBundle\Controller\ObjectStateController::bulkDeleteAction' ezplatform.object_state.contentstate.update: - path: /state/contentstate/update/{contentInfoId}/group/{objectStateGroupId} + path: /state/contentstate/update/{contentInfoId}/group/{objectStateGroupId}/{locationId} defaults: _controller: 'EzSystems\EzPlatformAdminUiBundle\Controller\ObjectStateController::updateContentStateAction' diff --git a/src/bundle/Resources/views/themes/admin/content/tab/details.html.twig b/src/bundle/Resources/views/themes/admin/content/tab/details.html.twig index 105c515d88..e4a1ce6b4c 100644 --- a/src/bundle/Resources/views/themes/admin/content/tab/details.html.twig +++ b/src/bundle/Resources/views/themes/admin/content/tab/details.html.twig @@ -125,7 +125,8 @@ 'method': 'POST', 'action': path('ezplatform.object_state.contentstate.update', { 'contentInfoId': content_info.id, - 'objectStateGroupId': object_state.objectStateGroup.id + 'objectStateGroupId': object_state.objectStateGroup.id, + 'locationId': location.id, }), 'attr': {'class': 'form-inline ez-form-inline ez-form-inline--align-left'} }) }} diff --git a/src/lib/Form/Data/ObjectState/ContentObjectStateUpdateData.php b/src/lib/Form/Data/ObjectState/ContentObjectStateUpdateData.php index 2ccb84d544..7b8dbbfe9c 100644 --- a/src/lib/Form/Data/ObjectState/ContentObjectStateUpdateData.php +++ b/src/lib/Form/Data/ObjectState/ContentObjectStateUpdateData.php @@ -9,86 +9,73 @@ namespace EzSystems\EzPlatformAdminUi\Form\Data\ObjectState; use eZ\Publish\API\Repository\Values\Content\ContentInfo; +use eZ\Publish\API\Repository\Values\Content\Location; use eZ\Publish\API\Repository\Values\ObjectState\ObjectState; use eZ\Publish\API\Repository\Values\ObjectState\ObjectStateGroup; class ContentObjectStateUpdateData { - /** - * @var \eZ\Publish\API\Repository\Values\Content\ContentInfo - */ + /** @var \eZ\Publish\API\Repository\Values\Content\ContentInfo|null */ private $contentInfo; - /** - * @var \eZ\Publish\API\Repository\Values\ObjectState\ObjectStateGroup - */ + /** @var \eZ\Publish\API\Repository\Values\ObjectState\ObjectStateGroup|null */ private $objectStateGroup; - /** - * @var \eZ\Publish\API\Repository\Values\ObjectState\ObjectState - */ + /** @var \eZ\Publish\API\Repository\Values\ObjectState\ObjectState|null rm -r*/ private $objectState; - /** - * @param \eZ\Publish\API\Repository\Values\Content\ContentInfo|null $contentInfo - * @param \eZ\Publish\API\Repository\Values\ObjectState\ObjectStateGroup|null $objectStateGroup - * @param \eZ\Publish\API\Repository\Values\ObjectState\ObjectState|null $objectState - */ + /** @var \eZ\Publish\API\Repository\Values\Content\Location|null */ + private $location; + public function __construct( ContentInfo $contentInfo = null, ObjectStateGroup $objectStateGroup = null, - ObjectState $objectState = null + ObjectState $objectState = null, + Location $location = null ) { $this->contentInfo = $contentInfo; $this->objectStateGroup = $objectStateGroup; $this->objectState = $objectState; + $this->location = $location; } - /** - * @return \eZ\Publish\API\Repository\Values\Content\ContentInfo - */ public function getContentInfo(): ContentInfo { return $this->contentInfo; } - /** - * @param \eZ\Publish\API\Repository\Values\Content\ContentInfo $contentInfo - */ public function setContentInfo(ContentInfo $contentInfo) { $this->contentInfo = $contentInfo; } - /** - * @return \eZ\Publish\API\Repository\Values\ObjectState\ObjectStateGroup - */ public function getObjectStateGroup(): ObjectStateGroup { return $this->objectStateGroup; } - /** - * @param \eZ\Publish\API\Repository\Values\ObjectState\ObjectStateGroup $objectStateGroup - */ public function setObjectStateGroup(ObjectStateGroup $objectStateGroup) { $this->objectStateGroup = $objectStateGroup; } - /** - * @return \eZ\Publish\API\Repository\Values\ObjectState\ObjectState|null - */ public function getObjectState(): ?ObjectState { return $this->objectState; } - /** - * @param \eZ\Publish\API\Repository\Values\ObjectState\ObjectState $objectState - */ public function setObjectState(ObjectState $objectState) { $this->objectState = $objectState; } + + public function getLocation(): ?Location + { + return $this->location; + } + + public function setLocation(Location $location) + { + $this->location = $location; + } } diff --git a/src/lib/Form/Type/ObjectState/ContentObjectStateUpdateType.php b/src/lib/Form/Type/ObjectState/ContentObjectStateUpdateType.php index f419ae7af1..85470084d2 100644 --- a/src/lib/Form/Type/ObjectState/ContentObjectStateUpdateType.php +++ b/src/lib/Form/Type/ObjectState/ContentObjectStateUpdateType.php @@ -60,20 +60,25 @@ public function buildForm(FormBuilderInterface $builder, array $options) $contentObjectStateUpdateData = $event->getData(); $objectStateGroup = $contentObjectStateUpdateData->getObjectStateGroup(); $contentInfo = $contentObjectStateUpdateData->getContentInfo(); + $location = $contentObjectStateUpdateData->getLocation(); $form = $event->getForm(); $form->add('objectState', ObjectStateChoiceType::class, [ 'label' => false, - 'choice_loader' => new CallbackChoiceLoader(function () use ($objectStateGroup, $contentInfo) { - $contentState = $this->objectStateService->getContentState($contentInfo, $objectStateGroup); - - return array_filter( - $this->objectStateService->loadObjectStates($objectStateGroup), - function (ObjectState $objectState) use ($contentInfo, $contentState) { - return $this->permissionResolver->canUser('state', 'assign', $contentInfo, [$objectState]); - } - ); - }), + 'choice_loader' => new CallbackChoiceLoader( + function () use ($objectStateGroup, $contentInfo, $location) { + return array_filter( + $this->objectStateService->loadObjectStates($objectStateGroup), + function (ObjectState $objectState) use ($contentInfo, $location) { + return $this->permissionResolver->canUser( + 'state', + 'assign', + $contentInfo, + [$location, $objectState], + ); + } + ); + }), ]); }); } diff --git a/src/lib/Tab/LocationView/DetailsTab.php b/src/lib/Tab/LocationView/DetailsTab.php index b439ea0892..cca0d6e878 100644 --- a/src/lib/Tab/LocationView/DetailsTab.php +++ b/src/lib/Tab/LocationView/DetailsTab.php @@ -133,7 +133,7 @@ public function getTemplateParameters(array $contextParameters = []): array ]); $this->supplySectionParameters($viewParameters, $contentInfo, $location); - $this->supplyObjectStateParameters($viewParameters, $contentInfo); + $this->supplyObjectStateParameters($viewParameters, $contentInfo, $location); $this->supplyTranslations($viewParameters, $versionInfo); $this->supplyFormLocationUpdate($viewParameters, $location); $this->supplyCreator($viewParameters, $contentInfo); @@ -185,14 +185,13 @@ private function supplyLastContributor(ArrayObject $parameters, VersionInfo $ver } } - /** - * @param \ArrayObject $parameters - * @param \eZ\Publish\API\Repository\Values\Content\ContentInfo $contentInfo - */ - private function supplyObjectStateParameters(ArrayObject &$parameters, ContentInfo $contentInfo): void - { + private function supplyObjectStateParameters( + ArrayObject &$parameters, + ContentInfo $contentInfo, + Location $location + ): void { $objectStatesDataset = $this->datasetFactory->objectStates(); - $objectStatesDataset->load($contentInfo); + $objectStatesDataset->load($contentInfo, $location); $canAssignObjectState = $this->canUserAssignObjectState(); @@ -206,7 +205,10 @@ private function supplyObjectStateParameters(ArrayObject &$parameters, ContentIn $objectStateUpdateForm = $this->formFactory->create( ContentObjectStateUpdateType::class, new ContentObjectStateUpdateData( - $contentInfo, $objectStateGroup, $objectState + $contentInfo, + $objectStateGroup, + $objectState, + $location, ) )->createView(); diff --git a/src/lib/UI/Dataset/ObjectStatesDataset.php b/src/lib/UI/Dataset/ObjectStatesDataset.php index 941de114b1..31a31f8ed8 100644 --- a/src/lib/UI/Dataset/ObjectStatesDataset.php +++ b/src/lib/UI/Dataset/ObjectStatesDataset.php @@ -10,6 +10,7 @@ use eZ\Publish\API\Repository\ObjectStateService; use eZ\Publish\API\Repository\Values\Content\ContentInfo; +use eZ\Publish\API\Repository\Values\Content\Location; use eZ\Publish\API\Repository\Values\ObjectState\ObjectStateGroup; use EzSystems\EzPlatformAdminUi\UI\Value as UIValue; use EzSystems\EzPlatformAdminUi\UI\Value\ValueFactory; @@ -25,31 +26,21 @@ class ObjectStatesDataset /** @var UIValue\ObjectState\ObjectState[] */ protected $data; - /** - * @param \eZ\Publish\API\Repository\ObjectStateService $objectStateService - * @param \EzSystems\EzPlatformAdminUi\UI\Value\ValueFactory $valueFactory - */ public function __construct(ObjectStateService $objectStateService, ValueFactory $valueFactory) { $this->objectStateService = $objectStateService; $this->valueFactory = $valueFactory; } - - /** - * @param \eZ\Publish\API\Repository\Values\Content\ContentInfo $contentInfo - * - * @return ObjectStatesDataset - */ - public function load(ContentInfo $contentInfo): self + public function load(ContentInfo $contentInfo, Location $location): self { $data = array_map( - function (ObjectStateGroup $objectStateGroup) use ($contentInfo) { + function (ObjectStateGroup $objectStateGroup) use ($contentInfo, $location) { $hasObjectStates = !empty($this->objectStateService->loadObjectStates($objectStateGroup)); if (!$hasObjectStates) { return []; } - return $this->valueFactory->createObjectState($contentInfo, $objectStateGroup); + return $this->valueFactory->createObjectState($contentInfo, $objectStateGroup, $location); }, $this->objectStateService->loadObjectStateGroups() ); diff --git a/src/lib/UI/Value/ValueFactory.php b/src/lib/UI/Value/ValueFactory.php index 3012135ec0..7c5a783272 100644 --- a/src/lib/UI/Value/ValueFactory.php +++ b/src/lib/UI/Value/ValueFactory.php @@ -253,22 +253,23 @@ public function createLocation(Location $location): UIValue\Content\Location } /** - * @param \eZ\Publish\API\Repository\Values\Content\ContentInfo $contentInfo - * @param \eZ\Publish\API\Repository\Values\ObjectState\ObjectStateGroup $objectStateGroup - * - * @return UIValue\ObjectState\ObjectState - * * @throws \eZ\Publish\API\Repository\Exceptions\BadStateException * @throws \eZ\Publish\API\Repository\Exceptions\InvalidArgumentException */ public function createObjectState( ContentInfo $contentInfo, - ObjectStateGroup $objectStateGroup + ObjectStateGroup $objectStateGroup, + Location $location ): UIValue\ObjectState\ObjectState { $objectState = $this->objectStateService->getContentState($contentInfo, $objectStateGroup); return new UIValue\ObjectState\ObjectState($objectState, [ - 'userCanAssign' => $this->permissionResolver->canUser('state', 'assign', $contentInfo, [$objectState]), + 'userCanAssign' => $this->permissionResolver->canUser( + 'state', + 'assign', + $contentInfo, + [$location, $objectState], + ), ]); } From e47a00196a6271a762cf112953b3df0cb55ca1b4 Mon Sep 17 00:00:00 2001 From: Bartek Wajda Date: Wed, 8 Nov 2023 12:22:51 +0100 Subject: [PATCH 2/3] IBX-6592: CS --- src/lib/Form/Data/ObjectState/ContentObjectStateUpdateData.php | 2 +- src/lib/UI/Dataset/ObjectStatesDataset.php | 1 + 2 files changed, 2 insertions(+), 1 deletion(-) diff --git a/src/lib/Form/Data/ObjectState/ContentObjectStateUpdateData.php b/src/lib/Form/Data/ObjectState/ContentObjectStateUpdateData.php index 7b8dbbfe9c..58d78d51b0 100644 --- a/src/lib/Form/Data/ObjectState/ContentObjectStateUpdateData.php +++ b/src/lib/Form/Data/ObjectState/ContentObjectStateUpdateData.php @@ -21,7 +21,7 @@ class ContentObjectStateUpdateData /** @var \eZ\Publish\API\Repository\Values\ObjectState\ObjectStateGroup|null */ private $objectStateGroup; - /** @var \eZ\Publish\API\Repository\Values\ObjectState\ObjectState|null rm -r*/ + /** @var \eZ\Publish\API\Repository\Values\ObjectState\ObjectState|null */ private $objectState; /** @var \eZ\Publish\API\Repository\Values\Content\Location|null */ diff --git a/src/lib/UI/Dataset/ObjectStatesDataset.php b/src/lib/UI/Dataset/ObjectStatesDataset.php index 31a31f8ed8..c06344661c 100644 --- a/src/lib/UI/Dataset/ObjectStatesDataset.php +++ b/src/lib/UI/Dataset/ObjectStatesDataset.php @@ -31,6 +31,7 @@ public function __construct(ObjectStateService $objectStateService, ValueFactory $this->objectStateService = $objectStateService; $this->valueFactory = $valueFactory; } + public function load(ContentInfo $contentInfo, Location $location): self { $data = array_map( From 7e135a6df44aff4f6201010175190d70154ae68a Mon Sep 17 00:00:00 2001 From: Bartek Wajda Date: Wed, 8 Nov 2023 12:45:35 +0100 Subject: [PATCH 3/3] IBX-6592: Refactored solution to base Object State on Location instead of ContentInfo --- .../Controller/ObjectStateController.php | 22 ++++++---------- src/bundle/Resources/config/routing.yaml | 2 +- .../admin/content/tab/details.html.twig | 2 -- .../ContentObjectStateUpdateData.php | 16 ------------ .../ContentObjectStateUpdateType.php | 25 ++++++------------- src/lib/Tab/LocationView/DetailsTab.php | 11 +++++--- src/lib/UI/Dataset/ObjectStatesDataset.php | 7 +++--- src/lib/UI/Value/ValueFactory.php | 3 +-- 8 files changed, 27 insertions(+), 61 deletions(-) diff --git a/src/bundle/Controller/ObjectStateController.php b/src/bundle/Controller/ObjectStateController.php index b06ebcec8e..bec40959b2 100644 --- a/src/bundle/Controller/ObjectStateController.php +++ b/src/bundle/Controller/ObjectStateController.php @@ -10,7 +10,7 @@ use eZ\Publish\API\Repository\ObjectStateService; use eZ\Publish\API\Repository\PermissionResolver; -use eZ\Publish\API\Repository\Values\Content\ContentInfo; +use eZ\Publish\API\Repository\Values\Content\Location; use eZ\Publish\API\Repository\Values\ObjectState\ObjectState; use eZ\Publish\API\Repository\Values\ObjectState\ObjectStateGroup; use eZ\Publish\Core\MVC\ConfigResolverInterface; @@ -296,17 +296,10 @@ public function updateAction(Request $request, ObjectState $objectState): Respon } /** - * @param \Symfony\Component\HttpFoundation\Request $request - * @param \eZ\Publish\API\Repository\Values\Content\ContentInfo $contentInfo - * @param \eZ\Publish\API\Repository\Values\ObjectState\ObjectStateGroup $objectStateGroup - * - * @return \Symfony\Component\HttpFoundation\Response - * * @throws \eZ\Publish\API\Repository\Exceptions\InvalidArgumentException */ public function updateContentStateAction( Request $request, - ContentInfo $contentInfo, ObjectStateGroup $objectStateGroup, Location $location ): Response { @@ -320,18 +313,19 @@ public function updateContentStateAction( $form = $this->formFactory->create( ContentObjectStateUpdateType::class, - new ContentObjectStateUpdateData($contentInfo, $objectStateGroup, null, $location) + new ContentObjectStateUpdateData($objectStateGroup, null, $location) ); $form->handleRequest($request); + $contentInfo = $location->getContentInfo(); + if ($form->isSubmitted()) { $result = $this->submitHandler->handle($form, function (ContentObjectStateUpdateData $data) { - $contentInfo = $data->getContentInfo(); + $location = $data->getLocation(); $objectStateGroup = $data->getObjectStateGroup(); $objectState = $data->getObjectState(); - $location = $data->getLocation(); $this->objectStateService->setContentState( - $contentInfo, + $location->getContentInfo(), $objectStateGroup, $objectState, $location @@ -351,8 +345,8 @@ public function updateContentStateAction( } return $this->redirectToRoute('_ez_content_view', [ - 'contentId' => $contentInfo->id, - 'locationId' => $contentInfo->mainLocationId, + 'contentId' => $contentInfo->getId(), + 'locationId' => $contentInfo->getMainLocationId(), '_fragment' => 'ez-tab-location-view-details', ]); } diff --git a/src/bundle/Resources/config/routing.yaml b/src/bundle/Resources/config/routing.yaml index b1c22cd69c..a94751a578 100644 --- a/src/bundle/Resources/config/routing.yaml +++ b/src/bundle/Resources/config/routing.yaml @@ -821,7 +821,7 @@ ezplatform.object_state.state.bulk_delete: _controller: 'EzSystems\EzPlatformAdminUiBundle\Controller\ObjectStateController::bulkDeleteAction' ezplatform.object_state.contentstate.update: - path: /state/contentstate/update/{contentInfoId}/group/{objectStateGroupId}/{locationId} + path: /state/contentstate/update/{locationId}/group/{objectStateGroupId} defaults: _controller: 'EzSystems\EzPlatformAdminUiBundle\Controller\ObjectStateController::updateContentStateAction' diff --git a/src/bundle/Resources/views/themes/admin/content/tab/details.html.twig b/src/bundle/Resources/views/themes/admin/content/tab/details.html.twig index e4a1ce6b4c..d86ffb7b57 100644 --- a/src/bundle/Resources/views/themes/admin/content/tab/details.html.twig +++ b/src/bundle/Resources/views/themes/admin/content/tab/details.html.twig @@ -124,13 +124,11 @@ {{ form_start(form_state_update[object_state.objectStateGroup.id], { 'method': 'POST', 'action': path('ezplatform.object_state.contentstate.update', { - 'contentInfoId': content_info.id, 'objectStateGroupId': object_state.objectStateGroup.id, 'locationId': location.id, }), 'attr': {'class': 'form-inline ez-form-inline ez-form-inline--align-left'} }) }} - {{ form_row(form_state_update[object_state.objectStateGroup.id].contentInfo) }} {{ form_row(form_state_update[object_state.objectStateGroup.id].objectStateGroup) }} {{ form_row(form_state_update[object_state.objectStateGroup.id].objectState, { 'attr': {'class': 'ez-form-autosubmit'} }) }} {% do form_state_update[object_state.objectStateGroup.id].set.setRendered %} diff --git a/src/lib/Form/Data/ObjectState/ContentObjectStateUpdateData.php b/src/lib/Form/Data/ObjectState/ContentObjectStateUpdateData.php index 58d78d51b0..9b9d4fbf65 100644 --- a/src/lib/Form/Data/ObjectState/ContentObjectStateUpdateData.php +++ b/src/lib/Form/Data/ObjectState/ContentObjectStateUpdateData.php @@ -8,16 +8,12 @@ namespace EzSystems\EzPlatformAdminUi\Form\Data\ObjectState; -use eZ\Publish\API\Repository\Values\Content\ContentInfo; use eZ\Publish\API\Repository\Values\Content\Location; use eZ\Publish\API\Repository\Values\ObjectState\ObjectState; use eZ\Publish\API\Repository\Values\ObjectState\ObjectStateGroup; class ContentObjectStateUpdateData { - /** @var \eZ\Publish\API\Repository\Values\Content\ContentInfo|null */ - private $contentInfo; - /** @var \eZ\Publish\API\Repository\Values\ObjectState\ObjectStateGroup|null */ private $objectStateGroup; @@ -28,27 +24,15 @@ class ContentObjectStateUpdateData private $location; public function __construct( - ContentInfo $contentInfo = null, ObjectStateGroup $objectStateGroup = null, ObjectState $objectState = null, Location $location = null ) { - $this->contentInfo = $contentInfo; $this->objectStateGroup = $objectStateGroup; $this->objectState = $objectState; $this->location = $location; } - public function getContentInfo(): ContentInfo - { - return $this->contentInfo; - } - - public function setContentInfo(ContentInfo $contentInfo) - { - $this->contentInfo = $contentInfo; - } - public function getObjectStateGroup(): ObjectStateGroup { return $this->objectStateGroup; diff --git a/src/lib/Form/Type/ObjectState/ContentObjectStateUpdateType.php b/src/lib/Form/Type/ObjectState/ContentObjectStateUpdateType.php index 85470084d2..447d782694 100644 --- a/src/lib/Form/Type/ObjectState/ContentObjectStateUpdateType.php +++ b/src/lib/Form/Type/ObjectState/ContentObjectStateUpdateType.php @@ -12,7 +12,7 @@ use eZ\Publish\API\Repository\PermissionResolver; use eZ\Publish\API\Repository\Values\ObjectState\ObjectState; use EzSystems\EzPlatformAdminUi\Form\Data\ObjectState\ContentObjectStateUpdateData; -use EzSystems\EzPlatformAdminUi\Form\Type\Content\ContentInfoType; +use EzSystems\EzPlatformAdminUi\Form\Type\Content\LocationType; use Symfony\Component\Form\AbstractType; use Symfony\Component\Form\ChoiceList\Loader\CallbackChoiceLoader; use Symfony\Component\Form\Extension\Core\Type\SubmitType; @@ -29,23 +29,16 @@ class ContentObjectStateUpdateType extends AbstractType /** @var \eZ\Publish\API\Repository\PermissionResolver */ private $permissionResolver; - /** - * @param \eZ\Publish\API\Repository\ObjectStateService $objectStateService - * @param \eZ\Publish\API\Repository\PermissionResolver $permissionResolver - */ public function __construct(ObjectStateService $objectStateService, PermissionResolver $permissionResolver) { $this->objectStateService = $objectStateService; $this->permissionResolver = $permissionResolver; } - /** - * @inheritdoc - */ - public function buildForm(FormBuilderInterface $builder, array $options) + public function buildForm(FormBuilderInterface $builder, array $options): void { $builder - ->add('contentInfo', ContentInfoType::class, [ + ->add('location', LocationType::class, [ 'label' => false, ]) ->add('objectStateGroup', ObjectStateGroupType::class, [ @@ -59,21 +52,20 @@ public function buildForm(FormBuilderInterface $builder, array $options) /** @var \EzSystems\EzPlatformAdminUi\Form\Data\ObjectState\ContentObjectStateUpdateData $contentObjectStateUpdateData */ $contentObjectStateUpdateData = $event->getData(); $objectStateGroup = $contentObjectStateUpdateData->getObjectStateGroup(); - $contentInfo = $contentObjectStateUpdateData->getContentInfo(); $location = $contentObjectStateUpdateData->getLocation(); $form = $event->getForm(); $form->add('objectState', ObjectStateChoiceType::class, [ 'label' => false, 'choice_loader' => new CallbackChoiceLoader( - function () use ($objectStateGroup, $contentInfo, $location) { + function () use ($objectStateGroup, $location) { return array_filter( $this->objectStateService->loadObjectStates($objectStateGroup), - function (ObjectState $objectState) use ($contentInfo, $location) { + function (ObjectState $objectState) use ($location) { return $this->permissionResolver->canUser( 'state', 'assign', - $contentInfo, + $location->getContentInfo(), [$location, $objectState], ); } @@ -83,10 +75,7 @@ function (ObjectState $objectState) use ($contentInfo, $location) { }); } - /** - * @inheritdoc - */ - public function configureOptions(OptionsResolver $resolver) + public function configureOptions(OptionsResolver $resolver): void { $resolver->setDefaults([ 'data_class' => ContentObjectStateUpdateData::class, diff --git a/src/lib/Tab/LocationView/DetailsTab.php b/src/lib/Tab/LocationView/DetailsTab.php index cca0d6e878..43b02d61b3 100644 --- a/src/lib/Tab/LocationView/DetailsTab.php +++ b/src/lib/Tab/LocationView/DetailsTab.php @@ -116,6 +116,8 @@ public function getTemplate(): string /** * @inheritdoc + * + * @throws \eZ\Publish\API\Repository\Exceptions\InvalidArgumentException */ public function getTemplateParameters(array $contextParameters = []): array { @@ -133,7 +135,7 @@ public function getTemplateParameters(array $contextParameters = []): array ]); $this->supplySectionParameters($viewParameters, $contentInfo, $location); - $this->supplyObjectStateParameters($viewParameters, $contentInfo, $location); + $this->supplyObjectStateParameters($viewParameters, $location); $this->supplyTranslations($viewParameters, $versionInfo); $this->supplyFormLocationUpdate($viewParameters, $location); $this->supplyCreator($viewParameters, $contentInfo); @@ -185,13 +187,15 @@ private function supplyLastContributor(ArrayObject $parameters, VersionInfo $ver } } + /** + * @throws \eZ\Publish\API\Repository\Exceptions\InvalidArgumentException + */ private function supplyObjectStateParameters( ArrayObject &$parameters, - ContentInfo $contentInfo, Location $location ): void { $objectStatesDataset = $this->datasetFactory->objectStates(); - $objectStatesDataset->load($contentInfo, $location); + $objectStatesDataset->load($location); $canAssignObjectState = $this->canUserAssignObjectState(); @@ -205,7 +209,6 @@ private function supplyObjectStateParameters( $objectStateUpdateForm = $this->formFactory->create( ContentObjectStateUpdateType::class, new ContentObjectStateUpdateData( - $contentInfo, $objectStateGroup, $objectState, $location, diff --git a/src/lib/UI/Dataset/ObjectStatesDataset.php b/src/lib/UI/Dataset/ObjectStatesDataset.php index c06344661c..e7780b15f2 100644 --- a/src/lib/UI/Dataset/ObjectStatesDataset.php +++ b/src/lib/UI/Dataset/ObjectStatesDataset.php @@ -9,7 +9,6 @@ namespace EzSystems\EzPlatformAdminUi\UI\Dataset; use eZ\Publish\API\Repository\ObjectStateService; -use eZ\Publish\API\Repository\Values\Content\ContentInfo; use eZ\Publish\API\Repository\Values\Content\Location; use eZ\Publish\API\Repository\Values\ObjectState\ObjectStateGroup; use EzSystems\EzPlatformAdminUi\UI\Value as UIValue; @@ -32,16 +31,16 @@ public function __construct(ObjectStateService $objectStateService, ValueFactory $this->valueFactory = $valueFactory; } - public function load(ContentInfo $contentInfo, Location $location): self + public function load(Location $location): self { $data = array_map( - function (ObjectStateGroup $objectStateGroup) use ($contentInfo, $location) { + function (ObjectStateGroup $objectStateGroup) use ($location) { $hasObjectStates = !empty($this->objectStateService->loadObjectStates($objectStateGroup)); if (!$hasObjectStates) { return []; } - return $this->valueFactory->createObjectState($contentInfo, $objectStateGroup, $location); + return $this->valueFactory->createObjectState($objectStateGroup, $location); }, $this->objectStateService->loadObjectStateGroups() ); diff --git a/src/lib/UI/Value/ValueFactory.php b/src/lib/UI/Value/ValueFactory.php index 7c5a783272..0562c096df 100644 --- a/src/lib/UI/Value/ValueFactory.php +++ b/src/lib/UI/Value/ValueFactory.php @@ -16,7 +16,6 @@ use eZ\Publish\API\Repository\SearchService; use eZ\Publish\API\Repository\UserService; use eZ\Publish\API\Repository\Values\Content\Content; -use eZ\Publish\API\Repository\Values\Content\ContentInfo; use eZ\Publish\API\Repository\Values\Content\DraftList\Item\ContentDraftListItem; use eZ\Publish\API\Repository\Values\Content\DraftList\Item\UnauthorizedContentDraftListItem; use eZ\Publish\API\Repository\Values\Content\Language; @@ -257,10 +256,10 @@ public function createLocation(Location $location): UIValue\Content\Location * @throws \eZ\Publish\API\Repository\Exceptions\InvalidArgumentException */ public function createObjectState( - ContentInfo $contentInfo, ObjectStateGroup $objectStateGroup, Location $location ): UIValue\ObjectState\ObjectState { + $contentInfo = $location->getContentInfo(); $objectState = $this->objectStateService->getContentState($contentInfo, $objectStateGroup); return new UIValue\ObjectState\ObjectState($objectState, [