forked from quocnguyen/phim
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathrouter.js
104 lines (92 loc) · 1.95 KB
/
router.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
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
'use strict'
const qs = require('querystring')
const ctrl = require('./ctrl')
const consolidate = require('consolidate')
const {resolve} = require('path')
const Router = require('router')
const url = require('url')
const compression = require('compression')
const serveStatic = require('serve-static')
const helmet = require('helmet')
const csurf = require('csurf')
const cookieParser = require('cookie-parser')
const DAY_IN_MILISECOND = 24 * 60 * 60 * 1000
const app = Router()
// gzip
app.use(
compression({
level: process.env.COMPRESSION_LEVEL || 1
})
)
// assets
app.use(
serveStatic(
resolve(__dirname, '..', 'public'),
{
maxAge: DAY_IN_MILISECOND
}
)
)
// render
app.use(
(req, res, next) => {
res.render = (filename, params = {}) => {
const path = resolve(__dirname, '..', 'views', filename)
res.locals = res.locals || {}
consolidate.mustache(
path,
Object.assign(params, res.locals),
(err, html) => {
if (err) { throw err }
res.setHeader('Content-Type', 'text/html; charset=utf8')
res.end(html)
}
)
}
next()
}
)
// query string
app.use(
(req, res, next) => {
req.query = qs.parse(
url.parse(req.url).query
)
next()
}
)
// parse body
app.use((req, res, next) => {
req.body = {}
if (req.method !== 'POST') { return next() }
let body = ''
req.on('data', (buf) => {
body += buf.toString()
})
req.on('end', () => {
req.body = qs.parse(body)
next()
})
})
// enable cookie
app.use(cookieParser())
// helmet best practise protection
app.use(helmet())
// csrf protection
app.use(
csurf({
cookie: true
})
)
// assign csrfToken to view
app.use(
(req, res, next) => {
res.locals = res.locals || {}
res.locals.csrfToken = req.csrfToken()
next()
}
)
app.get('/', ctrl.home.index)
app.get('/search', ctrl.home.handleSearchVideos)
app.get('/watch', ctrl.home.watch)
module.exports = app