const jwt = require('jsonwebtoken');
const User = require('../models/User');

const auth = async (req, res, next) => {
    try {
        const token = req.header('Authorization').replace('Bearer ', '');
        const decoded = jwt.verify(token, process.env.JWT_SECRET || 'your-secret-key');
        const user = await User.findById(decoded.id);

        if (!user) {
            throw new Error('用户不存在');
        }

        req.token = token;
        req.user = user;
        next();
    } catch (error) {
        console.error('认证失败:', error);
        res.status(401).json({ message: '请先登录' });
    }
};

const admin = (req, res, next) => {
    if (req.user && req.user.role === 'admin') {
        next();
    } else {
        res.status(401).json({ message: '未授权,需要管理员权限' });
    }
};

module.exports = { auth, admin };