forked from RisingStack/risingstack-bootcamp
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathindex.js
42 lines (35 loc) · 1.2 KB
/
index.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
/* eslint-disable global-require */
'use strict'
// load .env in local development
if (process.env.NODE_ENV === 'development') {
require('dotenv').config({ silent: true })
}
const logger = require('winston')
const semver = require('semver')
const pkg = require('./package.json')
const config = require('./config')
// validate Node version requirement
const runtime = {
expected: semver.validRange(pkg.engines.node),
actual: semver.valid(process.version)
}
const valid = semver.satisfies(runtime.actual, runtime.expected)
if (!valid) {
throw new Error(
`Expected Node.js version ${runtime.expected}, but found v${runtime.actual}. Please update or change your runtime!`
)
}
// configure logger
logger.default.transports.console.colorize = true
logger.default.transports.console.timestamp = true
logger.default.transports.console.prettyPrint = config.env === 'development'
logger.level = config.logger.level
// start process
logger.info(`Starting ${config.process.type} process`, { pid: process.pid })
if (config.process.type === 'web') {
require('./web')
} else if (config.process.type === 'worker') {
require('./worker')
} else {
throw new Error(`${config.process.type} is an unsupported process type.`)
}