summaryrefslogtreecommitdiff
path: root/src/web/server.ts
diff options
context:
space:
mode:
authorsyuilo <syuilotan@yahoo.co.jp>2016-12-29 07:49:51 +0900
committersyuilo <syuilotan@yahoo.co.jp>2016-12-29 07:49:51 +0900
commitb3f42e62af698a67c2250533c437569559f1fdf9 (patch)
treecdf6937576e99cccf85e6fa3aa8860a1173c7cfb /src/web/server.ts
downloadsharkey-b3f42e62af698a67c2250533c437569559f1fdf9.tar.gz
sharkey-b3f42e62af698a67c2250533c437569559f1fdf9.tar.bz2
sharkey-b3f42e62af698a67c2250533c437569559f1fdf9.zip
Initial commit :four_leaf_clover:
Diffstat (limited to 'src/web/server.ts')
-rw-r--r--src/web/server.ts77
1 files changed, 77 insertions, 0 deletions
diff --git a/src/web/server.ts b/src/web/server.ts
new file mode 100644
index 0000000000..d30680f68c
--- /dev/null
+++ b/src/web/server.ts
@@ -0,0 +1,77 @@
+/**
+ * Web Server
+ */
+
+import * as ms from 'ms';
+
+// express modules
+import * as express from 'express';
+import * as bodyParser from 'body-parser';
+import * as favicon from 'serve-favicon';
+import * as compression from 'compression';
+const subdomain = require('subdomain');
+import serveApp from './serve-app';
+
+/**
+ * Init app
+ */
+const app = express();
+app.disable('x-powered-by');
+app.set('view engine', 'pug');
+
+app.use(bodyParser.urlencoded({ extended: true }));
+app.use(compression());
+
+/**
+ * Initialize requests
+ */
+app.use((req, res, next) => {
+ res.header('X-Frame-Options', 'DENY');
+ next();
+});
+
+/**
+ * Static resources
+ */
+app.use(favicon(`${__dirname}/resources/favicon.ico`));
+app.use(require('./manifest'));
+app.use(require('./apple-touch-icon'));
+app.use('/_/resources', express.static(`${__dirname}/resources`, {
+ maxAge: ms('7 days')
+}));
+
+/**
+ * Common API
+ */
+app.get(/\/api:meta/, require('./meta'));
+app.get(/\/api:url/, require('./service/url-preview'));
+app.post(/\/api:rss/, require('./service/rss-proxy'));
+
+/**
+ * Subdomain
+ */
+app.use(subdomain({
+ base: config.host,
+ prefix: '@'
+}));
+
+/**
+ * Routing
+ */
+
+app.use('/@/about/resources', express.static(`${__dirname}/about/resources`, {
+ maxAge: ms('7 days')
+}));
+
+app.get('/@/about/:page(*)', (req, res) => {
+ res.render(`${__dirname}/about/pages/${req.params.page}`, {
+ path: req.params.page,
+ config: config
+ });
+});
+
+app.get('/@/auth/*', serveApp('auth')); // authorize form
+app.get('/@/dev/*', serveApp('dev')); // developer center
+app.get('*', serveApp('client')); // client
+
+module.exports = app;