All files / postcardotp-backend/src/middleware authMiddleware.js

78.94% Statements 15/19
50% Branches 2/4
100% Functions 1/1
78.94% Lines 15/19

Press n or j to go to the next uncovered block, b, p or k for the previous block.

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 311x 1x 1x 1x 1x   1x 5x 5x 5x       5x 5x   5x     5x       5x 5x            
const { jwt } = require("../config/config");
const JWT = require("jsonwebtoken");
const { models } = require("../config/sequelize");
const logger = require("../utils/logger");
const { ApiError } = require("../utils/errorHandler");
 
exports.authMiddleware = async (req, res, next) => {
  const token = req?.headers?.authorization;
  try {
    Iif (!token) {
      throw new ApiError("Oops! Token is required", 400);
    }
 
    const tokenSpilt = token.split(" ");
    const decodedToken = JWT.verify(tokenSpilt[1], jwt.secret);
 
    const user = await models.User.findOne({
      where: { id: decodedToken.userId },
    });
    Iif (!user) {
      throw new ApiError("Sorry! Invalid token.", 401);
    }
 
    req.userId = user.id;
    next();
  } catch (error) {
    logger.error(`Error occurred: ${error.message}`, { stack: error.stack });
    next(error);
  }
};