express-memfilestore
Version:
express-session full featured MemoryStore layer without leaks! Allows persisting sessions to disk.
68 lines (50 loc) • 3.71 kB
Markdown
# Express-MemFileStore
> express-session full featured `MemoryStore` module without leaks! This fork of MemoryStore allows sessions to be persisted to the disk.
A session store implementation for Express using [lru-cache](https://github.com/isaacs/node-lru-cache).
Because the default `MemoryStore` for [express-session](https://github.com/expressjs/session) will lead to a memory leak due to it haven't a suitable way to make them expire.
The sessions are still stored in memory, so they're not shared with other processes or services. The sessions will also be persisted to the disk.
## Setup
$ npm install express-session express-memfilestore
Pass the `express-session` store into `express-memfilestore` to create a `MemoryStore` constructor.
```javascript
const session = require('express-session')
const MemFileStore = require('express-memfilestore')(session)
app.use(session({
cookie: { maxAge: 86400000 },
store: new MemFileStore({
checkPeriod: 86400000, // prune expired entries every 24h
savePeriod: 300000, // saves sessions to disk every 5m
saveFile: path.join(__dirname, 'sessions.json')
}),
resave: false,
secret: 'keyboard cat'
}))
```
## Options
* `checkPeriod` Define how long MemFileStore will check for expired. The period is in ms.
* `savePeriod` Sets how often MemFileStore will save sessions to disk. This is in ms.
* `saveFile` The file that MemFileStore will save the sessions to. If this is in a directory, the directory must already exist.
* `max` The maximum size of the cache, checked by applying the length
function to all values in the cache. It defaults to `Infinity`.
* `ttl` Session TTL (expiration) in milliseconds. Defaults to session.maxAge (if set), or one day. This may also be set to a function of the form `(options, sess, sessionID) => number`.
* `dispose` Function that is called on sessions when they are dropped
from the cache. This can be handy if you want to close file
descriptors or do other cleanup tasks when sessions are no longer
accessible. Called with `key, value`. It's called *before*
actually removing the item from the internal cache, so if you want
to immediately put it back in, you'll have to do that in a
`nextTick` or `setTimeout` callback or it won't do anything.
* `stale` By default, if you set a `maxAge`, it'll only actually pull
stale items out of the cache when you `get(key)`. (That is, it's
not pre-emptively doing a `setTimeout` or anything.) If you set
`stale:true`, it'll return the stale value before deleting it. If
you don't set this, then it'll return `undefined` when you try to
get a stale entry, as if it had already been deleted.
* `noDisposeOnSet` By default, if you set a `dispose()` method, then it'll be called whenever a `set()` operation overwrites an existing key. If you set this option, `dispose()` will only be called when a key falls out of the cache, not when it is overwritten.
* `serializer` An object containing `stringify` and `parse` methods compatible with Javascript's `JSON` to override the serializer used.
## Methods
`MemFileStore` implements all the **required**, **recommended** and **optional** methods of the [express-session](https://github.com/expressjs/session#session-store-implementation) store. Plus a few more:
- `startInterval()` and `stopInterval()` methods to start/clear the automatic check for expired. `startSaveInterval()` and `stopSaveInterval()` methods start/stop the session saving.
- `prune()` that you can use to manually remove only the expired entries from the store.
## Debug
To enable debug set the env var `DEBUG=MemFileStore`