-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathuser.js
75 lines (56 loc) · 2.18 KB
/
user.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
const connection = require('./connect');
const jwt = require('jsonwebtoken');
const bcrypt = require('bcryptjs');
// Regist a user
exports.addNewUser = function(req, res, next) {
let username = req.body.username;
let email = req.body.email;
let password = bcrypt.hashSync(req.body.password);
let sql = 'SELECT username FROM user WHERE username=?';
connection.query(sql, [username], function(err, rows) {
if (err) {
res.json({ "Error": true, "Message": "Error executing MySQL query" });
} else {
if (rows) {
let lqs = 'INSERT INTO user (username, email, password) VALUES (?,?,?)';
connection.query(lqs, [username, email, password], function(err, rows) {
if (err) {
res.json({ "Error": true, "Message": "Username has already registered" });
} else {
res.json({ "Error": false, "Message": "Yayy your success regist your username" });
}
});
}
}
});
};
// User Login
exports.userLogin = function(req, res) {
let username = req.body.username;
let password = bcrypt.compare(req.body.password);
let sql = 'SELECT * FROM user WHERE username=?';
connection.query(sql, [username, password], function(err, rows) {
if (!err) {
if (rows.length > 0) {
if (password) {
token = jwt.sign(JSON.parse(JSON.stringify(rows[0])), 'secretkey', {
expiresIn: 3600
});
res.json({
"success": true,
"message": "Token generated",
"token": token,
"Username": username
});
} else {
res.json({
"success": false,
"message": "Can not log in",
"Username": username
});
}
}
} else
console.log(err);
});
}