summaryrefslogtreecommitdiff
path: root/src/server/index.ts
diff options
context:
space:
mode:
authorAkihiko Odaki <nekomanma@pixiv.co.jp>2018-03-29 01:20:40 +0900
committerAkihiko Odaki <nekomanma@pixiv.co.jp>2018-03-29 01:54:41 +0900
commit90f8fe7e538bb7e52d2558152a0390e693f39b11 (patch)
tree0f830887053c8f352b1cd0c13ca715fd14c1f030 /src/server/index.ts
parentImplement remote account resolution (diff)
downloadsharkey-90f8fe7e538bb7e52d2558152a0390e693f39b11.tar.gz
sharkey-90f8fe7e538bb7e52d2558152a0390e693f39b11.tar.bz2
sharkey-90f8fe7e538bb7e52d2558152a0390e693f39b11.zip
Introduce processor
Diffstat (limited to 'src/server/index.ts')
-rw-r--r--src/server/index.ts82
1 files changed, 82 insertions, 0 deletions
diff --git a/src/server/index.ts b/src/server/index.ts
new file mode 100644
index 0000000000..3908b8a52c
--- /dev/null
+++ b/src/server/index.ts
@@ -0,0 +1,82 @@
+/**
+ * Core Server
+ */
+
+import * as fs from 'fs';
+import * as http from 'http';
+import * as https from 'https';
+import * as express from 'express';
+import * as morgan from 'morgan';
+import Accesses from 'accesses';
+
+import log from './log-request';
+import config from '../conf';
+
+/**
+ * Init app
+ */
+const app = express();
+app.disable('x-powered-by');
+app.set('trust proxy', 'loopback');
+
+// Log
+if (config.accesses && config.accesses.enable) {
+ const accesses = new Accesses({
+ appName: 'Misskey',
+ port: config.accesses.port
+ });
+
+ app.use(accesses.express);
+}
+
+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
+}));
+
+app.use((req, res, next) => {
+ log(req);
+ next();
+});
+
+// Drop request when without 'Host' header
+app.use((req, res, next) => {
+ if (!req.headers['host']) {
+ res.sendStatus(400);
+ } else {
+ next();
+ }
+});
+
+/**
+ * Register modules
+ */
+app.use('/api', require('./api/server'));
+app.use('/files', require('./file/server'));
+app.use(require('./web/server'));
+
+function createServer() {
+ if (config.https) {
+ const certs = {};
+ Object.keys(config.https).forEach(k => {
+ certs[k] = fs.readFileSync(config.https[k]);
+ });
+ return https.createServer(certs, app);
+ } else {
+ return http.createServer(app);
+ }
+}
+
+export default () => new Promise(resolve => {
+ const server = createServer();
+
+ /**
+ * Steaming
+ */
+ require('./api/streaming')(server);
+
+ /**
+ * Server listen
+ */
+ server.listen(config.port, resolve);
+});