Spaces:
Sleeping
Sleeping
| // 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 }; |