-
Notifications
You must be signed in to change notification settings - Fork 2
Expand file tree
/
Copy pathserver.js
More file actions
95 lines (85 loc) · 2.21 KB
/
server.js
File metadata and controls
95 lines (85 loc) · 2.21 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
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
var pino = require('pino')
// Create a Pino logger instance.
var log = pino({ name: 'licensezero.com' })
log.info({ directory: process.env.DIRECTORY }, 'starting')
// Check required environment variables.
var requiredEnvironmentVariables = [
'NODE_ENV',
'STRIPE_PUBLISHABLE_KEY',
'STRIPE_SECRET_KEY',
'STRIPE_WEBHOOK_SECRET',
'STRIPE_CLIENT_ID',
'DIRECTORY',
'PORT',
'PUBLIC_KEY',
'PRIVATE_KEY',
'COMMISSION'
]
if (process.env.NODE_ENV !== 'test') {
requiredEnvironmentVariables.push(
'MAILGUN_KEY',
'MAILGUN_DOMAIN',
'MAILGUN_FROM'
)
}
requiredEnvironmentVariables.forEach(function (key) {
if (!process.env[key]) {
log.error({ key }, 'missing environment variable')
process.exit(1)
}
})
if (process.env.NODE_ENV !== 'test') {
var prefixes = {
STRIPE_PUBLISHABLE_KEY: 'pk_live_',
STRIPE_SECRET_KEY: 'sk_live_',
STRIPE_CLIENT_ID: 'ca_'
}
Object.keys(prefixes).forEach(function (key) {
var prefix = prefixes[key]
if (!process.env[key].startsWith(prefix)) {
log.error('invalid ' + key)
process.exit(1)
}
})
}
// Create the HTTP server.
var requestHandler = require('./')(log)
var server = require('http').createServer(requestHandler)
// Trap signals.
process
.on('SIGTERM', logSignalAndShutDown)
.on('SIGQUIT', logSignalAndShutDown)
.on('SIGINT', logSignalAndShutDown)
.on('uncaughtException', function handleUncaught (exception) {
log.error(exception)
shutDown()
})
// Start the HTTP server.
server.listen(process.env.PORT, function onListening () {
var boundPort = this.address().port
log.info({ port: boundPort }, 'listening')
})
// Run a number of jobs in the background, cron-style.
var schedule = require('node-schedule')
var jobs = [
require('./jobs/delete-expired-orders'),
require('./jobs/delete-expired-purchases'),
require('./jobs/delete-expired-reset-tokens')
]
jobs.forEach(function (job) {
job(log, function () { })
schedule.scheduleJob('0 * * * *', function () {
job(log, function () { /* pass */ })
})
})
// Helper Functions
function logSignalAndShutDown () {
log.info('signal')
shutDown()
}
function shutDown () {
server.close(function onClosed () {
log.info('closed')
process.exit()
})
}