-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathserver.js
executable file
·219 lines (187 loc) · 6.18 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
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
var path = require('path')
var express = require('express')
var session = require('express-session')
var nunjucks = require('express-nunjucks')
var routes = require('./app/routes.js')
var favicon = require('serve-favicon')
var app = express()
var bodyParser = require('body-parser')
var browserSync = require('browser-sync')
var config = require('./app/config.js')
var utils = require('./lib/utils.js')
var locals = require('./app/locals')
var i18n = require("./lib/i18n")
var moment = require('moment')
var packageJson = require(path.join(__dirname, '/package.json'))
// Grab environment variables specified in Procfile or as Heroku config vars
var releaseVersion = packageJson.version
var username = process.env.USERNAME
var password = process.env.PASSWORD
var env = process.env.NODE_ENV || 'development'
var useAuth = process.env.USE_AUTH || config.useAuth
var useHttps = process.env.USE_HTTPS || config.useHttps
env = env.toLowerCase()
useAuth = useAuth.toLowerCase()
useHttps = useHttps.toLowerCase()
// Authenticate against the environment-provided credentials, if running
// the app in production (Heroku, effectively)
if (env === 'production' && useAuth === 'true') {
app.use(utils.basicAuth(username, password))
}
// Application settings
app.set('view engine', 'html')
app.set('views', [path.join(__dirname, '/app/views'), path.join(__dirname, '/lib/')])
nunjucks.setup({
autoescape: true,
watch: true,
noCache: true
}, app)
// require core and custom filters, merges to one object
// and then add the methods to nunjucks env obj
nunjucks.ready(function (env) {
var coreFilters = require(path.join(__dirname, '/lib/core_filters.js'))(env)
var customFilters = require(path.join(__dirname, '/app/filters.js'))(env)
var globals = require(path.join(__dirname, '/app/globals.js'))(env)
var filters = Object.assign(coreFilters, customFilters)
Object.keys(filters).forEach(function (filterName) {
env.addFilter(filterName, filters[filterName])
})
Object.keys(globals).forEach(function (globalName) {
env.addGlobal(globalName, globals[globalName])
})
})
i18n.expressBind(app, {
locales: ['en', 'cy'],
cookieName: 'locale', //lang || locale
directory: path.join(__dirname, '/app/assets/locales'),
extension: '.json',
renderer: function (template, args) {
return nunjucks.env.renderString(template, args)
}
});
app.use(function(req, res, next) {
req.i18n.setLocale('en')
next();
});
moment().format()
// Middleware to serve static assets
app.use('/public', express.static(path.join(__dirname, '/public')))
app.use('/public', express.static(path.join(__dirname, '/govuk_modules/govuk_template/assets')))
app.use('/public', express.static(path.join(__dirname, '/govuk_modules/govuk_frontend_toolkit')))
app.use('/public/images/icons', express.static(path.join(__dirname, '/govuk_modules/govuk_frontend_toolkit/images')))
// Elements refers to icon folder instead of images folder
app.use(favicon(path.join(__dirname, 'govuk_modules', 'govuk_template', 'assets', 'images', 'favicon.ico')))
// Support for parsing data in POSTs
app.use(bodyParser.json())
app.use(bodyParser.urlencoded({
extended: true
}))
// Support session data
app.use(session({
resave: false,
saveUninitialized: false,
secret: Math.round(Math.random() * 100000).toString()
}))
app.use(locals);
// send assetPath to all views
app.use(function (req, res, next) {
res.locals.asset_path = '/public/'
next()
})
app.use(function (req, res, next) {
let isGovUK = false;
let govUKWhiteList = [
'idam',
'sign-in',
'saveaccount',
'submit-your-appeal/guidance/overview',
'submit-your-appeal/guidance/submit-appeal',
'submit-your-appeal/guidance/after-submit-appeal',
'submit-your-appeal/guidance/at-the-hearing',
'submit-your-appeal/guidance/unhappy-tribunals-decision',
'guidance-r2/'
];
if(new RegExp(govUKWhiteList.join("|")).test(req.originalUrl)) {
isGovUK = true;
}
res.locals.isGovUK = isGovUK;
next()
})
// Add variables that are available in all views
app.use(function (req, res, next) {
res.locals.serviceName = config.serviceName
res.locals.cookieText = config.cookieText
res.locals.releaseVersion = 'v' + releaseVersion
next()
})
// Force HTTPs on production connections
if (env === 'production' && useHttps === 'true') {
app.use(utils.forceHttps)
}
// Disallow search index idexing
app.use(function (req, res, next) {
// Setting headers stops pages being indexed even if indexed pages link to them.
res.setHeader('X-Robots-Tag', 'noindex')
next()
})
app.get('/robots.txt', function (req, res) {
res.type('text/plain')
res.send('User-agent: *\nDisallow: /')
})
// routes (found in app/routes.js)
if (typeof (routes) !== 'function') {
console.log(routes.bind)
console.log('Warning: the use of bind in routes is deprecated - please check the prototype kit documentation for writing routes.')
routes.bind(app)
} else {
app.use('/', routes)
}
// Strip .html and .htm if provided
app.get(/\.html?$/i, function (req, res) {
var path = req.path
var parts = path.split('.')
parts.pop()
path = parts.join('.')
res.redirect(path)
})
// auto render any view that exists
app.get(/^\/([^.]+)$/, function (req, res) {
var path = (req.params[0])
res.render(path, function (err, html) {
if (err) {
res.render(path + '/index', function (err2, html) {
if (err2) {
console.log(err)
res.status(404).send(err + '<br>' + err2)
} else {
res.end(html)
}
})
} else {
res.end(html)
}
})
})
console.log('\nGOV.UK Prototype kit v' + releaseVersion)
// Display warning not to use kit for production services.
console.log('\nNOTICE: the kit is for building prototypes, do not use it for production services.')
// start the app
utils.findAvailablePort(app, function (port) {
console.log('Listening on port ' + port + ' url: http://localhost:' + port)
if (env === 'production') {
app.listen(port)
} else {
app.listen(port - 50, function () {
browserSync({
proxy: 'localhost:' + (port - 50),
port: port,
ui: false,
files: ['public/**/*.*', 'app/views/**/*.*'],
ghostmode: false,
open: false,
notify: false,
logLevel: 'error'
})
})
}
})