52 lines
1.9 KiB
JavaScript
52 lines
1.9 KiB
JavaScript
"use strict";
|
|
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
};
|
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
exports.authenticateSocket = exports.authenticateToken = void 0;
|
|
const jsonwebtoken_1 = __importDefault(require("jsonwebtoken"));
|
|
const database_js_1 = require("../config/database.js");
|
|
const env_js_1 = require("../config/env.js");
|
|
const authenticateToken = (req, res, next) => {
|
|
try {
|
|
const authHeader = req.headers.authorization;
|
|
const token = authHeader?.split(" ")[1];
|
|
if (!token) {
|
|
res.status(401).json({ success: false, error: "Access token required" });
|
|
return;
|
|
}
|
|
const decoded = jsonwebtoken_1.default.verify(token, env_js_1.env.JWT_SECRET);
|
|
req.user = decoded;
|
|
next();
|
|
}
|
|
catch (error) {
|
|
console.error("Authentication error:", error);
|
|
res.status(403).json({ success: false, error: "Invalid or expired token" });
|
|
}
|
|
};
|
|
exports.authenticateToken = authenticateToken;
|
|
const authenticateSocket = async (socket, next) => {
|
|
try {
|
|
const token = socket.handshake.auth.token;
|
|
if (!token) {
|
|
return next(new Error("Authentication token required"));
|
|
}
|
|
const decoded = jsonwebtoken_1.default.verify(token, env_js_1.env.JWT_SECRET);
|
|
const user = await database_js_1.prisma.user.findUnique({
|
|
where: {
|
|
id: decoded.userId,
|
|
},
|
|
});
|
|
if (!user)
|
|
return next(new Error("User not found"));
|
|
const authenticateSocket = socket;
|
|
authenticateSocket.userId = user.id;
|
|
authenticateSocket.user = user;
|
|
next();
|
|
}
|
|
catch (error) {
|
|
console.error("Socket authentication error:", error);
|
|
}
|
|
};
|
|
exports.authenticateSocket = authenticateSocket;
|