From edfe81e11cc7d6b2b6be7c3e1b7b8085bb74f489 Mon Sep 17 00:00:00 2001 From: Naz Date: Thu, 25 Nov 2021 13:20:29 +0400 Subject: [PATCH] Moved validation dependency to constructor param refs https://github.com/TryGhost/Toolbox/issues/139 - Having no external dependencies makes the class way easier to test --- core/server/services/redirects/api.js | 14 ++++++++------ core/server/services/redirects/index.js | 4 +++- 2 files changed, 11 insertions(+), 7 deletions(-) diff --git a/core/server/services/redirects/api.js b/core/server/services/redirects/api.js index cfbfce8786..f4710e245b 100644 --- a/core/server/services/redirects/api.js +++ b/core/server/services/redirects/api.js @@ -7,8 +7,6 @@ const logging = require('@tryghost/logging'); const tpl = require('@tryghost/tpl'); const errors = require('@tryghost/errors'); -const validation = require('./validation'); - const messages = { jsonParse: 'Could not parse JSON: {context}.', yamlParse: 'Could not parse YAML: {context}.', @@ -22,7 +20,7 @@ const messages = { * @typedef {Object} RedirectConfig * @property {String} from - Defines the relative incoming URL or pattern (regex) * @property {String} to - Defines where the incoming traffic should be redirected to, which can be a static URL, or a dynamic value using regex (example: "to": "/$1/") - * @property {boolean} permanent - Can be defined with true for a permanent HTTP 301 redirect, or false for a temporary HTTP 302 redirect + * @property {boolean} [permanent] - Can be defined with true for a permanent HTTP 301 redirect, or false for a temporary HTTP 302 redirect */ /** @@ -138,14 +136,18 @@ class CustomRedirectsAPI { /** * @param {object} config * @param {string} config.basePath + * @param {Function} config.validate - validates redirects configuration * @param {IRedirectManager} config.redirectManager */ - constructor({basePath, redirectManager}) { + constructor({basePath, validate, redirectManager}) { /** @private */ this.basePath = basePath; /** @private */ this.redirectManager = redirectManager; + + /**private */ + this.validate = validate; } async init() { @@ -159,7 +161,7 @@ class CustomRedirectsAPI { const content = await readRedirectsFile(filePath); const ext = path.extname(filePath); const redirects = parseRedirectsFile(content, ext); - validation.validate(redirects); + this.validate(redirects); this.redirectManager.removeAllRedirects(); for (const redirect of redirects) { @@ -234,7 +236,7 @@ class CustomRedirectsAPI { const content = await readRedirectsFile(filePath); const parsed = parseRedirectsFile(content, ext); - validation.validate(parsed); + this.validate(parsed); if (ext === '.json') { await fs.writeFile(this.createRedirectsFilePath('.json'), JSON.stringify(parsed), 'utf-8'); diff --git a/core/server/services/redirects/index.js b/core/server/services/redirects/index.js index 6f9c9fce4d..0307905351 100644 --- a/core/server/services/redirects/index.js +++ b/core/server/services/redirects/index.js @@ -3,6 +3,7 @@ const urlUtils = require('../../../shared/url-utils'); const DynamicRedirectManager = require('@tryghost/express-dynamic-redirects'); const CustomRedirectsAPI = require('./api'); +const validation = require('./validation'); let customRedirectsAPI; let redirectManager; @@ -18,7 +19,8 @@ module.exports = { customRedirectsAPI = new CustomRedirectsAPI({ basePath: config.getContentPath('data'), - redirectManager + redirectManager, + validate: validation.validate.bind(validation) }); return customRedirectsAPI.init();