Files
habitica/website/server/index.js
Matteo Pagliazzi 45c31a2bcf Deprecate API v2 (#7761)
* deprecate api-v2

* remove v2 test helpers

* remove unused string
2016-07-16 19:56:18 +02:00

47 lines
1.5 KiB
JavaScript

'use strict';
/* eslint-disable global-require, no-process-env */
// Register babel hook so we can write the real entry file (server.js) in ES6
// In production, the es6 code is pre-transpiled so it doesn't need it
if (process.env.NODE_ENV !== 'production') {
require('babel-register');
}
// The BabelJS polyfill is needed in production too
require('babel-polyfill');
// Setup Bluebird as the global promise library
global.Promise = require('bluebird');
// Initialize configuration BEFORE anything
const setupNconf = require('./libs/setupNconf');
setupNconf();
const nconf = require('nconf');
const cluster = require('cluster');
const logger = require('./libs/logger');
const IS_PROD = nconf.get('IS_PROD');
const IS_DEV = nconf.get('IS_DEV');
const CORES = Number(nconf.get('WEB_CONCURRENCY')) || 0;
// Initialize New Relic
if (IS_PROD && nconf.get('NEW_RELIC_ENABLED') === 'true') require('newrelic');
// Setup the cluster module
if (CORES !== 0 && cluster.isMaster && (IS_DEV || IS_PROD)) {
// Fork workers. If config.json has CORES=x, use that - otherwise, use all cpus-1 (production)
for (let i = 0; i < CORES; i += 1) {
cluster.fork();
}
cluster.on('disconnect', function onWorkerDisconnect (worker) {
let w = cluster.fork(); // replace the dead worker
logger.info('[%s] [master:%s] worker:%s disconnect! new worker:%s fork', new Date(), process.pid, worker.process.pid, w.process.pid);
});
} else {
module.exports = require('./server.js');
}