-
Notifications
You must be signed in to change notification settings - Fork 0
/
server.js
91 lines (81 loc) · 2.41 KB
/
server.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
const express = require('express')
const app = express()
const http = require('http')
const server = http.createServer(app)
const { Server } = require("socket.io")
const io = new Server(server)
const bodyParser = require('body-parser')
const { User } = require('./model/user')
const mongoose = require('mongoose')
const bcrypt = require('bcryptjs')
const jwt = require('jsonwebtoken')
const { uri, jwt_secret } = require('./utils/config')
try {
mongoose.connect( uri, {
useNewUrlParser: true,
useUnifiedTopology: true,
dbName : 'accounts'
}).catch(e => console.log(e));
} catch (e) {
console.log("could not connect");
console.log(e)
}
mongoose.connection.on('connected', function() {
console.log('Mongoose connected')
})
mongoose.connection.on('disconnected', function() {
console.log('Mongoose disconnected')
})
app.use('/jquery', express.static(__dirname + '/node_modules/jquery/dist/'));
app.use(express.static(__dirname + '/public/pages'));
app.use(express.static(__dirname + '/public'));
app.use(bodyParser.json());
app.post('/api/register', async (req, res) => {
const { username, email, password: plainTextPassword } = req.body
const password = await bcrypt.hash(plainTextPassword, 10)
try {
const response = await User.findOne({
username,
email,
password
})
if(!response) {
let wins = 0;
let loses = 0;
const usr = new User({
username,
email,
password,
wins,
loses
})
await usr.save()
return res.json({ status: 'ok', data: 'Successfully created' })
} else {
return res.json({ status: 'error', error: 'User already exist' })
}
} catch(e) {
return res.json({ status: 'error', error: 'An error as occured, please try later' })
}
})
app.post('/api/login', async (req, res) => {
const { email, password } = req.body
const user = await User.findOne({
email: email
})
if(!user) {
return res.json({ status: 'error', error: 'Invalid username/password' })
}
if(await bcrypt.compare(password, user.password)) {
const token = jwt.sign({ id: user._id, username: user.username }, jwt_secret)
return res.json({ status: 'ok', data: token });
} else {
return res.json({ status: 'error', error: 'Invalid username/password' });
}
})
app.get('/', (req, res) => {
res.sendFile(__dirname + '/public/')
})
server.listen(3000, () => {
console.log('listening on port 3000')
})