JFIF$        dd7 

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

a

�M�e�
�@s�ddlZddlmZddlmZddlmZmZddlm	Z	m
Z
ddlmZddl
mZGdd	�d	e
�ZGd
d�de	�ZGdd
�d
e�ZGdd�de�ZdS)�N)�default_backend)�hashes)�dsa�utils)�CryptographyPrivateKey�CryptographyPublicKey)�	Algorithm)�DNSKEYc@s`eZdZUejed<ejZejZ	e
��Ze
e
dd�dd�Ze
d�dd�Zeedd	�d
d��ZdS)�	PublicDSA�keyN)�	signature�data�returncCsJ|dd�}|dd�}t�t�|d�t�|d��}|j�|||j�dS)N���big)rZencode_dss_signature�int�
from_bytesr�verify�chosen_hash)�selfrr
Zsig_rZsig_sZsig�r�6/usr/lib/python3.9/site-packages/dns/dnssecalgs/dsa.pyrs�zPublicDSA.verify)rcCs�|j��}|jjddd}|dkr.td��d|d}t�d|�}||jj�dd�7}||jj	�|d�7}||jj
�|d�7}||j�|d�7}|S)z,Encode a public key per RFC 2536, section 2.��@zunsupported DSA key size�!B�r)rZpublic_numbers�key_size�
ValueError�struct�packZparameter_numbers�q�to_bytes�p�g�y)rZpn�dsa_t�octets�resrrr�encode_key_bytess
zPublicDSA.encode_key_bytes)rrc	Cs�|�|�|j}t�d|dd��\}|dd�}d|d}|dd�}|dd�}|d|�}||d�}|d|�}||d�}|d|�}|t�t�|d�t�t�|d�t�|d�t�|d����	t
��d�S)	Nrrrrrrr�r)Z!_ensure_algorithm_key_combinationrr�unpackrZDSAPublicNumbersrrZDSAParameterNumbers�
public_keyr)	�clsrZkeyptr�tr'Zdsa_qZdsa_pZdsa_gZdsa_yrrr�from_dnskey(s0




����zPublicDSA.from_dnskey)�__name__�
__module__�__qualname__rZDSAPublicKey�__annotations__�key_clsrZDSA�	algorithmrZSHA1r�bytesrr)�classmethodr	r/rrrrr
s

r
c@sJeZdZUejed<ejZeZd
e	e
e	d�dd�Zee
dd�dd��Zd	S)�
PrivateDSArF)r
rrc
Cs�|j��}|jdkrtd��|j�||jj�}t�|�\}}|jddd}d}t	�
d|�tj||dd�tj||dd�}	|r�|���
|	|�|	S)	z1Sign using a private key per RFC 2536, section 3.izDSA key size overflowrrrrr)�length�	byteorder)rr,rr�sign�
public_clsrrZdecode_dss_signaturerr rr"r)
rr
rZpublic_dsa_keyZ
der_signatureZdsa_rZdsa_sr&r'rrrrr;Gs 


���zPrivateDSA.sign)rrcCs|tj|d�d�S)N)rr*)rZgenerate_private_key)r-rrrr�generateYs
�zPrivateDSA.generateN)F)r0r1r2rZ
DSAPrivateKeyr3r4r
r<r6�boolr;r7rr=rrrrr8Bs

r8c@seZdZejZdS)�PublicDSANSEC3SHA1N)r0r1r2rZDSANSEC3SHA1r5rrrrr?`sr?c@seZdZeZdS)�PrivateDSANSEC3SHA1N)r0r1r2r?r<rrrrr@dsr@)rZcryptography.hazmat.backendsrZcryptography.hazmat.primitivesrZ)cryptography.hazmat.primitives.asymmetricrrZdns.dnssecalgs.cryptographyrrZdns.dnssectypesrZdns.rdtypes.ANY.DNSKEYr	r
r8r?r@rrrr�<module>s6
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