mirror of
				https://github.com/django/django.git
				synced 2025-10-25 06:36:07 +00:00 
			
		
		
		
	Fixed #17083 -- Allowed sessions to use non-default cache.
This commit is contained in:
		| @@ -445,6 +445,7 @@ MIDDLEWARE_CLASSES = ( | |||||||
| # SESSIONS # | # SESSIONS # | ||||||
| ############ | ############ | ||||||
|  |  | ||||||
|  | SESSION_CACHE_ALIAS = 'default'                         # Cache to store session data if using the cache session backend. | ||||||
| SESSION_COOKIE_NAME = 'sessionid'                       # Cookie name. This can be whatever you want. | SESSION_COOKIE_NAME = 'sessionid'                       # Cookie name. This can be whatever you want. | ||||||
| SESSION_COOKIE_AGE = 60 * 60 * 24 * 7 * 2               # Age of cookie, in seconds (default: 2 weeks). | SESSION_COOKIE_AGE = 60 * 60 * 24 * 7 * 2               # Age of cookie, in seconds (default: 2 weeks). | ||||||
| SESSION_COOKIE_DOMAIN = None                            # A string like ".example.com", or None for standard domain cookie. | SESSION_COOKIE_DOMAIN = None                            # A string like ".example.com", or None for standard domain cookie. | ||||||
|   | |||||||
| @@ -1,5 +1,6 @@ | |||||||
|  | from django.conf import settings | ||||||
| from django.contrib.sessions.backends.base import SessionBase, CreateError | from django.contrib.sessions.backends.base import SessionBase, CreateError | ||||||
| from django.core.cache import cache | from django.core.cache import get_cache | ||||||
| from django.utils.six.moves import xrange | from django.utils.six.moves import xrange | ||||||
|  |  | ||||||
| KEY_PREFIX = "django.contrib.sessions.cache" | KEY_PREFIX = "django.contrib.sessions.cache" | ||||||
| @@ -10,7 +11,7 @@ class SessionStore(SessionBase): | |||||||
|     A cache-based session store. |     A cache-based session store. | ||||||
|     """ |     """ | ||||||
|     def __init__(self, session_key=None): |     def __init__(self, session_key=None): | ||||||
|         self._cache = cache |         self._cache = get_cache(settings.SESSION_CACHE_ALIAS) | ||||||
|         super(SessionStore, self).__init__(session_key) |         super(SessionStore, self).__init__(session_key) | ||||||
|  |  | ||||||
|     @property |     @property | ||||||
|   | |||||||
| @@ -13,8 +13,8 @@ from django.contrib.sessions.backends.file import SessionStore as FileSession | |||||||
| from django.contrib.sessions.backends.signed_cookies import SessionStore as CookieSession | from django.contrib.sessions.backends.signed_cookies import SessionStore as CookieSession | ||||||
| from django.contrib.sessions.models import Session | from django.contrib.sessions.models import Session | ||||||
| from django.contrib.sessions.middleware import SessionMiddleware | from django.contrib.sessions.middleware import SessionMiddleware | ||||||
|  | from django.core.cache import get_cache | ||||||
| from django.core import management | from django.core import management | ||||||
| from django.core.cache import DEFAULT_CACHE_ALIAS |  | ||||||
| from django.core.exceptions import ImproperlyConfigured, SuspiciousOperation | from django.core.exceptions import ImproperlyConfigured, SuspiciousOperation | ||||||
| from django.http import HttpResponse | from django.http import HttpResponse | ||||||
| from django.test import TestCase, RequestFactory | from django.test import TestCase, RequestFactory | ||||||
| @@ -136,8 +136,8 @@ class SessionTestsMixin(object): | |||||||
|         self.assertTrue(self.session.modified) |         self.assertTrue(self.session.modified) | ||||||
|  |  | ||||||
|     def test_save(self): |     def test_save(self): | ||||||
|         if (hasattr(self.session, '_cache') and |         if (hasattr(self.session, '_cache') and'DummyCache' in | ||||||
|                 'DummyCache' in settings.CACHES[DEFAULT_CACHE_ALIAS]['BACKEND']): |             settings.CACHES[settings.SESSION_CACHE_ALIAS]['BACKEND']): | ||||||
|             raise unittest.SkipTest("Session saving tests require a real cache backend") |             raise unittest.SkipTest("Session saving tests require a real cache backend") | ||||||
|         self.session.save() |         self.session.save() | ||||||
|         self.assertTrue(self.session.exists(self.session.session_key)) |         self.assertTrue(self.session.exists(self.session.session_key)) | ||||||
| @@ -355,7 +355,8 @@ class CacheDBSessionTests(SessionTestsMixin, TestCase): | |||||||
|  |  | ||||||
|     backend = CacheDBSession |     backend = CacheDBSession | ||||||
|  |  | ||||||
|     @unittest.skipIf('DummyCache' in settings.CACHES[DEFAULT_CACHE_ALIAS]['BACKEND'], |     @unittest.skipIf('DummyCache' in | ||||||
|  |         settings.CACHES[settings.SESSION_CACHE_ALIAS]['BACKEND'], | ||||||
|         "Session saving tests require a real cache backend") |         "Session saving tests require a real cache backend") | ||||||
|     def test_exists_searches_cache_first(self): |     def test_exists_searches_cache_first(self): | ||||||
|         self.session.save() |         self.session.save() | ||||||
| @@ -454,6 +455,23 @@ class CacheSessionTests(SessionTestsMixin, unittest.TestCase): | |||||||
|             self.session._session_key = (string.ascii_letters + string.digits) * 20 |             self.session._session_key = (string.ascii_letters + string.digits) * 20 | ||||||
|             self.assertEqual(self.session.load(), {}) |             self.assertEqual(self.session.load(), {}) | ||||||
|  |  | ||||||
|  |     def test_default_cache(self): | ||||||
|  |         self.session.save() | ||||||
|  |         self.assertNotEqual(get_cache('default').get(self.session.cache_key), None) | ||||||
|  |  | ||||||
|  |     @override_settings(CACHES={ | ||||||
|  |         'default': { | ||||||
|  |             'BACKEND': 'django.core.cache.backends.dummy.DummyCache', | ||||||
|  |         }, | ||||||
|  |         'sessions': { | ||||||
|  |             'BACKEND': 'django.core.cache.backends.locmem.LocMemCache', | ||||||
|  |         }, | ||||||
|  |     }, SESSION_CACHE_ALIAS='sessions') | ||||||
|  |     def test_non_default_cache(self): | ||||||
|  |         self.session.save() | ||||||
|  |         self.assertEqual(get_cache('default').get(self.session.cache_key), None) | ||||||
|  |         self.assertNotEqual(get_cache('sessions').get(self.session.cache_key), None) | ||||||
|  |  | ||||||
|  |  | ||||||
| class SessionMiddlewareTests(unittest.TestCase): | class SessionMiddlewareTests(unittest.TestCase): | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1693,6 +1693,16 @@ This is useful if you have multiple Django instances running under the same | |||||||
| hostname. They can use different cookie paths, and each instance will only see | hostname. They can use different cookie paths, and each instance will only see | ||||||
| its own session cookie. | its own session cookie. | ||||||
|  |  | ||||||
|  | .. setting:: SESSION_CACHE_ALIAS | ||||||
|  |  | ||||||
|  | SESSION_CACHE_ALIAS | ||||||
|  | ------------------- | ||||||
|  |  | ||||||
|  | Default: ``default`` | ||||||
|  |  | ||||||
|  | If you're using :ref:`cache-based session storage <cached-sessions-backend>`, | ||||||
|  | this selects the cache to use. | ||||||
|  |  | ||||||
| .. setting:: SESSION_COOKIE_SECURE | .. setting:: SESSION_COOKIE_SECURE | ||||||
|  |  | ||||||
| SESSION_COOKIE_SECURE | SESSION_COOKIE_SECURE | ||||||
|   | |||||||
| @@ -299,6 +299,9 @@ Django 1.5 also includes several smaller improvements worth noting: | |||||||
| * RemoteUserMiddleware now forces logout when the REMOTE_USER header | * RemoteUserMiddleware now forces logout when the REMOTE_USER header | ||||||
|   disappears during the same browser session. |   disappears during the same browser session. | ||||||
|  |  | ||||||
|  | * The :ref:`cache-based session backend <cached-sessions-backend>` can store | ||||||
|  |   session data in a non-default cache. | ||||||
|  |  | ||||||
| Backwards incompatible changes in 1.5 | Backwards incompatible changes in 1.5 | ||||||
| ===================================== | ===================================== | ||||||
|  |  | ||||||
|   | |||||||
| @@ -45,6 +45,8 @@ If you want to use a database-backed session, you need to add | |||||||
| Once you have configured your installation, run ``manage.py syncdb`` | Once you have configured your installation, run ``manage.py syncdb`` | ||||||
| to install the single database table that stores session data. | to install the single database table that stores session data. | ||||||
|  |  | ||||||
|  | .. _cached-sessions-backend: | ||||||
|  |  | ||||||
| Using cached sessions | Using cached sessions | ||||||
| --------------------- | --------------------- | ||||||
|  |  | ||||||
| @@ -62,6 +64,13 @@ sure you've configured your cache; see the :doc:`cache documentation | |||||||
|     sessions directly instead of sending everything through the file or |     sessions directly instead of sending everything through the file or | ||||||
|     database cache backends. |     database cache backends. | ||||||
|  |  | ||||||
|  | If you have multiple caches defined in :setting:`CACHES`, Django will use the | ||||||
|  | default cache. To use another cache, set :setting:`SESSION_CACHE_ALIAS` to the | ||||||
|  | name of that cache. | ||||||
|  |  | ||||||
|  | .. versionchanged:: 1.5 | ||||||
|  |     The :setting:`SESSION_CACHE_ALIAS` setting was added. | ||||||
|  |  | ||||||
| Once your cache is configured, you've got two choices for how to store data in | Once your cache is configured, you've got two choices for how to store data in | ||||||
| the cache: | the cache: | ||||||
|  |  | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user