-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathserver.js
68 lines (56 loc) · 1.83 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
const express = require('express');
const path = require('path');
const app = express();
const db = require("./db.js");
const bodyParser = require("body-parser");
app.use(bodyParser.urlencoded({ extended: false }));
app.use(bodyParser.json());
app.use(express.static(path.join(__dirname, 'build')));
const getAllQuery = `SELECT * FROM esami`;
const insertQuery = `INSERT INTO esami (nome, crediti, voto) VALUES (?, ?, ?)`;
const deleteQuery = `DELETE FROM esami WHERE id=?`;
app.get('/ping', (_, res) => {
return res.send('pong');
});
app.get('/', (_, res) => {
res.sendFile(path.join(__dirname, 'build', 'index.html'));
});
app.get('/esami', (_, res) => {
return db.all(getAllQuery, [], (err, rows) => {
if (err) {
return res.status(500).send('Non sono riuscito a leggere i dati necessari');
}
return res.send(rows.reverse());
});
});
app.post('/esami', (req, res) => {
const nome = req.body.nome;
const crediti = parseInt(req.body.crediti);
const voto = parseInt(req.body.voto);
if (!nome || !crediti || !voto) {
return res.status(400).send('Tutti i parametri sono necessari');
}
return db.run(insertQuery, [nome, crediti, voto], function (err) {
if (err) {
return res.status(400).send('Impossibile inserire l\'esame');
}
return res.send({
lastID: this.lastID
});
});
});
app.delete('/esami', (req, res) => {
const id = req.body.id;
if (!id) {
return res.status(400).send('Fornire l\'id dell\'esame da eliminare');
}
return db.run(deleteQuery, id, function (err) {
if (err) {
return res.status(400).send('Impossibile rimuovere l\'esame');
}
return res.send({
cahnges: this.changes
});
});
});
app.listen(process.env.PORT || 8080);