-
-
Notifications
You must be signed in to change notification settings - Fork 173
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
Incorrect site content in multi-language setup after a plugin uses site()->content() #2629
Comments
Yes, we have already come across this multiple times on the forum and there is already an issue in the plugin: https://gitlab.com/kirbyzone/sitemapper/-/issues/4. But might make sense to solve this Kirby-wise. |
@texnixe yeah. It might be the expected behavior from Kirby's point of view, but leads to unexpected behavior from the user's point of view that goes unnoticed. At the very least, Kirby should throw an error to let you know that something is wrong. If |
These loading order issues are always super super hard. It would be so lovely if there was a way to load everything literally simultaneously, but of course that's impossible. So because there is a fixed loading order, stuff depends on another and changing the order becomes impossible as well. There is just some stuff plugins can't have access to while the system is still loading. In this particular case, the plugin should initialize the option default value with But as you both say, the question should be if we can at least prevent the consequences further down the chain directly in the core. These are our (non-)options:
|
@lukasbestle doesn't it make sense for the router to have two types of initializations? As far as my debugging went, the issue comes from the fact that the
If there's no easy workaround, it makes the most sense to me to throw an error. Maybe the App class could have some sort of flag that indicates whether Kirby is initialized and the Site object could throw an error if said flag is I would very much prefer to have a fatal error and know what's wrong than to spend several hours debugging. It would also lead to more stable plugins. |
Regarding the translation loading: @bastianallgeier can probably tell you more as he has written the translation loading code.
There is no real "Kirby is fully loaded" state. The objects depend on another, so a full block would also prevent Kirby from loading. So we would need to take a look at each initialization method on its own and verify that its specific prerequisites are there.
Exactly, that's what I think as well. |
@lukasbestle @bastianallgeier Hey there, I’ve just run into that issue with my meta plugin. I would really appreciate if you could handle this, as it is absolutely not obvious and has cost me quite some time to figure this out (I used |
@fabianmichael Sorry that this has cost you debugging time. In an ideal world we would review every part of Kirby for loading dependencies and add appropriate errors or warnings everywhere, but maybe we can already start with this specific part where we know it causes issues in the real world. I've added an issue summary to the initial post of this issue. |
@lukasbestle I did not mean to blame you for anything. But since this is really not obvious when calling the function, it would be very helpful if Kirby would use situations like this to protect itself from screwing up its own state. If this needs more investigation (i.e. will result in a longer process), a hint in the docs would be a first step. |
I didn't understand it as blame at all. :) A hint in the docs has the disadvantage that there's no good place to put it. It will be missed. |
This issue has been automatically marked as stale because it has not had recent activity. It will be closed in 14 days if no further activity occurs. |
If this issue still exists, I think it should still be fixed. Maybe the method could just throw an exception when called to early? |
The Problem seems to still exist in Kirby 4 in 2024. We had Problems with the $page->title() function like in #2611 |
Kirby Team summary
Status quo
In multi-lang setups, the
ModelWithContent::content()
method can be called with a specific language code ornull
for "the content of the current language". The return value fornull
is cached in memory. So if the method is called before the current language has been set by the router withAppTranslations::setCurrentLanguage()
, the default language is used instead. Even worse, the content of the default language is cached in memory and used for template rendering etc.Target goal
It should not be possible to access the content with
$languageCode = null
when the current language is not yet known.Possible solutions
As suggested here: Incorrect site content in multi-language setup after a plugin uses site()->content() #2629 (comment) (needs to be checked if viable without major restructuring)
If
ModelWithContent::content()
is called with$languageCode = null
in a multi-lang setup, it should check if the current language has already been set inApp
(we might need a new flag for this). If no language is set, throw aLogicException
that access to the content is not yet possible.Describe the bug
If a plugin calls the
site()
function immediately when loaded, the default language content is used and cached, and then the template does not use the translations.To reproduce
index.php
withsite()->content()
insideecho site()->title()
Kirby Version
4.3.6
Additional context
I'm pretty sure that this happens because Kirby loads plugins before figuring out the language. When the plugin calls
site()->content()
at that phase, it's likely the first call. This means that Kirby will load the content for the current language (which is not the correct one) and cache the resulting Content object for performance reasons. Later, in the template, that same Content object is returned and it holds the invalid values.This happened to me when using Sitemapper by Cre8iv Click. This is the line that causes the issue.
I know this is technically an issue with the plugin, but it's also an issue with Kirby. It took me a while to debug that, and the plugin author likely doesn't even know about it because that's a pretty tricky and obscure error.
Kirby should either determine the language before loading the plugins, or avoid caching the Content object until plugins have loaded and Kirby has initialized in general.
Edit: This issue also affects the panel. When you click to view the content of a translation, you just see the default content.
The text was updated successfully, but these errors were encountered: