-
Notifications
You must be signed in to change notification settings - Fork 0
/
server.js
84 lines (65 loc) · 1.96 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
81
82
83
84
'use strict';
const express = require('express');
const swig = require('swig');
const notifyValimate = require('valimate-notifier');
const http = require('http');
const app = express();
const env = process.env.NODE_ENV || 'production';
const getAcmeKeyAuth = require('./routes/getAcmeKeyAuth');
const getBlog = require('./routes/getBlog');
const getBlogPost = require('./routes/getBlogPost');
const getProjects = require('./routes/getProjects');
const getView = require('./routes/getView');
const setCacheHeaders = require('./routes/setCacheHeaders');
const standardiseUrl = require('./routes/standardiseUrl');
const handleError = require('./routes/handleError');
const IS_DEVELOPMENT = env !== 'production';
const IS_ACME_ENABLED = process.env.IS_ACME_ENABLED === 'true';
require('./init')();
app.use(express.static(__dirname + '/public'));
app.engine('html', swig.renderFile);
app.set('view engine', 'html');
app.set('views', __dirname + '/views');
swig.setDefaults({
cache: IS_DEVELOPMENT
? false
: 'memory',
locals: {
currentYear() {
return new Date().getFullYear();
},
isAnalyticsDisabled() {
return IS_DEVELOPMENT;
}
}
});
app.use((req, res, next) => {
console.log(`${new Date()} - ${req.url} requested`);
next();
});
/* Register here so that ACME challenges
* are notredirected to HTTP. */
if (IS_ACME_ENABLED) {
app.get('/.well-known/acme-challenge/:token', getAcmeKeyAuth);
}
if (!IS_DEVELOPMENT) {
app.use(standardiseUrl);
}
app.use(setCacheHeaders);
app.get('/projects', getProjects);
app.get('/blog', getBlog);
app.get('/blog/:slug', getBlogPost);
app.get('/:viewName?', getView);
app.use(handleError);
const server = http.createServer(app);
server.listen(process.env.PORT || 3000, function onBound() {
console.log('Website running on port ' + server.address().port
+ '\nEnvironment: ' + env);
notifyValimate(true);
});
process.on('SIGTERM', function die() {
console.log('Ending server process...');
server.close(() => {
process.exit(0);
});
});