Session file store for Express and Connect. Also you can use it with Koa
Session file store is a provision for storing session data in the session file
- Supports Express
>= 4.x
and Connect>= 1.4.0
through express-session - Supports Node.js
>= 8
- Indirectly supports Koa
>= 0.9.0
through express-session
$ npm install session-file-store
$ npm install
$ npm test
path
The directory where the session files will be stored. Defaults to./sessions
ttl
Session time to live in seconds. Defaults to3600
retries
The number of retries to get session data from a session file. Defaults to5
factor
The exponential factor to use for retry. Defaults to1
minTimeout
The number of milliseconds before starting the first retry. Defaults to50
maxTimeout
The maximum number of milliseconds between two retries. Defaults to100
reapIntervalObject
[OUT] Contains intervalObject if reap was scheduledreapInterval
Interval to clear expired sessions in seconds or -1 if do not need. Defaults to1 hour
reapAsync
use distinct worker process for removing stale sessions. Defaults tofalse
reapSyncFallback
reap stale sessions synchronously if can not do it asynchronously. Default tofalse
logFn
log messages. Defaults toconsole.log
fallbackSessionFn
returns fallback session object after all failed retries. No defaultsencoding
Object-to-text text encoding. Can be null. Defaults to'utf8'
encoder
Encoding function. Takes object, returns encoded data. Defaults toJSON.stringify
decoder
Decoding function. Takes encoded data, returns object. Defaults toJSON.parse
fileExtension
File extension of saved files. Defaults to'.json'
secret
Enables transparent encryption support conforming to OWASP's Session Management best practices.crypto.algorithm
Defaults toaes-256-gcm
but supports symmetric algorithms listed fromcrypto.getCiphers()
.crypto.hashing
Defaults tosha512
but supports hashing algorithms listed fromcrypto.getHashes()
.crypto.use_scrypt
Defaults totrue
. When not supported (node < 10.5) will fall back to thecrypto.pbkdf2()
key derivation function.
Due to express >= 4
changes, we need to pass express-session
to the function session-file-store
exports in order to extend session.Store
:
var session = require('express-session');
var FileStore = require('session-file-store')(session);
var fileStoreOptions = {};
app.use(session({
store: new FileStore(fileStoreOptions),
secret: 'keyboard cat'
}));
You can find basic work app examples
for express,
connect and
koa frameworks in examples
folder.