const jwt = require('jsonwebtoken'); const User = require('../models/User'); const auth = async (req, res, next) => { try { const token = req.header('Authorization')?.replace('Bearer ', ''); if (!token) { return res.status(401).json({ error: 'Access denied. No token provided.' }); } const decoded = jwt.verify(token, process.env.JWT_SECRET); const user = await User.findById(decoded.userId); if (!user || !user.isActive) { return res.status(401).json({ error: 'Token is not valid.' }); } req.userId = user._id.toString(); req.user = user; next(); } catch (error) { res.status(401).json({ error: 'Token is not valid.' }); } }; module.exports = auth;