-
-
Notifications
You must be signed in to change notification settings - Fork 224
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: Cleanup projection catch-up trigger extensibility #5288
TASK: Cleanup projection catch-up trigger extensibility #5288
Conversation
Neos.ContentRepository.Core/Classes/EventStore/EventPersister.php
Outdated
Show resolved
Hide resolved
* @return CommandResult | ||
* @throws ConcurrencyException in case the expectedVersion does not match | ||
*/ | ||
public function publishEvents(EventsToPublish $eventsToPublish): CommandResult | ||
public function publishEvents(EventsToPublish $eventsToPublish, ContentRepository $contentRepository): CommandResult |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
having to pass the full cr along here seems wrong but is the only way if the EventPersister wants to be a separate class and not inlined in the ContentRepository
Previously the dependency problem was not really visible as we used the contentRepositoryRegistry
to get the content repository in a ProjectionCatchUpTriggerInterface
but there was no dependency flow set up then as well.
c256b63
to
ac22547
Compare
... and remove `CatchUpTriggerWithSynchronousOption` which is currently hardcoded to `true`
ac22547
to
ddac2c4
Compare
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
+1 by reading, thanks!
…nCatchUpTrigger-extensibility
} | ||
|
||
public function handle(CommandInterface $command): CommandResult | ||
{ | ||
return $this->contentRepository->handle($command); | ||
} | ||
|
||
public function publishEvents(EventsToPublish $eventsToPublish): void |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This is the weirdest API, why would we have this here? CommandHandlingDependencies::publishEvents
makes no sense to me.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
the problem is that for publishing events we need a catchup afterwards and the catchup hook extensibility require the content repository to be build.
The CommandHandlingDependencies
are a purely internal thing and the handle()
method on it already is a code smell due to the workspace command handler "doing to much" besides just publishing events for one command as we issue sub commands in the middle of handling another command.
For publishing an event stream, we need low level access to publish all events which was previously done via $this->eventPersister->publishEvents($events)
.
This leveraged the odd dependency flow of refetching the content repository from the Neos registry (see comment above) but now we need to pass the content repository for the said reasons explicitly.
Instead of exposing the content repository from $commandHandlingDependencies
and using it like $this->eventPersister->publishEvents($events, $commandHandlingDependencies->contentRepository)
i propose to keep the contentRepository instance private and introduce the new method: $commandHandlingDependencies->publishEvents($events)
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I'd rather expose the CR here instead of adding this method, but maybe an abstraction around projection catchup is not bad, I do like the current api better than what happens in this change.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
we discussed having a factory like so, but the catchup logic is still placed ON the content repository and we would have to move the codeblock to the event persister ...
final readonly class CatchUpHookFactoryBuilder
{
public function __construct(
private ContentRepository $contentRepository
) {
}
public function build(CatchUpHookFactoryInterface $catchUpHookFactory): CatchUpHookInterface
{
return $catchUpHookFactory->build($this->contentRepository);
}
}
Also introducing a read site content repository or just passing the content repository read model to the catchup hooks would certainly be promising as it would prevent recursive handling via handle
but nothing for now.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
haha @kitsunet with #5301 on the rise i guess i can revert d3119b8 as well have so much logic on the poor object that an additional method persistEvents
wouldn't hurt :D
I just experimented with returning the events instead of handling them in between, which is much cleaner imo and would allow us to actually get rid of that thing :D https://neos-project.slack.com/archives/C0L41E268/p1729546247272549
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I still like it better this way 😆
} | ||
try { | ||
return $this->eventPersister->publishEvents( | ||
$commandHandlingDependencies->publishEvents( |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
so this seems to be the single use of this weird API, why don't we keep the EventPersister here?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I don't like the persistEvents api addition, that shouldn't be there IMHO.
…nCatchUpTrigger-extensibility
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I like it like this
Extracted from #4988
Followup for #5049
We decided to run the content repository in sync mode. This was done first via a little hack. This pr now removes the left-over interfaces of the catchup triggering and hardcodes the catchup to be fully synchronous.
Upgrade instructions
Review instructions
Checklist
FEATURE|TASK|BUGFIX
!!!
and have upgrade-instructions