-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathapp.js
41 lines (33 loc) · 1.45 KB
/
app.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
const express = require('express');
const bodyParser = require('body-parser');
const path = require('path');
const userRoutes = require('./routes/userRoutes');
const app = express();
const port = 3000;
app.use(bodyParser.json());
const adminAuth = (req, res, next) => {
const authHeader = req.headers['authorization'];
if (!authHeader || authHeader !== 'Bearer adminToken') {
return res.status(403).send('Acesso negado. Você precisa ser um administrador.');
}
next();
};
// Diretorio para puxar os arquivos
app.use(express.static(path.join(__dirname, 'publico')));
// Usando as rotas de usuários
app.use('/api/users', userRoutes);
// Rota para a página de cadastro
app.get('/cadastro', (req, res) => {
res.sendFile(path.join(__dirname, 'publico', 'cadastro.html'));
});
// Rota para a página de admin
app.get('/admin', adminAuth, (req, res) => {
res.sendFile(path.join(__dirname, 'publico', 'admin.html'));
});
// Informações iniciais para teste localhost sem /
app.get('/', (req, res) => {
res.send('<h1>Bem-vindo API de Gerenciamento de Usuários!</h1> <p>Escolha uma das opções abaixo:</p> <ul> <li><a href="/login.html">Login</a></li> <li><a href="/cadastro.html">Cadastro</a></li> <li><a href="/admin.html">Admin</a></li> <li><a href="/admin">Admin (Teste sem permissão)</a></li> </ul> <footer>Desenvolvido por --> João Paulo Estevam Valdivino</footer>');
});
app.listen(port, () => {
console.log(`API rodando em http://localhost:${port}`);
});