22 lines
798 B
TypeScript
22 lines
798 B
TypeScript
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: 'Неверный токен.' });
|
|
}
|
|
};
|