summaryrefslogtreecommitdiff
path: root/src/server/web
diff options
context:
space:
mode:
authortamaina <tamaina@hotmail.co.jp>2018-04-11 20:27:09 +0900
committerGitHub <noreply@github.com>2018-04-11 20:27:09 +0900
commitd43fe853c3605696e2e57e240845d0fc9c284f61 (patch)
tree838914e262c0fca5737588a7bba64e2b9f3d8e5f /src/server/web
parentUpdate README.md (diff)
parentwip #1443 (diff)
downloadmisskey-d43fe853c3605696e2e57e240845d0fc9c284f61.tar.gz
misskey-d43fe853c3605696e2e57e240845d0fc9c284f61.tar.bz2
misskey-d43fe853c3605696e2e57e240845d0fc9c284f61.zip
Merge pull request #1 from syuilo/master
追従
Diffstat (limited to 'src/server/web')
-rw-r--r--src/server/web/docs.ts24
-rw-r--r--src/server/web/index.ts64
-rw-r--r--src/server/web/url-preview.ts15
3 files changed, 103 insertions, 0 deletions
diff --git a/src/server/web/docs.ts b/src/server/web/docs.ts
new file mode 100644
index 0000000000..889532e17e
--- /dev/null
+++ b/src/server/web/docs.ts
@@ -0,0 +1,24 @@
+/**
+ * Docs Server
+ */
+
+import * as path from 'path';
+import * as express from 'express';
+
+const docs = path.resolve(`${__dirname}/../../client/docs/`);
+
+/**
+ * Init app
+ */
+const app = express();
+app.disable('x-powered-by');
+
+app.use('/assets', express.static(`${docs}/assets`));
+
+/**
+ * Routing
+ */
+app.get(/^\/([a-z_\-\/]+?)$/, (req, res) =>
+ res.sendFile(`${docs}/${req.params[0]}.html`));
+
+module.exports = app;
diff --git a/src/server/web/index.ts b/src/server/web/index.ts
new file mode 100644
index 0000000000..5b1b6409b9
--- /dev/null
+++ b/src/server/web/index.ts
@@ -0,0 +1,64 @@
+/**
+ * Web Client Server
+ */
+
+import * as path from 'path';
+import ms = require('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 client = path.resolve(`${__dirname}/../../client/`);
+
+// Create server
+const app = express();
+app.disable('x-powered-by');
+
+app.use('/docs', require('./docs'));
+
+app.use(bodyParser.urlencoded({ extended: true }));
+app.use(bodyParser.json({
+ type: ['application/json', 'text/plain']
+}));
+app.use(compression());
+
+app.use((req, res, next) => {
+ res.header('X-Frame-Options', 'DENY');
+ next();
+});
+
+//#region static assets
+
+app.use(favicon(`${client}/assets/favicon.ico`));
+app.get('/apple-touch-icon.png', (req, res) => res.sendFile(`${client}/assets/apple-touch-icon.png`));
+app.use('/assets', express.static(`${client}/assets`, {
+ maxAge: ms('7 days')
+}));
+app.use('/assets/*.js', (req, res) => res.sendFile(`${client}/assets/404.js`));
+app.use('/assets', (req, res) => {
+ res.sendStatus(404);
+});
+
+// ServiceWroker
+app.get(/^\/sw\.(.+?)\.js$/, (req, res) =>
+ res.sendFile(`${client}/assets/sw.${req.params[0]}.js`));
+
+// Manifest
+app.get('/manifest.json', (req, res) =>
+ res.sendFile(`${client}/assets/manifest.json`));
+
+//#endregion
+
+app.get(/\/api:url/, require('./url-preview'));
+
+// Render base html for all requests
+app.get('*', (req, res) => {
+ res.sendFile(path.resolve(`${client}/app/base.html`), {
+ maxAge: ms('7 days')
+ });
+});
+
+module.exports = app;
diff --git a/src/server/web/url-preview.ts b/src/server/web/url-preview.ts
new file mode 100644
index 0000000000..0c5fd8a78e
--- /dev/null
+++ b/src/server/web/url-preview.ts
@@ -0,0 +1,15 @@
+import * as express from 'express';
+import summaly from 'summaly';
+
+module.exports = async (req: express.Request, res: express.Response) => {
+ const summary = await summaly(req.query.url);
+ summary.icon = wrap(summary.icon);
+ summary.thumbnail = wrap(summary.thumbnail);
+ res.send(summary);
+};
+
+function wrap(url: string): string {
+ return url != null
+ ? `https://images.weserv.nl/?url=${url.replace(/^https?:\/\//, '')}`
+ : null;
+}