
     h                     \    d Z ddlmZ ddlZddlmZmZmZ dgZd Z	d Z
dZ G d	 de      Zy)
a  
passlib.crypto._md4 -- fallback implementation of MD4

Helper implementing insecure and obsolete md4 algorithm.
used for NTHASH format, which is also insecure and broken,
since it's just md4(password).

Implementated based on rfc at http://www.faqs.org/rfcs/rfc1320.html

.. note::

    This shouldn't be imported directly, it's merely used conditionally
    by ``passlib.crypto.lookup_hash()`` when a native implementation can't be found.
    )hexlifyN)bascii_to_strirangePY3md4c                     | |z  |  |z  z  S N xyzs      U/var/www/html/Resume-Scraper/venv/lib/python3.12/site-packages/passlib/crypto/_md4.pyFr      s    aCaR1H    c                 $    | |z  | |z  z  ||z  z  S r	   r
   r   s      r   Gr   !   s    aCAaC=AaC  r   l    c                   ~   e Zd ZdZd ZdxZZdZdZdZ	dZ
d6dZg dg dg d	g d
g dg dg dg dg dg dg dg dg dg dg dg dgZg dg dg dg dg dg dg dg dg dg dg d g d!g d"g d#g d$g d%gZg dg d&g d'g d(g dg d)g dg d*g dg d+g d,g d-g d"g d.g d/g d0gZd1 Zd2 Zd3 Zd4 Zd5 Zy)7r   a  pep-247 compatible implementation of MD4 hash algorithm

    .. attribute:: digest_size

        size of md4 digest in bytes (16 bytes)

    .. method:: update

        update digest by appending additional content

    .. method:: copy

        create clone of digest object, including current state

    .. method:: digest

        return bytes representing md4 digest of current content

    .. method:: hexdigest

        return hexadecimal version of digest
       @   r   Nc                 Z    d| _         g d| _        d| _        |r| j                  |       y y )Nr   )i#Egl   +_ l   \u1 ivT2r   )_count_state_bufupdate)selfcontents     r   __init__zmd4.__init__N   s+    F	KK  r   )r            r   r!   )r!   r   r   r    r      )r    r!   r   r   r       )r   r    r!   r   r!      )r   r   r    r!      r!   )r!   r   r   r       r"   )r    r!   r   r      r#   )r   r    r!   r   r"   r$   )r   r   r    r!      r!   )r!   r   r   r    	   r"   )r    r!   r   r   
   r#   )r   r    r!   r   r#   r$   )r   r   r    r!      r!   )r!   r   r   r       r"   )r    r!   r   r      r#   )r   r    r!   r      r$   )r!   r   r   r    r%   r&   )r    r!   r   r   r(   r)   )r   r    r!   r   r+   r,   )r   r   r    r!   r   r!   )r!   r   r   r    r&   r&   )r    r!   r   r   r)   r)   )r   r    r!   r   r,   r,   )r   r   r    r!   r    r!   )r!   r   r   r    r'   r&   )r    r!   r   r   r*   r)   )r   r    r!   r   r-   r,   )r   r   r    r!   r!   r!   )r!   r   r   r    r"   r&   )r    r!   r   r   r#   r)   )r   r    r!   r   r.   r,   )r!   r   r   r    r(   r)   )r    r!   r   r   r%   r#   )r   r    r!   r   r+   r.   )r!   r   r   r    r*   r)   )r   r    r!   r   r-   r.   )r!   r   r   r    r)   r)   )r    r!   r   r   r&   r#   )r   r    r!   r   r,   r.   )r!   r   r   r    r#   r)   )r    r!   r   r   r"   r#   )r   r    r!   r   r.   r.   c                    t        j                  d|      }| j                  }t        |      }| j                  D ]J  \  }}}}}	}
||   t        ||   ||   ||         z   ||	   z   t        z  }||
z  t        z  |d|
z
  z	  z   ||<   L | j                  D ]M  \  }}}}}	}
||   t        ||   ||   ||         z   ||	   z   dz   t        z  }||
z  t        z  |d|
z
  z	  z   ||<   O | j                  D ]H  \  }}}}}	}
||   ||   ||   z  ||   z  z   ||	   z   dz   t        z  }||
z  t        z  |d|
z
  z	  z   ||<   J t        d      D ]  }||   ||   z   t        z  ||<    y)zprocess 64 byte blockz<16I    iyZinr%   N)structunpackr   list_round1r   MASK_32_round2r   _round3r   )r   blockXorigstateabcdkstis                r   _processzmd4._process   s    MM&%( {{T
  << 	8KAa!AaqAeAhuQxa99AaD@GKAA(QAY7E!H	8
  << 	8KAa!AaqAeAhuQxa99AaD@:MQXXAA(QAY7E!H	8
  << 	8KAa!AaqU1Xa058;<qtCjPT[[AA(QAY7E!H	8
  	3AAwuQx'72DG	3r   c                 ,   t        |t              s"t        rt        d      |j	                  d      }| j
                  }|r||z   }d}t        |      }	 |dz   }||k  r,| j                  |||        | xj                  dz  c_        |}n||d  | _        y B)Nzexpected bytesasciir   r   r   )	
isinstancebytesr   	TypeErrorencoder   lenrD   r   )r   r   bufidxendnexts         r   r   z
md4.update   s    '5) 011 "..1iiGmG'l8Ds{gc$/0q #CDM	 r   c                     t               }| j                  |_        t        | j                        |_        | j                  |_        |S r	   )r   r   r3   r   r   )r   others     r   copyzmd4.copy   s4    {{DKK(YY
r   c                    t        | j                        }| j                  }| j                  dz  t	        |      dz  z   }|dz   ddt	        |      z
  dz  z  z   t        j                  d|t        z  |dz	  t        z        z   }t	        |      d	k(  r)| j                  |d d        | j                  |dd         n!t	        |      dk(  sJ | j                  |       t        j                  d
g| j                   }|| _        |S )Ni   r(          w   r   z<2Ir0      z<4I)	r3   r   r   r   rK   r1   packr5   rD   )r   r:   rL   msglenr8   outs         r   digestz
md4.digest   s     DKK 
 iiS3s8A:-gCCLB+> ??KKv/&"*1GHIu:MM%*%MM%*%u:##MM%  kk%.$++.
r   c                 F    t        t        | j                                     S r	   )r   r   r[   )r   s    r   	hexdigestzmd4.hexdigest   s    WT[[]344r   r	   )__name__
__module____qualname____doc__namedigest_size
digestsize
block_sizer   r   r   r   r4   r6   r7   rD   r   rR   r[   r]   r
   r   r   r   r   ,   s    2 D!!K*JFFD! 	'G0 	'G0 	'G,38,05r   )ra   binasciir   r1   passlib.utils.compatr   r   r   __all__r   r   r5   objectr   r
   r   r   <module>rj      s>   &   ; ;'
! 
@5& @5r   