U
��,a��@s�dZddddddddgZd d
lZd d
lZd d
lZd dlmZd dlmZe�Z e j
Ze jZd
d�Z
dZddd�Zddd�Zddd�Zd
S)z�Generate cryptographically strong pseudo-random numbers suitable for
managing secrets such as account authentication, tokens, and similar.
See PEP 506 for more information.
https://www.python.org/dev/peps/pep-0506/
�choice� randbelow�randbits�SystemRandom�token_bytes� token_hex�
token_urlsafe�compare_digest�N)r)rcCs|dkrtd��t�|�S)z(Return a random int in the range [0, n).r zUpper bound must be positive.)�
ValueError�_sysrandZ
_randbelow)Zexclusive_upper_bound�r�,/opt/alt/python38/lib64/python3.8/secrets.pyrs� cCs|dkrt}t�|�S)z�Return a random byte string containing *nbytes* bytes.
If *nbytes* is ``None`` or not supplied, a reasonable
default is used.
>>> token_bytes(16) #doctest:+SKIP
b'\xebr\x17D*t\xae\xd4\xe3S\xb6\xe2\xebP1\x8b'
N)�DEFAULT_ENTROPY�os�urandom��nbytesrrr
r#s
cCst�t|���d�S)a"Return a random text string, in hexadecimal.
The string has *nbytes* random bytes, each byte converted to two
hex digits. If *nbytes* is ``None`` or not supplied, a reasonable
default is used.
>>> token_hex(16) #doctest:+SKIP
'f9bf78b9a18ce6d46a0cd2b0b86df9da'
�ascii)�binasciiZhexlifyr�decoderrrr
r1scCst|�}t�|��d��d�S)z�Return a random URL-safe text string, in Base64 encoding.
The string has *nbytes* random bytes. If *nbytes* is ``None``
or not supplied, a reasonable default is used.
>>> token_urlsafe(16) #doctest:+SKIP
'Drmhze6EPcv0fN_81Bj-nA'
�=r)r�base64Zurlsafe_b64encode�rstripr)r�tokrrr
r>s
)N)N)N)�__doc__�__all__rrrZhmacrZrandomrrZgetrandbitsrrrrrrrrrrr
�<module>s&�
|