const semver = require('semver'); const errors = require('@tryghost/errors'); const i18n = require('../../../../shared/i18n'); function checkVersionMatch(req, res, next) { const clientVersion = req.get('X-Ghost-Version'); // can contain pre-release suffix, you should be able to use e.g. 1.19.0-pre [server] with 1.18.0 [client] const serverVersion = res.locals.version.match(/^(\d+\.)?(\d+\.)?(\d+)/)[0]; const constraint = '^' + clientVersion + '.0'; // no error when client is on an earlier minor version than server // error when client is on a later minor version than server // always error when the major version is different if (clientVersion && !semver.satisfies(serverVersion, constraint)) { return next(new errors.VersionMismatchError({ message: i18n.t('errors.middleware.api.versionMismatch', { clientVersion: clientVersion, serverVersion: serverVersion }) })); } next(); } module.exports = checkVersionMatch;