1
0
Fork 0
freesewing/sites/backend/src/middleware.mjs

38 lines
979 B
JavaScript
Raw Normal View History

import cors from 'cors'
import http from 'passport-http'
import jwt from 'passport-jwt'
import { ApikeyModel } from './models/apikey.mjs'
function loadExpressMiddleware(app) {
app.use(cors())
}
function loadPassportMiddleware(passport, tools) {
passport.use(
new http.BasicStrategy(async (key, secret, done) => {
const Apikey = new ApikeyModel(tools)
await Apikey.verify(key, secret)
2022-11-08 21:04:32 +01:00
return Apikey.verified
? done(null, { ...Apikey.record, apikey: true, uid: Apikey.record.userId })
: done(false)
})
)
passport.use(
new jwt.Strategy(
{
jwtFromRequest: jwt.ExtractJwt.fromAuthHeaderAsBearerToken(),
...tools.config.jwt,
},
(jwt_payload, done) => {
2022-11-12 17:33:55 +01:00
return done(null, {
...jwt_payload,
uid: jwt_payload._id,
level: tools.config.roles.levels[jwt_payload.role] || 0,
2022-11-12 17:33:55 +01:00
})
}
)
)
}
2022-10-29 22:25:00 +02:00
export { loadExpressMiddleware, loadPassportMiddleware }