add-determinism 0.7.3

RPM buildroot helper to strip nondeterministic bits in files
Documentation
a

Z��^�c@stdZgd�ZddlZddlZddlmZddlmZe�Zej	Z
ejZdd�ZdZ
dd	d
�Zddd�Zdd
d�ZdS)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).rzUpper bound must be positive.)Z
ValueError�_sysrandZ
_randbelow)Zexclusive_upper_bound�r
�/usr/lib64/python3.9/secrets.pyrsri cCs|durt}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_ENTROPYr	Z	randbytes��nbytesr
r
rr"s
rcCst�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�decoder
r
r
rr0srcCst|�}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'

    s=r)r�base64Zurlsafe_b64encodeZrstripr)rZtokr
r
rr=s
r�Nrr)Z__doc__Z__all__rrZhmacrZrandomrr	Zgetrandbitsrrrrrrrr
r
r
rZ<module>s