lamassu-server/lib/new-admin/middlewares/context.js
Sérgio Salgado 990ab32583 feat: db uses asynclocalstorage set schema
feat: set user input related header in public route requests to identify schema
fix: small fixes
2021-11-16 16:46:46 +00:00

28 lines
799 B
JavaScript

const users = require('../../users')
const buildApolloContext = async ({ req, res }) => {
if (!req.session.user) return { req, res }
const user = await users.verifyAndUpdateUser(
req.session.user.id,
req.headers['user-agent'] || 'Unknown',
req.ip
)
if (!user || !user.enabled) throw new AuthenticationError('Authentication failed')
req.session.ua = req.headers['user-agent'] || 'Unknown'
req.session.ipAddress = req.ip
req.session.lastUsed = new Date(Date.now()).toISOString()
req.session.user.id = user.id
req.session.user.username = user.username
req.session.user.role = user.role
res.set('role', user.role)
res.cookie('email', user.username)
res.set('Access-Control-Expose-Headers', 'role')
return { req, res }
}
module.exports = buildApolloContext