2011-03-28 10:11:19 +08:00
|
|
|
from functools import wraps
|
2015-01-28 20:35:27 +08:00
|
|
|
|
2005-10-09 08:37:56 +08:00
|
|
|
from django.utils.cache import patch_vary_headers
|
|
|
|
|
2013-11-03 07:53:29 +08:00
|
|
|
|
2005-10-09 08:37:56 +08:00
|
|
|
def vary_on_headers(*headers):
|
|
|
|
"""
|
|
|
|
A view decorator that adds the specified headers to the Vary header of the
|
|
|
|
response. Usage:
|
|
|
|
|
|
|
|
@vary_on_headers('Cookie', 'Accept-language')
|
|
|
|
def index(request):
|
|
|
|
...
|
|
|
|
|
|
|
|
Note that the header names are not case-sensitive.
|
|
|
|
"""
|
|
|
|
def decorator(func):
|
2017-01-22 02:20:17 +08:00
|
|
|
@wraps(func)
|
2005-10-09 08:37:56 +08:00
|
|
|
def inner_func(*args, **kwargs):
|
|
|
|
response = func(*args, **kwargs)
|
|
|
|
patch_vary_headers(response, headers)
|
|
|
|
return response
|
2011-05-02 00:46:02 +08:00
|
|
|
return inner_func
|
2005-10-09 08:37:56 +08:00
|
|
|
return decorator
|
|
|
|
|
2013-11-03 07:53:29 +08:00
|
|
|
|
2005-10-09 08:37:56 +08:00
|
|
|
def vary_on_cookie(func):
|
|
|
|
"""
|
|
|
|
A view decorator that adds "Cookie" to the Vary header of a response. This
|
|
|
|
indicates that a page's contents depends on cookies. Usage:
|
|
|
|
|
|
|
|
@vary_on_cookie
|
|
|
|
def index(request):
|
|
|
|
...
|
|
|
|
"""
|
2017-01-22 02:20:17 +08:00
|
|
|
@wraps(func)
|
2005-10-09 08:37:56 +08:00
|
|
|
def inner_func(*args, **kwargs):
|
|
|
|
response = func(*args, **kwargs)
|
|
|
|
patch_vary_headers(response, ('Cookie',))
|
|
|
|
return response
|
2011-05-02 00:46:02 +08:00
|
|
|
return inner_func
|