-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathapp.js
81 lines (63 loc) · 1.94 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
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
require('dotenv').config();
const express = require('express');
const rateLimit = require('express-rate-limit');
const helmet = require('helmet');
const cors = require('cors');
const cookieParser = require('cookie-parser');
const { errors } = require('celebrate');
const { createUser, login, logout } = require('./controllers/users');
const { requestLogger, errorLogger } = require('./middlewares/logger');
const { validateRegister, validateLogin } = require('./middlewares/validation');
const auth = require('./middlewares/auth');
const { NotFoundError } = require('./errors/classes');
const { StatusCodes } = require('./helpers/StatusCodes');
const { messages } = require('./helpers/messages');
const { PORT = 3000, HOST = 'localhost' } = process.env;
const app = express();
app.use(
rateLimit({
windowMs: 15 * 60 * 1000, // in 15m...
max: 100, // requests per IP.
}),
helmet(),
cors({
credentials: true,
origin: [
'https://m.e.s.t.o.nomoredomains.rocks',
'https://api.m.e.s.t.o.nomoredomains.rocks',
'https://localhost:3000',
],
}),
);
app.options('*', cors()); // preflight request
app.use(
cookieParser(),
express.json(),
);
app.use(requestLogger);
app.get('/crash-test', () => {
setTimeout(() => {
throw new Error('Сервер сейчас упадёт (или нет)');
}, 0);
});
app.post('/signup', validateRegister, createUser);
app.post('/signin', validateLogin, login);
app.delete('/signout', logout);
app.use('/users', auth, require('./routes/users'));
app.use('/cards', auth, require('./routes/cards'));
app.use('*', () => {
throw new NotFoundError(messages.notFound);
});
app.use(errorLogger);
app.use(
errors(),
(err, req, res, next) => {
const {
statusCode = StatusCodes.internal,
message = messages.internal,
} = err;
res.status(statusCode).send({ message });
next();
},
);
app.listen(PORT, () => console.log(`API listening on http://${HOST}:${PORT}`));