diff options
author | Russell Keith-Magee <russell@keith-magee.com> | 2011-01-24 14:24:35 +0000 |
---|---|---|
committer | Russell Keith-Magee <russell@keith-magee.com> | 2011-01-24 14:24:35 +0000 |
commit | 3f528e10d50ff7ba19a8a9e6cb2f9417a1e7f270 (patch) | |
tree | d99a22a125586c1f932171a1c78c1daf5b0e6371 /django/middleware/cache.py | |
parent | 3d7afd5d2b64546cdcfd812d2cecb61795e788f0 (diff) | |
download | django-3f528e10d50ff7ba19a8a9e6cb2f9417a1e7f270.tar.gz |
Fixed #15012 -- Added post-rendering callbacks to TemplateResponse so that decorators (in particular, the cache decorator) can defer processing until after rendering has occurred. Thanks to Joshua Ginsberg for the draft patch.
git-svn-id: http://code.djangoproject.com/svn/django/trunk@15295 bcc190cf-cafb-0310-a4f2-bffc1f526a37
Diffstat (limited to 'django/middleware/cache.py')
-rw-r--r-- | django/middleware/cache.py | 8 |
1 files changed, 7 insertions, 1 deletions
diff --git a/django/middleware/cache.py b/django/middleware/cache.py index 907edbb16f..ab72db3c18 100644 --- a/django/middleware/cache.py +++ b/django/middleware/cache.py @@ -52,6 +52,7 @@ from django.conf import settings from django.core.cache import get_cache, DEFAULT_CACHE_ALIAS from django.utils.cache import get_cache_key, learn_cache_key, patch_response_headers, get_max_age + class UpdateCacheMiddleware(object): """ Response-phase cache middleware that updates the cache if the response is @@ -87,7 +88,12 @@ class UpdateCacheMiddleware(object): patch_response_headers(response, timeout) if timeout: cache_key = learn_cache_key(request, response, timeout, self.key_prefix, cache=self.cache) - self.cache.set(cache_key, response, timeout) + if hasattr(response, 'render') and callable(response.render): + response.add_post_render_callback( + lambda r: self.cache.set(cache_key, r, timeout) + ) + else: + self.cache.set(cache_key, response, timeout) return response class FetchFromCacheMiddleware(object): |