JFIF$        dd7 

Viewing File: /usr/lib/python3.9/site-packages/dns/dnssecalgs/__pycache__/rsa.cpython-39.pyc

a

�M�e�
�@s$ddlZddlZddlmZddlmZddlmZmZddl	m
Z
mZddlm
Z
ddlmZGdd	�d	e�ZGd
d�de
�ZGdd
�d
e�ZGdd�de�ZGdd�de�ZGdd�de�ZGdd�de�ZGdd�de�ZGdd�de�ZGdd�de�ZGdd�de�ZGdd�de�ZdS) �N)�default_backend)�hashes)�padding�rsa)�CryptographyPrivateKey�CryptographyPublicKey)�	Algorithm)�DNSKEYc@sdeZdZUejed<ejZeed<ej	ed<e
e
dd�dd�Ze
d�d	d
�Ze
edd�dd
��ZdS)�	PublicRSA�key�	algorithm�chosen_hashN)�	signature�data�returncCs|j�||t��|j�dS)N)r�verifyr�PKCS1v15r
)�selfrr�r�6/usr/lib/python3.9/site-packages/dns/dnssecalgs/rsa.pyrszPublicRSA.verify)rcCs�|j��}t�t�|j�d�}tj|j|dd�}|dkrLdt�	d|�}nt�	d|�}|j
��dkst|j
��d	kr|td
��|||j
�|j
��ddd�S)z,Encode a public key per RFC 3110, section 2.��big)�length�	byteorder���!H�!Biizunsupported RSA key length�)rZpublic_numbers�mathZceil�int�
bit_length�e�to_bytes�struct�pack�n�
ValueError)rZpnZ_exp_lenZexpZ
exp_headerrrr�encode_key_bytess
zPublicRSA.encode_key_bytes)rrcCs�|�|�|j}t�d|dd��\}|dd�}|dkr\t�d|dd��\}|dd�}|d|�}||d�}|t�t�|d�t�|d���t	��d�S)Nrr�r�r�r)
Z!_ensure_algorithm_key_combinationrr$�unpackrZRSAPublicNumbersr �
from_bytes�
public_keyr)�clsrZkeyptrZbytes_Zrsa_eZrsa_nrrr�from_dnskey#s 
���zPublicRSA.from_dnskey)�__name__�
__module__�__qualname__rZRSAPublicKey�__annotations__�key_clsrrZ
HashAlgorithm�bytesrr(�classmethodr	r0rrrrr

s



r
c@sNeZdZUejed<ejZeZdZ	de
ee
d�dd�Ze
edd�dd	��Zd
S)�
PrivateRSAriF)rrrcCs0|j�|t��|jj�}|r,|���||�|S)z1Sign using a private key per RFC 3110, section 3.)r�signrr�
public_clsr
r.r)rrrrrrrr9;szPrivateRSA.sign)�key_sizercCs|tj|j|t�d�d�S)N)Zpublic_exponentr;Zbackendr+)rZgenerate_private_key�default_public_exponentr)r/r;rrr�generateBs��zPrivateRSA.generateN)F)r1r2r3rZ
RSAPrivateKeyr4r5r
r:r<r6�boolr9r7r r=rrrrr85s

r8c@seZdZejZe��ZdS)�PublicRSAMD5N)	r1r2r3rZRSAMD5rrZMD5r
rrrrr?Msr?c@seZdZeZdS)�
PrivateRSAMD5N)r1r2r3r?r:rrrrr@Rsr@c@seZdZejZe��ZdS)�
PublicRSASHA1N)	r1r2r3rZRSASHA1rr�SHA1r
rrrrrAVsrAc@seZdZeZdS)�PrivateRSASHA1N)r1r2r3rAr:rrrrrC[srCc@seZdZejZe��ZdS)�PublicRSASHA1NSEC3SHA1N)	r1r2r3rZRSASHA1NSEC3SHA1rrrBr
rrrrrD_srDc@seZdZeZdS)�PrivateRSASHA1NSEC3SHA1N)r1r2r3rDr:rrrrrEdsrEc@seZdZejZe��ZdS)�PublicRSASHA256N)	r1r2r3rZ	RSASHA256rrZSHA256r
rrrrrFhsrFc@seZdZeZdS)�PrivateRSASHA256N)r1r2r3rFr:rrrrrGmsrGc@seZdZejZe��ZdS)�PublicRSASHA512N)	r1r2r3rZ	RSASHA512rrZSHA512r
rrrrrHqsrHc@seZdZeZdS)�PrivateRSASHA512N)r1r2r3rHr:rrrrrIvsrI)rr$Zcryptography.hazmat.backendsrZcryptography.hazmat.primitivesrZ)cryptography.hazmat.primitives.asymmetricrrZdns.dnssecalgs.cryptographyrrZdns.dnssectypesrZdns.rdtypes.ANY.DNSKEYr	r
r8r?r@rArCrDrErFrGrHrIrrrr�<module>s&(
Back to Directory  nL+D550H?Mx ,D"v]qv;6*Zqn)ZP0!1 A "#a$2Qr D8 a Ri[f\mIykIw0cuFcRı?lO7к_f˓[C$殷WF<_W ԣsKcëIzyQy/_LKℂ;C",pFA:/]=H  ~,ls/9ć:[=/#f;)x{ٛEQ )~ =𘙲r*2~ a _V=' kumFD}KYYC)({ *g&f`툪ry`=^cJ.I](*`wq1dđ#̩͑0;H]u搂@:~וKL Nsh}OIR*8:2 !lDJVo(3=M(zȰ+i*NAr6KnSl)!JJӁ* %݉?|D}d5:eP0R;{$X'xF@.ÊB {,WJuQɲRI;9QE琯62fT.DUJ;*cP A\ILNj!J۱+O\͔]ޒS߼Jȧc%ANolՎprULZԛerE2=XDXgVQeӓk yP7U*omQIs,K`)6\G3t?pgjrmۛجwluGtfh9uyP0D;Uڽ"OXlif$)&|ML0Zrm1[HXPlPR0'G=i2N+0e2]]9VTPO׮7h(F*癈'=QVZDF,d߬~TX G[`le69CR(!S2!P <0x<!1AQ "Raq02Br#SCTb ?Ζ"]mH5WR7k.ۛ!}Q~+yԏz|@T20S~Kek *zFf^2X*(@8r?CIuI|֓>^ExLgNUY+{.RѪ τV׸YTD I62'8Y27'\TP.6d&˦@Vqi|8-OΕ]ʔ U=TL8=;6c| !qfF3aů&~$l}'NWUs$Uk^SV:U# 6w++s&r+nڐ{@29 gL u"TÙM=6(^"7r}=6YݾlCuhquympǦ GjhsǜNlɻ}o7#S6aw4!OSrD57%|?x>L |/nD6?/8w#[)L7+6〼T ATg!%5MmZ/c-{1_Je"|^$'O&ޱմTrb$w)R$& N1EtdU3Uȉ1pM"N*(DNyd96.(jQ)X 5cQɎMyW?Q*!R>6=7)Xj5`J]e8%t!+'!1Q5 !1 AQaqё#2"0BRb?Gt^## .llQT $v,,m㵜5ubV =sY+@d{N! dnO<.-B;_wJt6;QJd.Qc%p{ 1,sNDdFHI0ГoXшe黅XۢF:)[FGXƹ/w_cMeD,ʡcc.WDtA$j@:) -# u c1<@ۗ9F)KJ-hpP]_x[qBlbpʖw q"LFGdƶ*s+ډ_Zc"?%t[IP 6J]#=ɺVvvCGsGh1 >)6|ey?Lӣm,4GWUi`]uJVoVDG< SB6ϏQ@ TiUlyOU0kfV~~}SZ@*WUUi##; s/[=!7}"WN]'(L! ~y5g9T̅JkbM' +s:S +B)v@Mj e Cf jE 0Y\QnzG1д~Wo{T9?`Rmyhsy3!HAD]mc1~2LSu7xT;j$`}4->L#vzŏILS ֭T{rjGKC;bpU=-`BsK.SFw4Mq]ZdHS0)tLg