-
-
Notifications
You must be signed in to change notification settings - Fork 3.7k
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
Use a sensible default if none is found #36692
Use a sensible default if none is found #36692
Conversation
Signed-off-by: Roland Dalmulder <contact@rolandd.com>
@roland-d This comment was created with the J!Tracker Application at issues.joomla.org/tracker/joomla-cms/36692. |
@ChristineWk Thank you for testing. I was actually doing my tests on PHP 8.1 but even though the issue should be reproducible on 7.4. For it to show on PHP 7.4 I have changed the instructions a bit, can you see if you can get an error now? |
Tested again. No error ... Checks: |
This comment was marked as abuse.
This comment was marked as abuse.
I do not think this is so different from the default set in the TemplateAdapter.php except that there the default is set to |
@ChristineWk I am going to test it again to see if I cannot get the error but I really do not understand why you see no error. |
IMHO, such a module (or any extension) without a client in the manifest should just be prevented from being installed and should throw an error. |
@infograf768 That actually crossed my mind as well but the module is already installed at this point, so I figured why not :) I am fine to change this PR to also check if the client is set. Regardless I think a default is not a bad fallback. |
In fact, I tried to installed that module and result depends on php version. php 7.4.21: the module installs with a default clientId of 0 (site) and can be uninstalled without any error. Therefore, what we need is preventing installing and meaningfull error I guess to adapt to php 8+ |
@infograf768 The So I checked again on PHP 7.4 and now the installer runs fine as @ChristineWk and you found out. This is because an undefined constant is only fatal since PHP 8. The default client ID of 0 is not a change from this PR, that is already in Joomla. The adaptation to PHP 8+ is to also set a default client to |
If possible why not change it so that modules cannot be installed without a defined client AND use a default when uninstalling a module that doesnt have a defined client |
I wonder if not allowing a module to install when the client is missing is a B/C break at this point. |
It would be friendly allowing the installation and write an information "Module is installed for frontend. " |
@chmst That already happens based on the |
This pull request has automatically rebased to 4.2-dev. |
This pull requests has been automatically converted to the PSR-12 coding standard. |
This pull request has been automatically rebased to 4.3-dev. |
One issue is that we allow extensions with the client tag to be 0 while it should be site, for instance. We should stop allowing extensions to be installed with an improper value for 'client'. It is now well documented (change for 5.0 ?). |
I have tested this item ✅ successfully on e45e805 This comment was created with the J!Tracker Application at issues.joomla.org/tracker/joomla-cms/36692. |
I have tested this item ✅ successfully on e45e805 I'm on PHP 8.1 installing the test module is not working. I get the same error as @infograf768. Adding the patch will allow the module to install. I count this as a successful test. |
This pull request has been automatically rebased to 4.4-dev. |
I have tested this item ✅ successfully on e45e805 This comment was created with the J!Tracker Application at issues.joomla.org/tracker/joomla-cms/36692. |
I have tested this item ✅ successfully on 8f9f2ce This comment was created with the J!Tracker Application at issues.joomla.org/tracker/joomla-cms/36692. |
1 similar comment
I have tested this item ✅ successfully on 8f9f2ce This comment was created with the J!Tracker Application at issues.joomla.org/tracker/joomla-cms/36692. |
RTC This comment was created with the J!Tracker Application at issues.joomla.org/tracker/joomla-cms/36692. |
Successfully tested this in Joomla 5.1 alpha 3 with php 8.3.3. When installing I get a warning: Unable to detect manifest file. Nothing is installed. This comment was created with the J!Tracker Application at issues.joomla.org/tracker/joomla-cms/36692. |
I have tested this item ✅ successfully on 0e5c276 This comment was created with the J!Tracker Application at issues.joomla.org/tracker/joomla-cms/36692. |
Thank you! |
Summary of Changes
When you have a module installed but the module manifest does not have the
data:image/s3,"s3://crabby-images/5ff3d/5ff3d01b63da37e651734c38873816a2dbdfdd32" alt="image"
client
attribute set, uninstalling this module crashes:The same thing happens when you install the module but when you refresh the page it tells you the module installation was fine.
So the change here is to set a sensible default of
site
as that is where most modules are installed.This was tested on PHP 8.1
Testing Instructions
mod_test.zip
Actual result BEFORE applying this Pull Request
The module does install but the user faces a fatal error
Expected result AFTER applying this Pull Request
The module is installed but no fatal error is shown
Documentation Changes Required
None