-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathserver.js
50 lines (46 loc) · 1.32 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
// Only used for production server.
// You may not even need this if you have proxying setup (just run build/index.js directly).
// Please update as neccesary.
const ms = require('ms')
global.SECURITY = {
noSniff: true,
ieNoOpen: true,
xssFilter: true,
frameguard: true,
hidePoweredBy: true,
referrerPolicy: true,
dnsPrefetchControl: true,
hpkp: {
maxAge: ms('90 days'),
sha256s: ['AbCdEf123=', 'ZyXwVu456='] // CHANGE ME
},
hsts: {
maxAge: ms('90 days'),
includeSubdomains: true,
force: true
},
contentSecurityPolicy: {
directives: {
defaultSrc: ["'self'"],
scriptSrc: ["'self'", "'unsafe-inline'", 'www.google-analytics.com'],
styleSrc: ["'self'", "'unsafe-inline'"],
fontSrc: ["'self'"],
imgSrc: ["'self'", 'data:', 'www.google-analytics.com', 'stats.g.doubleclick.net'],
sandbox: ['allow-same-origin', 'allow-scripts']
}
}
}
// Start secure server.
const app = require('./build').default
const server = require('auto-sni')({
agreeTos: true,
email: '[email protected]', // CHANGE ME
domains: ['domain.com'], // CHANGE ME
ports: {
http: process.env.HTTP_PORT,
https: process.env.HTTPS_PORT
}
}, app.emit.bind(app, 'request'))
server.once('listening', () => {
console.log(`Production Server running on port ${server.address().port}`)
})