2013-11-25 22:22:59 -05:00
|
|
|
// # Ghost bootloader
|
|
|
|
// Orchestrates the loading of Ghost
|
|
|
|
// When run from command line.
|
|
|
|
|
2014-02-19 22:22:02 -05:00
|
|
|
var when = require('when'),
|
|
|
|
bootstrap = require('./bootstrap');
|
2013-11-25 22:22:59 -05:00
|
|
|
|
|
|
|
process.env.NODE_ENV = process.env.NODE_ENV || 'development';
|
|
|
|
|
2014-02-08 10:41:15 -05:00
|
|
|
function startGhost(options) {
|
2014-02-19 22:22:02 -05:00
|
|
|
// When we no longer need to require('./server')
|
|
|
|
// in a callback this extra deferred object
|
|
|
|
// won't be necessary, we'll just be able to return
|
|
|
|
// the server object directly.
|
|
|
|
var deferred = when.defer();
|
|
|
|
|
2014-02-08 10:41:15 -05:00
|
|
|
options = options || {};
|
2014-02-19 22:22:02 -05:00
|
|
|
|
2014-02-08 10:41:15 -05:00
|
|
|
bootstrap(options.config).then(function () {
|
2014-05-11 11:33:18 -05:00
|
|
|
try {
|
|
|
|
var ghost = require('./server');
|
|
|
|
return ghost(options.app)
|
|
|
|
.then(deferred.resolve)
|
|
|
|
.otherwise(function (e) {
|
|
|
|
// We don't return the rejected promise to stop
|
|
|
|
// the propogation of the rejection and just
|
|
|
|
// allow the user to manage what to do.
|
|
|
|
deferred.reject(e);
|
|
|
|
});
|
|
|
|
} catch (e) {
|
2014-02-19 22:22:02 -05:00
|
|
|
deferred.reject(e);
|
2014-05-11 11:33:18 -05:00
|
|
|
}
|
2014-02-19 22:22:02 -05:00
|
|
|
});
|
|
|
|
|
|
|
|
return deferred.promise;
|
2013-11-25 22:22:59 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
module.exports = startGhost;
|