mirror of
				https://github.com/django/django.git
				synced 2025-10-26 07:06:08 +00:00 
			
		
		
		
	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 {}
 |