libcachebust/README.md

58 lines
1.7 KiB
Markdown
Raw Normal View History

2021-04-08 19:38:26 +05:30
<div align="center">
2021-07-04 15:04:14 +05:30
<img
width="250px"
class="greetings"
src="./examples/actix-web/static/cachable/img/Spock_vulcan-salute.png"
2023-10-17 00:18:20 +05:30
alt="A photo of Spock showing the Vulkan greeting"
2021-07-04 15:04:14 +05:30
/>
<h1>
libcachebust
2021-07-04 15:04:14 +05:30
</h1>
<p>
2021-07-04 15:20:14 +05:30
<strong>May your cache live long and prosper!</strong>
2021-07-04 15:04:14 +05:30
</p>
2021-04-08 19:38:26 +05:30
[![status-badge](https://ci.batsense.net/api/badges/100/status.svg)](https://ci.batsense.net/repos/100)
2021-04-08 19:38:26 +05:30
<br />
</div>
2021-05-12 18:20:26 +05:30
## What is cache busting?
To optimise network load time, browsers cache static files. Caching
greatly improves performance but how do you inform browsers to
2021-07-04 15:04:14 +05:30
invalidate cache when your files have changed?
2021-05-12 18:20:26 +05:30
Cache busting is a simple but effective solution for this issue. There
are several ways to achieve this but the way this library does this is
by changing file names to include the hash of the files' contents.
So if you have `bundle.js`, it will become
`bundle.<long-sha256-hash>.js`. This lets you set a super long cache age
as, because of the file names changing, the path to the filename, too,
will change. So as far as the browser is concerned, you are trying to load
a file that it doesn't have. Pretty neat, isn't it?
2021-04-08 19:38:26 +05:30
## Features
2021-12-17 11:39:02 +05:30
- [x] `SHA-256` based name generation during compile-time
- [x] Processes files based on provided MIME filters
- [x] Exclude certain files from processing based on file extensions
and/or file paths
- [x] Exposes modified names to program during runtime
- [x] Route prefixes(optional)
2021-04-08 19:38:26 +05:30
## Usage:
Add this to your `Cargo.toml`:
```toml
libcachebust = 0.2
2021-04-08 19:38:26 +05:30
```
## Examples:
2021-12-17 11:39:02 +05:30
- See [acix-example](./examples/actix-web)
- See [mCaptcha/mcaptcha](https://github.com/mCaptcha/mcaptcha) for use
with [Sailfish](https://crates.io/crates/sailfish) template engine.