mirror of
https://github.com/TryGhost/Ghost.git
synced 2025-01-06 22:40:14 -05:00
Added flag to skip gscan checks during boot
no issue - bumped gscan version to provide `skipChecks` flag to `check` function - added `optimization:themes:skipBootChecks` config flag defaulting to `false` to maintain current behaviour - updated theme service initialization to use `skipChecks: true` when the config flag is set - we only want to skip the checks during boot in specific cases to improve performance, they are still useful for general development and any production use-cases where themes get edited directly on the server - updated our theme validate module to accept and pass through `skipChecks` option - switched the `isZip` positional argument of `validate.check()` to an options object property to make usage cleaner
This commit is contained in:
parent
ab4c67f2d2
commit
e97717a0cc
7 changed files with 26 additions and 18 deletions
|
@ -14,14 +14,14 @@ const messages = {
|
||||||
themeCannotBeActivated: '{themeName} cannot be activated because it was not found in the theme directory.'
|
themeCannotBeActivated: '{themeName} cannot be activated because it was not found in the theme directory.'
|
||||||
};
|
};
|
||||||
|
|
||||||
module.exports.loadAndActivate = async (themeName) => {
|
module.exports.loadAndActivate = async (themeName, options = {}) => {
|
||||||
debug('loadAndActivate', themeName);
|
debug('loadAndActivate', themeName);
|
||||||
try {
|
try {
|
||||||
// Just read the active theme for now
|
// Just read the active theme for now
|
||||||
const loadedTheme = await themeLoader.loadOneTheme(themeName);
|
const loadedTheme = await themeLoader.loadOneTheme(themeName);
|
||||||
// Validate
|
// Validate
|
||||||
// @NOTE: this is now the only usage of check, rather than checkSafe...
|
// @NOTE: this is now the only usage of check, rather than checkSafe...
|
||||||
const checkedTheme = await validate.check(themeName, loadedTheme);
|
const checkedTheme = await validate.check(themeName, loadedTheme, {skipChecks: options.skipChecks});
|
||||||
|
|
||||||
if (!validate.canActivate(checkedTheme)) {
|
if (!validate.canActivate(checkedTheme)) {
|
||||||
logging.error(validate.getThemeValidationError('activeThemeHasFatalErrors', themeName, checkedTheme));
|
logging.error(validate.getThemeValidationError('activeThemeHasFatalErrors', themeName, checkedTheme));
|
||||||
|
|
|
@ -5,6 +5,7 @@ const getJSON = require('./to-json');
|
||||||
const installer = require('./installer');
|
const installer = require('./installer');
|
||||||
const validate = require('./validate');
|
const validate = require('./validate');
|
||||||
const settingsCache = require('../../../shared/settings-cache');
|
const settingsCache = require('../../../shared/settings-cache');
|
||||||
|
const config = require('../../../shared/config');
|
||||||
|
|
||||||
module.exports = {
|
module.exports = {
|
||||||
/*
|
/*
|
||||||
|
@ -13,8 +14,10 @@ module.exports = {
|
||||||
init: async () => {
|
init: async () => {
|
||||||
validate.init();
|
validate.init();
|
||||||
|
|
||||||
|
const skipChecks = config.get('optimization:themes:skipBootChecks') || false;
|
||||||
|
|
||||||
const themeName = settingsCache.get('active_theme');
|
const themeName = settingsCache.get('active_theme');
|
||||||
return activate.loadAndActivate(themeName);
|
return activate.loadAndActivate(themeName, {skipChecks});
|
||||||
},
|
},
|
||||||
/**
|
/**
|
||||||
* Load all inactive themes
|
* Load all inactive themes
|
||||||
|
|
|
@ -44,25 +44,27 @@ const getErrorsFromCheckedTheme = function getErrorsFromCheckedTheme(checkedThem
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
const check = async function check(themeName, theme, isZip) {
|
const check = async function check(themeName, theme, options = {}) {
|
||||||
debug('Begin: Check');
|
debug('Begin: Check');
|
||||||
// gscan can slow down boot time if we require on boot, for now nest the require.
|
// gscan can slow down boot time if we require on boot, for now nest the require.
|
||||||
const gscan = require('gscan');
|
const gscan = require('gscan');
|
||||||
const checkedVersion = 'v5';
|
const checkedVersion = 'v5';
|
||||||
let checkedTheme;
|
let checkedTheme;
|
||||||
|
|
||||||
if (isZip) {
|
if (options.isZip === true) {
|
||||||
debug('zip mode');
|
debug('zip mode');
|
||||||
checkedTheme = await gscan.checkZip(theme, {
|
checkedTheme = await gscan.checkZip(theme, {
|
||||||
keepExtractedDir: true,
|
keepExtractedDir: true,
|
||||||
checkVersion: checkedVersion,
|
checkVersion: checkedVersion,
|
||||||
labs: labs.getAll()
|
labs: labs.getAll(),
|
||||||
|
skipChecks: options.skipChecks || false
|
||||||
});
|
});
|
||||||
} else {
|
} else {
|
||||||
debug('non-zip mode');
|
debug('non-zip mode');
|
||||||
checkedTheme = await gscan.check(theme.path, {
|
checkedTheme = await gscan.check(theme.path, {
|
||||||
checkVersion: checkedVersion,
|
checkVersion: checkedVersion,
|
||||||
labs: labs.getAll()
|
labs: labs.getAll(),
|
||||||
|
skipChecks: options.skipChecks || false
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -119,7 +121,7 @@ const getThemeErrors = async function getThemeErrors(themeName) {
|
||||||
};
|
};
|
||||||
|
|
||||||
const checkSafe = async function checkSafe(themeName, theme, isZip) {
|
const checkSafe = async function checkSafe(themeName, theme, isZip) {
|
||||||
const checkedTheme = await check(themeName, theme, isZip);
|
const checkedTheme = await check(themeName, theme, {isZip});
|
||||||
|
|
||||||
if (canActivate(checkedTheme)) {
|
if (canActivate(checkedTheme)) {
|
||||||
return checkedTheme;
|
return checkedTheme;
|
||||||
|
|
|
@ -164,6 +164,9 @@
|
||||||
"threshold": 200,
|
"threshold": 200,
|
||||||
"level": "warn"
|
"level": "warn"
|
||||||
}
|
}
|
||||||
|
},
|
||||||
|
"themes": {
|
||||||
|
"skipBootChecks": false
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"imageOptimization": {
|
"imageOptimization": {
|
||||||
|
|
|
@ -188,7 +188,7 @@
|
||||||
"ghost-storage-base": "1.0.0",
|
"ghost-storage-base": "1.0.0",
|
||||||
"glob": "8.1.0",
|
"glob": "8.1.0",
|
||||||
"got": "11.8.6",
|
"got": "11.8.6",
|
||||||
"gscan": "4.43.7",
|
"gscan": "4.44.0",
|
||||||
"human-number": "2.0.4",
|
"human-number": "2.0.4",
|
||||||
"image-size": "1.1.1",
|
"image-size": "1.1.1",
|
||||||
"intl": "1.2.5",
|
"intl": "1.2.5",
|
||||||
|
|
|
@ -45,7 +45,7 @@ describe('Themes', function () {
|
||||||
checkZipStub.resolves({});
|
checkZipStub.resolves({});
|
||||||
formatStub.returns({results: {error: []}});
|
formatStub.returns({results: {error: []}});
|
||||||
|
|
||||||
return validate.check(testTheme.name, testTheme, true)
|
return validate.check(testTheme.name, testTheme, {isZip: true})
|
||||||
.then((checkedTheme) => {
|
.then((checkedTheme) => {
|
||||||
checkZipStub.calledOnce.should.be.true();
|
checkZipStub.calledOnce.should.be.true();
|
||||||
checkZipStub.calledWith(testTheme).should.be.true();
|
checkZipStub.calledWith(testTheme).should.be.true();
|
||||||
|
@ -61,7 +61,7 @@ describe('Themes', function () {
|
||||||
checkStub.resolves({});
|
checkStub.resolves({});
|
||||||
formatStub.returns({results: {error: []}});
|
formatStub.returns({results: {error: []}});
|
||||||
|
|
||||||
return validate.check(testTheme.name, testTheme, false)
|
return validate.check(testTheme.name, testTheme, {isZip: false})
|
||||||
.then((checkedTheme) => {
|
.then((checkedTheme) => {
|
||||||
checkZipStub.callCount.should.be.equal(0);
|
checkZipStub.callCount.should.be.equal(0);
|
||||||
checkStub.calledOnce.should.be.true();
|
checkStub.calledOnce.should.be.true();
|
||||||
|
@ -91,7 +91,7 @@ describe('Themes', function () {
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
return validate.check(testTheme.name, testTheme, true)
|
return validate.check(testTheme.name, testTheme, {isZip: true})
|
||||||
.then((checkedTheme) => {
|
.then((checkedTheme) => {
|
||||||
checkZipStub.calledOnce.should.be.true();
|
checkZipStub.calledOnce.should.be.true();
|
||||||
checkZipStub.calledWith(testTheme).should.be.true();
|
checkZipStub.calledWith(testTheme).should.be.true();
|
||||||
|
@ -120,7 +120,7 @@ describe('Themes', function () {
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
return validate.check(testTheme.name, testTheme, false)
|
return validate.check(testTheme.name, testTheme, {isZip: false})
|
||||||
.then((checkedTheme) => {
|
.then((checkedTheme) => {
|
||||||
checkStub.calledOnce.should.be.true();
|
checkStub.calledOnce.should.be.true();
|
||||||
checkStub.calledWith(testTheme.path).should.be.true();
|
checkStub.calledWith(testTheme.path).should.be.true();
|
||||||
|
@ -135,7 +135,7 @@ describe('Themes', function () {
|
||||||
checkZipStub.rejects(new Error('invalid zip file'));
|
checkZipStub.rejects(new Error('invalid zip file'));
|
||||||
formatStub.returns({results: {error: []}});
|
formatStub.returns({results: {error: []}});
|
||||||
|
|
||||||
return validate.check(testTheme.name, testTheme, true)
|
return validate.check(testTheme.name, testTheme, {isZip: true})
|
||||||
.then((checkedTheme) => {
|
.then((checkedTheme) => {
|
||||||
checkedTheme.should.not.exist();
|
checkedTheme.should.not.exist();
|
||||||
}).catch((error) => {
|
}).catch((error) => {
|
||||||
|
|
|
@ -18669,10 +18669,10 @@ growly@^1.3.0:
|
||||||
resolved "https://registry.yarnpkg.com/growly/-/growly-1.3.0.tgz#f10748cbe76af964b7c96c93c6bcc28af120c081"
|
resolved "https://registry.yarnpkg.com/growly/-/growly-1.3.0.tgz#f10748cbe76af964b7c96c93c6bcc28af120c081"
|
||||||
integrity sha512-+xGQY0YyAWCnqy7Cd++hc2JqMYzlm0dG30Jd0beaA64sROr8C4nt8Yc9V5Ro3avlSUDTN0ulqP/VBKi1/lLygw==
|
integrity sha512-+xGQY0YyAWCnqy7Cd++hc2JqMYzlm0dG30Jd0beaA64sROr8C4nt8Yc9V5Ro3avlSUDTN0ulqP/VBKi1/lLygw==
|
||||||
|
|
||||||
gscan@4.43.7:
|
gscan@4.44.0:
|
||||||
version "4.43.7"
|
version "4.44.0"
|
||||||
resolved "https://registry.yarnpkg.com/gscan/-/gscan-4.43.7.tgz#fe39e9db02a770ee0e5a9f67b2129a29ee4b5bbf"
|
resolved "https://registry.yarnpkg.com/gscan/-/gscan-4.44.0.tgz#7f8d9408fa390dd5829aafc98159245277acf42b"
|
||||||
integrity sha512-Y91yFnr4owcmuzCK0PbQUUaqfX8YPYZQQiam3rp5XvfpazQYM4oaWF2AGGPmKXLnQg7m75qHcq+E860GnkQ8QA==
|
integrity sha512-f+ZLM5FKiJrglzQMkfpgNivJNEJ9+bllVFx972FfkKUV/b/PjE55KlNLJhw+ZxYZVBNM6lbxCsTywOeuvPgFFg==
|
||||||
dependencies:
|
dependencies:
|
||||||
"@sentry/node" "^7.73.0"
|
"@sentry/node" "^7.73.0"
|
||||||
"@tryghost/config" "^0.2.18"
|
"@tryghost/config" "^0.2.18"
|
||||||
|
|
Loading…
Reference in a new issue