summaryrefslogtreecommitdiff
path: root/src/server/web/server.ts
diff options
context:
space:
mode:
authorsyuilo <syuilotan@yahoo.co.jp>2018-03-29 20:32:18 +0900
committersyuilo <syuilotan@yahoo.co.jp>2018-03-29 20:32:18 +0900
commitcf33e483f7e6f40e8cbbbc0118a7df70bdaf651f (patch)
tree318279530d3392ee40d91968477fc0e78d5cf0f7 /src/server/web/server.ts
parentUpdate .travis.yml (diff)
downloadsharkey-cf33e483f7e6f40e8cbbbc0118a7df70bdaf651f.tar.gz
sharkey-cf33e483f7e6f40e8cbbbc0118a7df70bdaf651f.tar.bz2
sharkey-cf33e483f7e6f40e8cbbbc0118a7df70bdaf651f.zip
整理した
Diffstat (limited to 'src/server/web/server.ts')
-rw-r--r--src/server/web/server.ts51
1 files changed, 20 insertions, 31 deletions
diff --git a/src/server/web/server.ts b/src/server/web/server.ts
index b117f6ae81..2fc8f1b8ab 100644
--- a/src/server/web/server.ts
+++ b/src/server/web/server.ts
@@ -1,5 +1,5 @@
/**
- * Web Server
+ * Web Client Server
*/
import * as path from 'path';
@@ -11,9 +11,9 @@ import * as bodyParser from 'body-parser';
import * as favicon from 'serve-favicon';
import * as compression from 'compression';
-/**
- * Init app
- */
+const client = `${__dirname}/../../client/`;
+
+// Create server
const app = express();
app.disable('x-powered-by');
@@ -25,51 +25,40 @@ app.use(bodyParser.json({
}));
app.use(compression());
-/**
- * Initialize requests
- */
app.use((req, res, next) => {
res.header('X-Frame-Options', 'DENY');
next();
});
-/**
- * Static assets
- */
-app.use(favicon(`${__dirname}/assets/favicon.ico`));
-app.get('/apple-touch-icon.png', (req, res) => res.sendFile(`${__dirname}/assets/apple-touch-icon.png`));
-app.use('/assets', express.static(`${__dirname}/assets`, {
+//#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(`${__dirname}/assets/404.js`));
+app.use('/assets/*.js', (req, res) => res.sendFile(`${client}/assets/404.js`));
app.use('/assets', (req, res) => {
res.sendStatus(404);
});
-app.use('/recover', (req, res) => res.sendFile(`${__dirname}/assets/recover.html`));
+app.use('/recover', (req, res) => res.sendFile(`${client}/assets/recover.html`));
-/**
- * ServiceWroker
- */
+// ServiceWroker
app.get(/^\/sw\.(.+?)\.js$/, (req, res) =>
- res.sendFile(`${__dirname}/assets/sw.${req.params[0]}.js`));
+ res.sendFile(`${client}/assets/sw.${req.params[0]}.js`));
-/**
- * Manifest
- */
+// Manifest
app.get('/manifest.json', (req, res) =>
- res.sendFile(`${__dirname}/assets/manifest.json`));
+ res.sendFile(`${client}/assets/manifest.json`));
-/**
- * Common API
- */
-app.get(/\/api:url/, require('./service/url-preview'));
+//#endregion
-/**
- * Routing
- */
+app.get(/\/api:url/, require('./url-preview'));
+
+// Render base html for all requests
app.get('*', (req, res) => {
- res.sendFile(path.resolve(`${__dirname}/app/base.html`), {
+ res.sendFile(path.resolve(`${client}/app/base.html`), {
maxAge: ms('7 days')
});
});