budibase/packages/server/middleware/authenticated.js

21 lines
511 B
JavaScript
Raw Normal View History

const jwt = require("jsonwebtoken");
module.exports = async (ctx, next) => {
2020-05-04 18:13:57 +02:00
if (!ctx.headers.authorization) {
ctx.isAuthenticated = false
await next();
return;
};
// if (!ctx.headers.authorization) ctx.throw(403, "No token provided");
const [_, token] = ctx.headers.authorization.split(" ");
try {
ctx.request.jwtPayload = jwt.verify(token, ctx.config.jwtSecret);
2020-05-04 18:13:57 +02:00
ctx.isAuthenticated = true;
} catch (err) {
ctx.throw(err.status || 403, err.text);
}
await next();
};