| 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; |