Skip to content
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: Remove obsolete findContentStream(s) #5340

Merged
merged 7 commits into from
Jan 14, 2025

Conversation

mhsdesign
Copy link
Member

@mhsdesign mhsdesign commented Nov 2, 2024

The following API was introduced in Neos 9 beta15 via #5096

  • ContentRepository::findContentStream($id): ContentStream
  • ContentRepository::findContentStreams(): ContentStreams

to replace the usages of the @internal content stream finder which was designed to back the content stream pruner.

With the overhaul of the content stream pruner #5297, we dont need to access all the content streams anymore, but it was forgotten to remove these helpers.

In here we discussed to remove the now obsolete api.

For testing we now utilise the same trick as for countNodes by acquiring the read model directly.
While this requires a work around, we discussed that we are fine with this method getContentGraphReadModel() (slack)

Upgrade instructions

Review instructions

Checklist

  • Code follows the PSR-2 coding style
  • Tests have been created, run and adjusted as needed
  • The PR is created against the lowest maintained branch
  • Reviewer - PR Title is brief but complete and starts with FEATURE|TASK|BUGFIX
  • Reviewer - The first section explains the change briefly for change-logs
  • Reviewer - Breaking Changes are marked with !!! and have upgrade-instructions

@mhsdesign mhsdesign force-pushed the task/remove-obsolete-findContentStreams branch from d0420bc to 9375fd9 Compare November 2, 2024 15:33
return $this->getContentRepositoryService($accessorFactory)->dependencies;
}

final protected function getContentGraphReadModel(): ContentGraphReadModelInterface
Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

or maybe, if we like it or not, we should just expose the ContentGraphReadModel ON the content repository directly as @internal method with note to be careful. We cannot avoid people ditching security (see $context->withoutAuthorisationChecks) and as this ContentGraphReadModel will soon to be exposed for catchup hooks as api already ...

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

IMO it's not about preventing folks to intentionally circumvent security – they always can, as you pointed out.
But the API should make that cumbersome or at least very very explicit. And exposing a internal concept in an api-object is a code smell IMO (even if it is marked with warnings)

I think, we should just have some custom "accessor factory" in our CRTestSuiteTrait that is instantiated once and provides read-access to all required dependencies.

Copy link
Member Author

@mhsdesign mhsdesign Nov 4, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

that is instantiated once

Okay agreed, but that escalated to a (possibly) bigger change: #5341 so lets have this optimisation separate for later.

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I would rather merge many small changes than always having these huge refactor everyhting things...

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

oke so are you fine with the code now? @kitsunet

mhsdesign added a commit to mhsdesign/neos-development-collection that referenced this pull request Nov 4, 2024
@mhsdesign mhsdesign changed the title TASK: Remove obsolete findContentStreams TASK: Remove obsolete findContentStream(s) Nov 4, 2024
@mhsdesign
Copy link
Member Author

Actually with the discussion here https://neos-project.slack.com/archives/C04PYL8H3/p1731148458597629 we think that we need some Version available to the cr user after all:

Okay today we discussed if we should introduce some concept like idempotency key / rebase token to solve this (which would be either a hash of the base version or possibly a hash of all the events that failed last time)

but bastian pointed out that we have this kind of versioning already with the Version and introducing this to the Workspace read model would make sense for this case and allow it to be used here for the RebaseWorkspace command as argument.

Its only a little "shady" that the version of the workspace is actually the one of the content stream ... that would mean that all the node command handler fetch the version currently via the cs readmodel while i was just about to change the workspace command handling to use the same version then thats inside the Workspace for simplification.

But another gain would be that for the import we could relatively early assert that the workspace better be 0 and fail early.

So in case that we find out that its wrong if the Workspace has this version information, we probably should keep the findContentStream thingy api?

@mhsdesign
Copy link
Member Author

As discussed with christian we are rather fine with adding the version on the workspace and push the whole content stream fetching back into the land of internals. There is no need for them to be public in any way.

@mhsdesign mhsdesign merged commit 07bbe1b into neos:9.0 Jan 14, 2025
10 checks passed
@mhsdesign mhsdesign deleted the task/remove-obsolete-findContentStreams branch January 14, 2025 16:21
mhsdesign added a commit to mhsdesign/neos-development-collection that referenced this pull request Jan 14, 2025
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
Status: Done
Development

Successfully merging this pull request may close these issues.

3 participants