nepada / bust-cache
Cache busting Latte tag.
Installs: 12 053
Dependents: 0
Suggesters: 0
Security: 0
Stars: 5
Watchers: 3
Forks: 1
Open Issues: 0
Requires
- php: >=8.1.0 <8.5
- latte/latte: ^3.0.1@dev
Requires (Dev)
- nepada/coding-standard: 7.14.0
- nepada/phpstan-nette-tester: 1.2.1
- nette/application: ^3.1.6@dev
- nette/bootstrap: >=3.1@dev
- nette/caching: ^3.0.2@dev
- nette/component-model: >=3.0.2
- nette/di: ^3.0.6@dev
- nette/http: *@dev
- nette/neon: >=3.3.4@dev
- nette/robot-loader: *@dev
- nette/schema: ^1.0.3@dev
- nette/tester: 2.5.4
- php-parallel-lint/php-parallel-lint: 1.4.0
- phpstan/phpstan: 1.12.5
- phpstan/phpstan-nette: 1.3.8
- phpstan/phpstan-strict-rules: 1.6.1
- shipmonk/phpstan-rules: 3.2.0
- spaze/phpstan-disallowed-calls: 3.4.0
Suggests
- nette/caching: for caching support
- nette/di: for integration with Nette DI container
Conflicts
- nette/caching: <3.0.2
- nette/di: <3.0.6
README
Installation
Via Composer:
$ composer require nepada/bust-cache
Register the extension in config.neon
:
extensions: bustCache: Nepada\Bridges\BustCacheDI\BustCacheExtension(%wwwDir%, %debugMode%)
Overview of available configuration options with their default values:
bustCache: strategy: contentHash # modificationTime in debugMode autoRefresh: %debugMode% manifest: true strictMode: false
If you're using stand-alone Latte, install the Latte extension manually:
$fileSystem = Nepada\BustCache\LocalFileSystem::forDirectory($wwwDir); $manifestFinder = new Nepada\BustCache\Manifest\AutodetectManifestFinder($fileSystem); $revisionFinder = new Nepada\BustCache\Manifest\DefaultRevisionFinder($fileSystem, $manifestFinder); $cache = new Nepada\BustCache\Caching\NullCache(); // or other implementation of Cache $strategy = new Nepada\BustCache\CacheBustingStrategies\ContentHash(); // or other strategy $pathProcessor = new Nepada\BustCache\BustCachePathProcessor($fileSystem, $cache, $revisionFinder, $strategy); $latte->addExtension(new Nepada\Bridges\BustCacheLatte\BustCacheLatteExtension($pathProcessor, $strictMode, $autoRefresh));
Usage
Basic example:
<link rel="stylesheet" href="{bustCache /css/style.css}">
The resulting path depends on the (auto-)chosen cache busting strategy:
<!-- using path from revision manifest --> <link rel="stylesheet" href="/css/style-30cc681d44.css"> <!-- using query cache busting with modificationTime strategy: timestamp of the last file modification --> <link rel="stylesheet" href="/css/style.css?1449177985"> <!-- using query cache busting with contentHash strategy: first 10 letters of md5 hash of the file content --> <link rel="stylesheet" href="/css/style.css?a1d0c6e83a">
Usage in application with non-trivial base path:
<link rel="stylesheet" href="{$basePath}{bustCache /css/style.css}">
Generating full absolute URL:
<link rel="stylesheet" href="{$baseUrl}{bustCache /css/style.css}">
Revision manifest support
Revision manifest is a JSON file that contains mapping between original asset path and its revision path.
Example:
{ "css/style.css": "css/style-30cc681d44.css", "js/app.js": "js/app-68130ccd44.js" }
Configuration
With default configuration the path of manifest file is auto-detected by traversing up from asset directory and looking for manifest.json
or rev-manifest.json
. If a manifest file is found, the contained revision mapping is used instead of cache busting using query parameter.
You can completely disable the revision manifest support by setting manifest: false
in your config.
You can also bypass the auto-detection and specify the manifest file path statically, e.g. manifest: "assets/my-manifest.json"
Caching
The caching is implemented on two levels - runtime and compile-time.
Runtime caching
The cache stores the computed cache busted path for each input path.
DI extension automatically enables this cache, if you have nette/caching
configured. In production mode with default settings, asset files are not checked for modification to avoid unnecessary I/O, i.e. the cache is not automatically refreshed.
Compile time caching
When the file path is specified as literal string, the cache busted path is computed in compile time of Latte template and the cache busted path is directly dumped into the compiled code of template.
With the default settings, this is enabled only in production mode.
Cache busting of files that are modified in app runtime
If you want to use cache busting on files that are expected to be modified in app runtime, you can use dynamic
keyword to opt-out of compile time caching and force auto refresh of cache even in production mode:
<link rel="stylesheet" href="{bustCache dynamic /css/theme.css}">
Handling of missing manifest or asset files
With default configuration, when a missing file (manifest or asset) is encountered a warning triggered and asset dummy path is generated. You can switch to strictMode: true
to fail hard by throwing exception instead.
"Missing file" is one of the following cases:
- the static manifest file specified in configuration does not exist
- a manifest file points to a revision path that does not exist
- using cache busting by query parameter with asset path that does not exist