-
Notifications
You must be signed in to change notification settings - Fork 3
/
index.js
56 lines (43 loc) · 1.61 KB
/
index.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
//index.js
require("dotenv-safe").config();
const jwt = require('jsonwebtoken');
const express = require('express');
const app = express();
const blacklist = [];
app.use(express.json());
app.get('/', (req, res, next) => {
res.json({ message: "Tudo ok por aqui!" });
})
app.get('/clientes', verifyJWT, (req, res, next) => {
console.log("Retornou todos clientes!");
res.json([{ id: 1, nome: 'luiz' }]);
})
function verifyJWT(req, res, next) {
var token = req.headers['authorization'];
if (!token) return res.status(401).json({ auth: false, message: 'No token provided.' });
const index = blacklist.findIndex(item => item === token);
if(index !== -1) return res.status(401).end();
jwt.verify(token, process.env.SECRET, function (err, decoded) {
if (err) return res.status(401).json({ auth: false, message: 'Failed to authenticate token.' });
// se tudo estiver ok, salva no request para uso posterior
req.userId = decoded.id;
next();
});
}
app.post('/login', (req, res, next) => {
//esse teste abaixo deve ser feito no seu banco de dados
if (req.body.user === 'luiz' && req.body.pwd === '123') {
//auth ok
const userId = 1; //esse id viria do banco de dados
const token = jwt.sign({ userId }, process.env.SECRET, {
expiresIn: 300 // expires in 5min
});
return res.json({ auth: true, token: token });
}
res.status(401).json({ message: 'Login inválido!' });
})
app.post('/logout', function (req, res) {
blacklist.push(req.headers['x-access-token']);
res.json({ auth: false, token: null });
})
app.listen(3000, () => console.log("Servidor escutando na porta 3000..."));