-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathapp.js
More file actions
99 lines (74 loc) · 2.62 KB
/
app.js
File metadata and controls
99 lines (74 loc) · 2.62 KB
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
const Joi = require('joi');
const express = require('express');
const helmet = require('helmet');
const app = express();
// Middleware to parse json from the http body
app.use(express.json());
// security best practices
app.use(helmet()); // or app.disable('x-powered-by');
const remedios = [
{id: 1, nome: 'Remedio 1'},
{id: 2, nome: 'Remedio 2'},
{id: 3, nome: 'Remedio 3'},
{id: 4, nome: 'Remedio 4'},
{id: 5, nome: 'Remedio 5'},
];
app.get('/', (req, res) => {
res.send('This is a simple Node Rest API made by Felipe Rabelo Ferreira for testing his applications');
});
app.get('/api/remedios', (req, res) => {
res.send(remedios);
});
app.get('/api/remedios/:id', (req, res) => {
const remedio = remedios.find( c => c.id === parseInt(req.params.id));
if(!remedio) // 404 - Not Found
return res.status(404).send(`O remedio com ID: ${req.params.id} não foi encontado`);
res.send(remedio);
});
app.post('/api/remedios', (req, res) => {
const error = validateRemedio(req.body)
if(error) return res.status(404).send(error.details[0].message);
const remedio = {
id: remedios.length + 1,
nome: req.body.nome
};
remedios.push(remedio);
res.send(remedio);
});
app.put('/api/remedios/:id', (req, res) => {
const remedio = remedios.find( remedio => remedio.id === parseInt(req.params.id));
if(!remedio) // 404 - Not Found
return res.status(404).send(`O remedio com ID: ${req.params.id} não foi encontado`);
const error = validateRemedio(req.body)
if(error) return res.status(404).send(error.details[0].message);
remedio.nome = req.body.nome;
res.send(remedio);
});
app.delete('/api/remedios/:id', (req, res) => {
const remedio = remedios.find( remedio => remedio.id === parseInt(req.params.id));
if(!remedio) // 404 - Not Found
return res.status(404).send(`O remedio com ID: ${req.params.id} não foi encontado`);
const index = remedios.indexOf(remedio);
remedios.splice(index,1);
res.send(remedio);
});
// How to read params
app.get('/api/params/:id', (req, res) => {
res.send(req.params);
});
// How to read query params
// Test URL: http://localhost:PORT/api/query/?param1=56765
app.get('/api/query/', (req, res) => {
res.send(req.query);
});
function validateRemedio(remedio) {
// Usando Joi Package
const schema = Joi.object({
nome: Joi.string().min(3).required()
});
const { error } = schema.validate(remedio);
if(error) return error;
}
// PORT to listen
const port = process.env.PORT || 3000;
app.listen(port, () => console.log(`Listening on port ${port}...`));