-
Notifications
You must be signed in to change notification settings - Fork 1
Expand file tree
/
Copy pathindex.js
More file actions
74 lines (63 loc) · 1.88 KB
/
index.js
File metadata and controls
74 lines (63 loc) · 1.88 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
require('dotenv').config()
const http = require('http')
const express = require('express')
const session = require('express-session')
const passport = require('passport')
// logger
const { errorLogger } = require('./services/logger')
// Databases
const db = require('./db/dbConnection')
require('./mongodb/mongoConnection')
const connectRedis = require('connect-redis')
const RSessionStore = connectRedis(session)
const client = require('./services/redisConnectService')
// app
const app = express()
app.use(express.urlencoded({ extended: true, limit: '1mb' }))
app.use(express.json())
// authentication
const rStore = new RSessionStore({ client, prefix: 'denis:sess:' })
app.use(
session({
store: rStore,
secret: process.env.SESSION_SECRET,
saveUninitialized: false,
rolling: false,
resave: false
})
)
app.use(passport.initialize())
app.use(passport.session())
app.set('trust proxy', 1)
// apply Limiters
const { limiter, loginLimiter, wsLimiter } = require('./services/rateLimitService')(client)
app.use('/api/v1/blog', limiter)
app.use('/api/v1/users', limiter)
app.use('/api/v1/profile', limiter)
app.use('/api/v1/login', loginLimiter)
// routes
const routes = require('./routes')
app.use(routes)
// error handlers
app.use((req, res, next) => {
const error = new Error('Not found')
error.status = 404
next(error)
})
app.use((error, req, res, next) => {
res.status(error.status || 500)
res.json({ data: error })
})
const server = http.createServer(app)
// WS
const io = require('./services/socketService')(server, rStore, wsLimiter)
app.set('socketio', io)
// Connect to DB and run the server
db.authenticate()
.then(() => {
server.listen(process.env.PORT, err => {
if (err) errorLogger.error(`Some problem with server running`, { metadata: err })
console.log('server listening port 8803')
})
})
.catch(err => errorLogger.error(`Some problem with MySQL connection`, { metadata: err }))