rajesh-grocery-api / src /middleware /authMiddleware.js
rohanshaw's picture
Upload 20 files
efb87a5 verified
// src/middleware/authMiddleware.js
const jwt = require('jsonwebtoken');
const User = require('../models/User');
const protect = async (req, res, next) => {
let token;
if (
req.headers.authorization &&
req.headers.authorization.startsWith('Bearer')
) {
try {
// Get token from header (Bearer <token>)
token = req.headers.authorization.split(' ')[1];
// Verify token
const decoded = jwt.verify(token, process.env.JWT_SECRET);
// Get user from the token ID
req.user = await User.findById(decoded.id).select('-password');
next();
} catch (error) {
console.error(error);
res.status(401).json({ message: 'Not authorized, token failed' });
}
}
if (!token) {
res.status(401).json({ message: 'Not authorized, no token' });
}
};
// Admin only middleware
const adminOnly = (req, res, next) => {
if (req.user && req.user.role === 'admin') {
next();
} else {
res.status(401).json({ message: 'Not authorized as an admin' });
}
};
module.exports = { protect, adminOnly };