-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathserver.js
104 lines (104 loc) · 2.85 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
92
93
94
95
96
97
98
99
100
101
102
103
104
const fetch = require('node-fetch');
const cryptoRandomString = require('crypto-random-string');
var Datastore = require('nedb');
var db = new Datastore();
const html = require('node-html-parser');
const express = require('express');
const app = express();
const port = process.env.PORT || 3002;
app.use(express.json());
app.get('/', (req, res) => {
res.sendFile('landing.html', {
root: __dirname + '/public'
});
});
app.get('/style.css', (req, res) => {
res.sendFile('style.css', {
root: __dirname + '/public'
});
});
app.get('/api', (req, res) => {
res.sendStatus(200);
});
app.post('/api/init', (req, res) => {
if (req.body.user) {
db.find({
user: req.body.user
}, (err, docs) => {
if (docs[0]) {
db.remove({
user: req.body.user
}, {
multi: true
}, (err, numRemoved) => {
console.log(`Removed duplicate user ${req.body.user} from database`);
});
}
});
var code = cryptoRandomString({
length: 45,
type: 'distinguishable'
});
var doc = {
user: req.body.user,
code: code
}
db.insert(doc, (err, newDoc) => {
console.log(`Successfully created a verification code for user ${req.body.user}`);
res.send({
code: code
});
})
} else {
res.sendStatus(406);
console.log(req);
}
});
app.post('/api/verify', (req, res) => {
if (req.body.user) {
db.find({
user: req.body.user
}, (err, docs) => {
if (docs[0] !== undefined) {
console.log(`User ${req.body.user} exists in database`);
var code = docs[0].code;
fetch(`https://scratch.mit.edu/site-api/comments/user/${req.body.user}/?page=1`)
.then((res) => {
return res.text();
})
.then((data) => {
const root = html.parse(data);
var comment = {
plaintext: root.querySelector('.content').text.trim(),
username: root.querySelector('#comment-user').getAttribute('data-comment-user')
};
if (comment.plaintext == docs[0].code && comment.username == req.body.user) {
res.sendStatus(200);
db.find({
user: req.body.user
}, (err, docss) => {
if (docss[0]) {
db.remove({
user: req.body.user
}, {
multi: true
}, (err, numRemoved) => {
console.log(`Removed duplicate user ${req.body.user} from database`);
});
}
});
} else {
res.sendStatus(403);
}
})
} else {
res.sendStatus(403);
}
})
} else {
res.sendStatus(406);
}
});
app.listen(port, () => {
console.log(`Example app listening at http://localhost:${port}`)
});