If you aren’t able to figure it out, you might have more luck searching for this as a Drupal hosting issue more generally. It is not specific to farmOS.
The fact that all links are 404ing is a good clue. Is the 404 page a Drupal 404 or a generic Apache 404? This would tell you whether or not Drupal is receiving the request or not. If Drupal isn’t receiving the request for the CSS/JS file, then it can’t generate the aggregated files and save them to the files directory. This feels like an Apache configuration issue to me, but it will take some debugging to trace the exact cause I think.
it’s definitely an Apache 404… so I’ll start digging into the apache angle.
@lmcmullen Good luck! That’s a good clue.
@bejuco I wonder if you are experiencing the same thing?
Yeah, all /sites/default/files/css
and /js
related stuff have 404 errors on the acces log.
They also have crazy paths. For example:
/sites/default/files/js/js_rAH38gm8rBrYefWrcvOwTNYozvIfkRe9vDHjYc1YJuM.js?scope=footer&delta=0&language=en&theme=gin&include=eJx9TtEOgzAI_KFqv2FfYhBRiW1pKJpsXz_N1i3rwx4I3B3HgaLkk2iEwA9yGEDFL0FGCF2xe-C0uIWTP8vhtTvpniH0gMYHdae-VX3gxPYBgEjpBYsxbnc3g8Zh58FWiuRnESNtyJVC_omZVPK4m0lyJhJGUP_ujbOyNb7ivZDWY9fcM0oqDqb4Xarm3pToj9SvcpwvtxIVhEy3y9Y8pbTwmfYEmiqJvQ
I finally identified my issue. The tar file is downloaded with the name farmOS. In my farmos.conf file, I was using /var/www/html/farmOS/web as the DocumentRoot but /var/www/html/farmos/web as the Directory. Case does matter in Linux/Unix.
@bejuco Did you find the solution to this?
I had exactly the same thing.
Need to use 777 and files/css/ files/js/ are not created.
I’ve verified that my Apache user is www-data.
I don’t seem to have the 404 errors
But I do get this error in the farmOS Recent Log Messages :
User warning: mkdir(): Permission Denied in Drupal\Component\PhpStorage\FileStorage->createDirectory() (line 123 of /home/jk/farmos-project/farmos/web/core/lib/Drupal/Component/PhpStorage/FileStorage.php)
#0 /home/jk/farmos-project/farmos/web/core/includes/bootstrap.inc(164): _drupal_error_handler_real()
#1 [internal function]: _drupal_error_handler()
#2 /home/jk/farmos-project/farmos/web/core/lib/Drupal/Component/PhpStorage/FileStorage.php(123): trigger_error()
#3 /home/jk/farmos-project/farmos/web/core/lib/Drupal/Component/PhpStorage/FileStorage.php(73): Drupal\Component\PhpStorage\FileStorage->createDirectory()
#4 /home/jk/farmos-project/farmos/web/core/lib/Drupal/Component/PhpStorage/MTimeProtectedFastFileStorage.php(66): Drupal\Component\PhpStorage\FileStorage->ensureDirectory()
#5 /home/jk/farmos-project/farmos/web/core/lib/Drupal/Core/Template/TwigPhpStorageCache.php(112): Drupal\Component\PhpStorage\MTimeProtectedFastFileStorage->save()
#6 /home/jk/farmos-project/farmos/vendor/twig/twig/src/Environment.php(382): Drupal\Core\Template\TwigPhpStorageCache->write()
#7 /home/jk/farmos-project/farmos/vendor/twig/twig/src/Environment.php(343): Twig\Environment->loadTemplate()
#8 /home/jk/farmos-project/farmos/web/core/themes/engines/twig/twig.engine(39): Twig\Environment->load()
#9 /home/jk/farmos-project/farmos/web/core/lib/Drupal/Core/Theme/ThemeManager.php(348): twig_render_template()
#10 /home/jk/farmos-project/farmos/web/core/lib/Drupal/Core/Render/Renderer.php(480): Drupal\Core\Theme\ThemeManager->render()
#11 /home/jk/farmos-project/farmos/web/core/lib/Drupal/Core/Render/Renderer.php(240): Drupal\Core\Render\Renderer->doRender()
#12 /home/jk/farmos-project/farmos/web/core/lib/Drupal/Core/Render/Renderer.php(165): Drupal\Core\Render\Renderer->render()
#13 /home/jk/farmos-project/farmos/web/core/lib/Drupal/Core/Render/Renderer.php(627): Drupal\Core\Render\Renderer->Drupal\Core\Render\{closure}()
#14 /home/jk/farmos-project/farmos/web/core/lib/Drupal/Core/Render/Renderer.php(164): Drupal\Core\Render\Renderer->executeInRenderContext()
#15 /home/jk/farmos-project/farmos/web/core/lib/Drupal/Core/Render/Renderer.php(183): Drupal\Core\Render\Renderer->renderPlain()
#16 /home/jk/farmos-project/farmos/web/core/lib/Drupal/Core/Render/Renderer.php(712): Drupal\Core\Render\Renderer->doRenderPlaceholder()
#17 [internal function]: Drupal\Core\Render\Renderer->Drupal\Core\Render\{closure}()
#18 /home/jk/farmos-project/farmos/web/core/lib/Drupal/Core/Render/Renderer.php(720): Fiber->start()
#19 /home/jk/farmos-project/farmos/web/core/lib/Drupal/Core/Render/Renderer.php(597): Drupal\Core\Render\Renderer->replacePlaceholders()
#20 /home/jk/farmos-project/farmos/web/core/lib/Drupal/Core/Render/Renderer.php(240): Drupal\Core\Render\Renderer->doRender()
#21 /home/jk/farmos-project/farmos/web/core/lib/Drupal/Core/Render/Renderer.php(153): Drupal\Core\Render\Renderer->render()
#22 /home/jk/farmos-project/farmos/web/core/lib/Drupal/Core/Render/Renderer.php(627): Drupal\Core\Render\Renderer->Drupal\Core\Render\{closure}()
#23 /home/jk/farmos-project/farmos/web/core/lib/Drupal/Core/Render/Renderer.php(152): Drupal\Core\Render\Renderer->executeInRenderContext()
#24 /home/jk/farmos-project/farmos/web/core/lib/Drupal/Core/Render/HtmlResponseAttachmentsProcessor.php(286): Drupal\Core\Render\Renderer->renderRoot()
#25 /home/jk/farmos-project/farmos/web/core/lib/Drupal/Core/Render/HtmlResponseAttachmentsProcessor.php(135): Drupal\Core\Render\HtmlResponseAttachmentsProcessor->renderPlaceholders()
#26 /home/jk/farmos-project/farmos/web/core/lib/Drupal/Core/EventSubscriber/HtmlResponseSubscriber.php(45): Drupal\Core\Render\HtmlResponseAttachmentsProcessor->processAttachments()
#27 [internal function]: Drupal\Core\EventSubscriber\HtmlResponseSubscriber->onRespond()
#28 /home/jk/farmos-project/farmos/web/core/lib/Drupal/Component/EventDispatcher/ContainerAwareEventDispatcher.php(111): call_user_func()
#29 /home/jk/farmos-project/farmos/vendor/symfony/http-kernel/HttpKernel.php(214): Drupal\Component\EventDispatcher\ContainerAwareEventDispatcher->dispatch()
#30 /home/jk/farmos-project/farmos/vendor/symfony/http-kernel/HttpKernel.php(202): Symfony\Component\HttpKernel\HttpKernel->filterResponse()
#31 /home/jk/farmos-project/farmos/vendor/symfony/http-kernel/HttpKernel.php(76): Symfony\Component\HttpKernel\HttpKernel->handleRaw()
#32 /home/jk/farmos-project/farmos/web/modules/simple_oauth/src/HttpMiddleware/BasicAuthSwap.php(54): Symfony\Component\HttpKernel\HttpKernel->handle()
#33 /home/jk/farmos-project/farmos/web/core/lib/Drupal/Core/StackMiddleware/Session.php(58): Drupal\simple_oauth\HttpMiddleware\BasicAuthSwap->handle()
#34 /home/jk/farmos-project/farmos/web/core/lib/Drupal/Core/StackMiddleware/KernelPreHandle.php(48): Drupal\Core\StackMiddleware\Session->handle()
#35 /home/jk/farmos-project/farmos/web/core/lib/Drupal/Core/StackMiddleware/ContentLength.php(28): Drupal\Core\StackMiddleware\KernelPreHandle->handle()
#36 /home/jk/farmos-project/farmos/web/core/lib/Drupal/Core/StackMiddleware/ReverseProxyMiddleware.php(48): Drupal\Core\StackMiddleware\ContentLength->handle()
#37 /home/jk/farmos-project/farmos/web/core/lib/Drupal/Core/StackMiddleware/NegotiationMiddleware.php(51): Drupal\Core\StackMiddleware\ReverseProxyMiddleware->handle()
#38 /home/jk/farmos-project/farmos/web/core/lib/Drupal/Core/StackMiddleware/AjaxPageState.php(36): Drupal\Core\StackMiddleware\NegotiationMiddleware->handle()
#39 /home/jk/farmos-project/farmos/web/core/lib/Drupal/Core/StackMiddleware/StackedHttpKernel.php(51): Drupal\Core\StackMiddleware\AjaxPageState->handle()
#40 /home/jk/farmos-project/farmos/web/core/lib/Drupal/Core/DrupalKernel.php(704): Drupal\Core\StackMiddleware\StackedHttpKernel->handle()
#41 /home/jk/farmos-project/farmos/web/index.php(19): Drupal\Core\DrupalKernel->handle()
#42 {main}
.
I’ve tried creating the css-folder like this
sudo -u www-data mkdir /home/jk/farmos-project/farmos/web/sites/default/files/css
And it’s created, but also deleted by the site.
It makes me wonder if the site actually creates the css-folder in the …/files/ folder.
Or if it’s related to the fact that only 777 works.
Edit:
I do get 404
[Fri Aug 23 11:15:55 2024] [::1]:42278 [404]: GET /sites/default/files/js/js_LpFqHN-hFKs7s2si.....etP5dg - No such file or directory
Definitely sounds like a permissions issue.
You shouldn’t need to create any directories inside the files
directory manually (like css
or js
). Drupal will do that for you, as long as it can write to files
.
I wonder what directory is actually being created by mkdir()
when it runs into this. Maybe it’s something else that’s breaking, before it can even get to the next step of saving CSS/JS. It would require a bit of digging but you might be able to debug that line of PHP itself to find out.
If it’s helpful, this is the official Drupal documentation: https://www.drupal.org/docs/administering-a-drupal-site/security-in-drupal/securing-file-permissions-and-ownership
A search for “drupal css aggregation doesn’t work” reveals lots of results. Not sure if any are helpful but here are two:
- Drupal aggregate css not working. all styles gone - Stack Overflow
- 8 - Problem when agreggating CSS/JS files - Drupal Answers
Ultimately this is a Drupal setup issue not specific to farmOS, so chances are the answer is out there somewhere, if not on this forum. If you do trace it down please summarize what the issue was here for others!
A bit tricky this one.
In the Drupal docs I found a script supposed to fix the permission issues.
I ran it and it fixed a few without giving me any more errors.
All checks passed, go!
Processing Drupal installed on '/home/jk/farmos-project/farmos/web'
Fixing ownership of files and directories
Fixing permissions on code files and directories
Setting permissions on code directories to u=rwx,g=rx,o= under 'web'
Setting permissions on code files to u=rw,g=r,o= under 'web'
Setting permissions on vendor code directories to u=rwx,g=rx,o= under '../vendor'
Removing all permissions on vendor code files to other users (o=) under '../vendor'
Fixing permissions on content files and directories under 'sites' folder
Checking folder default
Setting permissions on content directories to u=rwx,g=rwx,o= under 'files'
Setting permissions on content files to ug=rw,o= under 'files'
Processing additional content folders
Permissions and ownership fixed!
Still not a fix for my problem, but propably a useful tool
Running scripts off of GitHub is very risky! (Regardless of where you found the link!)
I would always prefer to (and recommend) understanding the considerations and making these changes manually so you know what’s happening. This is part of the responsibility of hosting your own farmOS (or any Drupal)! Its on you to make sure it’s configured properly and can’t be hacked.
Either that or put it behind a firewall/basic authentication so it isn’t publicly accessible at all.
Good point
I might have stumbled upon a clue on this case tho…
Webserver of a working docker-setup:
Webserver of the problem setup:
Maybe they need different permissions…
Nah… same old…