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

Fix multilang redirects and routes #3004

Open
wants to merge 1 commit into
base: develop
Choose a base branch
from

Conversation

nbusseneau
Copy link
Contributor

@nbusseneau nbusseneau commented Sep 12, 2020

Multilang redirects and routes were not working as per the documentation ("All redirect rules apply on the slug-path beginning after the language part (if you use multi-language pages)") due to language prefixes being included in URL when trying to match source URL and redirect/route source pattern.

Using $route parameter fixes the issue as given route does not include language prefixes (coming from $uri->path() in PagesServiceProvider).

Fixes #2435.

Multilang redirects and routes were not working due to language prefixes
being included in URL when trying to match source URL and redirect/route
source pattern.

Using `$route` parameter fixes the issue as given route does not include
language prefixes (coming from `$uri->path()` in `PagesServiceProvider`).

Fixes getgrav#2435.
@nbusseneau
Copy link
Contributor Author

nbusseneau commented Sep 12, 2020

Note: see issue #2435 for discussion regarding potential shortcomings.

Thus, the question is: why are regex redirects and routes relying on $uri->uri(false) rather than the given dispatch() $route? Is there any specific reason?

@mahagr mahagr requested review from rhukster and mahagr September 14, 2020 07:09
Copy link
Member

@mahagr mahagr left a comment

Choose a reason for hiding this comment

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

According to the documentation, this is the correct way to do it. The current code includes the language prefix in the route which is against the docs.

Not only that, but the current logic is also flawed. It checks the given route against the current URL, not the one which you want to dispatch into!

@nbusseneau
Copy link
Contributor Author

Bumping this :)

@mahagr mahagr added the bug label Dec 10, 2020
@mahagr
Copy link
Member

mahagr commented Dec 10, 2020

@rhukster Can you confirm my findings?

The issue is that the redirect is done based on the CURRENT URL and not the route which was given as a parameter to the method.

@rhukster
Copy link
Member

OK, looking into the history of this, the code used to be using $route however, about 3 years ago it was changed to use the URL because the prior approach didn't take into account any query or params on the URL. I think the ultimate solution would be to use the $route plus rebuild any query or params that were requested in the original URL.

@nbusseneau
Copy link
Contributor Author

I think the ultimate solution would be to use the $route plus rebuild any query or params that were requested in the original URL.

I can have a poke at that. I take it query parameters are ?foo=bar&bar=qux and params are Grav-specific parameters /foo:bar/baz:qux?

@mahagr
Copy link
Member

mahagr commented Dec 11, 2020

I think that the whole concept of having redirect in that method is wrong. Redirecting should be part of routing, not in method that gets a page. I will need to think a bit, but in the mean time there is this in Grav 1.7:

https://github.com/getgrav/grav/blob/1.7/system/src/Grav/Common/Service/PagesServiceProvider.php#L79-L105

It is not being called in this case as there's $page = $pages->dispatch($path); call in line 63, but I'm wondering if we should have the whole logic here and just call $pages->find(), which doesn't do the redirecting.

@nbusseneau
Copy link
Contributor Author

nbusseneau commented Jan 24, 2021

@mahagr I don't know if something changed in 1.7 since your last message, but I can't reproduce the issue anymore after upgrading to 1.7.3. I didn't investigate to understand why dispatch() is now correctly handling multilang redirects even though code did not change, but I can if it's not something you changed intentionally.

Forget what I said, I'm stupid and forgot that redirects work when using the workaround stated in #2435 (prefixing with (/.*)? to catch language fragment). Without the workaround, redirects still fail.

@mahagr
Copy link
Member

mahagr commented Jan 25, 2021

You are right, looks like configuration redirects still happen and are wrong, even when you're using $pages->find().

@mahagr
Copy link
Member

mahagr commented Mar 12, 2021

The above pull request will not fix the language redirects needing the language code, but will only separate the logic between find() and dispatch() methods and make site.routes more usable.

For the language codes, I still think that site.redirects should not be based on routes, but they should blindly match the current URL (including query parameters etc) and do transformation based on that.

However it could be a good idea to be able to pass more information to the redirects, such as '/({LANG})/foo/(\d+)': '/$1/bar/$2' which would match all language codes.

The reason why I'd like to do it in that way is that you do not want to restrict redirects to Grav routes as you may have migrated from another CMS.

@nbusseneau
Copy link
Contributor Author

nbusseneau commented Oct 19, 2021

@mahagr Revisiting old PRs -- I see there was some work on this via #3266. If you have some additional thoughts on how to advance this further I am open for taking a jab at it. The workaround outlined above has been working fine forever, but still think it would be nice to have it work as intended by the documentation (or fix the documentation, which I can also do if we think that's better).

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Projects
None yet
Development

Successfully merging this pull request may close these issues.

Multi-language redirects
3 participants