o
    CZh                     @  s   d dl mZ d dlZd dlmZ d dlmZ d dlmZ d dl	m
Z
mZmZmZmZ d dlmZ g dZejeje
jejejejf ZG d	d
 d
ZG dd dZ	d$d%ddZ	d$d&ddZejejef Zd'd"d#ZdS )(    )annotationsN)x509)serialization)PBES)dsaeced448ed25519rsa)PrivateKeyTypes)r   PKCS12PrivateKeyTypesPKCS12CertificatePKCS12KeyAndCertificatesload_key_and_certificatesload_pkcs12serialize_key_and_certificatesc                   @  sP   e Zd ZdddZeddd	Zedd
dZdddZdddZdddZ	dS )r   certx509.Certificatefriendly_namebytes | Nonec                 C  s>   t |tjs
td|d urt |tstd|| _|| _d S )Nz!Expecting x509.Certificate objectz#friendly_name must be bytes or None)
isinstancer   Certificate	TypeErrorbytes_cert_friendly_name)selfr   r    r   j/var/www/html/lang_env/lib/python3.10/site-packages/cryptography/hazmat/primitives/serialization/pkcs12.py__init__)   s   
zPKCS12Certificate.__init__returnc                 C     | j S N)r   r   r   r   r   r   5      zPKCS12Certificate.friendly_namec                 C  r!   r"   r   r#   r   r   r   certificate9   r$   zPKCS12Certificate.certificateotherobjectboolc                 C  s&   t |tstS | j|jko| j|jkS r"   )r   r   NotImplementedr&   r   r   r'   r   r   r   __eq__=   s
   

zPKCS12Certificate.__eq__intc                 C  s   t | j| jfS r"   )hashr&   r   r#   r   r   r   __hash__F   s   zPKCS12Certificate.__hash__strc                 C  s   d | j| jS )Nz+<PKCS12Certificate({}, friendly_name={!r})>)formatr&   r   r#   r   r   r   __repr__I   s   zPKCS12Certificate.__repr__N)r   r   r   r   )r    r   )r    r   r'   r(   r    r)   r    r-   r    r0   )
__name__
__module____qualname__r   propertyr   r&   r,   r/   r2   r   r   r   r   r   (   s    


	r   c                   @  s^   e Zd ZdddZedd
dZedddZedddZd ddZd!ddZ	d"ddZ
dS )#r   keyPrivateKeyTypes | Noner   PKCS12Certificate | Noneadditional_certslist[PKCS12Certificate]c                 C  sx   |d urt |tjtjtjtjt	j
fstd|d ur$t |ts$tdtdd |D s1td|| _|| _|| _d S )NLKey must be RSA, DSA, EllipticCurve, ED25519, or ED448 private key, or None.z/cert must be a PKCS12Certificate object or Nonec                 s  s    | ]}t |tV  qd S r"   )r   r   ).0Zadd_certr   r   r   	<genexpr>f   s
    
z4PKCS12KeyAndCertificates.__init__.<locals>.<genexpr>z@all values in additional_certs must be PKCS12Certificate objects)r   r
   RSAPrivateKeyr   DSAPrivateKeyr   EllipticCurvePrivateKeyr	   Ed25519PrivateKeyr   Ed448PrivateKeyr   r   all_keyr   _additional_certs)r   r:   r   r=   r   r   r   r   P   s.   


z!PKCS12KeyAndCertificates.__init__r    c                 C  r!   r"   )rH   r#   r   r   r   r:   r   r$   zPKCS12KeyAndCertificates.keyc                 C  r!   r"   r%   r#   r   r   r   r   v   r$   zPKCS12KeyAndCertificates.certc                 C  r!   r"   )rI   r#   r   r   r   r=   z   r$   z)PKCS12KeyAndCertificates.additional_certsr'   r(   r)   c                 C  s2   t |tstS | j|jko| j|jko| j|jkS r"   )r   r   r*   r:   r   r=   r+   r   r   r   r,   ~   s   


zPKCS12KeyAndCertificates.__eq__r-   c                 C  s   t | j| jt| jfS r"   )r.   r:   r   tupler=   r#   r   r   r   r/      s   z!PKCS12KeyAndCertificates.__hash__r0   c                 C  s   d}| | j| j| jS )Nz@<PKCS12KeyAndCertificates(key={}, cert={}, additional_certs={})>)r1   r:   r   r=   )r   fmtr   r   r   r2      s   z!PKCS12KeyAndCertificates.__repr__N)r:   r;   r   r<   r=   r>   )r    r;   )r    r<   )r    r>   r3   r4   r5   )r6   r7   r8   r   r9   r:   r   r=   r,   r/   r2   r   r   r   r   r   O   s    
"


r   datar   passwordr   backend
typing.Anyr    Ntuple[PrivateKeyTypes | None, x509.Certificate | None, list[x509.Certificate]]c                 C     ddl m} || |S Nr   rN   ),cryptography.hazmat.backends.openssl.backendrN   Z%load_key_and_certificates_from_pkcs12rL   rM   rN   Zosslr   r   r   r      s   	r   c                 C  rQ   rR   )rT   rN   r   rU   r   r   r   r      s   r   namer:   PKCS12PrivateKeyTypes | Noner   x509.Certificate | Nonecas&typing.Iterable[_PKCS12CATypes] | Noneencryption_algorithm(serialization.KeySerializationEncryptionc                 C  s   |d urt |tjtjtjtjt	j
fstd|d ur%t |tjs%td|d ur:t|}tdd |D s:tdt |tjsDtd|d u rR|d u rR|sRtddd	lm} || ||||S )
Nr?   z"cert must be a certificate or Nonec                 s  s     | ]}t |tjtfV  qd S r"   )r   r   r   r   )r@   valr   r   r   rA      s    
z1serialize_key_and_certificates.<locals>.<genexpr>z&all values in cas must be certificateszFKey encryption algorithm must be a KeySerializationEncryption instancez1You must supply at least one of key, cert, or casr   rS   )r   r
   rB   r   rC   r   rD   r	   rE   r   rF   r   r   r   listrG   r   ZKeySerializationEncryption
ValueErrorrT   rN   Z(serialize_key_and_certificates_to_pkcs12)rV   r:   r   rY   r[   rN   r   r   r   r      s@   



r   r"   )rL   r   rM   r   rN   rO   r    rP   )rL   r   rM   r   rN   rO   r    r   )rV   r   r:   rW   r   rX   rY   rZ   r[   r\   r    r   ) 
__future__r   typingZcryptographyr   Zcryptography.hazmat.primitivesr   Z-cryptography.hazmat.primitives._serializationr   Z)cryptography.hazmat.primitives.asymmetricr   r   r   r	   r
   Z/cryptography.hazmat.primitives.asymmetric.typesr   __all__UnionrB   rC   rD   rE   rF   r   r   r   r   r   r   Z_PKCS12CATypesr   r   r   r   r   <module>   s8   
	'F
