-
-
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
!!! FEATURE: Overhaul node uri building #4892
!!! FEATURE: Overhaul node uri building #4892
Conversation
a5e9319
to
a90fddb
Compare
ad7df6c
to
f3f34f9
Compare
f3f34f9
to
d32a2d4
Compare
d32a2d4
to
b90b043
Compare
5c1e131
to
95ea686
Compare
6489bc9
to
8a2748f
Compare
be04b6d
to
abed60a
Compare
abed60a
to
e953cd9
Compare
Neos.Neos/Classes/FrontendRouting/NodeUri/NodeUriBuilderFactory.php
Outdated
Show resolved
Hide resolved
Neos.Neos/Classes/FrontendRouting/FrontendNodeRoutePartHandlerInterface.php
Show resolved
Hide resolved
Neos.Neos/Classes/FrontendRouting/EventSourcedFrontendNodeRoutePartHandler.php
Show resolved
Hide resolved
* | ||
* See also {@link https://docs.neos.io/guide/rendering/rendering-special-formats} | ||
*/ | ||
public function withCustomFormat(string $format): self |
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 also noticed that the current format will NOT be takend from the actionRequest
so one would need to take care of this themselves is this ok?
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.
But i guess the Fusion helpers should default to the requests format? Either in php or better via
format = ${request.format}
what do you think? ...
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.
Good question, I'm not sure about that. When I played with HTMX, I used a custom format for the HX requests (see https://github.com/bwaidelich/Wwwision.HtmxTest/blob/main/Resources%2FPrivate%2FFusion%2FComponents%2FHtmxUri.fusion)
In the results I would not want this format to be used for all links implicitly
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.
Currently it's the expected behavior, I have had it in both directions in projects. Sometimes I was happy it would automatically keep the xml I had in hte current request without me having to check it at every link, other times I would have wished to ignore it and use html by default 🤷
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.
yeah i guess for fusion (especially as the magic is currently still part of the Neos.Fusion:ActionUri
) i think it would make sense to keep it for the Neos.Neos:NodeUri
as well.
Ill vote for making it a default value on fusion side so its directly visible to the human eye? or should it be part of the fusion php implementation?
edit on the other hand this is core behaviour and has to be documented via comment. Otherwise it would be weird that we access the request
differently in two places (once for the uri builder and then for the format)
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.
My gut feeling is still: html is like the 99% case and I would want to explicitly change that if I wanted to create links to other resources in the same format (e.g. in a JSON response I might want to link to other JSON resources, but I would expect the node URI to still have the default format:
{
"title": "foo",
"contactUri": "https://domain.tld/contact",
"includedResources": {
"contacts": [
{"id": "123", "href": "/api/contacts/123.json"}
]
}
}
Or maybe I can override the default format for the RoutingDefaults
per controller/action?
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 agree that the magic of keeping the format either has helped (by knowing it beforehand) or worse lead to confusion and i had to debug many times (because i forgot) why uri building failed ... the @format: json
part in the exception dump cat Data...
tends to go unnoticed for the untrained eye.
Still for this change it would be cruel to change behaviour like this ever so slightly and id prefer a dedicated discussion and separate pr.
I think we only have to agree that the PHP Node Uri building api doesnt do it by default and how to implement this magic again for the Fusion prototypes.
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.
That makes sense ... to me.
I would be fine with simply adding a default format of "html" to the fusion prototypes that is documented.
That way you only have to read the fusion documentation to get it and not know about some magic behavior that works until you forget it and then causes trouble.
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.
Im not against removing the format by request magic but id prefer a separate pr for that (and probably wont do it myself right now because i cant sell it as well as you do :D)
I guess this pr is a step in the right direction by removing that feature from the core node uribuilding and making it opt in from the outside. That means we can eventually get rid of it!
…uilding uris from Fusion or Fluid The magic of keeping the format either has helped (by knowing it beforehand) or worse lead to confusion and hard to debug uri building errors (the `@format: json` part in the exception dump tends to go unnoticed for the untrained eye) Still for this change it would be cruel to change behaviour like this so we reimplement it.
The filter like signatures dont feel quite right because they only have one argument ... and its a yagni to add new args
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.
Giving this 👀
Might do some more testing tomorrow, if it doesn't get merged.
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 👀 and 🧪
Should be tested with: neos/neos-ui#3802 as otherwise you end up with errors in the backend.
@@ -7,7 +7,6 @@ | |||
uriPattern: 'neos/preview' | |||
defaults: | |||
'@action': 'preview' | |||
appendExceedingArguments: true |
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.
\o/ ... yeha that alone is worth it ... if only this would be the main fe route. I fear this needs appendExceedingArguments
a while longer
* | ||
* See also {@link https://docs.neos.io/guide/rendering/rendering-special-formats} | ||
*/ | ||
public function withCustomFormat(string $format): self |
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.
That makes sense ... to me.
I would be fine with simply adding a default format of "html" to the fusion prototypes that is documented.
That way you only have to read the fusion documentation to get it and not know about some magic behavior that works until you forget it and then causes trouble.
Thank you so much for all the reviews and discussions ;) Glad to have this merged!!! One step closer. |
This reintroduces ```yaml appendExceedingArguments: true ``` for the preview route so that uris could still build via plain fusion or flows `Neos\Flow\Mvc\Routing\UriBuilder` ``` previewAction = Neos.Fusion:ActionUri { request = ${request.mainRequest} package = 'Neos.Neos' controller = 'Frontend\\\Node' action = 'preview' arguments = ${{node: someNodeAddress}} } ``` This was initially reverted via 2c4670c in neos#4892 in effort to get slowly rid of the `appendExceedingArguments` ugliness. But in the Dresden sprint '24 was considered to big of a change for now, especially as there is no alternative to build the uris in fusion without the `queryParameters` option introduced for the `Neos.Fusion:ActionUri` which will only be part of: neos#3914
This reintroduces ```yaml appendExceedingArguments: true ``` for the preview route so that uris could still build via plain fusion or flows `Neos\Flow\Mvc\Routing\UriBuilder` ``` previewAction = Neos.Fusion:ActionUri { request = ${request.mainRequest} package = 'Neos.Neos' controller = 'Frontend\\\Node' action = 'preview' arguments = ${{node: someNodeAddress}} } ``` This was initially reverted via 8ba43d6 in neos/neos-development-collection#4892 in effort to get slowly rid of the `appendExceedingArguments` ugliness. But in the Dresden sprint '24 was considered to big of a change for now, especially as there is no alternative to build the uris in fusion without the `queryParameters` option introduced for the `Neos.Fusion:ActionUri` which will only be part of: neos/neos-development-collection#3914
This reintroduces ```yaml appendExceedingArguments: true ``` for the preview route so that uris could still build via plain fusion or flows `Neos\Flow\Mvc\Routing\UriBuilder` ``` previewAction = Neos.Fusion:ActionUri { request = ${request.mainRequest} package = 'Neos.Neos' controller = 'Frontend\\\Node' action = 'preview' arguments = ${{node: someNodeAddress}} } ``` This was initially reverted via 2c4670c130b14d484bb73308f1867b6f5306a4c9 in neos/neos-development-collection#4892 in effort to get slowly rid of the `appendExceedingArguments` ugliness. But in the Dresden sprint '24 was considered to big of a change for now, especially as there is no alternative to build the uris in fusion without the `queryParameters` option introduced for the `Neos.Fusion:ActionUri` which will only be part of: neos/neos-development-collection#3914
Resolves: #4552
Introduces a new API for node-uribuilding to replace the
LinkingService
Currently Neos9-Beta10 does already contain a similar new
NodeUriBuilder
but this change overhauls the API to not expose the implementations of the Flow UriBuilder.Upgrade instructions
The new
NodeUriBuilder
is not a singleton and thus cannot be injected but must be created via theNodeUriBuilderFactory
with the currentActionRequest
at hand.Simple case:
Advanced case:
Also notice that the PHP api for uri building will no longer keep the current format of the action request by default unlike in the Fusion api.
If this behaviour is required it should be implemented via
$options->withCustomFormat($actionRequest->getFormat());
Review instructions
Currently in 9.0-dev the
NodeUriBuilder
is a not well though out abstraction. It has a really shallow implementation and doest abstract the uribuilder away, but rather exposes it to be set from outside. That makes it impossible to swap out the implementation and also the api is questionable. How do i really set theformat
option or add additional queryparameters?With the overhaul of the api and lately new introduced
Shared\NodeAddress
we can go one step further and not use the legacyFrontendRouting\NodeAdress
any further. The new address will fill its place and make thus also cross site linking will be possible: #4441We decided against adding the query parameters to be encoded as array option to the NodeUriBuilder
Options
and promote to use the helperUriHelper::uriWithAdditionalQueryParameters
.It is better to have it separated into a helper because its not core PSR standard behaviour (where the query is just a string) and anything further like
http_build_query
is php magic which does not obey an official standard.Also another argument is that its just string manipulation after the resolve was successful for the same reason a fragment cannot be provided as option but must be set via the PSR Api
withFragment
.Adjustment prs:
Related discussions:
UriHelper
to work with query parameters flow-development-collection#3316NodeAddress
into dedicated classes #4564NodeAddress
into dedicated classes #4564Checklist
FEATURE|TASK|BUGFIX
!!!
and have upgrade-instructions