AlkantarClanX12

Your IP : 13.58.38.184


Current Path : /proc/self/root/opt/alt/python311/lib64/python3.11/http/__pycache__/
Upload File :
Current File : //proc/self/root/opt/alt/python311/lib64/python3.11/http/__pycache__/cookies.cpython-311.opt-1.pyc

�

c��f�M���dZddlZddlZddlZgd�ZdjZdjZdjZGd�de	��Z
ejejzd	zZ
e
d
zZd�eed����eeee����z
D��Ze�ed
��ded��di��ejdeje
��z��jZd�Zejd��jZd�Zd�Zgd�Zgd�Zdeefd�Z Gd�de!��Z"dZ#e#dzZ$ejde#zdze$zdzej%ej&z��Z'Gd �d!e!��Z(Gd"�d#e(��Z)dS)$a.

Here's a sample session to show how to use this module.
At the moment, this is the only documentation.

The Basics
----------

Importing is easy...

   >>> from http import cookies

Most of the time you start by creating a cookie.

   >>> C = cookies.SimpleCookie()

Once you've created your Cookie, you can add values just as if it were
a dictionary.

   >>> C = cookies.SimpleCookie()
   >>> C["fig"] = "newton"
   >>> C["sugar"] = "wafer"
   >>> C.output()
   'Set-Cookie: fig=newton\r\nSet-Cookie: sugar=wafer'

Notice that the printable representation of a Cookie is the
appropriate format for a Set-Cookie: header.  This is the
default behavior.  You can change the header and printed
attributes by using the .output() function

   >>> C = cookies.SimpleCookie()
   >>> C["rocky"] = "road"
   >>> C["rocky"]["path"] = "/cookie"
   >>> print(C.output(header="Cookie:"))
   Cookie: rocky=road; Path=/cookie
   >>> print(C.output(attrs=[], header="Cookie:"))
   Cookie: rocky=road

The load() method of a Cookie extracts cookies from a string.  In a
CGI script, you would use this method to extract the cookies from the
HTTP_COOKIE environment variable.

   >>> C = cookies.SimpleCookie()
   >>> C.load("chips=ahoy; vienna=finger")
   >>> C.output()
   'Set-Cookie: chips=ahoy\r\nSet-Cookie: vienna=finger'

The load() method is darn-tootin smart about identifying cookies
within a string.  Escaped quotation marks, nested semicolons, and other
such trickeries do not confuse it.

   >>> C = cookies.SimpleCookie()
   >>> C.load('keebler="E=everybody; L=\\"Loves\\"; fudge=\\012;";')
   >>> print(C)
   Set-Cookie: keebler="E=everybody; L=\"Loves\"; fudge=\012;"

Each element of the Cookie also supports all of the RFC 2109
Cookie attributes.  Here's an example which sets the Path
attribute.

   >>> C = cookies.SimpleCookie()
   >>> C["oreo"] = "doublestuff"
   >>> C["oreo"]["path"] = "/"
   >>> print(C)
   Set-Cookie: oreo=doublestuff; Path=/

Each dictionary element has a 'value' attribute, which gives you
back the value associated with the key.

   >>> C = cookies.SimpleCookie()
   >>> C["twix"] = "none for you"
   >>> C["twix"].value
   'none for you'

The SimpleCookie expects that all values should be standard strings.
Just to be sure, SimpleCookie invokes the str() builtin to convert
the value to a string, when the values are set dictionary-style.

   >>> C = cookies.SimpleCookie()
   >>> C["number"] = 7
   >>> C["string"] = "seven"
   >>> C["number"].value
   '7'
   >>> C["string"].value
   'seven'
   >>> C.output()
   'Set-Cookie: number=7\r\nSet-Cookie: string=seven'

Finis.
�N)�CookieError�
BaseCookie�SimpleCookie�z; � c��eZdZdS)rN)�__name__�
__module__�__qualname__���3/opt/alt/python311/lib64/python3.11/http/cookies.pyrr�s�������Dr
rz!#$%&'*+-.^_`|~:z
 ()/<=>?@[]{}c��i|]}|d|z��	S)z\%03or)�.0�ns  r�
<dictcomp>r�s4��J�J�J���(�Q�,�J�J�Jr
��"�\"�\z\\z[%s]+c�h�|�t|��r|Sd|�t��zdzS)z�Quote a string for use in a cookie header.

    If the string does not need to be double-quoted, then just return the
    string.  Otherwise, surround the string in doublequotes and quote
    (with a \) special characters.
    Nr)�
_is_legal_key�	translate�_Translator��strs r�_quoter�s6���{�m�C�(�(�{��
��S�]�]�;�/�/�/�#�5�5r
z\\(?:([0-3][0-7][0-7])|(.))c�h�|dr#tt|dd����S|dS)N���)�chr�int)�ms r�_unquote_replacer%�s1����t���3�q��t�Q�<�<� � � ���t�r
c��|�t|��dkr|S|ddks|ddkr|S|dd�}tt|��S)Nr!rr���r)�len�_unquote_subr%rs r�_unquoter*�s\���{�c�#�h�h��l�l��
�
�1�v��}�}��B��3����
��a��d�)�C��(�#�.�.�.r
)�Mon�Tue�Wed�Thu�Fri�Sat�Sun)
N�Jan�Feb�Mar�Apr�May�Jun�Jul�Aug�Sep�Oct�Nov�Decc	��ddlm}m}|��}|||z��\	}}}}	}
}}}
}d|||||||	|
|fzS)Nr)�gmtime�timez#%s, %02d %3s %4d %02d:%02d:%02d GMT)r@r?)�future�weekdayname�	monthnamer?r@�now�year�month�day�hh�mm�ss�wd�y�zs               r�_getdaterN�su��!�!�!�!�!�!�!�!�
�$�&�&�C�-3�V�C�&�L�-A�-A�*�D�%��b�"�b�"�a��0���O�S�)�E�"2�D�"�b�"�E�F�Fr
c
��eZdZdZdddddddd	d
d�	Zdd
hZd�Zed���Zed���Z	ed���Z
d�Zd!d�Zd�Z
ejZd�Zd�Zd�Zd�Zd�Zd�Zd"d�ZeZd�Zd!d�Zd!d �Zeej��ZdS)#�MorselaCA class to hold ONE (key, value) pair.

    In a cookie, each such pair may have several attributes, so this class is
    used to keep the attributes associated with the appropriate key,value pair.
    This class also includes a coded_value attribute, which is used to hold
    the network representation of the value.
    �expires�Path�Comment�DomainzMax-Age�Secure�HttpOnly�Version�SameSite)	rQ�path�comment�domain�max-age�secure�httponly�version�samesiter]r^c�|�dx|_x|_|_|jD]}t�||d���dS)Nr)�_key�_value�_coded_value�	_reserved�dict�__setitem__)�self�keys  r�__init__zMorsel.__init__sP��6:�:��	�:�D�K�$�"3��>�	,�	,�C����T�3��+�+�+�+�	,�	,r
c��|jS�N)rb�rhs rriz
Morsel.keys
���y�r
c��|jSrl)rcrms r�valuezMorsel.values
���{�r
c��|jSrl)rdrms r�coded_valuezMorsel.coded_values��� � r
c��|���}||jvrtd|�����t�|||��dS�NzInvalid attribute )�lowerrerrfrg)rh�K�Vs   rrgzMorsel.__setitem__#sO��
�G�G�I�I���D�N�"�"��+���;�<�<�<�����q�!�$�$�$�$�$r
Nc��|���}||jvrtd|�����t�|||��Srs)rtrerrf�
setdefault)rhri�vals   rrxzMorsel.setdefault)sG���i�i�k�k���d�n�$�$��+���=�>�>�>����t�S�#�.�.�.r
c���t|t��stSt�||��o/|j|jko|j|jko|j|jkSrl)�
isinstancerP�NotImplementedrf�__eq__rcrbrd�rh�morsels  rr}z
Morsel.__eq__/sg���&�&�)�)�	"�!�!����D�&�)�)�9���v�}�,�9��	�V�[�(�9��!�V�%8�8�	:r
c��t��}t�||��|j�|j��|Srl)rPrf�update�__dict__r~s  r�copyzMorsel.copy9s<���������F�D�!�!�!�����t�}�-�-�-��
r
c��i}t|�����D]9\}}|���}||jvrt	d|�����|||<�:t�||��dSrs)rf�itemsrtrerr�)rh�values�datarirys     rr�z
Morsel.update?s������V���*�*�,�,�	�	�H�C���)�)�+�+�C��$�.�(�(�!�k�C�C�"A�B�B�B��D��I�I����D�$�����r
c�8�|���|jvSrl)rtre)rhrus  r�
isReservedKeyzMorsel.isReservedKeyHs���w�w�y�y�D�N�*�*r
c���|���|jvrtd|�����t|��std|�����||_||_||_dS)NzAttempt to set a reserved key zIllegal key )rtrerrrbrcrd)rhriry�	coded_vals    r�setz
Morsel.setKso���9�9�;�;�$�.�(�(��+�C�C�I�J�J�J��S�!�!�	9��+�#�#�7�8�8�8���	����%����r
c�,�|j|j|jd�S)N)rirorq�rbrcrdrms r�__getstate__zMorsel.__getstate__Vs!���9��[��,�
�
�	
r
c�T�|d|_|d|_|d|_dS)Nrirorqr�)rh�states  r�__setstate__zMorsel.__setstate__]s+���%�L��	��G�n���!�-�0����r
�Set-Cookie:c�6�|�d|�|����S)Nr)�OutputString)rh�attrs�headers   r�outputz
Morsel.outputbs"�� �&�&�$�"3�"3�E�":�":�":�;�;r
c�L�d|jj�d|����d�S)N�<�: �>)�	__class__r	r�rms r�__repr__zMorsel.__repr__gs,���!�^�4�4�4�d�6G�6G�6I�6I�6I�6I�J�Jr
c�Z�d|�|���dd��zS)Nz�
        <script type="text/javascript">
        <!-- begin hiding
        document.cookie = "%s";
        // end hiding -->
        </script>
        rr)r��replace)rhr�s  r�	js_outputzMorsel.js_outputjs4���� � ��'�'�/�/��U�;�;�
=�	=r
c��g}|j}||j�d|j����|�|j}t	|�����}|D�]\}}|dkr�
||vr�|dkr>t
|t��r)||j|�dt|�������V|dkr1t
|t��r|d|j||fz����|dkr>t
|t��r)||j|�dt|��������||jvr'|r#|t|j|������||j|�d|������t|��S)N�=rrQr\z%s=%drZ)
�appendrirqre�sortedr�r{r#rNrr�_flags�_semispacejoin)rhr��resultr�r�riros       rr�zMorsel.OutputStringts��������	��$�(�(�(�D�$4�$4�5�6�6�6��=��N�E��t�z�z�|�|�$�$���	?�	?�J�C����{�{���%�����i���J�u�c�$:�$:����$�.��"5�"5�"5�x�����G�H�H�H�H��	�!�!�j���&<�&<�!���w�$�.��"5�u�!=�=�>�>�>�>��	�!�!�j���&<�&<�!���$�.��"5�"5�"5�v�e�}�}�}�E�F�F�F�F����#�#��5��F�3�t�~�c�2�3�3�4�4�4����$�.��"5�"5�"5�u�u�=�>�>�>�>��f�%�%�%r
rl)Nr�)r	r
r�__doc__rer�rj�propertyrirorqrgrxr}�object�__ne__r�r�r�r�r�r�r��__str__r�r�r��classmethod�types�GenericAlias�__class_getitem__rr
rrPrP�s���������*���������
�
�I��
�
#�F�,�,�,�����X������X���!�!��X�!�%�%�%�/�/�/�/�:�:�:��]�F���� � � �+�+�+�	&�	&�	&�
�
�
�1�1�1�
<�<�<�<��G�K�K�K�=�=�=�=�&�&�&�&�B$��E�$6�7�7���r
rPz,\w\d!#%&'~_`><@,:/\$\*\+\-\.\^\|\)\(\?\}\{\=z\[\]z�
    \s*                            # Optional whitespace at start of cookie
    (?P<key>                       # Start of group 'key'
    [a	]+?   # Any word of at least one letter
    )                              # End of group 'key'
    (                              # Optional group: there may not be a value.
    \s*=\s*                          # Equal Sign
    (?P<val>                         # Start of group 'val'
    "(?:[^\\"]|\\.)*"                  # Any doublequoted string
    |                                  # or
    \w{3},\s[\w\d\s-]{9,11}\s[\d:]{8}\sGMT  # Special case for "expires" attr
    |                                  # or
    [a-]*      # Any word or empty string
    )                                # End of group 'val'
    )?                             # End of optional value group
    \s*                            # Any number of spaces.
    (\s+|;|$)                      # Ending either at space, semicolon, or EOS.
    c�\�eZdZdZd�Zd�Zdd�Zd�Zd�Zdd
�Z	e	Z
d�Zdd�Zd
�Z
efd�ZdS)rz'A container class for a set of Morsels.c�
�||fS)a
real_value, coded_value = value_decode(STRING)
        Called prior to setting a cookie's value from the network
        representation.  The VALUE is the value read from HTTP
        header.
        Override this function to modify the behavior of cookies.
        r�rhrys  r�value_decodezBaseCookie.value_decode�s
���C�x�r
c�(�t|��}||fS)z�real_value, coded_value = value_encode(VALUE)
        Called prior to setting a cookie's value from the dictionary
        representation.  The VALUE is the value being assigned.
        Override this function to modify the behavior of cookies.
        r�rhry�strvals   r�value_encodezBaseCookie.value_encode�s���S�����v�~�r
Nc�8�|r|�|��dSdSrl)�load)rh�inputs  rrjzBaseCookie.__init__�s,���	��I�I�e������	�	r
c��|�|t����}|�|||��t�|||��dS)z+Private method for setting a cookie's valueN)�getrPr�rfrg)rhri�
real_valuerq�Ms     r�__setzBaseCookie.__set�sM���H�H�S�&�(�(�#�#��	���c�:�{�+�+�+�����s�A�&�&�&�&�&r
c���t|t��rt�|||��dS|�|��\}}|�|||��dS)zDictionary style assignment.N)r{rPrfrgr��_BaseCookie__set)rhriro�rval�cvals     rrgzBaseCookie.__setitem__�se���e�V�$�$�	(����T�3��.�.�.�.�.��*�*�5�1�1�J�D�$��J�J�s�D�$�'�'�'�'�'r
r��
c���g}t|�����}|D].\}}|�|�||�����/|�|��S)z"Return a string suitable for HTTP.)r�r�r�r��join)rhr�r��sepr�r�riros        rr�zBaseCookie.output�sd�����t�z�z�|�|�$�$���	7�	7�J�C���M�M�%�,�,�u�f�5�5�6�6�6�6��x�x����r
c���g}t|�����}|D]1\}}|�|�dt|j�������2d|jj�dt|���d�S)Nr�r�r�r�)r�r�r��reprror�r	�
_spacejoin)rh�lr�riros     rr�zBaseCookie.__repr__�s�����t�z�z�|�|�$�$���	9�	9�J�C��
�H�H����T�%�+�%6�%6�%6�7�8�8�8�8�	9�!�^�4�4�4�j��m�m�m�m�D�Dr
c���g}t|�����}|D]-\}}|�|�|�����.t	|��S)z(Return a string suitable for JavaScript.)r�r�r�r��	_nulljoin)rhr�r�r�riros      rr�zBaseCookie.js_output�s^�����t�z�z�|�|�$�$���	2�	2�J�C���M�M�%�/�/�%�0�0�1�1�1�1��� � � r
c��t|t��r|�|��n|���D]
\}}|||<�dS)z�Load cookies from a string (presumably HTTP_COOKIE) or
        from a dictionary.  Loading cookies from a dictionary 'd'
        is equivalent to calling:
            map(Cookie.__setitem__, d.keys(), d.values())
        N)r{r�_BaseCookie__parse_stringr�)rh�rawdatariros    rr�zBaseCookie.load�sZ���g�s�#�#�	"�����(�(�(�(�&�m�m�o�o�
"�
"�
��U�!��S�	�	��r
c�v�d}t|��}g}d}d}d}d|cxkr|k�rVn�nR|�||��}	|	s�n8|	�d��|	�d��}}
|	�d��}|
ddkr$|s�z|�||
dd�|f��n�|
���tjvrg|sdS|�;|
���tjvr|�||
df��nZdS|�||
t|��f��n2|�.|�||
|�
|��f��d}ndSd|cxkr|k��Pnd}|D]6\}
}
}|
|kr|||
<�|\}}|�|
||��||
}�7dS)	NrFrr!riry�$T)r(�match�group�endr�rtrPrer�r*r�r�)rhr�patt�ir�parsed_items�morsel_seen�TYPE_ATTRIBUTE�
TYPE_KEYVALUEr�riror��tpr�r�s                r�__parse_stringzBaseCookie.__parse_string	s��
����H�H���������
�
�1�j�j�j�j�q�j�j�j�j�j��J�J�s�A�&�&�E��
�����U�+�+�U�[�[��-?�-?��C��	�	�!���A��1�v��}�}�"����#�#�^�S����W�e�$D�E�E�E�E������� 0�0�0�"���F��=��y�y�{�{�f�m�3�3�$�+�+�^�S�$�,G�H�H�H�H��� �'�'���h�u�o�o�(N�O�O�O�O��"��#�#�]�C��9J�9J�5�9Q�9Q�$R�S�S�S�"�����E�1�j�j�j�j�q�j�j�j�j�J
��*�	�	�N�B��U��^�#�#���#���#�
��d��
�
�3��d�+�+�+���I���	�	r
rl)Nr�r�)r	r
rr�r�r�rjr�rgr�r�r�r�r��_CookiePatternr�rr
rrr�s�������1�1�����������'�'�'�(�(�(� � � � ��G�E�E�E�!�!�!�!����(6�:�:�:�:�:�:r
rc��eZdZdZd�Zd�ZdS)rz�
    SimpleCookie supports strings as cookie values.  When setting
    the value using the dictionary assignment notation, SimpleCookie
    calls the builtin str() to convert the value to a string.  Values
    received from HTTP are kept as strings.
    c�$�t|��|fSrl)r*r�s  rr�zSimpleCookie.value_decodeMs����}�}�c�!�!r
c�B�t|��}|t|��fSrl)rrr�s   rr�zSimpleCookie.value_encodePs���S�����v�f�~�~�%�%r
N)r	r
rr�r�r�rr
rrrFs<��������"�"�"�&�&�&�&�&r
r)*r��re�stringr��__all__r�r�r�r��	Exceptionr�
ascii_letters�digits�_LegalChars�_UnescapedCharsr��range�map�ordrr��compile�escape�	fullmatchrr�subr)r%r*�_weekdayname�
_monthnamerNrfrP�_LegalKeyChars�_LegalValueChars�ASCII�VERBOSEr�rrrr
r�<module>r�s���NX�X�z
�	�	�	�
�
�
�
�����
7�
7�
7���G�	����
�X�
�
	�	�	�	�	�)�	�	�	�"�"�V�]�2�5G�G����/��J�J���E�E�#�J�J���#�#�c�c�#��.G�.G�*H�*H�H�J�J�J������C��H�H�e��C��I�I�v�����
��
�7�Y�R�Y�{�%;�%;�;�<�<�F�
�
6�
6�
6��r�z�8�9�9�=�����/�/�/�6A�@�@��8�8�8�
��<�:�F�F�F�F�i8�i8�i8�i8�i8�T�i8�i8�i8�jB��!�G�+�����	���		�	�����"
��B�J�	�# � ��.I�I�I�I�I��I�I�I�X&�&�&�&�&�:�&�&�&�&�&r