o
    `qiM                     @   s  d Z ddlZddlmZ ddlmZmZ ddlmZm	Z	m
Z
mZmZmZmZmZmZmZmZmZ ee	e
eeeeeeeeedZdZdd Zg d	d
edddfd	d
edddfdd
edddfddeddddfddedddfddeddd fd!d"ed#d$dd%fd&d'ed(dd)fd*d'ed+dd,fd-d.ed/d0dd1fd-d2ed3d4dd5fdd
ed6d7d8fdded9d7d:fdded;d7d<fd!d"ed=d7d>fd?d.ed@d7dAfd?dBedCd7dDfddedEdFdGfddedHdIdJfddedKdLdMfdedNedOdPdQfedRedSedTdPdUfddedVdPdWfd!d"edXdPdYfd*edZed[dPd\fd-ed]ed^dPd_fd-ed`edadPdbfdceddededfdgfdhediedjdfdkfdledmedndfdofdpeddedqdrdsfdtediedudrdvfdwedmedxdrdyfdzedded{d|d}fd~ediedd|dfdedmedd|dfdeddedddfdediedddfdtedmedddfaG dd dejZG dd dejZG dd dejZG dd dejZi fddZedkr	dd Z ej!dd dS dS )z$Self-test suite for Crypto.Hash.HMAC    N)hexlify)tostrtobytes)HMACMD5SHA1SHA256SHA224SHA384SHA512	RIPEMD160SHA3_224SHA3_256SHA3_384SHA3_512)r   r   r   r	   r
   r   r   r   r   r   r   c                 C   s   t tt| S N)r   r   r   )text r   e/home/app/PaddleOCR-VL/.venv_paddleocr/lib/python3.10/site-packages/Crypto/SelfTest/Hash/test_HMAC.pyxl-   s   r   Z 0b0b0b0b0b0b0b0b0b0b0b0b0b0b0b0bZ4869205468657265Z 9294727a3638bb1c13f48ef8158bfc9d)default_hashzdefault-is-MD5)r   zRFC 2202 #1-MD5 (HMAC-MD5)Z(0b0b0b0b0b0b0b0b0b0b0b0b0b0b0b0b0b0b0b0bZ(b617318655057264e28bc0b6fb378c8ef146be00)r   zRFC 2202 #1-SHA1 (HMAC-SHA1)Z4a656665Z87768617420646f2079612077616e7420666f72206e6f7468696e673fZ 750c783e6ab0b503eaa86e310a5db738Z(effcdf6ae5eb2fa2d27416d5f184df9c259a7c79)r   r   zRFC 2202 #2 (HMAC-MD5/SHA1)Z aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaZdddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddZ 56be34521d144c88dbb8c733f0e8b3f6zRFC 2202 #3-MD5 (HMAC-MD5)Z(aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaZ(125d7342b9ac11cd91a39af48aa17b4f63f175d3zRFC 2202 #3-SHA1 (HMAC-SHA1)Z20102030405060708090a0b0c0d0e0f10111213141516171819ZdcdcdcdcdcdcdcdcdcdcdcdcdcdcdcdcdcdcdcdcdcdcdcdcdcdcdcdcdcdcdcdcdcdcdcdcdcdcdcdcdcdcdcdcdcdcdcdcdcdcdZ 697eaf0aca3a3aea3a75164746ffaa79Z(4c9007f4026250c6bc8414f9bf50c86c2d7235dazRFC 2202 #4 (HMAC-MD5/SHA1)Z 0c0c0c0c0c0c0c0c0c0c0c0c0c0c0c0cZ(546573742057697468205472756e636174696f6eZ 56461ef2342edc00f9bab995690efd4czRFC 2202 #5-MD5 (HMAC-MD5)Z(0c0c0c0c0c0c0c0c0c0c0c0c0c0c0c0c0c0c0c0cZ(4c1a03424b55e07fe7f27be1d58bb9324a9a5a04zRFC 2202 #5-SHA1 (HMAC-SHA1)ZaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaZl54657374205573696e67204c6172676572205468616e20426c6f636b2d53697a65204b6579202d2048617368204b6579204669727374Z 6b1ab7fe4bd7bf8f0b62e6ce61b9d0cdZ(aa4ae5e15272d00e95705637ce8a3b55ed402112zRFC 2202 #6 (HMAC-MD5/SHA1)Z54657374205573696e67204c6172676572205468616e20426c6f636b2d53697a65204b657920616e64204c6172676572205468616e204f6e6520426c6f636b2d53697a652044617461Z 6f630fad67cda0ee1fb1f562db3aa53eZ(e8e99d0f45237d786d6bbaa7965c7808bbff1a91zRFC 2202 #7 (HMAC-MD5/SHA1)zc
            b0344c61d8db38535ca8afceaf0bf12b
            881dc200c9833da726e9376c2e32cff7
        )r   zRFC 4231 #1 (HMAC-SHA256)zc
            5bdcc146bf60754e6a042426089575c7
            5a003f089d2739839dec58b964ec3843
        zRFC 4231 #2 (HMAC-SHA256)zc
            773ea91e36800e46854db8ebd09181a7
            2959098b3ef8c122d9635514ced565fe
        zRFC 4231 #3 (HMAC-SHA256)zc
            82558a389a443c0ea4cc819899f2083a
            85f0faa3e578f8077a2e3ff46729665b
        zRFC 4231 #4 (HMAC-SHA256)A  aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaazc
            60e431591ee0b67f0d8a26aacbf5b77f
            8e0bc6213728c5140546040f0ee37f54
        zRFC 4231 #6 (HMAC-SHA256)A0  5468697320697320612074657374207573696e672061206c6172676572207468616e20626c6f636b2d73697a65206b657920616e642061206c6172676572207468616e20626c6f636b2d73697a6520646174612e20546865206b6579206e6565647320746f20626520686173686564206265666f7265206265696e6720757365642062792074686520484d414320616c676f726974686d2ezc
            9b09ffa71b942fcb27635fbcd5b0e944
            bfdc63644f0713938a7f51535c3a35e2
        zRFC 4231 #7 (HMAC-SHA256)Z8a30e01098bc6dbbf45690f3a7e9e6d0f8bbea2a39e6148008fd05e44)r	   z!RFC 4634 8.4 SHA224 (HMAC-SHA224)Z`af45d2e376484031617f78d2b58a6b1b9c7ef464f5a01b47e42ec3736322445e8e2240ca5e69e2c78b3239ecfab21649)r
   z!RFC 4634 8.4 SHA384 (HMAC-SHA384)Z164b7a7bfcf819e2e395fbe73b56e0a387bd64222e831fd610270cd7ea2505549758bf75c05a994a6d034f65f8f0e6fdcaeab1a34d4a6b4b636e070a38bce737)r   z!RFC 4634 8.4 SHA512 (HMAC-SHA512)zHi ThereZ(24cb4bd67d20fc1a5d2ed7732dcc39377f0a5668)r   zRFC 2286 #1 (HMAC-RIPEMD)ZJefezwhat do ya want for nothing?Z(dda6c0213a485a9e24f4742064a7f033b43c4069zRFC 2286 #2 (HMAC-RIPEMD)Z(b0b105360de759960ab4f35298e116e295d8e7c1zRFC 2286 #3 (HMAC-RIPEMD)Z(d5ca862f4d21d5e610e18b4cf1beb97a4365ecf4zRFC 2286 #4 (HMAC-RIPEMD)zTest With TruncationZ(7619693978f91d90539ae786500ff3d8e0518e39zRFC 2286 #5 (HMAC-RIPEMD)z6Test Using Larger Than Block-Size Key - Hash Key FirstZ(6466ca07ac5eac29e1bd523e5ada7605b791fd8bzRFC 2286 #6 (HMAC-RIPEMD)zITest Using Larger Than Block-Size Key and Larger Than One Block-Size DataZ(69ea60798d71616cce5fd0871e23754cd75d5a0azRFC 2286 #7 (HMAC-RIPEMD)Z8000102030405060708090a0b0c0d0e0f101112131415161718191a1bz"Sample message for keylen<blocklenZ8332cfd59347fdb8e576e77260be4aba2d6dc53117b3bfb52c6d18c04)r   zNIST CSRC Sample #1 (SHA3-224)A   000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a8b8c8d8e8fz"Sample message for keylen=blocklenZ8d8b733bcf66c644a12323d564e24dcf3fc75f231f3b67968359100c7zNIST CSRC Sample #2 (SHA3-224)AX  000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a8b8c8d8e8f909192939495969798999a9b9c9d9e9fa0a1a2a3a4a5a6a7a8a9aaabz"Sample message for keylen>blocklenZ8078695eecc227c636ad31d063a15dd05a7e819a66ec6d8de1e193e59zNIST CSRC Sample #3 (SHA3-224)Z@000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1fZ@4fe8e202c4f058e8dddc23d8c34e467343e23555e24fc2f025d598f558f67205)r   zNIST CSRC Sample #1 (SHA3-256)A  000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f8081828384858687Z@68b94e2e538a9be4103bebb5aa016d47961d4d1aa906061313b557f8af2c3faazNIST CSRC Sample #2 (SHA3-256)AP  000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a8b8c8d8e8f909192939495969798999a9b9c9d9e9fa0a1a2a3a4a5a6a7Z@9bcf2c238e235c3ce88404e813bd2f3a97185ac6f238c63d6229a00b07974258zNIST CSRC Sample #3 (SHA3-256)Z`000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2fZ`d588a3c51f3f2d906e8298c1199aa8ff6296218127f6b38a90b6afe2c5617725bc99987f79b22a557b6520db710b7f42)r   zNIST CSRC Sample #1 (SHA3-384)Z000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f6061626364656667Z`a27d24b592e8c8cbf6d4ce6fc5bf62d8fc98bf2d486640d9eb8099e24047837f5f3bffbe92dcce90b4ed5b1e7e44fa90zNIST CSRC Sample #2 (SHA3-384)A0  000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a8b8c8d8e8f9091929394959697Z`e5ae4c739f455279368ebf36d4f5354c95aa184c899d3870e460ebc288ef1f9470053f73f7c6da2a71bcaec38ce7d6aczNIST CSRC Sample #3 (SHA3-384)Z000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3fZ4efd629d6c71bf86162658f29943b1c308ce27cdfa6db0d9c3ce81763f9cbce5f7ebe9868031db1a8f8eb7b6b95e5c5e3f657a8996c86a2f6527e307f0213196)r   zNIST CSRC Sample #1 (SHA3-512)Z000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f4041424344454647Z544e257ea2a3e5ea19a590e6a24b724ce6327757723fe2751b75bf007d80f6b360744bf1b7a88ea585f9765b47911976d3191cf83c039f5ffab0d29cc9d9b6dazNIST CSRC Sample #2 (SHA3-512)Z5f464f5e5b7848e3885e49b2c385f0694985d0e38966242dc4a5fe3fea4b37d46b65ceced5dcf59438dd840bab22269f0ba7febdb9fcf74602a35666b2a32915zNIST CSRC Sample #3 (SHA3-512)c                   @   s(   e Zd ZdZdd Zdd Zdd ZdS )	HMAC_Module_and_Instance_TestzTest the HMAC construction and verify that it does not
    matter if you initialize it with a hash module or
    with an hash instance.

    See https://bugs.launchpad.net/pycrypto/+bug/1209399
    c                 C   s   t j|  || _d| _dS )zTInitialize the test with a dictionary of hash modules
        indexed by their names N)unittestTestCase__init__hashmodsdescription)selfr   r   r   r   r     s   
z&HMAC_Module_and_Instance_Test.__init__c                 C   s   | j S r   )r   )r   r   r   r   shortDescription  s   z.HMAC_Module_and_Instance_Test.shortDescriptionc                 C   sh   d}d}| j  D ](\}}|d u rq	d| | _t||| }t|||  }| || q	d S )Ns   sd                                                                                                       zTest HMAC in combination with )r   itemsr   r   newdigestassertEqual)r   keypayloadhashnameZhashmodonetwor   r   r   runTest  s   
z%HMAC_Module_and_Instance_Test.runTestN)__name__
__module____qualname____doc__r   r   r)   r   r   r   r   r     s
    r   c                   @      e Zd Zdd ZdS )	HMAC_Nonec                 C   s8   d}t |dt }t |d t }| || d S )Ns       )r   r!   r   r"   r#   )r   r$   r'   r(   r   r   r   r)     s   zHMAC_None.runTestNr*   r+   r,   r)   r   r   r   r   r/         r/   c                   @   r.   )ByteArrayTestsc                 C   s   d}d}t |}t |}t||}t||}d|d d< d|d d< | | |  t |}t |}t|}t|}|| || d|d d< | | |  d S )N   0000000000000000          )	bytearrayr   r!   r#   r"   update)r   r$   dataZkey_baZdata_bah1h2r   r   r   r)     s"   



zByteArrayTests.runTestNr1   r   r   r   r   r3     r2   r3   c                   @   r.   )MemoryViewTestsc           
      C   s   d}d}dd }dd }||fD ]Z}||}||}t ||}t ||}	|js5d|d d< d|d d< | | |	  ||}t |}t |}	|| |	| |js`d|d d< | | |	  qd S )	Nr4   r5   c                 S   s   t | S r   )
memoryviewr:   r   r   r   	get_mv_ro  s   z*MemoryViewTests.runTest.<locals>.get_mv_roc                 S   s   t t| S r   )r>   r8   r?   r   r   r   	get_mv_rw  s   z*MemoryViewTests.runTest.<locals>.get_mv_rwr6   r7   )r   r!   readonlyr#   r"   r9   )
r   r$   r:   r@   rA   Zget_mvZkey_mvZdata_mvr;   r<   r   r   r   r)     s,   



zMemoryViewTests.runTestNr1   r   r   r   r   r=     r2   r=   c                 C   s   dd l }ddlm} g }tD ]'}|d  D ]}t|}|d | |d< |tt | d || qq|t	d|}|t
t |t  |t  |t  |S )Nr   r7   )make_mac_tests   )	digestmodr   )typescommonrC   	test_datakeyslistappenddictglobalsr   r   hash_modulesr/   r3   r=   )configrF   rC   Zexp_test_datarowmodnamettestsr   r   r   	get_tests  s    rT   __main__c                   C   s   t t S r   )r   Z	TestSuiterT   r   r   r   r   <lambda>#  s    rV   suite)ZdefaultTest)"r-   r   binasciir   ZCrypto.Util.py3compatr   r   ZCrypto.Hashr   r   r   r   r	   r
   r   r   r   r   r   r   rL   rN   r   r   rH   r   r   r/   r3   r=   rT   r*   rW   mainr   r   r   r   <module>   s  8	"(/6<DNXbl{       "  )  /  5  ;  A  G  M  T  [	  i  {   	        #    +    7
    H    Q    [	    l 
&
