95 lines
2.5 KiB
JavaScript
95 lines
2.5 KiB
JavaScript
const User = require("../models/User");
|
|
const bcrypt = require("bcryptjs");
|
|
const jwt = require("jsonwebtoken");
|
|
|
|
// Generate JWT Token
|
|
const generateToken = (userId) => {
|
|
return jwt.sign({ id: userId }, process.env.JWT_SECRET, { expiresIn: "7d" });
|
|
};
|
|
|
|
// @desc Register a new user
|
|
// @route POST /api/auth/register
|
|
// @access Public
|
|
const registerUser = async (req, res) => {
|
|
try {
|
|
const { name, email, password, profileImageUrl } = req.body;
|
|
|
|
// Check if user already exists
|
|
const userExists = await User.findOne({ email });
|
|
if (userExists) {
|
|
return res.status(400).json({ message: "User already exists" });
|
|
}
|
|
|
|
// Hash password
|
|
const salt = await bcrypt.genSalt(10);
|
|
const hashedPassword = await bcrypt.hash(password, salt);
|
|
|
|
// Create new user
|
|
const user = await User.create({
|
|
name,
|
|
email,
|
|
password: hashedPassword,
|
|
profileImageUrl,
|
|
});
|
|
|
|
// Return user data with JWT
|
|
res.status(201).json({
|
|
_id: user._id,
|
|
name: user.name,
|
|
email: user.email,
|
|
profileImageUrl: user.profileImageUrl,
|
|
token: generateToken(user._id),
|
|
});
|
|
} catch (error) {
|
|
res.status(500).json({ message: "Server error", error: error.message });
|
|
}
|
|
};
|
|
|
|
// @desc Login user
|
|
// @route POST /api/auth/login
|
|
// @access Public
|
|
const loginUser = async (req, res) => {
|
|
try {
|
|
const { email, password } = req.body;
|
|
|
|
const user = await User.findOne({ email });
|
|
if (!user) {
|
|
return res.status(500).json({ message: "Invalid email or password" });
|
|
}
|
|
|
|
// Compare password
|
|
const isMatch = await bcrypt.compare(password, user.password);
|
|
if (!isMatch) {
|
|
return res.status(500).json({ message: "Invalid email or password" });
|
|
}
|
|
|
|
// Return user data with JWT
|
|
res.json({
|
|
_id: user._id,
|
|
name: user.name,
|
|
email: user.email,
|
|
profileImageUrl: user.profileImageUrl,
|
|
token: generateToken(user._id),
|
|
});
|
|
} catch (error) {
|
|
res.status(500).json({ message: "Server error", error: error.message });
|
|
}
|
|
};
|
|
|
|
// @desc Get user profile
|
|
// @route GET /api/auth/profile
|
|
// @access Private (Requires JWT)
|
|
const getUserProfile = async (req, res) => {
|
|
try {
|
|
const user = await User.findById(req.user.id).select("-password");
|
|
if (!user) {
|
|
return res.status(404).json({ message: "User not found" });
|
|
}
|
|
res.json(user);
|
|
} catch (error) {
|
|
res.status(500).json({ message: "Server error", error: error.message });
|
|
}
|
|
};
|
|
|
|
module.exports = { registerUser, loginUser, getUserProfile };
|