-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathrouters.js
173 lines (148 loc) · 4.66 KB
/
routers.js
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
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
var express = require('express');
var router = express.Router();
// configure database
var mongoose = require('mongoose');
mongoose.connect('mongodb://localhost/my_db');
var personSchema = mongoose.Schema({
name: String,
age: Number,
nationality: String
});
var Person = mongoose.model('Person', personSchema);
/*
* router.METHOD(route, callback)
* TODO: tell what to do when a get request at the given route is called.
* METHOD: any one of the HTTP verbs(get, set, put, delete)
* @PARAM:
* route: a given route
* callback has two parameters: req, res
* --> req: represents the HTTP request
* --> res: represents the HTTP response
*/
router.get('/', function(req, res){
//res.send('Main page');
res.render('index');
});
// TEST: navigate to http://<HOST>/hello
router.get('/hello', function(req, res){
res.send('Hello');
});
// TEST: curl -X POST "http://<HOST>/hello"
router.post('/hello', function(req, res){
res.send('You just called the post method at /hello');
});
// just for test
router.all('/test', function(req, res){
res.send('HTTP method doesn\'t have any effect on this route');
});
router.get('/:id([0-9]{5})', function(req, res){
//res.send('The id you specified is: ' + req.params.id);
params = {
id_params : req.params.id,
};
res.render('id', params);
});
// test get form
router.get('/form', function(req, res){
res.render('form');
});
// test cookie
// open console in browser: console.log(document.cookie)
router.get('/cookie', function(req, res){
//res.cookie('name', 'express', {expire: 360000 + Date.now()}).send('cookie set'); // set name=express
res.cookie('name', 'express', {maxAge: 360000}).send('cookie set'); // set name=express
});
// test cookie from server
router.get('/getcookie', function(req, res){
res.send('Cookies: ' + JSON.stringify(req.cookies));
});
// test delete cookie
router.get('/delcookie', function(req, res){
res.clearCookie('name').send('cookie cleared');
})
// test post form
router.post('/form', function(req, res){
res.send('Received your request: ' + ' body:' + JSON.stringify(req.body));
});
var Users = {};
// sign up
router.get('/signup', function(req, res){
res.render('signup');
})
router.post('/signup', function(req, res){
if(!req.body.id || !req.body.password){
res.status('400');
res.send('Invalid details');
}else{
if(Users[req.body.id] !== undefined)
res.render('signup', {message: 'User already exists'});
var newUser = {id: req.body.id, password: req.body.password, valid: 1};
Users[req.body.id] = newUser;
res.redirect('/protected_page/' + req.body.id);
}
});
router.get('/protected_page/:id', function(req, res){
if(Users[req.params.id] === undefined || Users[req.params.id].valid === 0){
res.send('The user doesn\'t exist or never log in');
}
else{
var params = {
id : req.params.id,
};
res.render('protected_page', params);
}
});
router.get('/login', function(req, res){
res.render('login');
});
router.post('/login', function(req, res){
if(!req.body.id || !req.body.password)
res.render('login', {message: "Please enter both id and password"});
else{
if(Users[req.body.id].id === undefined)
res.render('login', {message: 'Please sign up'});
else if (Users[req.body.id].password !== req.body.password)
res.render('login', {message: 'wrong password'});
else {
Users[req.body.id].valid = 1;
res.redirect('/protected_page/' + req.body.id);
}
}
});
router.get('/logout/:id', function(req, res){
Users[req.params.id].valid = 0;
res.redirect('/login');
});
// test with database
router.get('/person', function(req, res){
res.render('person');
});
router.post('/person', function(req, res){
var personInfo = req.body;
if( !personInfo.name || !personInfo.age || !personInfo.nationality){
res.send('Sorry, you provided wrong info');
}else{
var newPerson = new Person({
name: personInfo.name,
age: personInfo.age,
nationality: personInfo.nationality
});
newPerson.save(function(err, res2){
console.log(res2);
if(err) res.send('Database error');
else res.send('New person added');
});
}
});
router.get('/people', function(req, res){
Person.find(function(err, res2){
res.json(res2);
});
});
router.put('/people/:id', function(req, res){
Person.findByIdAndUpdate(req.params.id, req.body, function(err, res2){
if(err) res.json({message: 'Error in updating person with id: ' + req.params.id});
else res.json(res2);
});
});
module.exports = router;