27 lines
765 B
JavaScript
27 lines
765 B
JavaScript
const express = require('express')
|
|
const router = express.Router()
|
|
const session = require('express-session')
|
|
const PgSession = require('connect-pg-simple')(session)
|
|
const db = require('../../db')
|
|
const { USER_SESSIONS_TABLE_NAME } = require('../../constants')
|
|
const { getOperatorId } = require('../../operator')
|
|
|
|
router.use('*', async (req, res, next) => getOperatorId('authentication').then(({ operatorId }) => session({
|
|
store: new PgSession({
|
|
pgPromise: db,
|
|
tableName: USER_SESSIONS_TABLE_NAME
|
|
}),
|
|
name: 'lamassu_sid',
|
|
secret: operatorId,
|
|
resave: false,
|
|
saveUninitialized: false,
|
|
cookie: {
|
|
httpOnly: true,
|
|
secure: true,
|
|
sameSite: true,
|
|
maxAge: 60 * 10 * 1000 // 10 minutes
|
|
}
|
|
})(req, res, next))
|
|
)
|
|
|
|
module.exports = router
|