import jwt from "jsonwebtoken"; const JWT_SECRET = process.env.JWT_SECRET || "sbsports-dev-secret-change-in-prod"; const JWT_EXPIRES = "8h"; export function signToken(payload) { return jwt.sign(payload, JWT_SECRET, { expiresIn: JWT_EXPIRES }); } export function requireAuth(req, res, next) { const header = req.headers.authorization || ""; const token = header.startsWith("Bearer ") ? header.slice(7) : null; if (!token) return res.status(401).json({ error: "No autenticado" }); try { req.user = jwt.verify(token, JWT_SECRET); next(); } catch { res.status(401).json({ error: "Token inválido o expirado" }); } }