avholodnyak / assets-buster-bundle
This bundle provides support for cache busting using buster files. It uses custom version strategies feature that was introduced in Symfony 3.1.
Installs: 19
Dependents: 0
Suggesters: 0
Security: 0
Stars: 1
Watchers: 1
Forks: 0
Open Issues: 0
Type:symfony-bundle
Requires
- symfony/asset: ^3.1
- symfony/config: ^3.1
- symfony/dependency-injection: ^3.1
- symfony/http-kernel: ^3.1
Requires (Dev)
- doctrine/annotations: ^1.3
- phpunit/phpunit: ^5.7
- satooshi/php-coveralls: ^1.0
- symfony/framework-bundle: ^3.1
- symfony/templating: ^3.1
- symfony/translation: ^3.1
- symfony/twig-bundle: ^3.1
This package is not auto-updated.
Last update: 2024-11-09 20:34:02 UTC
README
When you write your front-end application you often need to update cached assets on the client side. This bundle provides you an ability to update cached assets by using busters files (you can generate these files by using gulp-buster package).
This bundle uses the custom version strategies feature that was introduced in Symfony 3.1. When I was creating this bundle I was inspired by that article.
Installation
Install the bundle using composer:
$ composer require avholodnyak/assets-buster-bundle
Then, enable the bundle by adding it to the list of registered bundles
in the app/AppKernel.php
file of your project:
<?php // app/AppKernel.php public function registerBundles() { $bundles = array( // ... new AVHolodnyak\AssetsBusterBundle\AssetsBusterBundle(), ); }
Then, configure the bundle in your app/config/config.yml
file:
assets_buster: # Absolute path to the busters file busters_path: "%kernel.root_dir%/../web/busters.json" # (Optional) Version format (sprintf-compatible format string). Default value is "%%s?%%s" version_format: "%%s?v=%%s"
How to use
Just use the standard symfony asset()
function for Twig templates
(or $view["assets"]->getUrl()
for PHP templates),
and a version of an asset file will be appended automatically.
If you don't want to append a version of an asset file,
then don't put the corresponding version to the busters file.
Here is an example of how to use the bundle with Twig templates:
<link rel="stylesheet" href="{{ asset('js/example-script.js') }}">
By default the bundle uses "%s?%s"
version format. If a corresponding version will be found in the
busters file, then it will be appended to the result asset path:
<link rel="stylesheet" href="/js/example-script.js?cc1d8837ebc45c34f9e35217db1d2a7e">
If no version will be found in the busters file, then nothing will be appended to the result path:
<link rel="stylesheet" href="/js/example-script.js">
You can change the way the bundle appends a version of an asset file
by changing the version_format
option in your configuration file (see the Installation section above).