From e498159c5550dd16b1ebee4ea0ae870f8965def1 Mon Sep 17 00:00:00 2001 From: Maros Hluska Date: Wed, 29 Aug 2018 21:48:11 +0900 Subject: [PATCH 1/3] Fix cache --- src/express-http-server.js | 33 +++++++++++++++++++++++++-------- 1 file changed, 25 insertions(+), 8 deletions(-) diff --git a/src/express-http-server.js b/src/express-http-server.js index 2aef6cf9..3bcc8193 100644 --- a/src/express-http-server.js +++ b/src/express-http-server.js @@ -87,23 +87,40 @@ class ExpressHTTPServer { } interceptResponseCompletion(path, res) { - let send = res.send.bind(res); + let prevWrite = res.write; + let prevEnd = res.end; + let chunks = []; + let cache = this.cache; + let ui = this.ui; + + let pushChunk = (chunk) => { + if (!chunk) return; + chunks.push(Buffer.isBuffer(chunk) ? chunk : Buffer.from(chunk)); + }; + + res.write = function(chunk) { + pushChunk(chunk); + prevWrite.apply(res, arguments); + }; + + res.end = function(chunk) { + pushChunk(chunk); - res.send = (body) => { - let ret = send(body); + let body = Buffer.concat(chunks).toString(); - this.cache.put(path, body, res) + cache.put(path, body, res) .then(() => { - this.ui.writeLine(`stored in cache; path=${path}`); + ui.writeLine(`stored in cache; path=${path}`); }) .catch(() => { let truncatedBody = body.replace(/\n/g).substr(0, 200); - this.ui.writeLine(`error storing cache; path=${path}; body=${truncatedBody}...`); + ui.writeLine(`error storing cache; path=${path}; body=${truncatedBody}...`); }); - res.send = send; + res.write = prevWrite; + res.end = prevEnd; - return ret; + prevEnd.apply(res, arguments); }; } } From 304f922dc7f1c7c55c6e53d1311bbe4dcafe9684 Mon Sep 17 00:00:00 2001 From: Maros Hluska Date: Wed, 29 Aug 2018 22:00:59 +0900 Subject: [PATCH 2/3] Move cache before gzip --- src/express-http-server.js | 14 +++++++------- 1 file changed, 7 insertions(+), 7 deletions(-) diff --git a/src/express-http-server.js b/src/express-http-server.js index 3bcc8193..223811d2 100644 --- a/src/express-http-server.js +++ b/src/express-http-server.js @@ -30,8 +30,12 @@ class ExpressHTTPServer { this.beforeMiddleware(app); + if (this.cache) { + app.get('/*', this.buildCacheMiddleware()); + } + if (this.gzip) { - this.app.use(require('compression')()); + app.use(require('compression')()); } if (username !== undefined || password !== undefined) { @@ -39,10 +43,6 @@ class ExpressHTTPServer { app.use(basicAuth(username, password)); } - if (this.cache) { - app.get('/*', this.buildCacheMiddleware()); - } - if (this.distPath) { app.get('/', fastbootMiddleware); app.use(express.static(this.distPath)); @@ -75,12 +75,12 @@ class ExpressHTTPServer { .then(response => { if (response) { this.ui.writeLine(`cache hit; path=${path}`); - res.send(response); + res.body = response; } else { this.ui.writeLine(`cache miss; path=${path}`); this.interceptResponseCompletion(path, res); - next(); } + next(); }) .catch(() => next()); }; From 376411412533c5e6f73377471195614c5d432e2b Mon Sep 17 00:00:00 2001 From: Maros Hluska Date: Wed, 29 Aug 2018 23:52:21 +0900 Subject: [PATCH 3/3] Add short circuit if using cache --- src/express-http-server.js | 10 ++++++++++ src/worker.js | 1 + 2 files changed, 11 insertions(+) diff --git a/src/express-http-server.js b/src/express-http-server.js index 223811d2..0992036a 100644 --- a/src/express-http-server.js +++ b/src/express-http-server.js @@ -38,6 +38,16 @@ class ExpressHTTPServer { app.use(require('compression')()); } + if (this.cache) { + app.use(function(req, res, next) { + if (res.body) { + res.send(res.body); + } else { + next(); + } + }); + } + if (username !== undefined || password !== undefined) { this.ui.writeLine(`adding basic auth; username=${username}; password=${password}`); app.use(basicAuth(username, password)); diff --git a/src/worker.js b/src/worker.js index 72f83151..befc2bbf 100644 --- a/src/worker.js +++ b/src/worker.js @@ -37,6 +37,7 @@ class Worker { } if (!this.httpServer.cache) { this.httpServer.cache = this.cache; } + if (!this.httpServer.gzip) { this.httpServer.gzip = this.gzip; } if (!this.httpServer.distPath) { this.httpServer.distPath = this.distPath; } if (!this.httpServer.ui) { this.httpServer.ui = this.ui; } }