21 lines
653 B
JavaScript
21 lines
653 B
JavaScript
import session from 'express-session';
|
|
import MongoStoreFactory from 'connect-mongo';
|
|
|
|
const MongoStore = MongoStoreFactory(session);
|
|
const sessionSecret = process.env.SESSION_SECRET;
|
|
const url = process.env.MONGODB || process.env.MONGOHQ_URL;
|
|
|
|
export default function sessionsMiddleware() {
|
|
return session({
|
|
// 900 day session cookie
|
|
cookie: { maxAge: 900 * 24 * 60 * 60 * 1000 },
|
|
// resave forces session to be resaved
|
|
// regardless of whether it was modified
|
|
// this causes race conditions during parallel req
|
|
resave: false,
|
|
saveUninitialized: true,
|
|
secret: sessionSecret,
|
|
store: new MongoStore({ url })
|
|
});
|
|
}
|