0
Fork 0
mirror of https://github.com/TryGhost/Ghost.git synced 2025-01-20 22:42:53 -05:00

Fixed inconsistent format of image sizes cache

refs https://github.com/TryGhost/Toolbox/issues/364
refs 147ec91162

- This looks like a subtle bug that has gone unnoticed for years. Have checked if we rely on the logic anywhere (mostly used in image-dimensions frontend helper) - we don't access the "url" directly.
- There is no reasoning attached behind why the cached size was stored as a url (see refed commit)

- WHY is this even being fixed? Caches can store anything... does not mean we should! Inconsistent data becomes a real PITA  if the cache is persisted and is hard to repopulate (e.g. to migrate the cached data format).
This commit is contained in:
Naz 2022-08-16 15:12:17 +02:00
parent e811a75972
commit 6cf49d8f89
2 changed files with 21 additions and 3 deletions

View file

@ -2,11 +2,25 @@ const debug = require('@tryghost/debug')('utils:image-size-cache');
const errors = require('@tryghost/errors');
const logging = require('@tryghost/logging');
/**
* @example
* {
* height: 50,
* url: 'https://mysite.com/images/cat.jpg',
* width: 50
* }
* @typedef ImageSizeCache
* @type {Object}
* @property {string} url image url
* @property {number} height image height
* @property {number} width image width
*/
class CachedImageSizeFromUrl {
/**
*
* @param {Object} options
* @param {Function} options.getImageSizeFromUrl - method that resolves images based on URL
* @param {(url: string) => Promise<ImageSizeCache>} options.getImageSizeFromUrl - method that resolves images based on URL
* @param {Object} options.cache - cache store instance
*/
constructor({getImageSizeFromUrl, cache}) {
@ -18,7 +32,7 @@ class CachedImageSizeFromUrl {
* Get cached image size from URL
* Always returns {object} imageSizeCache
* @param {string} url
* @returns {Promise<Object>} imageSizeCache
* @returns {Promise<ImageSizeCache>}
* @description Takes a url and returns image width and height from cache if available.
* If not in cache, `getImageSizeFromUrl` is called and returns the dimensions in a Promise.
*/
@ -50,7 +64,9 @@ class CachedImageSizeFromUrl {
}
// in case of error we just attach the url
this.cache.set(url, url);
this.cache.set(url, {
url
});
return this.cache.get(url);
}

View file

@ -74,6 +74,7 @@ describe('lib/image: image size cache', function () {
cacheStore.get(url).should.not.be.undefined;
const image = cacheStore.get(url);
should.equal(image.url, 'http://mysite.com/content/image/mypostcoverimage.jpg');
should.not.exist(image.width);
should.not.exist(image.height);
});
@ -93,6 +94,7 @@ describe('lib/image: image size cache', function () {
cacheStore.get(url).should.not.be.undefined;
const image = cacheStore.get(url);
should.equal(image.url, 'http://mysite.com/content/image/mypostcoverimage.jpg');
should.not.exist(image.width);
should.not.exist(image.height);
});