-
Notifications
You must be signed in to change notification settings - Fork 0
/
server.js
83 lines (62 loc) · 2.29 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
require('dotenv').config();
const express = require('express');
const app = express();
const port = 3300;
//todo - conexão com a base de dados
const mongoose = require('mongoose');
mongoose.connect(process.env.MONGODB,
{ useNewUrlParser: true,
useUnifiedTopology: true,
})
.then(() => {
console.log('conectei a base de dados');
app.emit('Estou pronto'); //todo - emitir um evento para a base escutar primeiro
})
.catch(e => console.log(e));
/**
*? middleware express-session armazena os dados da sessão no servidor; ele salva apenas o ID da sessão no cookie, não os dados da sessão. Por padrão, ele usa armazenamento em memória e não é projetado para um ambiente de produção. */
const session = require('express-session');
//? CONEXÃO COM O BANCO DE DADOS MONGODB
const MongoStore = require('connect-mongo');
//? PERMITE QUE UMA MSG SEJA ENVIADA SEMPRE QUE O USUARIO REDIRECIONAR PARA UMA PAGINA ESPECIFICA
const flash = require('connect-flash');
//? ROTAS
const routes = require('./routes');
//? CONTROLE DE ARQUIVOS E DIRETÓRIOS
const path = require('path');
//?SEGURANÇA
const helmet = require('helmet');
const csrf = require('csurf');
//?const meuMiddleware = require('./src/middlewares/middleware');
const {middlewareGlobal, checkCsrfError, csrfMiddleware} = require('./src/middlewares/middleware');
app.use(helmet());
app.use(express.urlencoded({extended: true}));
//Pasta de conteúdo estáticos. ex (assets, img, css)ss
app.use(express.static(path.resolve(__dirname, 'public')));
//configurando a sessao
const sessionOptions = session({
secret: 'texto que ninguem pode saber aqui',
store: MongoStore.create({ mongoUrl: process.env.MONGODB }),
resave: false,
saveUninitialized: false,
cookie: {
maxAge: 1000 * 60 * 60 * 24 * 7,
httpOnly: true
}
});
app.use(sessionOptions);
app.use(flash());
app.set('views', path.resolve(__dirname, 'src', 'views'));
app.set('view engine', 'ejs');
//todo - meu próprio middleware
app.use(csrf());
app.use(middlewareGlobal);
app.use(checkCsrfError);
app.use(csrfMiddleware);
app.use(routes);
//todo - recebendo o emit para escutar primeiro.
app.on('connect', () => {
});
app.listen(port, () => {
console.log(`Servidor executando na porta http://localhost:${port}`);
});