import { Request, Response, NextFunction } from 'express'; import jwt from 'jsonwebtoken'; const SECRET_KEY = process.env.JWT_SECRET || 'your_secret_key'; export const verifyToken = (req: Request, res: Response, next: NextFunction): void => { const token = req.header('Authorization')?.replace('Bearer ', ''); if (!token) { res.status(401).json({ message: 'Доступ запрещён. Токен отсутствует.' }); return; } try { const decoded = jwt.verify(token, SECRET_KEY) as { id: number; username: string }; req.user = decoded; // Добавляем `user` в `req` next(); // Передаём управление следующему middleware } catch (error) { res.status(401).json({ message: 'Неверный токен.' }); } };