diff options
| author | Aymeric Augustin <aymeric.augustin@m4x.org> | 2014-12-23 22:29:01 +0100 |
|---|---|---|
| committer | Aymeric Augustin <aymeric.augustin@m4x.org> | 2014-12-27 18:26:20 +0100 |
| commit | 3483682749577b4b5a8141a766489d5b460e30e9 (patch) | |
| tree | 0771e63e01d6d65881c811c9494bc7b7517824a9 /docs | |
| parent | b429a9796a162f9e12e6d34579468621ba9accc7 (diff) | |
[1.7.x] Fixed #23831 -- Supported strings escaped by third-party libs in Django.
Refs #7261 -- Made strings escaped by Django usable in third-party libs.
The changes in mark_safe and mark_for_escaping are straightforward. The
more tricky part is to handle correctly objects that implement __html__.
Historically escape() has escaped SafeData. Even if that doesn't seem a
good behavior, changing it would create security concerns. Therefore
support for __html__() was only added to conditional_escape() where this
concern doesn't exist.
Then using conditional_escape() instead of escape() in the Django
template engine makes it understand data escaped by other libraries.
Template filter |escape accounts for __html__() when it's available.
|force_escape forces the use of Django's HTML escaping implementation.
Here's why the change in render_value_in_context() is safe. Before Django
1.7 conditional_escape() was implemented as follows:
if isinstance(text, SafeData):
return text
else:
return escape(text)
render_value_in_context() never called escape() on SafeData. Therefore
replacing escape() with conditional_escape() doesn't change the
autoescaping logic as it was originally intended.
This change should be backported to Django 1.7 because it corrects a
feature added in Django 1.7.
Thanks mitsuhiko for the report.
Backport of 6d52f6f from master.
Diffstat (limited to 'docs')
| -rw-r--r-- | docs/releases/1.7.2.txt | 3 |
1 files changed, 3 insertions, 0 deletions
diff --git a/docs/releases/1.7.2.txt b/docs/releases/1.7.2.txt index 84188cd494..da6721a1ba 100644 --- a/docs/releases/1.7.2.txt +++ b/docs/releases/1.7.2.txt @@ -178,3 +178,6 @@ Bugfixes * Restored support for objects that aren't :class:`str` or :class:`bytes` in :func:`~django.utils.safestring.mark_for_escaping` on Python 3. + +* Supported strings escaped by third-party libraries with the ``__html__`` + convention in the template engine (:ticket:`23831`). |
