2015-07-25 05:22:40 +00:00
|
|
|
// this ensures node understands the future
|
2016-01-20 17:03:58 +00:00
|
|
|
require('babel-register');
|
2015-07-25 05:22:40 +00:00
|
|
|
|
|
|
|
var startTime = Date.now();
|
|
|
|
var timeoutHandler;
|
|
|
|
// this is where server starts booting up
|
|
|
|
var app = require('./server');
|
|
|
|
console.log('waiting for db to connect');
|
|
|
|
|
|
|
|
|
|
|
|
var onConnect = function() {
|
|
|
|
console.log('db connected in %s ms', Date.now() - startTime);
|
|
|
|
if (timeoutHandler) {
|
|
|
|
clearTimeout(timeoutHandler);
|
|
|
|
}
|
|
|
|
app.start();
|
|
|
|
};
|
|
|
|
|
|
|
|
var timeoutHandler = setTimeout(function() {
|
|
|
|
var message =
|
2016-05-15 11:13:41 +00:00
|
|
|
'db did not connect after ' +
|
2015-07-25 05:22:40 +00:00
|
|
|
(Date.now() - startTime) +
|
2016-05-15 11:13:41 +00:00
|
|
|
' ms --- crashing hard';
|
2015-07-25 05:22:40 +00:00
|
|
|
|
|
|
|
console.log(message);
|
|
|
|
// purposely shutdown server
|
|
|
|
// pm2 should restart this in production
|
|
|
|
throw new Error(message);
|
2016-02-07 06:58:41 +00:00
|
|
|
}, 15000);
|
2015-07-25 05:22:40 +00:00
|
|
|
|
|
|
|
app.dataSources.db.on('connected', onConnect);
|