2016-12-28 15:49:51 -07:00
|
|
|
/**
|
|
|
|
* Core Server
|
|
|
|
*/
|
|
|
|
|
|
|
|
import * as fs from 'fs';
|
|
|
|
import * as http from 'http';
|
|
|
|
import * as https from 'https';
|
2017-01-16 17:33:38 -07:00
|
|
|
import * as cluster from 'cluster';
|
2016-12-28 15:49:51 -07:00
|
|
|
import * as express from 'express';
|
2017-01-19 00:00:14 -07:00
|
|
|
import * as morgan from 'morgan';
|
2017-01-02 14:03:19 -07:00
|
|
|
import vhost = require('vhost');
|
2016-12-28 15:49:51 -07:00
|
|
|
|
2017-01-16 16:19:34 -07:00
|
|
|
import config from './conf';
|
2017-01-16 16:06:39 -07:00
|
|
|
|
2016-12-28 15:49:51 -07:00
|
|
|
/**
|
|
|
|
* Init app
|
|
|
|
*/
|
|
|
|
const app = express();
|
|
|
|
app.disable('x-powered-by');
|
2017-02-13 17:01:25 -07:00
|
|
|
app.set('trust proxy', 'loopback');
|
2016-12-28 15:49:51 -07:00
|
|
|
|
2017-01-19 00:00:14 -07:00
|
|
|
// Log
|
2017-01-19 18:19:09 -07:00
|
|
|
app.use(morgan(process.env.NODE_ENV == 'production' ? 'combined' : 'dev', {
|
|
|
|
// create a write stream (in append mode)
|
|
|
|
stream: config.accesslog ? fs.createWriteStream(config.accesslog) : null
|
|
|
|
}));
|
2017-01-19 00:00:14 -07:00
|
|
|
|
2017-01-13 18:56:24 -07:00
|
|
|
// Drop request that without 'Host' header
|
2017-01-07 07:57:45 -07:00
|
|
|
app.use((req, res, next) => {
|
2017-01-18 00:31:43 -07:00
|
|
|
if (!req.headers['host']) {
|
2017-01-07 07:57:45 -07:00
|
|
|
res.sendStatus(400);
|
|
|
|
} else {
|
|
|
|
next();
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
2016-12-28 15:49:51 -07:00
|
|
|
/**
|
|
|
|
* Register modules
|
|
|
|
*/
|
|
|
|
app.use(vhost(`api.${config.host}`, require('./api/server')));
|
|
|
|
app.use(vhost(config.secondary_host, require('./himasaku/server')));
|
|
|
|
app.use(vhost(`file.${config.secondary_host}`, require('./file/server')));
|
|
|
|
app.use(require('./web/server'));
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Create server
|
|
|
|
*/
|
|
|
|
const server = config.https.enable ?
|
|
|
|
https.createServer({
|
|
|
|
key: fs.readFileSync(config.https.key),
|
|
|
|
cert: fs.readFileSync(config.https.cert),
|
|
|
|
ca: fs.readFileSync(config.https.ca)
|
|
|
|
}, app) :
|
|
|
|
http.createServer(app);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Steaming
|
|
|
|
*/
|
|
|
|
require('./api/streaming')(server);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Server listen
|
|
|
|
*/
|
|
|
|
server.listen(config.port, () => {
|
2017-01-16 17:33:38 -07:00
|
|
|
if (cluster.isWorker) {
|
|
|
|
// Send a 'ready' message to parent process
|
|
|
|
process.send('ready');
|
|
|
|
}
|
2016-12-28 15:49:51 -07:00
|
|
|
});
|
2017-01-16 15:51:27 -07:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Export app for testing
|
|
|
|
*/
|
|
|
|
module.exports = app;
|