
    ¿ig                     l   d dl Z d dlZd dlmZ d dlmZm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 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 d d	lm Z  d
 Z! G d de"          Z# G d dej$                  Z% G d dej$                  Z& G d dej$                  Z' G d dej$                  Z( G d dej$                  Z) G d dej$                  Z* G d dej$                  Z+d Z, G d dej$                  Z-d Z. e.e-           i fdZ/e0d k    rd! Z1 ej2        d"#           dS dS )$    N)	unhexlify)bbchr)list_test_cases)load_test_vectorsload_test_vectors_wycheproof)SHA1HMACSHA256MD5SHA224SHA384SHA512)AESDES3)PBKDF1PBKDF2_S2VHKDFscryptbcryptbcrypt_checkSP800_108_Counter)_bcrypt_decodec                     | d S |                      dd                               dd          }t          t          |                    S )N  
)replacer   r   )tt2s     a/var/www/html/afkarena/venv/lib/python3.11/site-packages/Cryptodome/SelfTest/Protocol/test_KDF.pyt2br#   )   sC    yt	
3			#	#D"	-	-BQrUU    c                       e Zd ZdS )
TestVectorN)__name__
__module____qualname__ r$   r"   r&   r&   0   s        Dr$   r&   c                       e Zd ZdZd ZdS )PBKDF1_Tests))password78578E5A5D63CB06   i   DC19847E05C64D2FAF10EBFB4A3D2A20c                     | j         d         }t          |d         t          |d                   |d         |d         t                    }|                     |t          |d                              d S )Nr               )	_testDatar   r#   r	   assertEqual)selfvress      r"   test1zPBKDF1_Tests.test1B   s_    N1QqT3qt99adAaD$77c!A$ii(((((r$   N)r'   r(   r)   r6   r;   r*   r$   r"   r,   r,   4   s*        I
) ) ) ) )r$   r,   c                       e Zd Zddddedfdddded	fdddd
edfddddedfddddedfddddedfddddedfddddedffZd Zd Zd Zd  Z	d!S )"PBKDF2_Testsr-   r.      i   0BFDE6BE94DF7E11DD409BCE20A0255EC327CB936FFE9364373616c74   r2   (0c60c80f961f0e71f3a9b524af6012062fe037a6r3   (ea6c014dc72d6f8ccd1ed92ace1d41f0d8de8957i   (4b007901b765489abead49d926f721d065a429c1passwordPASSWORDpasswordH73616c7453414c5473616c7453414c5473616c7453414c5473616c7453414c5473616c74   23d2eec4fe41c849b80c8d83662c0e44a8b291a964cf2f07038z	pass word
7361006c74r/    56fa6aa75548099dcc37d7f03425e0c3passwd@   ڀ55ac046e56e3089fec1691c22544b605f94185216dde0465e68b9d57c20dacbc49ca9cccf179b645991664b39d77ef317c71b845b1e30bd509112041d3a19783Password4e61436ci8 ڀ4ddcd8f60b98be21830cee5ef22701f9641a4418d04c0414aeff08876b34ab56a1d425a1225833549adb841b51c9b3176a272bdebba1d078478f62b397f33c8dc                    d }d }t          t          | j                            D ]}| j        |         }|d         }t          |d                   }|d         }|d         }|d         }	t          |d                   }
|	t          u rRt          ||||          }|                     ||
           t          |||||          }|                     ||
           t          |||||          }|                     ||
           d S )	Nc                 \    t          j        | |t                                                    S Nr
   newr	   digestpss     r"   prf_SHA1z$PBKDF2_Tests.test1.<locals>.prf_SHA1d   "    8Aa%%,,...r$   c                 \    t          j        | |t                                                    S rS   r
   rU   r   rV   rW   s     r"   
prf_SHA256z&PBKDF2_Tests.test1.<locals>.prf_SHA256g   s"    8Aa''..000r$   r   r2   r3   r4   r5      )rangelenr6   r#   r	   r   r7   )r8   rZ   r^   ir9   r-   saltout_lenitershash_modexpectedr:   s               r"   r;   zPBKDF2_Tests.test1a   s+   	/ 	/ 	/	1 	1 	1 s4>**++ 	0 	0Aq!AtHqt99DdGaDEtH1Q4yyH4XtWe<<  h///XtWeXFF  h////XtWeZHH  h////#	0 	0r$   c           
          d }|                      t          t          t          d          t          d          dd|t                     d S )Nc                 \    t          j        | |t                                                    S rS   rT   rW   s     r"   rZ   z$PBKDF2_Tests.test2.<locals>.prf_SHA1   r[   r$   xxxyyyr/   d   )prfhmac_hash_module)assertRaises
ValueErrorr   r   r	   )r8   rZ   s     r"   test2zPBKDF2_Tests.test2}   sW    	/ 	/ 	/ 	*fahh%"c& 	 	? 	? 	? 	? 	?r$   c           	         t          d          }t          d          }t          t          t          t          t
          t          fD ]Ct          ||ddfd          }t          ||dd          }|                     ||           Dd S )Nrj   rk   r/   rl   c                 T    t          j        | |                                          S rS   r
   rU   rV   )rX   rY   hashmods     r"   <lambda>z$PBKDF2_Tests.test3.<locals>.<lambda>   s!    $(1Qw*?*?*F*F*H*H r$   )rm   )rn   )	r   r   r	   r   r   r   r   r   r7   )r8   r-   rc   pr1pr2ru   s        @r"   test3zPBKDF2_Tests.test3   s     U88xxT6666B 	' 	'G4SHHHHJ J JC4S7KKKCS#&&&&	' 	'r$   c                    t          dt          d          dd          }t          t          d          t          d          dd          }|                     ||           t          t          d          ddd          }t          t          d          t          d          dd          }|                     ||           d S )Nrj   rk   r/   
   )r   r   r7   )r8   k1k2s      r"   test4zPBKDF2_Tests.test4   s    E1U88R,,AeHHahhB//R   AeHHeR,,AeHHahhB//R     r$   N)
r'   r(   r)   r	   r   r6   r;   rq   ry   r~   r*   r$   r"   r=   r=   H   s         *2d>pq
B>hi
B>hi
B>hi'(r$&>rt\"T>`a
B  AC  D*b%  AC  D
I0 0 08? ? ?' ' '! ! ! ! !r$   r=   c                   2    e Zd ZdddefdddefgZd Zd Zd	S )
	S2V_Tests)0101112131415161718191a1b1c1d1e1f2021222324252627112233445566778899aabbccddee fffefdfcfbfaf9f8f7f6f5f4f3f2f1f0 85632d07c6e8f37f950acd320a2ecc93)P00112233445566778899aabbccddeeffdeaddadadeaddadaffeeddccbbaa99887766554433221100102030405060708090a0 09f911029d74e35bd84156c5635688c0^7468697320697320736f6d6520706c61696e7465787420746f20656e6372797074207573696e67205349562d414553 7f7e7d7c7b7a79787776757473727170 7bdb6e3b432667eb06f4d14bff2fbd0fc                 J   | j         D ]}t          j        t          |d                   |d                   }|d         D ]$}|                    t          |                     %|                                }|                     |t          |d                              dS )z!Verify correctness of test vectorr2   r4   r   r3   N)r6   r   rU   r#   updatederiver7   )r8   tvs2vrY   results        r"   r;   zS2V_Tests.test1   s    . 	1 	1B(3r!u::r!u--CU # #

3q66""""ZZ\\FVSAZZ0000	1 	1r$   c                 z   t          d          dz  t          d          dz  z   }t          t          fD ]}t          j        ||          }|j        dz  dz
  }t          |          D ]$}|                    t          d                     %| 	                    t          |j        t          d                     dS )zOVerify that no more than 127(AES) and 63(TDES)
        components are accepted.r         r2   XXYYN)r   r   r   r   rU   
block_sizer`   r   r   ro   	TypeError)r8   keymoduler   	max_compsrb   s         r"   rq   zS2V_Tests.test2   s     1ggkDIIM)Dk 	> 	>F(3''C)!+A-I9%% $ $

1T77####iQtWW====	> 	>r$   N)r'   r(   r)   r   r6   r;   rq   r*   r$   r"   r   r      sa        1..2 /.
I61 1 1	> 	> 	> 	> 	>r$   r   c                       e Zd Zedddddfedddd	d
fedddddfedddddfedddd	dfedddddfedddddffZd Zd ZdS )
HKDF_Tests,0b0b0b0b0b0b0b0b0b0b0b0b0b0b0b0b0b0b0b0b0b0b000102030405060708090a0b0cf0f1f2f3f4f5f6f7f8f9*   T3cb25f25faacd57a90434f64d0362f2a2d2d0a90cf1a5a4c5db02d56ecc4c5bf34007208d5b887185865ڠ000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4fڠ606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a8b8c8d8e8f909192939495969798999a9b9c9d9e9fa0a1a2a3a4a5a6a7a8a9aaabacadaeafڠb0b1b2b3b4b5b6b7b8b9babbbcbdbebfc0c1c2c3c4c5c6c7c8c9cacbcccdcecfd0d1d2d3d4d5d6d7d8d9dadbdcdddedfe0e1e2e3e4e5e6e7e8e9eaebecedeeeff0f1f2f3f4f5f6f7f8f9fafbfcfdfeffR   ڤb11e398dc80327a1c8e7f78c596a49344f012eda2d4efad8a050cc4c19afa97c59045a99cac7827271cb41c65e590e09da3275600c2f09b8367793a9aca3db71cc30c58179ec3e87c14c01d5c1f3434f1d87NT8da4e775a563c18f715f802a063c5a31b8a11f5c5ee1879ec3454e5f3c738d2d9d201395faa4b61a96c80b0b0b0b0b0b0b0b0b0b0bT085a01ea1b10f36933068b56efa5ad81a4f14b822f5b091568a9cdd4f155fda2c22e422478d305f3f896ڤ0bd770a74d1160f7c9f12cd5912a06ebff6adcae899d92191fe4305673ba2ffe8fa3f1a4e5ad79f3f334b3b202b2173c486ea37ce3d397ed034c7f9dfeb15c5e927336d0441f4c4300e2cff0d0900b52d3b4r   T0ac1af7002b3d761d1e55298da9d0506b9ae52057220a306e07b6b87e8df21d0ea00033de03984d34918,0c0c0c0c0c0c0c0c0c0c0c0c0c0c0c0c0c0c0c0c0c0cT2c91117204d745f3500d636a62f64f0ab3bae548aa53d423b0d1f27ebba6f5e5673a081d70cce7acfc48c           	          | j         D ]PfddD             \  }}}}fddD             \  }}t          ||||d|          }|                     ||           Qd S )Nc                 :    g | ]}t          |                   S r*   )r#   .0xr   s     r"   
<listcomp>z$HKDF_Tests.test1.<locals>.<listcomp>I  s#    &G&G&GqBqE

&G&G&Gr$   )r2   r3   r4   r_   c                      g | ]
}|         S r*   r*   r   s     r"   r   z$HKDF_Tests.test1.<locals>.<listcomp>J  s    7771A777r$   )r5   r   r2   )_test_vectorr   r7   )	r8   secretrc   infoexpkey_lenru   outputr   s	           @r"   r;   zHKDF_Tests.test1G  s    # 	* 	*B&G&G&G&GI&G&G&G#FD$7777777GW&'4!TBBFVS))))	* 	*r$   c                    t          t          d          dt          d          t                    }t          t          d          dt          d          t          d          \  }}|                     |d d         |dd          f||f           t          t          d          dt          d          t          d          \  }}}|                     |d d         |dd         |dd          f|||f           d S )	NXXXXXX   YYYY   r3   r5   r4   r   )r   r   r	   r7   r8   refkey1key2key3s        r"   rq   zHKDF_Tests.test2O  s    1X;;AfIIt44 !H++q!F))T1==
d#bqb'3qrr7+dD\:::  (Q&		4CCdD#bqb'3qs8SW5dD7IJJJJJr$   )r'   r(   r)   r   r	   r   r;   rq   r*   r$   r"   r   r      s        >,&'	 3
3
3
 %4 >'	 (,&'	 3
3
3
 %4 >'	 >'	we
LN* * *	K 	K 	K 	K 	Kr$   r   c                   $    e Zd ZdZd Zd Zd ZdS )scrypt_Tests))r   r   r/   r2   r2   a%  
                    77 d6 57 62 38 65 7b 20 3b 19 ca 42 c1 8a 04 97
                    f1 6b 48 44 e3 07 4a e8 df df fa 3f ed e2 14 42
                    fc d0 06 9d ed 09 48 f8 32 6a 75 3a 0f c8 1f 17
                    e8 d3 e0 fb 2e 0d 36 28 cf 35 e2 0c 38 d1 89 06
                    )r-   NaCli   r   r/   a%  
                    fd ba be 1c 9d 34 72 00 78 56 e7 19 0d 01 e9 fe
                    7c 6a d7 cb c8 23 78 30 e7 73 76 63 4b 37 31 62
                    2e af 30 d9 2e 22 a3 88 6f f1 09 27 9d 98 30 da
                    c7 27 af b9 4a 83 ee 6d 83 60 cb df a2 cc 06 40
                    )pleaseletmeinSodiumChloridei @  r   r2   a%  
                    70 23 bd cb 3a fd 73 48 46 1c 06 cd 81 fd 38 eb
                    fd a8 fb ba 90 4f 8e 3e a9 b5 43 f6 54 5d a1 f2
                    d5 43 29 55 61 3f 0f cf 62 d4 97 05 24 2a 9a f9
                    e6 1e 85 dc 0d 65 1e 40 df cf 01 7b 45 57 58 87
                    )r   r      r   r2   a%  
                    21 01 cb 9b 6a 51 1a ae ad db be 09 cf 70 f8 81
                    ec 56 8d 57 4a 2f fd 4d ab e5 ee 98 20 ad aa 47
                    8e 56 fd 8f 4b a5 d0 9f fa 1c 6d 92 7c 40 f4 c3
                    37 30 40 49 e8 a9 52 fb cb f4 5c 6f a7 7a 41 a4
                    c                    g }| j         D ]}t                      }t          |d                   |_        t          |d                   |_        |d         |_        |d         |_        |d         |_        t          |d                   |_	        t          |j	                  |_        |                    |           || _         d S )Nr   r2   r3   r4   r5   r_   )datar&   r   PSNrrX   r#   r   ra   dkLenappend)r8   new_test_vectorsr   new_tvs       r"   setUpzscrypt_Tests.setUp  s    ) 		, 		,B\\FAxxFHAxxFH!uFH!uFH!uFH1JJFMv}--FL##F++++$			r$   c           	      `   | j         D ]}	 t          |j        |j        |j        |j        |j        |j                  }nT# t          $ rG}dt          |          v r/|j        dk    r$dd l
}|                    dt                     Y d }~|d }~ww xY w|                     ||j                   d S )Nz 2 r   r   z6Not enough memory to unit test scrypt() with N=1048576)r   r   r   r   r   r   r   rX   rp   strwarningswarnRuntimeWarningr7   r   )r8   r   r   er   s        r"   rq   zscrypt_Tests.test2  s    ) 
	0 
	0BbdBHbdBD"$GG   CFF??rtw#OOOMM"Z\jkkkHHHHG VRY////
	0 
	0s   2>
B;B
B

Bc           	         t          t          d          t          d          dddd          }t          t          d          t          d          ddddd          \  }}|                     |d d         |dd          f||f           t          t          d          t          d          ddddd	          \  }}}|                     |d d         |dd
         |d
d          f|||f           d S )Nr-   rc   r   r/   r2   r   r3   r5   r4   r   )r   r   r7   r   s        r"   ry   zscrypt_Tests.test3  s    Qz]]AfIIr2q!<< AjMM1V99aQ1EE
d#bqb'3qrr7+dD\::: "!J--6Ar1aKKdD#bqb'3qs8SW5dD7IJJJJJr$   N)r'   r(   r)   r   r   rq   ry   r*   r$   r"   r   r   [  sN        5Dn% % %0 0 0	K 	K 	K 	K 	Kr$   r   c                   P    e Zd Zd Zd Zd Zd Zd Zd Zd Z	d Z
d	 Zd
 Zd ZdS )bcrypt_Testsc                    |                      t          t          dd           |                      t          t          dd           |                      t          t          dd           |                      t          t          ddd           |                      t          t          ddd	           |                      t          t          ddd
           |                      t          t          dd           d S )NsI   1111111111111111111111111111111111111111111111111111111111111111111111111r{   s
   1111111111r4       r5   r$   rc      1s   11111111111111111s   1 1 1 1 1 1 1 1 1 1 )ro   rp   r   r8   s    r"   test_negative_casesz bcrypt_Tests.test_negative_cases  s    *fi<<<*fi;;;*fi<<<*fiEEE*fiFFF*fiKKK*fmQ?????r$   c                 l   t          dd          }t          d|           t          |          }t          d|           |d d         t          |d         dz            z   }|                     t
          t          d|           d|dd          z   }|                     t
          t          d|           d S )Npwdr5   r2      x)r   r   	bytearrayr   ro   rp   )r8   r   brefwrongs       r"   test_bytearray_mismatchz$bcrypt_Tests.test_bytearray_mismatch  s    UAUC   ~~UD!!!CRC4R4000*lE5AAAs122w*lE5AAAAAr$   c                     g d}t          |          D ]O\  }\  }}}}t          ||t          |                    }|                     ||           t	          ||           Pd S )N))r$   r5      zVHmKQtGGQob.b/Nc7l9NOs<   $2a$04$zVHmKQtGGQob.b/Nc7l9NO8UlrYcW05FiuCj/SxsFO/ZtiN9.mNzy)r$   r_   r   s<   $2a$05$zVHmKQtGGQob.b/Nc7l9NOWES.1hkVBgy5IWImh9DOjKNU8atY4Iy)r$   r   r   s<   $2a$06$zVHmKQtGGQob.b/Nc7l9NOjOl7l4oz3WSh5fJ6414Uw8IXRAUoiaO)r$      r   s<   $2a$07$zVHmKQtGGQob.b/Nc7l9NOBsj1dQpBA1HYNGpIETIByoNX9jc.hOi)r$   r   r   s<   $2a$08$zVHmKQtGGQob.b/Nc7l9NOiLTUh/9MDpX86/DLyEzyiFjqjBFePgOr   	enumerater   r   r7   r   r8   tvsidxr-   costsalt64r   r   s           r"   test_empty_passwordz bcrypt_Tests.test_empty_password  s    
 
 
 8A~~ 	+ 	+3S28T66xN6,B,BCCCAQ'''6****	+ 	+r$   c                     g d}t          |          D ]O\  }\  }}}}t          ||t          |                    }|                     ||           t	          ||           Pd S )N))s
   <.S.2K(Zq'r5   s   VYAclAMpaXY/oqAo9yUpkus<   $2a$04$VYAclAMpaXY/oqAo9yUpkuWmoYywaPzyhu56HxXpVltnBIfmO9tgu)s
   5.rApO%5jAr_   s   kVNDrnYKvbNr5AIcxNzeIus<   $2a$05$kVNDrnYKvbNr5AIcxNzeIuRcyIF5cZk6UrwHGxENbxP5dVv.WQM/G)s
   oW++kSrQW^r   s   QLKkRMH9Am6irtPeSKN5sOs<   $2a$06$QLKkRMH9Am6irtPeSKN5sObJGr3j47cO6Pdf5JZ0AsJXuze0IbsNm)s
   ggJ\KbTnDGr   s   4H896R09bzjhapgCPS/LYus<   $2a$07$4H896R09bzjhapgCPS/LYuMzAQluVgR5iu/ALF8L8Aln6lzzYXwbq)s
   49b0:;VkH/r   s   hfvO2retKrSrx5f2RXikWes<   $2a$08$hfvO2retKrSrx5f2RXikWeFWdtSesPlbj08t/uXxCeZoHRWDz/xFe)s
   >9N^5jc##'	   s   XZLvl7rMB3EvM0c1.JHivus<   $2a$09$XZLvl7rMB3EvM0c1.JHivuIDPJWeNJPTVrpjZIEVRYYB/mF6cYgJK)s
   \$ch)s4WXpr{   s   aIjpMOLK5qiS9zjhcHR5TOs<   $2a$10$aIjpMOLK5qiS9zjhcHR5TOU7v2NFDmcsBmSFDt5EHOgp/jeTF3O/q)s
   RYoj\_>2P7r   s   esIAHiQAJNNBrsr5V13l7.s<   $2a$12$esIAHiQAJNNBrsr5V13l7.RFWWJI2BZFtQlkFyiWXjou05GyuREZar   r   r   s           r"   &test_random_password_and_salt_short_pwz3bcrypt_Tests.test_random_password_and_salt_short_pw      	
 	
 	
 8A~~ 	+ 	+3S28T66xN6,B,BCCCAQ'''6****	+ 	+r$   c                     g d}t          |          D ]O\  }\  }}}}t          ||t          |                    }|                     ||           t	          ||           Pd S )N))s   ^Q&"]A`%/A(BVGt>QaX0M-#<Q148&fr5   s   vrRP5vQxyD4LrqiLd/oWROs<   $2a$04$vrRP5vQxyD4LrqiLd/oWROgrrGINsw3gb4Ga5x2sn01jNmiLVECl6)s   nZa!rRf\U;OL;R?>1ghq_+":Y0CRmYr_   s   YuQvhokOGVnevctykUYpKus<   $2a$05$YuQvhokOGVnevctykUYpKutZD2pWeGGYn3auyLOasguMY3/0BbIyq)s   F%uN/j>[GuB7-jB'_Yj!Tnb7Y!u^6)r   s   5L3vpQ0tG9O7k5gQ8nAHAes<   $2a$06$5L3vpQ0tG9O7k5gQ8nAHAe9xxQiOcOLh8LGcI0PLWhIznsDt.S.C6)s   Z>BobP32ub"Cfe*Q<<WUq3rc=[GJr-r   s   hp8IdLueqE6qFh1zYycUZ.s<   $2a$07$hp8IdLueqE6qFh1zYycUZ.twmUH8eSTPQAEpdNXKMlwms9XfKqfea)s   Ik&8N['7*[1aCc1lOm8\jWeD*H$eZMr   s   2ANDTYCB9m7vf0Prh7rSrus<   $2a$08$2ANDTYCB9m7vf0Prh7rSrupqpO3jJOkIz2oW/QHB4lCmK7qMytGV6)s   O)=%3[E$*q+>-q-=tRSjOBh8\mLNW.r   s   nArqOfdCsD9kIbVnAixnwes<   $2a$09$nArqOfdCsD9kIbVnAixnwe6s8QvyPYWtQBpEXKir2OJF9/oNBsEFe)s   /MH51`!BP&0tj3%YCA;Xk%e3S`o\EIr{   s   ePiAc.s.yoBi3B6p1iQUCes<   $2a$10$ePiAc.s.yoBi3B6p1iQUCezn3mraLwpVJ5XGelVyYFKyp5FZn/y.u)s   ptAP"mcg6oH.";c0U2_oll.OKi<!kur   s   aroG/pwwPj1tU5fl9a9pkOs<   $2a$12$aroG/pwwPj1tU5fl9a9pkO4rydAmkXRj/LqfHZOSnR6LGAZ.z.jwar   r   r   s           r"   %test_random_password_and_salt_long_pwz2bcrypt_Tests.test_random_password_and_salt_long_pw  r   r$   c                     g d}t          |          D ]O\  }\  }}}}t          ||t          |                    }|                     ||           t	          ||           Pd S )N))   Q/A:k3DP;X@=<0"hg&9cr5   s   wbgDTvLMtyjQlNK7fjqwyOs<   $2a$04$wbgDTvLMtyjQlNK7fjqwyOakBoACQuYh11.VsKNarF4xUIOBWgD6S)r   r_   s   zbAaOmloOhxiKItjznRqrus<   $2a$05$zbAaOmloOhxiKItjznRqrunRqHlu3MAa7pMGv26Rr3WwyfGcwoRm6)r   r   s   aOK0bWUvLI0qLkc3ti5jyus<   $2a$06$aOK0bWUvLI0qLkc3ti5jyuAIQoqRzuqoK09kQqQ6Ou/YKDhW50/qar   r   r   s           r"   "test_same_password_and_random_saltz/bcrypt_Tests.test_same_password_and_random_salt  s    
 
 
 8A~~ 	+ 	+3S28T66xN6,B,BCCCAQ'''6****	+ 	+r$   c                     g d}t          |          D ]O\  }\  }}}}t          ||t          |                    }|                     ||           t	          ||           Pd S )N))   o<&+X'F4AQ8H,LU,N`&rr5      BK5u.QHk1Driey7bvnFTH.s<   $2a$04$BK5u.QHk1Driey7bvnFTH.3smGwxd91PtoK2GxH5nZ7pcBsYX4lMq)r  r_   r  s<   $2a$05$BK5u.QHk1Driey7bvnFTH.t5P.jZvFBMzDB1IY4PwkkRPOyVbEtFG)r  r   r  s<   $2a$06$BK5u.QHk1Driey7bvnFTH.6Ea1Z5db2p25CPXZbxb/3OyKQagg3pa)r  r   r  s<   $2a$07$BK5u.QHk1Driey7bvnFTH.sruuQi8Lhv/0LWKDvNp3AGFk7ltdkm6)r  r   r  s<   $2a$08$BK5u.QHk1Driey7bvnFTH.IE7KsaUzc4m7gzAMlyUPUeiYyACWe0q)r  r   r  s<   $2a$09$BK5u.QHk1Driey7bvnFTH.1v4Xj1dwkp44QNg0cVAoQt4FQMMrvnS)r  r{   r  s<   $2a$10$BK5u.QHk1Driey7bvnFTH.ESINe9YntUMcVgFDfkC.Vbhc9vMhNX2)r  r   r  s<   $2a$12$BK5u.QHk1Driey7bvnFTH.QM1/nnGe/f5cTzb6XTTi/vMzcAnycqGr   r   r   s           r"   2test_same_password_and_salt_increasing_cost_factorz?bcrypt_Tests.test_same_password_and_salt_increasing_cost_factor  r   r$   c                     g d}t          |          D ]O\  }\  }}}}t          ||t          |                    }|                     ||           t	          ||           Pd S )N))sF   g*3Q45="8NNgpT&mbMJ$Omfr.#ZeW?FP=CE$#roHd?97uL0F-]`?u73c"\[."*)qU34@VGr5   s   T2XJ5MOWvHQZRijl8LIKkOs<   $2a$04$T2XJ5MOWvHQZRijl8LIKkOQKIyX75KBfuLsuRYOJz5OjwBNF2lM8a)sF   \M+*8;&QE=Ll[>5?Ui"^ai#iQH7ZFtNMfs3AROnIncE9"BNNoEgO[[*Yk8;RQ(#S,;I+aTr_   s   wgkOlGNXIVE2fWkT3gyRoOs<   $2a$05$wgkOlGNXIVE2fWkT3gyRoOqWi4gbi1Wv2Q2Jx3xVs3apl1w.Wtj8C)sF   M.E1=dt<.L0Q&p;94NfGm_Oo23+Kpl@M5?WIAL.[@/:'S)W96G8N^AWb7_smmC]>7#fGoBr   s   W9zTCl35nEvUukhhFzkKMes<   $2a$06$W9zTCl35nEvUukhhFzkKMekjT9/pj7M0lihRVEZrX3m8/SBNZRX7ir   r   r   s           r"   test_long_passwordsz bcrypt_Tests.test_long_passwords.  s    
 
 
 8A~~ 	+ 	+3S28T66xN6,B,BCCCAQ'''6****	+ 	+r$   c                     g d}t          |          D ]O\  }\  }}}}t          ||t          |                    }|                     ||           t	          ||           Pd S )N))   ar5      5DCebwootqWMCp59ISrMJ.s<   $2a$04$5DCebwootqWMCp59ISrMJ.l4WvgHIVg17ZawDIrDM2IjlE64GDNQS)s   aar5   r	  s<   $2a$04$5DCebwootqWMCp59ISrMJ.AyUxBk.ThHlsLvRTH7IqcG7yVHJ3SXq)s   aaar5   r	  s<   $2a$04$5DCebwootqWMCp59ISrMJ.BxOVac5xPB6XFdRc/ZrzM9FgZkqmvbW)s   aaaar5   r	  s<   $2a$04$5DCebwootqWMCp59ISrMJ.Qbr209bpCtfl5hN7UQlG/L4xiD3AKau)s   aaaaar5   r	  s<   $2a$04$5DCebwootqWMCp59ISrMJ.oWszihPjDZI0ypReKsaDOW1jBl7oOii)s   aaaaaar5   r	  s<   $2a$04$5DCebwootqWMCp59ISrMJ./k.Xxn9YiqtV/sxh3EHbnOHd0Qsq27K)s   aaaaaaar5   r	  s<   $2a$04$5DCebwootqWMCp59ISrMJ.PYJqRFQbgRbIjMd5VNKmdKS4sBVOyDe)s   aaaaaaaar5   r	  s<   $2a$04$5DCebwootqWMCp59ISrMJ..VMYfzaw1wP/SGxowpLeGf13fxCCt.q)s	   aaaaaaaaar5   r	  s<   $2a$04$5DCebwootqWMCp59ISrMJ.5B0p054nO5WgAD1n04XslDY/bqY9RJi)s
   aaaaaaaaaar5   r	  s<   $2a$04$5DCebwootqWMCp59ISrMJ.INBTgqm7sdlBJDg.J5mLMSRK25ri04y)s   aaaaaaaaaaar5   r	  s<   $2a$04$5DCebwootqWMCp59ISrMJ.s3y7CdFD0OR5p6rsZw/eZ.Dla40KLfm)s   aaaaaaaaaaaar5   r	  s<   $2a$04$5DCebwootqWMCp59ISrMJ.Jx742Djra6Q7PqJWnTAS.85c28g.Siq)s   aaaaaaaaaaaaar5   r	  s<   $2a$04$5DCebwootqWMCp59ISrMJ.oKMXW3EZcPHcUV0ib5vDBnh9HojXnLu)s   aaaaaaaaaaaaaar5   r	  s<   $2a$04$5DCebwootqWMCp59ISrMJ.w6nIjWpDPNSH5pZUvLjC1q25ONEQpeS)s   aaaaaaaaaaaaaaar5   r	  s<   $2a$04$5DCebwootqWMCp59ISrMJ.k1b2/r9A/hxdwKEKurg6OCn4MwMdiGq)s   aaaaaaaaaaaaaaaar5   r	  s<   $2a$04$5DCebwootqWMCp59ISrMJ.3prCNHVX1Ws.7Hm2bJxFUnQOX9f7DFar   r   r   s           r"   test_increasing_password_lengthz,bcrypt_Tests.test_increasing_password_length>  s    
 
 
& 8A~~ 	+ 	+3S28T66xN6,B,BCCCAQ'''6****	+ 	+r$   c                     g d}t          |          D ]O\  }\  }}}}t          ||t          |                    }|                     ||           t	          ||           Pd S )N))0   àèìòùÀÈÌÒÙáéíóúýÁÉÍÓÚÝðÐr5   s   D3qS2aoTVyqM7z8v8crLm.s<   $2a$04$D3qS2aoTVyqM7z8v8crLm.3nKt4CzBZJbyFB.ZebmfCvRw7BGs.Xm)r  r_   s   VA1FujiOCMPkUHQ8kF7IaOs<   $2a$05$VA1FujiOCMPkUHQ8kF7IaOg7NGaNvpxwWzSluQutxEVmbZItRTsAa)r  r   s   TXiaNrPeBSz5ugiQlehRt.s<   $2a$06$TXiaNrPeBSz5ugiQlehRt.gwpeDQnXWteQL4z2FulouBr6G7D9KUi),   âêîôûÂÊÎÔÛãñõÃÑÕäëïöüÿr5   s   YTn1Qlvps8e1odqMn6G5x.s<   $2a$04$YTn1Qlvps8e1odqMn6G5x.85pqKql6w773EZJAExk7/BatYAI4tyO)r  r_   s   C.8k5vJKD2NtfrRI9o17DOs<   $2a$05$C.8k5vJKD2NtfrRI9o17DOfIW0XnwItA529vJnh2jzYTb1QdoY0py)r  r   s   xqfRPj3RYAgwurrhcA6uROs<   $2a$06$xqfRPj3RYAgwurrhcA6uROtGlXDp/U6/gkoDYHwlubtcVcNft5.vW)+   ÄËÏÖÜŸåÅæÆœŒßçÇøØ¢¿¡€r5   s   y8vGgMmr9EdyxP9rmMKjH.s<   $2a$04$y8vGgMmr9EdyxP9rmMKjH.wv2y3r7yRD79gykQtmb3N3zrwjKsyay)r  r_   s   iYH4XIKAOOm/xPQs7xKP1us<   $2a$05$iYH4XIKAOOm/xPQs7xKP1upD0cWyMn3Jf0ZWiizXbEkVpS41K1dcO)r  r   s   wCOob.D0VV8twafNDB2apes<   $2a$06$wCOob.D0VV8twafNDB2apegiGD5nqF6Y1e6K95q6Y.R8C4QGd265q)u8   ΔημοσιεύθηκεστηνΕφημερίδατηςr5   s   E5SQtS6P4568MDXW7cyUp.s<   $2a$04$E5SQtS6P4568MDXW7cyUp.18wfDisKZBxifnPZjAI1d/KTYMfHPYO)u8   АБбВвГгДдЕеЁёЖжЗзИиЙйКкЛлМмНr5   s   03e26gQFHhQwRNf81/ww9.s<   $2a$04$03e26gQFHhQwRNf81/ww9.p1UbrNwxpzWjLuT.zpTLH4t/w5WhAhC)uF   нОоПпРрСсТтУуФфХхЦцЧчШшЩщЪъЫыЬьЭэЮюr5   s   PHNoJwpXCfe32nUtLv2Upus<   $2a$04$PHNoJwpXCfe32nUtLv2UpuhJXOzd4k7IdFwnEpYwfJVCZ/f/.8Pje)u6   電电電島岛島兔兔兎龜龟亀國国国區区区r5   s   wU4/0i1TmNl2u.1jIwBX.us<   $2a$04$wU4/0i1TmNl2u.1jIwBX.uZUaOL3Rc5ID7nlQRloQh6q5wwhV/zLW)u6   诶比伊艾弗豆贝尔维吾艾尺开艾丝维贼德r5   s   P4kreGLhCd26d4WIy7DJXus<   $2a$04$P4kreGLhCd26d4WIy7DJXusPkhxLvBouzV6OXkL5EB0jux0osjsryr   r   r   s           r"   test_non_ascii_charactersz&bcrypt_Tests.test_non_ascii_charactersX  s    
 
 
" 8A~~ 	+ 	+3S28T66xN6,B,BCCCAQ'''6****	+ 	+r$   c                     g d}t          |          D ]O\  }\  }}}}t          ||t          |                    }|                     ||           t	          ||           Pd S )N))z
-O_=*N!2JPr5      ......................s<   $2a$04$......................JjuKLOX9OOwo5PceZZXSkaLDvdmgb82)z
7B[$Q<4b>Ur_   r  s<   $2a$05$......................DRiedDQZRL3xq5A5FL8y7/6NM8a2Y5W)z
>d5-I_8^.hr   r  s<   $2a$06$......................5Mq1Ng8jgDY.uHNU4h5p/x6BedzNH2W)z
)V`/UM/]1tr5      .OC/.OC/.OC/.OC/.OC/.Os<   $2a$04$.OC/.OC/.OC/.OC/.OC/.OQIvKRDAam.Hm5/IaV/.hc7P8gwwIbmi)z
:@t2.bWuH]r_   r  s<   $2a$05$.OC/.OC/.OC/.OC/.OC/.ONDbUvdOchUiKmQORX6BlkPofa/QxW9e)z
b(#KljF5s"r   r  s<   $2a$06$.OC/.OC/.OC/.OC/.OC/.OHfTd9e7svOu34vi1PCvOcAEq07ST7.K)z
@3YaJ^Xs]*r5      eGA.eGA.eGA.eGA.eGA.e.s<   $2a$04$eGA.eGA.eGA.eGA.eGA.e.stcmvh.R70m.0jbfSFVxlONdj1iws0C)z
'"5\!k*C(pr_   r  s<   $2a$05$eGA.eGA.eGA.eGA.eGA.e.vR37mVSbfdHwu.F0sNMvgn8oruQRghy)z
edEu7C?$'Wr   r  s<   $2a$06$eGA.eGA.eGA.eGA.eGA.e.tSq0FN8MWHQXJXNFnHTPQKtA.n2a..G)z
N7dHmg\PI^r5      999999999999999999999us<   $2a$04$999999999999999999999uCZfA/pLrlyngNDMq89r1uUk.bQ9icOu)z
"eJuHh!)7*r_   r  s<   $2a$05$999999999999999999999uj8Pfx.ufrJFAoWFLjapYBS5vVEQQ/hK)z
ZeDRJ:_tu:r   r  s<   $2a$06$999999999999999999999u6RB0P9UmbdbQgjoQFEJsrvrKe.BoU6qr   r   r   s           r"   test_special_case_saltz#bcrypt_Tests.test_special_case_saltp  s    
 
 
 8A~~ 	+ 	+3S28T66xN6,B,BCCCAQ'''6****	+ 	+r$   N)r'   r(   r)   r   r   r   r   r   r   r  r  r
  r  r  r*   r$   r"   r   r     s        @ @ @
B 
B 
B+ + ++ + +$+ + +$+ + ++ + +$+ + + + + +4+ + +0+ + + + +r$   r   c                   8    e Zd Zd Zd Zd Zd Zd Zd Zd Z	dS )	TestVectorsHKDFWycheproofc                 `    t           j                            |            || _        d| _        d S )NNone)unittestTestCase__init___wycheproof_warnings_id)r8   wycheproof_warningss     r"   r  z"TestVectorsHKDFWycheproof.__init__  s,    ""4((($7!r$   c                 H    d }d }t          d|d|z  d|id|i          }|S )Nc                     | d         }|dk    rt           S |dk    rt          S |dk    rt          S |dk    rt          S t	          d|z             )N	algorithmz
HKDF-SHA-1zHKDF-SHA-256zHKDF-SHA-384zHKDF-SHA-512zUnknown algorithm )r	   r   r   r   rp   )root	algo_names     r"   filter_algoz8TestVectorsHKDFWycheproof.add_tests.<locals>.filter_algo  s`    [)IL((n,,n,,n,, !5	!ABBBr$   c                 ,    t          | d                   S )Nsizeint)units    r"   filter_sizez8TestVectorsHKDFWycheproof.add_tests.<locals>.filter_size  s    tF|$$$r$   )Protocol
wycheproofzWycheproof HMAC (%s)hash_moduler'  )root_tagunit_tag)r   )r8   filenamer%  r+  r   s        r"   	add_testsz#TestVectorsHKDFWycheproof.add_tests  sa    	C 	C 	C	% 	% 	% ..H.6.Dx.O8E{7S8>7L	N N N
 r$   c                     g | _         |                     d           |                     d           |                     d           |                     d           d S )Nzhkdf_sha1_test.jsonzhkdf_sha256_test.jsonzhkdf_sha384_test.jsonzhkdf_sha512_test.json)r   r2  r   s    r"   r   zTestVectorsHKDFWycheproof.setUp  s[    ,---.///.///./////r$   c                     | j         S rS   )r  r   s    r"   shortDescriptionz*TestVectorsHKDFWycheproof.shortDescription  s	    xr$   c                 ~    |j         r3| j        r.dd l}|                    d| j        d|j        d           d S d S d S )Nr   zWycheproof warning: z ())warningr  r   r   r  comment)r8   r   r   s      r"   r   zTestVectorsHKDFWycheproof.warn  sd    : 	R$3 	ROOOMMM4888RZZZPQQQQQ	R 	R 	R 	Rr$   c                 6   d|j         |j        |j        fz  | _        	 t	          |j        |j        |j        |j        d|j	                  }||j
        k    r|j        rJ d S |j        sJ |                     |           d S # t          $ r |j        rJ Y d S w xY w)Nz!Wycheproof HKDF Test #%d (%s, %s)r2   )idr9  r1  r  r   ikmr'  rc   r.  r   okmvalidr   rp   )r8   r   r   s      r"   test_verifyz%TestVectorsHKDFWycheproof.test_verify  s    6"%R[9YY		rvrwBGLLC bf}}8#####x		"  	  	  	 x	 s   -B BBc                 D    | j         D ]}|                     |           d S rS   )r   r?  )r8   r   s     r"   runTestz!TestVectorsHKDFWycheproof.runTest  s4    ' 	! 	!BR    	! 	!r$   N)
r'   r(   r)   r  r2  r   r5  r   r?  rA  r*   r$   r"   r  r    s          
  20 0 0  R R R
  ! ! ! ! !r$   r  c                 ^    t          d| z   t                      t                      dg          S )NzCryptodome.Hash.rU   )
__import__globalslocals)	hash_names    r"   load_hash_by_namerG    s&    (94giiE7SSSr$   c                       e Zd Zd Zd ZdS )SP800_180_Counter_Testsc                     d }	 t          dd|d          }n%# t          $ r |                     d           Y nw xY w|                     t          t           dd|d           d S )Nc                 \    t          j        | |t                                                    S rS   r]   rY   r   s     r"   rm   z9SP800_180_Counter_Tests.test_negative_zeroes.<locals>.prf  "    8Aq&))00222r$      0000000000000000r2   s   A B)labelz+SP800_108_Counter failed with zero in label)context)r   rp   failro   )r8   rm   _s      r"   test_negative_zeroesz,SP800_180_Counter_Tests.test_negative_zeroes  s    	3 	3 	3	E!)Q9EEEAA 	E 	E 	EIICDDDDD	E*&7As"+ 	 	- 	- 	- 	- 	-s    ;;c                 V   d }d}t          |d|          }dD ]}t          |||d|z            }|                     t          |          d|z             |                     t          |d                   |           |                     d                    |          |           d S )Nc                 \    t          j        | |t                                                    S rS   r]   rL  s     r"   rm   z7SP800_180_Counter_Tests.test_multiple_keys.<locals>.prf  rM  r$   rN     )r2   r3   r4      r   r$   )r   r7   ra   join)r8   rm   r   rg   r   dkss         r"   test_multiple_keysz*SP800_180_Counter_Tests.test_multiple_keys  s    	3 	3 	3 $S&#66 	6 	6A#CCa88CSXXsAv...SQ[[!,,,SXXc]]H5555		6 	6r$   N)r'   r(   r)   rS  rZ  r*   r$   r"   rI  rI    s2        	- 	- 	-
6 
6 
6 
6 
6r$   rI  c                 
   t          ddddd i          pg }d }t          |          D ]\  }}t          |t                    rpt	          j        d|          }|r;|                    d                              dd	          }t          |          }d
}lt	          j        d|          }|rd}|sJ |d
k    r|fd}n|dk    r|fd}||j	        |j
        |j        |j        |j        fd}	t          | d|z  |	           d S )N)r,  zKDF_SP800_108_COUNTER.txtz NIST SP 800 108 KDF Counter Modecountc                      t          |           S rS   r(  )r   s    r"   rv   z-add_tests_sp800_108_counter.<locals>.<lambda>  s    3q66 r$   z\[HMAC-(SHA-[0-9]+)\]r2   -r   hmacz\[CMAC-AES-128\]cmacc                 R    t          j        | ||                                          S rS   rt   rY   r   r.  s      r"   rm   z(add_tests_sp800_108_counter.<locals>.prf   s"    x1k2299;;;r$   c                 h    t                               | |t                                                    S rS   )CMACrU   r   rV   rb  s      r"   rm   z(add_tests_sp800_108_counter.<locals>.prf  s$    xx1c**11333r$   c                     t          |t          |          |d||          }t          |          t          |          k    sJ |                     ||           d S )Nr2   )r   ra   r7   )r8   rm   kinrO  rP  koutr\  r   s           r"   kdf_testz-add_tests_sp800_108_counter.<locals>.kdf_test  sX    &sCIIsAugNNFv;;#d))++++VT*****r$   ztest_kdf_sp800_108_counter_%d)r   r   
isinstancer   rematchgroupr   rG  rf  rO  rP  rg  r\  setattr)
clstest_vectors_sp800_108_countermac_typer   r   r:   rF  r.  rm   rh  s
             r"   add_tests_sp800_108_counterrq    s   %6~7R7Y8?AQAQ7R&8 &8 &> <>	 # H;<< F FRb# 	(3R88C IIaLL00b99	/	::!(.33C !JJJv&1 < < < < <&1 4 4 4 4"bhZbgRX	+ 	+ 	+ 	+ 	4s:HEEEE;F Fr$   c                 >   |                      d          }|                      d          s<t          j        d d         t          _        t          j        d d         t          _        g }|t          t                    z  }|t          t                    z  }|t          t                    z  }|t          t                    z  }|t          |          gz  }|t          t                    z  }|t          t                    z  }|t          t                    z  }|S )Nr  
slow_testsr4   )getr=   r6   r   r   r   r,   r   r   r  r   rI  )configr  testss      r"   	get_testsrw    s     **%:;;::l## 2!-!7!;(-bqb1E	_\***E	_\***E	_Y'''E	_Z(((E	'(;<<==E	_\***E	_\***E	_4555ELr$   __main__c                  B    t          j        t                                S rS   )r  	TestSuiterw  r*   r$   r"   rv   rv   (  s    H&y{{33 r$   suite)defaultTest)3rj  r  binasciir   Cryptodome.Util.py3compatr   r   Cryptodome.SelfTest.st_commonr   Cryptodome.SelfTest.loaderr   r   Cryptodome.Hashr	   r
   r   r   r   r   r   Cryptodome.Cipherr   r   Cryptodome.Protocol.KDFr   r   r   r   r   r   r   r   r   r#   objectr&   r  r,   r=   r   r   r   r   r  rG  rI  rq  rw  r'   r{  mainr*   r$   r"   <module>r     s  . 
			        - - - - - - - - 9 9 9 9 9 9 V V V V V V V V K K K K K K K K K K K K K K K K K K ' ' ' ' ' ' ' '4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 3 2 2 2 2 2  	 	 	 	 	 	 	 	) ) ) ) )8$ ) ) )(S! S! S! S! S!8$ S! S! S!l6> 6> 6> 6> 6>! 6> 6> 6>rAK AK AK AK AK" AK AK AKHeK eK eK eK eK8$ eK eK eKPA+ A+ A+ A+ A+8$ A+ A+ A+H?! ?! ?! ?! ?! 1 ?! ?! ?!DT T T6 6 6 6 6h/ 6 6 64&F &F &FR  3 4 4 4     ( z33EHMg&&&&&& r$   