-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathindex.js
95 lines (84 loc) · 2.74 KB
/
index.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
const express = require('express');
const app = express();
const users = require('./sample/usersData');
const bodyParser = require("body-parser");
const jwt = require('jsonwebtoken');
const secret = 'ILoveGunjan'; // Note : Change this when going live
const bcrypt = require("bcrypt-nodejs");
/** bodyParser.urlencoded(options)
* Parses the text as URL encoded data (which is how browsers tend to send form data from regular forms set to POST)
* and exposes the resulting object (containing the keys and values) on req.body
*/
app.use(bodyParser.urlencoded({
extended: true
}));
app.post('register',function(req, res){
});
/**bodyParser.json(options)
* Parses the text as JSON and exposes the resulting object on req.body.
*/
app.use(bodyParser.json());
// const router = app.Router();
var myRouterfunction = function(req, res){
// res.sendFile(__dirname + '/abc.html');
// res.send({message : "welcome"});
if(req.query.name === 'Bhavesh')
res.json({message : "Hello Bhavesh! " + req.query.surname});
else
res.status(400).json({message : "Error Occured!"});
};
app.get('/',myRouterfunction);
app.get('/users', function(req,res){
if(req.headers.authorization)
res.json(users);
else {
res.status(401).json({message: "Token Missing!, Please login"})
}
})
app.get('/my-profile', function(req,res){
if(req.headers.authorization){
jwt.verify(req.headers.authorization, secret, function(err, decoded) {
if(err) {
res.staus(401).json({message:"Token invalid"})
} else {
res.json(decoded.data);
}
})
} else {
res.status(401).json({message: "Token Missing!, Please login"})
}
})
app.get('/users/:id', function(req,res){
const id = req.params.id;
let result = null;
users.forEach(function(val, key){
if(val.id == id){
result = val;
}
})
if(result) {
res.json({message: "User Found", data : result});
} else {
res.status('404').json({message: "User Not found!"});
}
})
app.post('/login', function(req, res){
const name = req.body.name;
const password = req.body.password;
let result = null;
users.forEach(function(val, key){
if(val.name == name && val.password == password){
result = Object.assign({},val);
delete result.password;
}
})
if(result) {
var token = jwt.sign({data: result}, secret, { expiresIn: '24h' });
res.json({message: "You are now logged In!!", token : token, profile : result});
} else {
res.status('401').json({message: "Username or password incorrect!"});
}
})
app.listen(3000, function() {
console.log("Server running on localhost:3000");
})