name : rsa.cpython-39.opt-1.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&(

© 2025 Cubjrnet7