Skip to content

Commit

Permalink
Adjust to workspace aware commands
Browse files Browse the repository at this point in the history
  • Loading branch information
Bernhard Schmitt authored and mhsdesign committed Mar 14, 2024
1 parent e3697ee commit dd0b92c
Show file tree
Hide file tree
Showing 11 changed files with 83 additions and 25 deletions.
4 changes: 2 additions & 2 deletions Classes/ContentRepository/Service/WorkspaceService.php
Original file line number Diff line number Diff line change
Expand Up @@ -179,13 +179,13 @@ public function predictRemoveNodeFeedbackFromDiscardIndividualNodesFromWorkspace
}

if (
$nodeToDiscard->contentStreamId->equals($change->contentStreamId)
$nodeToDiscard->workspaceName->equals($workspace->workspaceName)
&& $nodeToDiscard->nodeAggregateId->equals($change->nodeAggregateId)
&& $nodeToDiscard->dimensionSpacePoint->equals($change->originDimensionSpacePoint)
) {
$subgraph = $contentRepository->getContentGraph()
->getSubgraph(
$nodeToDiscard->contentStreamId,
$workspace->currentContentStreamId,
$nodeToDiscard->dimensionSpacePoint,
VisibilityConstraints::withoutRestrictions()
);
Expand Down
4 changes: 2 additions & 2 deletions Classes/Controller/BackendServiceController.php
Original file line number Diff line number Diff line change
Expand Up @@ -221,7 +221,7 @@ public function publishAction(array $nodeContextPaths, string $targetWorkspaceNa
foreach ($nodeContextPaths as $contextPath) {
$nodeAddress = $nodeAddressFactory->createFromUriString($contextPath);
$nodeIdentifiersToPublish[] = new NodeIdToPublishOrDiscard(
$nodeAddress->contentStreamId,
$workspaceName,
$nodeAddress->nodeAggregateId,
$nodeAddress->dimensionSpacePoint
);
Expand Down Expand Up @@ -279,7 +279,7 @@ public function discardAction(array $nodeContextPaths): void
foreach ($nodeContextPaths as $contextPath) {
$nodeAddress = $nodeAddressFactory->createFromUriString($contextPath);
$nodeIdentifiersToDiscard[] = new NodeIdToPublishOrDiscard(
$nodeAddress->contentStreamId,
$workspaceName,
$nodeAddress->nodeAggregateId,
$nodeAddress->dimensionSpacePoint
);
Expand Down
12 changes: 10 additions & 2 deletions Classes/Domain/Model/Changes/AbstractCreate.php
Original file line number Diff line number Diff line change
Expand Up @@ -108,16 +108,24 @@ protected function createNode(

$nodeAggregateId = NodeAggregateId::create(); // generate a new NodeAggregateId

$contentRepository = $this->contentRepositoryRegistry->get($parentNode->subgraphIdentity->contentRepositoryId);
$workspace = $this->contentRepositoryRegistry->get($this->subject->subgraphIdentity->contentRepositoryId)
->getWorkspaceFinder()->findOneByCurrentContentStreamId($parentNode->subgraphIdentity->contentStreamId);
if (!$workspace) {
throw new \Exception(
'Could not find workspace for content stream "' . $parentNode->subgraphIdentity->contentStreamId->value . '"',
1699008140
);
}
$command = CreateNodeAggregateWithNode::create(
$parentNode->subgraphIdentity->contentStreamId,
$workspace->workspaceName,
$nodeAggregateId,
$nodeTypeName,
OriginDimensionSpacePoint::fromDimensionSpacePoint($parentNode->subgraphIdentity->dimensionSpacePoint),
$parentNode->nodeAggregateId,
$succeedingSiblingNodeAggregateId,
$nodeName
);
$contentRepository = $this->contentRepositoryRegistry->get($parentNode->subgraphIdentity->contentRepositoryId);

$command = $this->applyNodeCreationHandlers($command, $nodeTypeName, $contentRepository);

Expand Down
5 changes: 5 additions & 0 deletions Classes/Domain/Model/Changes/CopyAfter.php
Original file line number Diff line number Diff line change
Expand Up @@ -71,12 +71,17 @@ public function apply(): void
$targetNodeName = NodeName::fromString(uniqid('node-'));

$contentRepository = $this->contentRepositoryRegistry->get($subject->subgraphIdentity->contentRepositoryId);
$workspace = $contentRepository->getWorkspaceFinder()->findOneByCurrentContentStreamId($subject->subgraphIdentity->contentStreamId);
if (!$workspace) {
throw new \Exception('Could not find workspace for content stream', 1699004343);
}
$command = CopyNodesRecursively::createFromSubgraphAndStartNode(
$contentRepository->getContentGraph()->getSubgraph(
$subject->subgraphIdentity->contentStreamId,
$subject->subgraphIdentity->dimensionSpacePoint,
VisibilityConstraints::withoutRestrictions()
),
$workspace->workspaceName,
$subject,
OriginDimensionSpacePoint::fromDimensionSpacePoint($subject->subgraphIdentity->dimensionSpacePoint),
$parentNodeOfPreviousSibling->nodeAggregateId,
Expand Down
6 changes: 5 additions & 1 deletion Classes/Domain/Model/Changes/CopyBefore.php
Original file line number Diff line number Diff line change
Expand Up @@ -63,13 +63,17 @@ public function apply(): void
) {
$targetNodeName = NodeName::fromString(uniqid('node-'));

$contentRepository = $this->contentRepositoryRegistry->get($subject->subgraphIdentity->contentRepositoryId);
$contentRepository = $this->contentRepositoryRegistry->get($subject->subgraphIdentity->contentRepositoryId);$workspace = $contentRepository->getWorkspaceFinder()->findOneByCurrentContentStreamId($subject->subgraphIdentity->contentStreamId);
if (!$workspace) {
throw new \Exception('Could not find workspace for content stream', 1699004343);
}
$command = CopyNodesRecursively::createFromSubgraphAndStartNode(
$contentRepository->getContentGraph()->getSubgraph(
$subject->subgraphIdentity->contentStreamId,
$subject->subgraphIdentity->dimensionSpacePoint,
$subject->subgraphIdentity->visibilityConstraints
),
$workspace->workspaceName,
$subject,
OriginDimensionSpacePoint::fromDimensionSpacePoint($subject->subgraphIdentity->dimensionSpacePoint),
$parentNodeOfSucceedingSibling->nodeAggregateId,
Expand Down
5 changes: 5 additions & 0 deletions Classes/Domain/Model/Changes/CopyInto.php
Original file line number Diff line number Diff line change
Expand Up @@ -72,12 +72,17 @@ public function apply(): void
$targetNodeName = NodeName::fromString(uniqid('node-'));

$contentRepository = $this->contentRepositoryRegistry->get($subject->subgraphIdentity->contentRepositoryId);
$workspace = $contentRepository->getWorkspaceFinder()->findOneByCurrentContentStreamId($subject->subgraphIdentity->contentStreamId);
if (!$workspace) {
throw new \Exception('Could not find workspace for content stream', 1699004343);
}
$command = CopyNodesRecursively::createFromSubgraphAndStartNode(
$contentRepository->getContentGraph()->getSubgraph(
$subject->subgraphIdentity->contentStreamId,
$subject->subgraphIdentity->dimensionSpacePoint,
$subject->subgraphIdentity->visibilityConstraints
),
$workspace->workspaceName,
$subject,
OriginDimensionSpacePoint::fromDimensionSpacePoint($subject->subgraphIdentity->dimensionSpacePoint),
$parentNode->nodeAggregateId,
Expand Down
15 changes: 12 additions & 3 deletions Classes/Domain/Model/Changes/MoveAfter.php
Original file line number Diff line number Diff line change
Expand Up @@ -76,17 +76,26 @@ public function apply(): void
$hasEqualParentNode = $parentNode->nodeAggregateId
->equals($parentNodeOfPreviousSibling->nodeAggregateId);


$contentRepository = $this->contentRepositoryRegistry->get($subject->subgraphIdentity->contentRepositoryId);
$workspace = $this->contentRepositoryRegistry->get($this->subject->subgraphIdentity->contentRepositoryId)
->getWorkspaceFinder()->findOneByCurrentContentStreamId($subject->subgraphIdentity->contentStreamId);
if (!$workspace) {
throw new \Exception(
'Could not find workspace for content stream "' . $subject->subgraphIdentity->contentStreamId->value . '"',
1699008140
);
}

$command = MoveNodeAggregate::create(
$subject->subgraphIdentity->contentStreamId,
$workspace->workspaceName,
$subject->subgraphIdentity->dimensionSpacePoint,
$subject->nodeAggregateId,
RelationDistributionStrategy::STRATEGY_GATHER_ALL,
$hasEqualParentNode ? null : $parentNodeOfPreviousSibling->nodeAggregateId,
$precedingSibling->nodeAggregateId,
$succeedingSibling?->nodeAggregateId,
);

$contentRepository = $this->contentRepositoryRegistry->get($subject->subgraphIdentity->contentRepositoryId);
$contentRepository->handle($command)->block();

$updateParentNodeInfo = new UpdateNodeInfo();
Expand Down
11 changes: 9 additions & 2 deletions Classes/Domain/Model/Changes/MoveBefore.php
Original file line number Diff line number Diff line change
Expand Up @@ -71,11 +71,18 @@ public function apply(): void
$hasEqualParentNode = $parentNode->nodeAggregateId
->equals($succeedingSiblingParent->nodeAggregateId);

$contentRepository = $this->contentRepositoryRegistry->get($subject->subgraphIdentity->contentRepositoryId);
$contentRepository = $this->contentRepositoryRegistry->get($subject->subgraphIdentity->contentRepositoryId);$workspace = $this->contentRepositoryRegistry->get($this->subject->subgraphIdentity->contentRepositoryId)
->getWorkspaceFinder()->findOneByCurrentContentStreamId($subject->subgraphIdentity->contentStreamId);
if (!$workspace) {
throw new \Exception(
'Could not find workspace for content stream "' . $subject->subgraphIdentity->contentStreamId->value . '"',
1699008140
);
}

$contentRepository->handle(
MoveNodeAggregate::create(
$subject->subgraphIdentity->contentStreamId,
$workspace->workspaceName,
$subject->subgraphIdentity->dimensionSpacePoint,
$subject->nodeAggregateId,
RelationDistributionStrategy::STRATEGY_GATHER_ALL,
Expand Down
12 changes: 9 additions & 3 deletions Classes/Domain/Model/Changes/MoveInto.php
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,6 @@
use Neos\ContentRepository\Core\Feature\NodeMove\Command\MoveNodeAggregate;
use Neos\ContentRepository\Core\Projection\ContentGraph\Node;
use Neos\ContentRepository\Core\Feature\NodeMove\Dto\RelationDistributionStrategy;
use Neos\Neos\Ui\Domain\Model\Feedback\Operations\RemoveNode;
use Neos\Neos\Ui\Domain\Model\Feedback\Operations\UpdateNodeInfo;

/**
Expand Down Expand Up @@ -83,10 +82,17 @@ public function apply(): void
$hasEqualParentNode = $otherParent && $otherParent->nodeAggregateId
->equals($parentNode->nodeAggregateId);

$contentRepository = $this->contentRepositoryRegistry->get($subject->subgraphIdentity->contentRepositoryId);
$contentRepository = $this->contentRepositoryRegistry->get($subject->subgraphIdentity->contentRepositoryId);$workspace = $this->contentRepositoryRegistry->get($this->subject->subgraphIdentity->contentRepositoryId)
->getWorkspaceFinder()->findOneByCurrentContentStreamId($subject->subgraphIdentity->contentStreamId);
if (!$workspace) {
throw new \Exception(
'Could not find workspace for content stream "' . $subject->subgraphIdentity->contentStreamId->value . '"',
1699008140
);
}
$contentRepository->handle(
MoveNodeAggregate::create(
$subject->subgraphIdentity->contentStreamId,
$workspace->workspaceName,
$subject->subgraphIdentity->dimensionSpacePoint,
$subject->nodeAggregateId,
RelationDistributionStrategy::STRATEGY_GATHER_ALL,
Expand Down
24 changes: 15 additions & 9 deletions Classes/Domain/Model/Changes/Property.php
Original file line number Diff line number Diff line change
Expand Up @@ -38,9 +38,6 @@
use Neos\Neos\Ui\Domain\Service\NodePropertyConversionService;
use Neos\Neos\Utility\NodeTypeWithFallbackProvider;

/** @codingStandardsIgnoreStart */
/** @codingStandardsIgnoreEnd */

/**
* Changes a property on a node
* @internal These objects internally reflect possible operations made by the Neos.Ui.
Expand Down Expand Up @@ -158,6 +155,15 @@ public function apply(): void

$propertyType = $this->getNodeType($subject)->getPropertyType($propertyName);

$workspace = $this->contentRepositoryRegistry->get($this->subject->subgraphIdentity->contentRepositoryId)
->getWorkspaceFinder()->findOneByCurrentContentStreamId($subject->subgraphIdentity->contentStreamId);
if (!$workspace) {
throw new \Exception(
'Could not find workspace for content stream "' . $subject->subgraphIdentity->contentStreamId->value . '"',
1699008140
);
}

// Use extra commands for reference handling
if ($propertyType === 'reference' || $propertyType === 'references') {
$value = $this->getValue();
Expand All @@ -180,7 +186,7 @@ public function apply(): void

$commandResult = $contentRepository->handle(
SetNodeReferences::create(
$subject->subgraphIdentity->contentStreamId,
$workspace->workspaceName,
$subject->nodeAggregateId,
$subject->originDimensionSpacePoint,
ReferenceName::fromString($propertyName),
Expand All @@ -201,7 +207,7 @@ public function apply(): void
// if origin dimension space point != current DSP -> translate transparently (matching old behavior)
$contentRepository->handle(
CreateNodeVariant::create(
$subject->subgraphIdentity->contentStreamId,
$workspace->workspaceName,
$subject->nodeAggregateId,
$subject->originDimensionSpacePoint,
$originDimensionSpacePoint
Expand All @@ -210,7 +216,7 @@ public function apply(): void
}
$commandResult = $contentRepository->handle(
SetNodeProperties::create(
$subject->subgraphIdentity->contentStreamId,
$workspace->workspaceName,
$subject->nodeAggregateId,
$originDimensionSpacePoint,
PropertyValuesToWrite::fromArray(
Expand All @@ -225,7 +231,7 @@ public function apply(): void
if ($propertyName === '_nodeType') {
$commandResult = $contentRepository->handle(
ChangeNodeAggregateType::create(
$subject->subgraphIdentity->contentStreamId,
$workspace->workspaceName,
$subject->nodeAggregateId,
NodeTypeName::fromString($value),
NodeAggregateTypeChangeChildConstraintConflictResolutionStrategy::STRATEGY_DELETE
Expand All @@ -235,7 +241,7 @@ public function apply(): void
if ($value === true) {
$commandResult = $contentRepository->handle(
DisableNodeAggregate::create(
$subject->subgraphIdentity->contentStreamId,
$workspace->workspaceName,
$subject->nodeAggregateId,
$subject->originDimensionSpacePoint->toDimensionSpacePoint(),
NodeVariantSelectionStrategy::STRATEGY_ALL_SPECIALIZATIONS
Expand All @@ -245,7 +251,7 @@ public function apply(): void
// unhide
$commandResult = $contentRepository->handle(
EnableNodeAggregate::create(
$subject->subgraphIdentity->contentStreamId,
$workspace->workspaceName,
$subject->nodeAggregateId,
$subject->originDimensionSpacePoint->toDimensionSpacePoint(),
NodeVariantSelectionStrategy::STRATEGY_ALL_SPECIALIZATIONS
Expand Down
10 changes: 9 additions & 1 deletion Classes/Domain/Model/Changes/Remove.php
Original file line number Diff line number Diff line change
Expand Up @@ -74,8 +74,16 @@ public function apply(): void

$subgraph = $this->contentRepositoryRegistry->subgraphForNode($this->subject);
$closestDocumentParentNode = $subgraph->findClosestNode($this->subject->nodeAggregateId, FindClosestNodeFilter::create(nodeTypes: NodeTypeNameFactory::NAME_DOCUMENT));
$workspace = $this->contentRepositoryRegistry->get($this->subject->subgraphIdentity->contentRepositoryId)
->getWorkspaceFinder()->findOneByCurrentContentStreamId($subject->subgraphIdentity->contentStreamId);
if (!$workspace) {
throw new \Exception(
'Could not find workspace for content stream "' . $subject->subgraphIdentity->contentStreamId->value . '"',
1699008140
);
}
$command = RemoveNodeAggregate::create(
$subject->subgraphIdentity->contentStreamId,
$workspace->workspaceName,
$subject->nodeAggregateId,
$subject->subgraphIdentity->dimensionSpacePoint,
NodeVariantSelectionStrategy::STRATEGY_ALL_SPECIALIZATIONS,
Expand Down

0 comments on commit dd0b92c

Please sign in to comment.