From 886bb355fd002005d7360ecd89b7b7278a81025e Mon Sep 17 00:00:00 2001 From: Rodrigo Ferreira de Souza Date: Mon, 17 Jul 2017 11:24:35 -0300 Subject: [PATCH] Remove image cache --- CHANGES.rst | 4 ++ sc/social/like/utils.py | 92 +++++++++++++++++------------------------ 2 files changed, 42 insertions(+), 54 deletions(-) diff --git a/CHANGES.rst b/CHANGES.rst index 08b0d050..3715a35f 100644 --- a/CHANGES.rst +++ b/CHANGES.rst @@ -6,6 +6,9 @@ There's a frood who really knows where his towel is. 2.11 (unreleased) ^^^^^^^^^^^^^^^^^ +- Remove image cache (closes `#109`_). + [rodfersou] + - Add ``canonical_domain`` field record to the registry when upgrading; this fixes an issue in the upgrade step to profile version 3045 (fixes `#114 `_). [hvelarde] @@ -296,3 +299,4 @@ Previous entries can be found in the HISTORY.rst file. .. _`#83`: https://github.com/collective/sc.social.like/issues/83 .. _`#91`: https://github.com/collective/sc.social.like/issues/91 .. _`#100`: https://github.com/collective/sc.social.like/issues/100 +.. _`#109`: https://github.com/collective/sc.social.like/issues/109 diff --git a/sc/social/like/utils.py b/sc/social/like/utils.py index 168d656f..abe74a5f 100644 --- a/sc/social/like/utils.py +++ b/sc/social/like/utils.py @@ -3,71 +3,55 @@ from Products.Archetypes.interfaces import IBaseContent from Products.CMFPlone.utils import safe_hasattr from urlparse import urlparse -from zope.annotation.interfaces import IAnnotations -from zope.globalrequest import getRequest from zope.interface import Invalid def get_images_view(context): - request = getRequest() - key = 'cache-view-' + str(context) - cache = IAnnotations(request) - value = cache.get(key, None) - if not value: - view = context.unrestrictedTraverse('@@images', None) - field = 'image' - if view: - fields = ['image', 'leadImage', 'portrait'] - if IBaseContent.providedBy(context): - schema = context.Schema() - field = [f for f in schema.keys() if f in fields] - if field: - field = field[0] - # if a content has an image field that isn't an ImageField - # (for example a relation field), set field='' to avoid errors - if schema[field].type not in ['image', 'blob']: - field = '' - value = (view, field) if (view and field) else (None, None) - cache[key] = value - return value + view = context.unrestrictedTraverse('@@images', None) + field = 'image' + if view: + fields = ['image', 'leadImage', 'portrait'] + if IBaseContent.providedBy(context): + schema = context.Schema() + field = [f for f in schema.keys() if f in fields] + if field: + field = field[0] + # if a content has an image field that isn't an ImageField + # (for example a relation field), set field='' to avoid errors + if schema[field].type not in ['image', 'blob']: + field = '' + return (view, field) if (view and field) else (None, None) def get_content_image(context, scale='large', width=None, height=None): - request = getRequest() - modification = context.ModificationDate() - key = 'cache-{0}-{1}-{2}-{3}-{4}'.format( - context, modification, scale, width, height) - cache = IAnnotations(request) - img = cache.get(key, None) - if not img: - view, field = get_images_view(context) - if view: + view, field = get_images_view(context) + img = None + if view: + try: + sizes = view.getImageSize(field) + except AttributeError: + sizes = img = None + if sizes == (0, 0) or sizes == ('', ''): + # this avoid strange cases where we can't get size infos. + # for example if the loaded image in a news is a bmp or a tiff + return None + if sizes: + kwargs = {} + if not (width or height): + kwargs['scale'] = scale + else: + new = (width, height) + width, height = _image_size(sizes, new) + kwargs['width'] = width + kwargs['height'] = height + kwargs['direction'] = 'down' try: - sizes = view.getImageSize(field) - except AttributeError: - sizes = img = None - if sizes == (0, 0) or sizes == ('', ''): - # this avoid strange cases where we can't get size infos. - # for example if the loaded image in a news is a bmp or a tiff - return None - if sizes: - kwargs = {} - if not (width or height): - kwargs['scale'] = scale - else: - new = (width, height) - width, height = _image_size(sizes, new) - kwargs['width'] = width - kwargs['height'] = height - kwargs['direction'] = 'down' - try: - img = view.scale(fieldname=field, **kwargs) - except (AttributeError, TypeError): - img = None - cache[key] = img + img = view.scale(fieldname=field, **kwargs) + except (AttributeError, TypeError): + img = None return img