mirror of
https://github.com/django/django.git
synced 2024-12-25 02:26:12 +00:00
bda21e2b9d
This also removes the implicit initialization of the session key on the first access in favor of explicit initialization. git-svn-id: http://code.djangoproject.com/svn/django/trunk@17155 bcc190cf-cafb-0310-a4f2-bffc1f526a37
31 lines
866 B
Python
31 lines
866 B
Python
from django.contrib.sessions.backends.base import SessionBase
|
|
|
|
class SessionStore(SessionBase):
|
|
"""
|
|
A simple cookie-based session storage implementation.
|
|
|
|
The session key is actually the session data, pickled and encoded.
|
|
This means that saving the session will change the session key.
|
|
"""
|
|
def __init__(self, session_key=None):
|
|
super(SessionStore, self).__init__(session_key)
|
|
|
|
def exists(self, session_key):
|
|
return False
|
|
|
|
def create(self):
|
|
self._session_key = self.encode({})
|
|
|
|
def save(self, must_create=False):
|
|
self._session_key = self.encode(self._session)
|
|
|
|
def delete(self, session_key=None):
|
|
self._session_key = self.encode({})
|
|
|
|
def load(self):
|
|
try:
|
|
return self.decode(self.session_key)
|
|
except:
|
|
self.modified = True
|
|
return {}
|