HEX
Server: Apache
System: Linux zacp120.webway.host 4.18.0-553.50.1.lve.el8.x86_64 #1 SMP Thu Apr 17 19:10:24 UTC 2025 x86_64
User: govancoz (1003)
PHP: 8.3.26
Disabled: exec,system,passthru,shell_exec,proc_close,proc_open,dl,popen,show_source,posix_kill,posix_mkfifo,posix_getpwuid,posix_setpgid,posix_setsid,posix_setuid,posix_setgid,posix_seteuid,posix_setegid,posix_uname
Upload Files
File: //usr/local/lib/python3.10/__pycache__/crypt.cpython-310.pyc
o

�i�@s.dZddlZzddlZWney ejdkred��ed��wddlZddlZ	ddl
mZddl
mZe	je	jdZe�ZGd	d
�d
ed
d��Zd&dd�d
d�Zd&dd�ZgZdd�dd�Zedddd�edddd�dD]Zeddeddee�dd�r�nqqedd d!d"�ed#dd$d%�[[dS)'zEWrapper to the POSIX crypt library call and associated functionality.�N�win32z,The crypt module is not supported on Windowsz;The required _crypt module was not built as part of CPython)�SystemRandom)�
namedtuplez./c@seZdZdZdd�ZdS)�_MethodziClass representing a salt method per the Modular Crypt Format or the
    legacy 2-character crypt method.cCsd�|j�S)Nz<crypt.METHOD_{}>)�format�name)�self�r	�"/usr/local/lib/python3.10/crypt.py�__repr__sz_Method.__repr__N)�__name__�
__module__�__qualname__�__doc__rr	r	r	r
rsrz name ident salt_chars total_size��roundscCsH|durtd}|durt|t�st|jj�d���|js d}nd|j�d�}|jrd|jddkrd|dur8d}n#t�|d�}|d|>krItd	��d
|krVdks[td��td��||d
�d�7}n/|jdvr�|dur�d|krzdkstd��td��|d|�d�7}n|dur�t|�d���|d�	dd�t
|j�D��7}|S)zsGenerate a salt for the specified method.

    If not specified, the strongest available method will be used.

    Nrz+ object cannot be interpreted as an integer��$�2��zrounds must be a power of 2��z%rounds out of the range 2**4 to 2**31Z02d)�5�6i�i�ɚ;z+rounds out of the range 1000 to 999_999_999zrounds=z$ doesn't support the rounds argumentcss�|]}t�t�VqdS�N)�_sr�choice�
_saltchars)�.0�charr	r	r
�	<genexpr>Bs�zmksalt.<locals>.<genexpr>)�methods�
isinstance�int�	TypeError�	__class__r�ident�
bit_length�
ValueError�join�rangeZ
salt_chars)�methodr�sZ
log_roundsr	r	r
�mksalt s<�
��r.cCs&|dus	t|t�r
t|�}t�||�S)aRReturn a string representing the one-way hash of a password, with a salt
    prepended.

    If ``salt`` is not specified or is ``None``, the strongest
    available method will be selected and a salt generated.  Otherwise,
    ``salt`` may be one of the ``crypt.METHOD_*`` values, or a string as
    returned by ``crypt.mksalt()``.

    N)r#rr.�_crypt�crypt)Zword�saltr	r	r
r0Fs
r0c
Gs�t|g|�R�}|t�d|<t||d�}d}ztd|�}Wnty=}z|jtjtjtjhvr8WYd}~dS�d}~ww|rNt	|�|j
krNt�|�dSdS)NZMETHOD_rrFT)
r�globalsr.r0�OSError�errno�EINVAL�EPERMZENOSYS�lenZ
total_sizer"�append)rr�argsr,r1�result�er	r	r
�_add_methodXs ��
r<ZSHA512r��jZSHA256r�?)�b�y�arZBLOWFISHr��;ZMD5�1��"ZCRYPT��
r)r�sys�_sysr/�ModuleNotFoundError�platform�ImportErrorr4�string�_string�randomrZ
_SystemRandom�collectionsrZ_namedtuple�
ascii_letters�digitsrrrr.r0r"r<Z_vr7r	r	r	r
�<module>s:
�	
&�