2020-04-23 15:37:08 +02:00
|
|
|
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");
|
2020-04-23 15:37:08 +02:00
|
|
|
|
|
|
|
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;
|
2020-04-23 15:37:08 +02:00
|
|
|
} catch (err) {
|
|
|
|
ctx.throw(err.status || 403, err.text);
|
|
|
|
}
|
|
|
|
|
|
|
|
await next();
|
|
|
|
};
|