Automatically closed - issue fixed for 2 weeks with no activity.
- First commit to issue fork.
- Assigned to josebc
- π―π΄Jordan josebc
Since this issue already exists I will add the changes here, initial PR for an alternative method of loading images similar to what core uses for image styles.
This solution changes the URLs to the physical path of the generated file and falls back to the router using a kernel event listener. - Merge request !13Alternative way for loading images by pointing the front end to the physical... β (Open) created by josebc
- πΊπΈUnited States Mohammed J. Razem Santa Clara, CA
Hoping for the maintainer(s) to reopen this issue.
We have created a fork of the module ( https://www.drupal.org/project/drimage_improved β ) to demonstrate a fully functional module that uses an alternative image loading method similar to what core uses for image styles.
This forked module is largely similar to the current pull request (PR), with the main difference being the introduction of some install hooks to replace Drimage plugins as drop-in replacements.
Our intention is not to maintain or keep this fork if the PR is merged. We hope that this PR is merged with the improvement logic, which offers a significant performance boost compared to redirects and Drupal bootstrapped-image serving.
Once the PR is merged, we can shut down the fork and fully rely on the Drimage module.
- Status changed to Needs review
8 months ago 12:41pm 30 May 2024 - π§πͺBelgium weseze
I'll reopen and try to make some time to review this. Sounds like a much better approach!
- πΊπΈUnited States Mohammed J. Razem Santa Clara, CA
Great! Happy to discuss if you have any questions.
- Status changed to Needs work
7 months ago 9:18am 19 June 2024 - π§πͺBelgium weseze
I did some small tests and have some feedback.
I will try and make some more time this week to further test and maybe try and get this fully working but feel free to help me out here ;)1/
The first request causes a redirect. Is this something we can avoid?2/
The image_widget_crop handling contains an error. See revised code below that does work correctly.if ($this->moduleHandler->moduleExists('image_widget_crop') && isset($style_parts[3])) { $width = $style_parts[1]; $height = $style_parts[2]; // Need to implode all parts from index 3 and further to get the correct iwc_id. // The image widget crop id itself can contain underscores. $iwc_id = implode('_', array_slice($style_parts, 3)); }
3/
Do we need the same kind if checks for the focal_point integration?4/
I think there is some code + documentation and example to rewrite url's via apache vhosts: this will need to change also.5/
Is there any other code we can delete once this new delivery mechanism is in place? - π―π΄Jordan Rajab Natshah Jordan
Fixed in the forked Drimage Improved project
π Redirect to 404 Page for Invalid Image Paths Fixed
Better to have a look at the latest changes at
https://git.drupalcode.org/project/drimage_improvedThanks a lot for the idea of Drimage, BBC, CNN, and more are using this idea
At this point we only can create MR from an issue fork, no direct project fork in Drupal.org
My only wish is that Drupal.org allow us to have a clean fork reference.
Like what we have in github.com or gitlab.com fork system.
to keep the forks related, as a child change of the original project, which could still upstream or merge pull requests, from any direction from forks or original. - π§πͺBelgium weseze
Any possibility of updating the MR instead of forking?
I am willing to commit to get this working within drimage itself.
But comparing the forked module to the drimage, porting over changes and testing them, is not making this easy for me... :( - π―π΄Jordan josebc
Hello @weseze
Regarding the redirect issue, I'm doing some work here https://git.drupalcode.org/issue/drimage_improved-3456741/-/compare/1.0.... but since there was a lot of functionality in the controller I ended up moving it to a new service.
Please have a look and let me know what you think if you can. - Issue was unassigned.
- Status changed to Needs review
7 months ago 3:20pm 25 June 2024 - π§πͺBelgium weseze
Thanks for the work! I'll make time at the end of the week and try and get it merged in and released.
- First commit to issue fork.
- πΈπ°Slovakia trafo
Thanks for all the work.
I updated
DrimageSubscriber
to userawurldecode()
because image style url is generated viaFileUrlGenerator
that usesDrupal\Component\Utility\UrlHelper::encodePath()
which usesrawurlencode()
to encode path.The difference is small, but if user decides to use
+
symbol in file name, it would be decoded as space instead of plus and this results in "Image not found".