users.js
3.56 KB
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
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
var express = require('express'),
User = require('../models/User');
var router = express.Router();
function needAuth(req, res, next) {
if (req.session.user) {
next();
} else {
req.flash('danger', '로그인이 필요합니다.');
res.redirect('/signin');
}
}
function validateForm(form, options) {
var name = form.name || "";
var email = form.email || "";
name = name.trim();
email = email.trim();
if (!name) {
return '이름을 입력해주세요.';
}
if (!email) {
return '이메일을 입력해주세요.';
}
if (!form.password && options.needPassword) {
return '비밀번호를 입력해주세요.';
}
if (form.password !== form.password_confirmation) {
return '비밀번호가 일치하지 않습니다.';
}
if (form.password.length < 6) {
return '비밀번호는 6글자 이상이어야 합니다.';
}
return null;
}
/* GET users listing. */
router.get('/', needAuth, function(req, res, next) {
User.find({}, function(err, users) {
if (err) {
return next(err);
}
res.render('users/index', {users: users});
});
});
router.get('/new', function(req, res, next) {
res.render('users/new', {messages: req.flash()});
});
router.get('/:id/edit', function(req, res, next) {
User.findById(req.params.id, function(err, user) {
if (err) {
return next(err);
}
res.render('users/edit', {user: user});
});
});
router.put('/:id', function(req, res, next) {
var err = validateForm(req.body);
if (err) {
req.flash('danger', err);
return res.redirect('back');
}
User.findById({_id: req.params.id}, function(err, user) {
if (err) {
return next(err);
}
if (!user) {
req.flash('danger', '존재하지 않는 사용자입니다.');
return res.redirect('back');
}
if (user.password !== req.body.current_password) {
req.flash('danger', '현재 비밀번호가 일치하지 않습니다.');
return res.redirect('back');
}
user.name = req.body.name;
user.email = req.body.email;
if (req.body.password) {
user.password = req.body.password;
}
user.save(function(err) {
if (err) {
return next(err);
}
req.flash('success', '사용자 정보가 변경되었습니다.');
res.redirect('/users');
});
});
});
router.delete('/:id', function(req, res, next) {
User.findOneAndRemove({_id: req.params.id}, function(err) {
if (err) {
return next(err);
}
req.flash('success', '사용자 계정이 삭제되었습니다.');
res.redirect('/users');
});
});
router.get('/:id', function(req, res, next) {
User.findById(req.params.id, function(err, user) {
if (err) {
return next(err);
}
res.render('users/show', {user: user});
});
});
router.post('/', function(req, res, next) {
var err = validateForm(req.body, {needPassword: true});
if (err) {
req.flash('danger', err);
return res.redirect('back');
}
User.findOne({email: req.body.email}, function(err, user) {
if (err) {
return next(err);
}
if (user) {
req.flash('danger', '동일한 이메일 주소가 이미 존재합니다.');
res.redirect('back');
}
var newUser = new User({
name: req.body.name,
email: req.body.email,
});
newUser.password = req.body.password;
newUser.save(function(err) {
if (err) {
return next(err);
} else {
req.flash('success', '가입이 완료되었습니다. 로그인 해주세요.');
res.redirect('/');
}
});
});
});
module.exports = router;