2018-09-03 10:23:18 +00:00
|
|
|
const path = require('path');
|
2018-10-08 09:58:56 +00:00
|
|
|
require('dotenv').config({ path: path.resolve(__dirname, '../../.env')});
|
2016-06-24 03:05:30 +00:00
|
|
|
|
2018-01-06 19:15:24 +00:00
|
|
|
const _ = require('lodash');
|
|
|
|
const Rx = require('rx');
|
|
|
|
const loopback = require('loopback');
|
|
|
|
const boot = require('loopback-boot');
|
|
|
|
const expressState = require('express-state');
|
2018-01-06 19:24:08 +00:00
|
|
|
const createDebugger = require('debug');
|
|
|
|
|
2018-08-23 15:29:26 +00:00
|
|
|
const { setupPassport } = require('./component-passport');
|
|
|
|
|
2018-01-06 19:24:08 +00:00
|
|
|
const log = createDebugger('fcc:server');
|
|
|
|
// force logger to always output
|
|
|
|
// this may be brittle
|
|
|
|
log.enabled = true;
|
2013-11-27 04:15:13 +00:00
|
|
|
|
2016-03-15 00:22:56 +00:00
|
|
|
Rx.config.longStackSupport = process.env.NODE_DEBUG !== 'production';
|
2018-01-06 19:15:24 +00:00
|
|
|
const app = loopback();
|
|
|
|
const isBeta = !!process.env.BETA;
|
2015-07-14 01:47:19 +00:00
|
|
|
|
2015-06-29 16:55:39 +00:00
|
|
|
expressState.extend(app);
|
2015-07-14 01:47:19 +00:00
|
|
|
app.set('state namespace', '__fcc__');
|
2014-01-12 03:53:31 +00:00
|
|
|
app.set('port', process.env.PORT || 3000);
|
|
|
|
app.set('views', path.join(__dirname, 'views'));
|
|
|
|
app.set('view engine', 'jade');
|
2015-08-16 16:54:34 +00:00
|
|
|
app.use(loopback.token());
|
2015-08-04 12:28:41 +00:00
|
|
|
app.disable('x-powered-by');
|
|
|
|
|
2015-06-04 17:52:12 +00:00
|
|
|
boot(app, {
|
|
|
|
appRootDir: __dirname,
|
|
|
|
dev: process.env.NODE_ENV
|
|
|
|
});
|
|
|
|
|
2016-02-12 06:33:54 +00:00
|
|
|
setupPassport(app);
|
2015-06-04 17:52:12 +00:00
|
|
|
|
2018-01-06 19:15:24 +00:00
|
|
|
const { db } = app.datasources;
|
2018-01-06 19:24:08 +00:00
|
|
|
db.on('connected', _.once(() => log('db connected')));
|
2015-10-15 06:48:48 +00:00
|
|
|
app.start = _.once(function() {
|
2018-01-06 19:15:24 +00:00
|
|
|
const server = app.listen(app.get('port'), function() {
|
2015-07-01 21:35:15 +00:00
|
|
|
app.emit('started');
|
2018-01-06 19:24:08 +00:00
|
|
|
log(
|
2017-01-14 02:14:43 +00:00
|
|
|
'freeCodeCamp server listening on port %d in %s',
|
2015-06-22 01:10:17 +00:00
|
|
|
app.get('port'),
|
|
|
|
app.get('env')
|
|
|
|
);
|
2015-10-07 05:37:08 +00:00
|
|
|
if (isBeta) {
|
2018-01-06 19:24:08 +00:00
|
|
|
log('freeCodeCamp is in beta mode');
|
2015-10-07 05:37:08 +00:00
|
|
|
}
|
2018-01-06 19:24:08 +00:00
|
|
|
log(`connecting to db at ${db.settings.url}`);
|
2018-01-06 19:15:24 +00:00
|
|
|
});
|
|
|
|
|
|
|
|
process.on('SIGINT', () => {
|
2018-01-06 19:24:08 +00:00
|
|
|
log('Shutting down server');
|
2018-01-06 19:15:24 +00:00
|
|
|
server.close(() => {
|
2018-01-06 19:24:08 +00:00
|
|
|
log('Server is closed');
|
2018-01-06 19:15:24 +00:00
|
|
|
});
|
2018-01-06 19:24:08 +00:00
|
|
|
log('closing db connection');
|
2018-08-23 15:29:26 +00:00
|
|
|
db.disconnect().then(() => {
|
|
|
|
log('DB connection closed');
|
|
|
|
// exit process
|
|
|
|
// this may close kept alive sockets
|
|
|
|
// eslint-disable-next-line no-process-exit
|
|
|
|
process.exit(0);
|
|
|
|
});
|
2015-06-22 01:10:17 +00:00
|
|
|
});
|
2015-10-15 06:48:48 +00:00
|
|
|
});
|
2015-06-22 01:37:29 +00:00
|
|
|
|
2015-07-25 05:22:40 +00:00
|
|
|
module.exports = app;
|
|
|
|
|
2015-06-22 01:37:29 +00:00
|
|
|
// start the server if `$ node server.js`
|
2015-07-25 05:22:40 +00:00
|
|
|
// in production use `$npm start-production`
|
|
|
|
// or `$node server/production` to start the server
|
|
|
|
// and wait for DB handshake
|
2015-06-22 01:37:29 +00:00
|
|
|
if (require.main === module) {
|
2015-07-25 05:22:40 +00:00
|
|
|
app.start();
|
2015-06-22 01:10:17 +00:00
|
|
|
}
|