U
    ft
                     @   s,   d dl mZ d dlmZ G dd deZdS )    )SessionBase)signingc                   @   sV   e Zd Zdd Zdd ZdddZdd	d
ZdddZdd Zdd Z	e
dd ZdS )SessionStorec                 C   s>   zt j| j| j|  ddW S  tk
r8   |   Y nX i S )z
        Load the data from the key itself instead of fetching from some
        external data store. Opposite of _get_session_key(), raise BadSignature
        if signature fails.
        /django.contrib.sessions.backends.signed_cookies)
serializerZmax_agesalt)r   loadssession_keyr   Zget_session_cookie_age	Exceptioncreateself r   S/tmp/pip-unpacked-wheel-_jot26k8/django/contrib/sessions/backends/signed_cookies.pyload   s    zSessionStore.loadc                 C   s
   d| _ dS )z
        To create a new key, set the modified flag so that the cookie is set
        on the client for the current request.
        TN)modifiedr   r   r   r   r      s    zSessionStore.createFc                 C   s   |   | _d| _dS )z
        To save, get the session key as a securely signed string and then set
        the modified flag so that the cookie is set on the client for the
        current request.
        TN)_get_session_key_session_keyr   )r   Zmust_creater   r   r   save!   s    
zSessionStore.saveNc                 C   s   dS )z
        This method makes sense when you're talking to a shared resource, but
        it doesn't matter when you're storing the information in the client's
        cookie.
        Fr   r   r	   r   r   r   exists*   s    zSessionStore.existsc                 C   s   d| _ i | _d| _dS )z
        To delete, clear the session key and the underlying data structure
        and set the modified flag so that the cookie is set on the client for
        the current request.
         TN)r   Z_session_cacher   r   r   r   r   delete2   s    zSessionStore.deletec                 C   s   |    dS )z
        Keep the same data but with a new key. Call save() and it will
        automatically save a cookie with a new key at the end of the request.
        N)r   r   r   r   r   	cycle_key<   s    zSessionStore.cycle_keyc                 C   s   t j| jdd| jdS )z
        Instead of generating a random string, generate a secure url-safe
        base64-encoded string of data as our session key.
        Tr   )compressr   r   )r   dumps_sessionr   r   r   r   r   r   C   s    zSessionStore._get_session_keyc                 C   s   d S )Nr   )clsr   r   r   clear_expiredO   s    zSessionStore.clear_expired)F)N)N)__name__
__module____qualname__r   r   r   r   r   r   r   classmethodr   r   r   r   r   r      s   
	


r   N)Z%django.contrib.sessions.backends.baser   Zdjango.corer   r   r   r   r   r   <module>   s   