hapi-etagger
Version:
Hapi plug-in for etags and HTTP 304 support
73 lines (53 loc) • 1.68 kB
Markdown
Hapi server plug-in for etags and HTTP 304 support.
It utilizes the popular [etag](https://www.npmjs.com/package/etag) library.
[](https://travis-ci.org/frankthelen/hapi-etagger)
[](https://coveralls.io/github/frankthelen/hapi-etagger?branch=master)
[]()
[](https://github.com/airbnb/javascript)
[]()
Tested with
* Hapi 20 on Node 12/14/15
* Hapi 19 on Node 12/14/15
```bash
npm install hapi-etagger
```
This plug-in provides a simple way to support etags and HTTP 304.
By default, it adds etags and HTTP 304 support to all requests that meet the following criteria:
* method is GET
* status code is 2xx
* response payload is a String, a stringifyable object or a Buffer
It is possible to opt-out.
Register the plugin with Hapi server like this:
```js
const Hapi = require('@hapi/hapi');
const etags = require('hapi-etagger');
const server = new Hapi.Server({
port: 3000,
});
const provision = async () => {
await server.register(etags);
// ...
await server.start();
};
provision();
```
You can opt-out by route configuration, e.g.:
```js
server.route({
method: 'GET',
path: '/example/{id}',
options: {
// ...
plugins: {
'hapi-etagger': {
enabled: false, // opt-out
},
},
},
// ...
});
```