From ffdae5b66d681145d6e9288fd98718e6c7b263e4 Mon Sep 17 00:00:00 2001 From: Tim Graham Date: Mon, 18 Nov 2013 07:58:43 -0500 Subject: [PATCH] Fixed #21404 -- Added session.set_expiry() note to 1.6 release notes. Thanks pwr for the suggestion. --- docs/releases/1.6.txt | 16 ++++++++++++---- 1 file changed, 12 insertions(+), 4 deletions(-) diff --git a/docs/releases/1.6.txt b/docs/releases/1.6.txt index c72f1fb6ad..ca0b00b968 100644 --- a/docs/releases/1.6.txt +++ b/docs/releases/1.6.txt @@ -807,10 +807,18 @@ For backwards compatibility, this setting defaulted to using :mod:`pickle` in Django 1.5.3, but we've changed the default to JSON in 1.6. If you upgrade and switch from pickle to JSON, sessions created before the upgrade will be lost. While JSON serialization does not support all Python objects like -:mod:`pickle` does, we highly recommend using JSON-serialized sessions. Also, -as JSON requires string keys, you will likely run into problems if you are -using non-string keys in ``request.session``. See the -:ref:`session_serialization` documentation for more details. +:mod:`pickle` does, we highly recommend using JSON-serialized sessions. Be +aware of the following when checking your code to determine if JSON +serialization will work for your application: + +* JSON requires string keys, so you will likely run into problems if you are + using non-string keys in ``request.session``. +* Setting session expiration by passing ``datetime`` values to + :meth:`~django.contrib.sessions.backends.base.SessionBase.set_expiry` will + not work as ``datetime`` values are not serializable in JSON. You can use + integer values instead. + +See the :ref:`session_serialization` documentation for more details. Object Relational Mapper changes ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~