HEX
Server: LiteSpeed
System: Linux php-prod-1.spaceapp.ru 5.15.0-157-generic #167-Ubuntu SMP Wed Sep 17 21:35:53 UTC 2025 x86_64
User: sport3497 (1034)
PHP: 8.1.33
Disabled: NONE
Upload Files
File: //proc/thread-self/root/usr/lib/python3.10/__pycache__/base64.cpython-310.pyc
o

E�hnQ�@s�dZddlZddlZddlZgd�ZeefZdd�ZdQdd�Z	dRd	d
�Z
dd�Zd
d�Ze�
dd�Ze�
dd�Zdd�Zdd�ZdZdZdZdZdZiaiadd�ZdSdd�Zdd�Zejd d!�e_dSd"d#�Zejd ed$�e_d%d&�Zejd'd!�e_dTd(d)�Zejd'd*d$�e_d+d,�Z dTd-d.�Z!da"da#d/Z$d0Z%dUd1d2�Z&ddddd3�d4d5�Z'ddd6d7�d8d9�Z(d:Z)da*da+da,dTd;d<�Z-d=d>�Z.d?Z/e/d@dAZ0dBdC�Z1dDdE�Z2dFdG�Z3dHdI�Z4dJdK�Z5dLdM�Z6dNdO�Z7e8dPkr�e6�dSdS)VzDBase16, Base32, Base64 (RFC 3548), Base85 and Ascii85 data encodings�N)�encode�decode�encodebytes�decodebytes�	b64encode�	b64decode�	b32encode�	b32decode�b32hexencode�b32hexdecode�	b16encode�	b16decode�	b85encode�	b85decode�	a85encode�	a85decode�standard_b64encode�standard_b64decode�urlsafe_b64encode�urlsafe_b64decodecCslt|t�rz|�d�WStytd��wt|t�r|Szt|���WSty5td|j	j
�d�w)N�asciiz4string argument should contain only ASCII charactersz>argument should be a bytes-like object or ASCII string, not %r)�
isinstance�strr�UnicodeEncodeError�
ValueError�bytes_types�
memoryview�tobytes�	TypeError�	__class__�__name__��s�r#�/usr/lib/python3.10/base64.py�_bytes_from_decode_data"s"
�
���r%cCsDtj|dd�}|dur t|�dksJt|���|�t�d|��S|S)a*Encode the bytes-like object s using Base64 and return a bytes object.

    Optional altchars should be a byte string of length 2 which specifies an
    alternative alphabet for the '+' and '/' characters.  This allows an
    application to e.g. generate url or filesystem safe Base64 strings.
    F)�newlineN��+/)�binascii�
b2a_base64�len�repr�	translate�bytes�	maketrans)r"�altchars�encodedr#r#r$r3s
rFcCsft|�}|dur!t|�}t|�dksJt|���|�t�|d��}|r.t�d|�s.t�	d��t�
|�S)anDecode the Base64 encoded bytes-like object or ASCII string s.

    Optional altchars must be a bytes-like object or ASCII string of length 2
    which specifies the alternative alphabet used instead of the '+' and '/'
    characters.

    The result is returned as a bytes object.  A binascii.Error is raised if
    s is incorrectly padded.

    If validate is False (the default), characters that are neither in the
    normal base-64 alphabet nor the alternative alphabet are discarded prior
    to the padding check.  If validate is True, these non-alphabet characters
    in the input result in a binascii.Error.
    Nr'r(s[A-Za-z0-9+/]*={0,2}zNon-base64 digit found)r%r+r,r-r.r/�re�	fullmatchr)�Error�
a2b_base64)r"r0�validater#r#r$rAs

rcC�t|�S)zrEncode bytes-like object s using the standard Base64 alphabet.

    The result is returned as a bytes object.
    )rr!r#r#r$rZsrcCr7)aQDecode bytes encoded with the standard Base64 alphabet.

    Argument s is a bytes-like object or ASCII string to decode.  The result
    is returned as a bytes object.  A binascii.Error is raised if the input
    is incorrectly padded.  Characters that are not in the standard alphabet
    are discarded prior to the padding check.
    )rr!r#r#r$rasrr(s-_cCst|��t�S)z�Encode bytes using the URL- and filesystem-safe Base64 alphabet.

    Argument s is a bytes-like object to encode.  The result is returned as a
    bytes object.  The alphabet uses '-' instead of '+' and '_' instead of
    '/'.
    )rr-�_urlsafe_encode_translationr!r#r#r$rosrcCst|�}|�t�}t|�S)a�Decode bytes using the URL- and filesystem-safe Base64 alphabet.

    Argument s is a bytes-like object or ASCII string to decode.  The result
    is returned as a bytes object.  A binascii.Error is raised if the input
    is incorrectly padded.  Characters that are not in the URL-safe base-64
    alphabet, and are not a plus '+' or slash '/', are discarded prior to the
    padding check.

    The alphabet uses '-' instead of '+' and '_' instead of '/'.
    )r%r-�_urlsafe_decode_translationrr!r#r#r$rxs
rzK
Encode the bytes-like objects using {encoding} and return a bytes object.
a�
Decode the {encoding} encoded bytes-like object or ASCII string s.

Optional casefold is a flag specifying whether a lowercase alphabet is
acceptable as input.  For security purposes, the default is False.
{extra_args}
The result is returned as a bytes object.  A binascii.Error is raised if
the input is incorrectly padded or if there are non-alphabet
characters present in the input.
a�
RFC 3548 allows for optional mapping of the digit 0 (zero) to the
letter O (oh), and for optional mapping of the digit 1 (one) to
either the letter I (eye) or letter L (el).  The optional argument
map01 when not None, specifies which letter the digit 1 should be
mapped to (when map01 is not None, the digit 0 is always mapped to
the letter O).  For security purposes the default is None, so that
0 and 1 are not allowed in the input.
s ABCDEFGHIJKLMNOPQRSTUVWXYZ234567s 0123456789ABCDEFGHIJKLMNOPQRSTUVcsR|tvrdd�|D���fdd��D�t|<d�t|t�s#t|���}t|�d}|r3|dd|}t�}tj}t|}t	dt|�d�D]+}||||d�d�}|||d?||d	?d
@||d?d
@||d
@7}qE|dkrd
|dd�<t
|�S|dkr�d|dd�<t
|�S|dkr�d|dd�<t
|�S|dkr�d|dd�<t
|�S)NcS�g|]}t|f��qSr#�r.��.0�ir#r#r$�
<listcomp>��z_b32encode.<locals>.<listcomp>csg|]}�D]}||�qqSr#r#�r=�a�b��b32tabr#r$r?����r�big��i��
�s======i����r's====����s===�����=���)�_b32tab2rrrrr+�	bytearray�int�
from_bytes�ranger.)�alphabetr"�leftoverr1rW�b32tab2r>�cr#rDr$�
_b32encode�sB
��
����r]c	Cs�|tvrdd�t|�D�t|<t|�}t|�drt�d��|dur=t|�}t|�dks2Jt|���|�t�	dd|��}|rC|�
�}t|�}|�d�}|t|�}t�}t|}t
d	t|�d�D]1}|||d�}	d	}
z|	D]
}|
d
>||}
qpWn
ty�t�d�d�w||
�d
d�7}qa|ds�|d
vr�t�d��|r�|r�|
d
|K}
|
�d
d�}dd
|d}
|d|
�|dd�<t|�S)NcSsi|]\}}||�qSr#r#)r=�k�vr#r#r$�
<dictcomp>�r@z_b32decode.<locals>.<dictcomp>�zIncorrect paddingrMs01�OrRrrGzNon-base32 digit foundrI>rrMrOrQ��+���)�_b32rev�	enumerater%r+r)r4r,r-r.r/�upper�rstriprUrX�KeyError�to_bytes)rYr"�casefold�map01�l�padchars�decoded�b32revr>�quanta�accr\�lastrZr#r#r$�
_b32decode�sF

��
rucC�
tt|�S�N)r]�_b32alphabetr!r#r#r$r��
r�base32)�encodingcCstt|||�Srw)rurx)r"rlrmr#r#r$r	�sr	)r{�
extra_argscCrvrw)r]�_b32hexalphabetr!r#r#r$r
ryr
�	base32hexcCstt||�Srw)rur}�r"rlr#r#r$rsr�cCst�|���S)zKEncode the bytes-like object s using Base16 and return a bytes object.
    )r)�hexlifyrhr!r#r#r$rsrcCs4t|�}|r
|��}t�d|�rt�d��t�|�S)a�Decode the Base16 encoded bytes-like object or ASCII string s.

    Optional casefold is a flag specifying whether a lowercase alphabet is
    acceptable as input.  For security purposes, the default is False.

    The result is returned as a bytes object.  A binascii.Error is raised if
    s is incorrectly padded or if there are non-alphabet characters present
    in the input.
    s	[^0-9A-F]zNon-base16 digit found)r%rhr2�searchr)r4�	unhexlifyrr#r#r$r
s


r
s<~s~>c	s�t|t�st|���}t|�d}|r|d|}t�dt|�d��|�}����fdd�|D�}|rQ|sQ|ddkrF�dd	|d<|dd|�|d<d
�|�S)NrQrHz!%dIcsPg|]$}�r
|s
dn�r|dkrdn�|d�|dd�|d�qS)�zi    �yi�^	�Ui9r#)r=�word��chars�chars2�foldnuls�
foldspacesr#r$r?9s�
�
��z_85encode.<locals>.<listcomp>rSr�rrG�)	rrrrr+�struct�Struct�unpack�join)	rCr�r��padr�r��padding�words�chunksr#r�r$�	_85encode/s
�
r�)r��wrapcolr��adobecs�tdurdd�tdd�D�add�tD�at|tt|d|��|r$t���rUt|r+dnd	�����fd
d�tdt����D�}|rPt|d�d�krP|�d
�d�|��|r[�t	7��S)a�Encode bytes-like object b using Ascii85 and return a bytes object.

    foldspaces is an optional flag that uses the special short sequence 'y'
    instead of 4 consecutive spaces (ASCII 0x20) as supported by 'btoa'. This
    feature is not supported by the "standard" Adobe encoding.

    wrapcol controls whether the output should have newline (b'\n') characters
    added to it. If this is non-zero, each output line will be at most this
    many characters long.

    pad controls whether the input is padded to a multiple of 4 before
    encoding. Note that the btoa implementation always pads.

    adobe controls whether the encoded byte sequence is framed with <~ and ~>,
    which is used by the Adobe implementation.
    NcSr:r#r;r<r#r#r$r?\r@za85encode.<locals>.<listcomp>�!�vcS�g|]}tD]}||�qqSr#)�	_a85charsrAr#r#r$r?]rFTr'rMcsg|]
}�||���qSr#r#r<��resultr�r#r$r?es�rrSr��
)
�
_a85chars2rXr�r��	_A85START�maxr+�appendr��_A85END)rCr�r�r�r�r�r#r�r$rGs$�

rs 	

)r�r��ignorecharsc	Cszt|�}|r$|�t�std�t���|�t�r|dd�}n|dd�}t�d�j	}g}|j
}g}|j
}|j}	|dD]k}
d|
krGdkr|nn3||
�t|�d	kr{d
}|D]
}
d||
d}qWz|||��Wn
tj
ywtd�d�w|	�q;|
d
kr�|r�td��|d�q;|r�|
dkr�|r�td��|d�q;|
|vr�q;td|
��d�|�}dt|�}
|
r�|d|
�}|S)a�Decode the Ascii85 encoded bytes-like object or ASCII string b.

    foldspaces is a flag that specifies whether the 'y' short sequence should be
    accepted as shorthand for 4 consecutive spaces (ASCII 0x20). This feature is
    not supported by the "standard" Adobe encoding.

    adobe controls whether the input sequence is in Adobe Ascii85 format (i.e.
    is framed with <~ and ~>).

    ignorechars should be a byte string containing characters to ignore from the
    input. This should only contain whitespace characters, and by default
    contains all whitespace characters in ASCII.

    The result is returned as a bytes object.
    z1Ascii85 encoded byte sequences must end with {!r}r'���N�!Isuuuur��urGrr�zAscii85 overflow�zzz inside Ascii85 5-tuples�yzy inside Ascii85 5-tuples    zNon-Ascii85 digit found: %cr�rQ)r%�endswithr�r�format�
startswithr�r�r��packr��clearr+�errorr�)rCr�r�r��packIrp�decoded_append�curr�curr_append�
curr_clear�xrsr�r�r#r#r$rps\
�

��


rsU0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz!#$%&()*+-;<=>?@^_`{|}~cCs2tdurdd�tD�add�tD�at|tt|�S)z�Encode bytes-like object b in base85 format and return a bytes object.

    If pad is true, the input is padded with b'\0' so its length is a multiple of
    4 bytes before encoding.
    NcSr:r#r;r<r#r#r$r?�r@zb85encode.<locals>.<listcomp>cSr�r#)�	_b85charsrAr#r#r$r?�rF)�
_b85chars2�_b85alphabetr�r�)rCr�r#r#r$r�s	rc
	Cs8tdurdgdatt�D]\}}|t|<q
t|�}t|�d}|d|}g}t�d�j}tdt|�d�D]T}|||d�}d}z|D]
}|dt|}qFWn t	yrt|�D]\}}t|durpt
d||�d�q]�wz	|�||��Wq7tjy�t
d	|�d�wd
�
|�}	|r�|	d|�}	|	S)zqDecode the base85-encoded bytes-like object or ASCII string b

    The result is returned as a bytes object.
    N�rG�~r�rr�z#bad base85 character at position %dz+base85 overflow in hunk starting at byte %dr�)�_b85decrgr�r%r+r�r�r�rXrrr�r�r�)
rCr>r\r��outr��chunkrs�jr�r#r#r$r�sP

��������
r�LrQrOcCsb	|�t�}|s
dSt|�tkr&|�tt|��}|sn
||7}t|�tkst�|�}|�|�q)z1Encode a file; input and output are binary files.TN)�read�
MAXBINSIZEr+r)r*�write)�input�outputr"�ns�liner#r#r$r�s
�

�rcCs(	|��}|s	dSt�|�}|�|�q)z1Decode a file; input and output are binary files.TN)�readliner)r5r�)r�r�r�r"r#r#r$rs

�rc
Cs�zt|�}Wnty}zd|jj}t|�|�d}~ww|jdvr0d|j|jjf}t|��|jdkrBd|j|jjf}t|��dS)Nz"expected bytes-like object, not %s)r\rC�Bz-expected single byte elements, not %r from %srMz(expected 1-D data, not %d-D data from %s)rrrr r��ndim)r"�m�err�msgr#r#r$�_input_type_checks$
��
�
��r�cCsLt|�g}tdt|�t�D]}|||t�}|�t�|��qd�|�S)zVEncode a bytestring into a bytes object containing multiple lines
    of base-64 data.rr�)r�rXr+r�r�r)r*r�)r"�piecesr>r�r#r#r$r$s
rcCst|�t�|�S)z8Decode a bytestring of base-64 data into a bytes object.)r�r)r5r!r#r#r$r/s
rc	
Cs4ddl}ddl}z|�|jdd�d�\}}Wn)|jy@}z|j|_t|�td|jd�|�d�WYd}~nd}~wwt}|D] \}}|dkrOt}|dkrUt	}|d	kr[t	}|d
kret
�dSqE|r�|ddkr�t|dd��}|||jj�Wd�dS1s�wYdS||j
j|jj�dS)
zSmall main programrNrM�deutz�usage: %s [-d|-e|-u|-t] [file|-]
        -d, -u: decode
        -e: encode (default)
        -t: encode and decode string 'Aladdin:open sesame'r'z-ez-dz-uz-t�-�rb)�sys�getopt�argvr��stderr�stdout�print�exitrr�test�open�buffer�stdin)	r�r��opts�argsr��func�orB�fr#r#r$�main6s.���"�r�cCsHd}tt|��t|�}tt|��t|�}tt|��||ks"J�dS)NsAladdin:open sesame)r�r,rr)�s0�s1�s2r#r#r$r�Psr��__main__rw)NF)FN)F)FFF)9�__doc__r2r�r)�__all__r.rUrr%rrrrr/r8r9rr�_B32_ENCODE_DOCSTRING�_B32_DECODE_DOCSTRING�_B32_DECODE_MAP01_DOCSTRINGrxr}rTrfr]rurr�r	r
rrr
r�r�r�r�r�rrr�r�r�r�rr�MAXLINESIZEr�rrr�rrr�r�r r#r#r#r$�<module>s~

	
	
$/
�
�

)H
-	

�