From cbd9d1a07ffa70b2bb5b48a37ecdf9ca0c9b7100 Mon Sep 17 00:00:00 2001 From: Csaky Date: Thu, 25 Jul 2024 15:45:15 -0700 Subject: [PATCH] Improve template file handling when a high frequency of requests hit the app, template files are not managed consistently. fileCache.find should handle when more than one template is found. --- app/src/components/carboneCopyApi.js | 4 ++-- app/src/components/fileCache.js | 7 +++++-- 2 files changed, 7 insertions(+), 4 deletions(-) diff --git a/app/src/components/carboneCopyApi.js b/app/src/components/carboneCopyApi.js index a5357e1..3992d1d 100644 --- a/app/src/components/carboneCopyApi.js +++ b/app/src/components/carboneCopyApi.js @@ -14,12 +14,12 @@ const carboneCopyApi = { carboneRender.carboneSet(); }, - findAndRender: (hash, req, res) => { + findAndRender: async (hash, req, res) => { const template = fileCache.find(hash); if (!template.success) { new Problem(template.errorType, { detail: template.errorMsg }).send(res); } else { - return carboneCopyApi.renderTemplate(template, req, res); + return await carboneCopyApi.renderTemplate(template, req, res); } }, diff --git a/app/src/components/fileCache.js b/app/src/components/fileCache.js index b240672..f73c6b6 100644 --- a/app/src/components/fileCache.js +++ b/app/src/components/fileCache.js @@ -63,14 +63,16 @@ class FileCache { if (!fs.existsSync(hashPath)) { result.errorType = 404; result.errorMsg = `Hash '${hash}' not found.`; + log.error(`Hash '${hash}' not found.`, { function: 'fileCache.find', result }); return result; } result.hash = hash; const files = fs.readdirSync(hashPath); - if (!files || files.length !== 1) { + if (!files || files.length === 0) { result.errorType = 404; result.errorMsg = 'Hash found; could not read file from cache.'; + log.error('Hash found. could not read file from cache', { function: 'fileCache.find', result }); return result; } else { result.name = files[0]; @@ -121,9 +123,10 @@ class FileCache { } const hashPath = this._getHashPath(result.hash); - // if file exists at temp file path + // if template exists if (fs.existsSync(hashPath)) { if (options.overwrite) { + // remove template fs.removeSync(hashPath); } else { // Remove temporary file from cache