1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
|
const User = require('../models/User');
const { generateToken } = require('../utils/jwt');
/**
* Register a new user
* @param {Object} req - Express request object
* @param {Object} res - Express response object
*/
const register = async (req, res) => {
try {
const { name, email, password, phone, address } = req.body;
// Check if user already exists
const existingUser = await User.findOne({ email });
if (existingUser) {
return res.status(400).json({ message: 'User already exists with this email' });
}
// Create new user
const user = await User.create({
name,
email,
password,
phone,
address,
role: 'customer' // Default role for registrations
});
// Generate token
const token = generateToken(user);
// Send response
res.status(201).json({
message: 'User registered successfully',
token,
user: {
id: user._id,
name: user.name,
email: user.email,
role: user.role
}
});
} catch (error) {
res.status(500).json({
message: 'Error registering user',
error: error.message
});
}
};
/**
* Login a user
* @param {Object} req - Express request object
* @param {Object} res - Express response object
*/
const login = async (req, res) => {
try {
const { email, password } = req.body;
// Find user by email
const user = await User.findOne({ email }).select('+password');
// Check if user exists and password is correct
if (!user || !(await user.comparePassword(password))) {
return res.status(401).json({ message: 'Invalid email or password' });
}
// Check if user is active
if (!user.active) {
return res.status(401).json({ message: 'Your account has been deactivated' });
}
// Generate token
const token = generateToken(user);
// Send response
res.status(200).json({
message: 'Logged in successfully',
token,
user: {
id: user._id,
name: user.name,
email: user.email,
role: user.role
}
});
} catch (error) {
res.status(500).json({
message: 'Error logging in',
error: error.message
});
}
};
/**
* Get current user profile
* @param {Object} req - Express request object
* @param {Object} res - Express response object
*/
const getProfile = async (req, res) => {
try {
const user = await User.findById(req.user._id);
if (!user) {
return res.status(404).json({ message: 'User not found' });
}
res.status(200).json({
user: {
id: user._id,
name: user.name,
email: user.email,
role: user.role,
phone: user.phone,
address: user.address
}
});
} catch (error) {
res.status(500).json({
message: 'Error retrieving profile',
error: error.message
});
}
};
module.exports = {
register,
login,
getProfile
};
|