Created the authentication middleware

This commit is contained in:
2022-12-27 15:06:13 +01:00
parent 1839caba1b
commit fa7dd5a352

View File

@ -0,0 +1,15 @@
const {validateSession} = require("../controller/session");
const {getUserById} = require("../controller/user");
module.exports = async (req, res, next) => {
const token = req.header("Authorization")?.split(" ");
if (!token) return res.status(400).json({message: "You need to provide a token"});
if (!(token.length === 2 && token[0] === "Bearer")) return res.status(400).json({message: "You need to provide a bearer token"});
const user = await validateSession(token[1]);
if (user === null) return res.status(401).json({message: "The provided token is incorrect"});
req.user = await getUserById(user.userId);
next();
}