codemonauts / craft-asset-autoversioning
A Twig extension for Craft CMS that helps you cache-bust your assets.
Installs: 16 113
Dependents: 0
Suggesters: 0
Security: 0
Stars: 4
Watchers: 5
Forks: 2
Open Issues: 2
Type:craft-plugin
Requires
- craftcms/cms: ^4.0.0-alpha.1
This package is auto-updated.
Last update: 2025-03-04 12:57:35 UTC
README
A really basic Twig extension for CraftCMS that helps you cache-bust your assets.
Background
To force the browser to download the new asset file after a update, the plugin allows you to add a Twig function, which adds the build number or the filemtime to the filename.
Requirements
- Craft CMS >= 4.0.0
Installation
Project
Open your terminal and go to your Craft project:
cd /path/to/project
composer require codemonauts/craft-asset-autoversioning
./craft install/plugin craft3-assets-autoversioning
CI/CD Pipeine
The build number which gets added to the asset URL is read from a file called build.txt
which must exist in your project folder. Use for example something like this in your deployment script (Example is for CodeShip):
echo -n "${CI_BUILD_NUMBER}" > build.txt
If the file doesn't exists, the filemtime of the asset is used.
Webserver
Because the clients will from now on start to request files like /css/styles.12345678.css
we need to tell the webserver how to rewrite these URLs so that the original /css/styles.css
will get served.
Apache
<IfModule mod_rewrite.c>
RewriteEngine On
RewriteCond %{REQUEST_FILENAME} !-f
RewriteRule ^(.*?\/)*?([a-z\.\-]+)(\d+)\.(bmp|css|cur|gif|ico|jpe?g|js|png|svgz?|webp|webmanifest)$ $1$2$4 [L]
</IfModule>
NGINX
location ~* (.+)\.(?:\d+)\.(js|css|png|jpg|jpeg|gif|webp)$ { try_files $uri $1.$2; }
Usage
Use the new Twig function versioning()
in your template. For example in pug:
<link rel="stylesheet" href="{{ versioning('/css/styles.css')}}">
will result in something like this:
<link rel="stylesheet" href="/css/styles.12345678.css">
With ❤ by codemonauts