From 2473b558716c35d9827f2daa9d64dad8cbf14e11 Mon Sep 17 00:00:00 2001 From: Olivier Tassinari Date: Tue, 6 Feb 2018 13:21:49 +0100 Subject: [PATCH] [ssr-caching] Only cache 200 status requests (#3708) * [ssr-caching] Only cache 200 requests I'm assuming caching an error page is a bad pattern. * Update server.js --- examples/ssr-caching/server.js | 30 ++++++++++++++++++------------ 1 file changed, 18 insertions(+), 12 deletions(-) diff --git a/examples/ssr-caching/server.js b/examples/ssr-caching/server.js index 11a1d98e..8f0ef4d8 100644 --- a/examples/ssr-caching/server.js +++ b/examples/ssr-caching/server.js @@ -45,26 +45,32 @@ function getCacheKey (req) { return `${req.url}` } -function renderAndCache (req, res, pagePath, queryParams) { +async function renderAndCache (req, res, pagePath, queryParams) { const key = getCacheKey(req) // If we have a page in the cache, let's serve it if (ssrCache.has(key)) { - console.log(`CACHE HIT: ${key}`) + res.setHeader('x-cache', 'HIT') res.send(ssrCache.get(key)) return } - // If not let's render the page into HTML - app.renderToHTML(req, res, pagePath, queryParams) - .then((html) => { - // Let's cache this page - console.log(`CACHE MISS: ${key}`) - ssrCache.set(key, html) + try { + // If not let's render the page into HTML + const html = await app.renderToHTML(req, res, pagePath, queryParams) + // Something is wrong with the request, let's skip the cache + if (res.statusCode !== 200) { res.send(html) - }) - .catch((err) => { - app.renderError(err, req, res, pagePath, queryParams) - }) + return + } + + // Let's cache this page + ssrCache.set(key, html) + + res.setHeader('x-cache', 'MISS') + res.send(html) + } catch (err) { + app.renderError(err, req, res, pagePath, queryParams) + } }