U
    [e                     @   s  d dl Z d dlZd dlZd dlZd dlZd dlmZ d dlmZ d dl	m
Z
mZmZmZ d dlmZ d dlmZm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 d dlmZ d dlm Z m!Z!m"Z"m#Z# ee$dddZ%dd Z&G dd de'Z(G dd de'Z)G dd de j*dZ+G dd de,Z-G dd de+Z.G dd de+Z/G dd  d e+Z0G d!d" d"e+Z1G d#d$ d$e+Z2G d%d& d&e,Z3G d'd( d(e+Z4G d)d* d*e+Z5G d+d, d,e+Z6G d-d. d.e+Z7G d/d0 d0e,Z8G d1d2 d2eZ9G d3d4 d4e+Z:G d5d6 d6e+Z;G d7d8 d8e,Z<G d9d: d:e,Z=G d;d< d<e,Z>G d=d> d>e+Z?G d?d@ d@e+Z@G dAdB dBe+ZAG dCdD dDe+ZBG dEdF dFeZCdGdH eCD ZDG dIdJ dJe+ZEG dKdL dLe+ZFG dMdN dNe+ZGG dOdP dPe,ZHG dQdR dRe,ZIG dSdT dTe+ZJG dUdV dVe+ZKG dWdX dXe+ZLG dYdZ dZe+ZMG d[d\ d\e+ZNG d]d^ d^e+ZOG d_d` d`e+ZPG dadb dbe+ZQG dcdd dde+ZRG dedf dfe+ZSdS )g    N)Enum)utils)
BIT_STRING	DERReaderOBJECT_IDENTIFIERSEQUENCE)_PUBLIC_KEY_TYPES)constant_timeserialization)EllipticCurvePublicKey)RSAPublicKey)SignedCertificateTimestamp)GeneralName	IPAddress	OtherName)RelativeDistinguishedName)CRLEntryExtensionOIDExtensionOIDOCSPExtensionOIDObjectIdentifier
public_keyreturnc              	   C   s   t | tr | tjjtjj}nt | tr@| tjj	tjj
}n| tjjtjj}t|}|t}|t}|t}W 5 Q R X |  |t | s|  W 5 Q R X | dkrtd|j}t| S )Nr   zInvalid public key encoding)
isinstancer   Zpublic_bytesr
   ZEncodingZDERZPublicFormatZPKCS1r   ZX962ZUncompressedPointZSubjectPublicKeyInfor   Zread_single_elementr   Zread_elementr   r   Zis_emptyZread_any_element	read_byte
ValueErrordatahashlibsha1digest)r   r   Z
serializedreaderZpublic_key_info	algorithmZpublic_key_data r"   ^/var/www/html/services/stratfitenv/lib/python3.8/site-packages/cryptography/x509/extensions.py_key_identifier_from_public_key%   s4    



r$   c                    s.    fdd} fdd} fdd}|||fS )Nc                    s   t t|  S N)lengetattrself
field_namer"   r#   
len_methodN   s    z*_make_sequence_methods.<locals>.len_methodc                    s   t t|  S r%   )iterr'   r(   r*   r"   r#   iter_methodQ   s    z+_make_sequence_methods.<locals>.iter_methodc                    s   t |  | S r%   )r'   )r)   idxr*   r"   r#   getitem_methodT   s    z._make_sequence_methods.<locals>.getitem_methodr"   )r+   r,   r.   r0   r"   r*   r#   _make_sequence_methodsM   s    r1   c                       s$   e Zd Zeed fddZ  ZS )DuplicateExtensionmsgoidc                    s   t t| | || _d S r%   )superr2   __init__r5   r)   r4   r5   	__class__r"   r#   r7   [   s    zDuplicateExtension.__init____name__
__module____qualname__strr   r7   __classcell__r"   r"   r9   r#   r2   Z   s   r2   c                       s$   e Zd Zeed fddZ  ZS )ExtensionNotFoundr3   c                    s   t t| | || _d S r%   )r6   rA   r7   r5   r8   r9   r"   r#   r7   a   s    zExtensionNotFound.__init__r;   r"   r"   r9   r#   rA   `   s   rA   c                   @   s    e Zd ZejedddZdS )ExtensionTyper   c                 C   s   dS )zK
        Returns the oid associated with the given extension type.
        Nr"   r(   r"   r"   r#   r5   g   s    zExtensionType.oidN)r<   r=   r>   abcabstractpropertyr   r5   r"   r"   r"   r#   rB   f   s   rB   )	metaclassc                   @   sT   e Zd Zejd dddZeddddZddd	d
Ze	d\Z
ZZdd ZdS )
Extensions	Extension)
extensionsc                 C   s
   || _ d S r%   )_extensions)r)   rI   r"   r"   r#   r7   o   s    zExtensions.__init__)r5   r   c                 C   s0   | D ]}|j |kr|  S qtd||d S )NNo {} extension was found)r5   rA   format)r)   r5   extr"   r"   r#   get_extension_for_oidr   s    

z Extensions.get_extension_for_oidrC   c                 C   sD   |t krtd| D ]}t|j|r|  S qtd||jd S )Nz|UnrecognizedExtension can't be used with get_extension_for_class because more than one instance of the class may be present.rK   )UnrecognizedExtension	TypeErrorr   valuerA   rL   r5   )r)   ZextclassrM   r"   r"   r#   get_extension_for_classy   s    
 z"Extensions.get_extension_for_classrJ   c                 C   s   d | jS )Nz<Extensions({})>)rL   rJ   r(   r"   r"   r#   __repr__   s    zExtensions.__repr__N)r<   r=   r>   typingListr7   r   rN   rR   r1   __len____iter____getitem__rS   r"   r"   r"   r#   rG   n   s
   rG   c                   @   sJ   e Zd ZejZedddZdd Zdd Z	dd	 Z
d
d ZedZdS )	CRLNumber
crl_numberc                 C   s   t |tstd|| _d S Nzcrl_number must be an integerr   intrP   _crl_numberr)   r[   r"   r"   r#   r7      s    
zCRLNumber.__init__c                 C   s   t |tstS | j|jkS r%   )r   rY   NotImplementedr[   r)   otherr"   r"   r#   __eq__   s    
zCRLNumber.__eq__c                 C   s
   | |k S r%   r"   rb   r"   r"   r#   __ne__   s    zCRLNumber.__ne__c                 C   s
   t | jS r%   hashr[   r(   r"   r"   r#   __hash__   s    zCRLNumber.__hash__c                 C   s   d | jS )Nz<CRLNumber({})>)rL   r[   r(   r"   r"   r#   rS      s    zCRLNumber.__repr__r_   N)r<   r=   r>   r   Z
CRL_NUMBERr5   r^   r7   rd   re   rh   rS   r   read_only_propertyr[   r"   r"   r"   r#   rY      s   rY   c                   @   s   e Zd ZejZeje ejej	e
  eje dddZeed dddZedd dd	d
Zdd Zdd Zdd Zdd ZedZedZedZdS )AuthorityKeyIdentifierkey_identifierauthority_cert_issuerauthority_cert_serial_numberc                 C   sr   |d k|d kkrt d|d k	rBt|}tdd |D sBtd|d k	r\t|ts\td|| _|| _|| _d S )NzXauthority_cert_issuer and authority_cert_serial_number must both be present or both Nonec                 s   s   | ]}t |tV  qd S r%   r   r   .0xr"   r"   r#   	<genexpr>   s    z2AuthorityKeyIdentifier.__init__.<locals>.<genexpr>z;authority_cert_issuer must be a list of GeneralName objectsz/authority_cert_serial_number must be an integer)	r   listallrP   r   r^   _key_identifier_authority_cert_issuer_authority_cert_serial_number)r)   rl   rm   rn   r"   r"   r#   r7      s,    
 zAuthorityKeyIdentifier.__init__r   c                 C   s   t |}| |d d dS Nrk   r$   )clsr   r   r"   r"   r#   from_issuer_public_key   s    z-AuthorityKeyIdentifier.from_issuer_public_keySubjectKeyIdentifier)skir   c                 C   s   | |j d d dS ry   r   )r{   r~   r"   r"   r#   "from_issuer_subject_key_identifier   s
    z9AuthorityKeyIdentifier.from_issuer_subject_key_identifierc                 C   s
   d | S )Nz<AuthorityKeyIdentifier(key_identifier={0.key_identifier!r}, authority_cert_issuer={0.authority_cert_issuer}, authority_cert_serial_number={0.authority_cert_serial_number})>rL   r(   r"   r"   r#   rS      s    zAuthorityKeyIdentifier.__repr__c                 C   s2   t |tstS | j|jko0| j|jko0| j|jkS r%   )r   rj   ra   rl   rm   rn   rb   r"   r"   r#   rd      s    

zAuthorityKeyIdentifier.__eq__c                 C   s
   | |k S r%   r"   rb   r"   r"   r#   re      s    zAuthorityKeyIdentifier.__ne__c                 C   s,   | j d krd }n
t| j }t| j|| jfS r%   )rm   tuplerg   rl   rn   )r)   Zacir"   r"   r#   rh      s    

zAuthorityKeyIdentifier.__hash__rv   rw   rx   N)r<   r=   r>   r   ZAUTHORITY_KEY_IDENTIFIERr5   rT   OptionalbytesIterabler   r^   r7   classmethodr   r|   r   rS   rd   re   rh   r   ri   rl   rm   rn   r"   r"   r"   r#   rj      s,   !
		

rj   c                   @   s^   e Zd ZejZedddZee	d dddZ
edZdd	 Zd
d Zdd Zdd ZdS )r}   r   c                 C   s
   || _ d S r%   )_digest)r)   r   r"   r"   r#   r7     s    zSubjectKeyIdentifier.__init__r   c                 C   s   | t |S r%   rz   )r{   r   r"   r"   r#   from_public_key  s    z$SubjectKeyIdentifier.from_public_keyr   c                 C   s   d | jS )Nz$<SubjectKeyIdentifier(digest={0!r})>)rL   r   r(   r"   r"   r#   rS     s    zSubjectKeyIdentifier.__repr__c                 C   s   t |tstS t| j|jS r%   )r   r}   ra   r	   Zbytes_eqr   rb   r"   r"   r#   rd     s    
zSubjectKeyIdentifier.__eq__c                 C   s
   | |k S r%   r"   rb   r"   r"   r#   re      s    zSubjectKeyIdentifier.__ne__c                 C   s
   t | jS r%   )rg   r   r(   r"   r"   r#   rh   #  s    zSubjectKeyIdentifier.__hash__N)r<   r=   r>   r   ZSUBJECT_KEY_IDENTIFIERr5   r   r7   r   r   r   r   ri   r   rS   rd   re   rh   r"   r"   r"   r#   r}   	  s   
r}   c                   @   sT   e Zd ZejZejd dddZe	d\Z
ZZdd Zdd	 Zd
d Zdd ZdS )AuthorityInformationAccessAccessDescriptiondescriptionsc                 C   s,   t |}tdd |D s"td|| _d S )Nc                 s   s   | ]}t |tV  qd S r%   r   r   rp   r"   r"   r#   rs   ,  s     z6AuthorityInformationAccess.__init__.<locals>.<genexpr>@Every item in the descriptions list must be an AccessDescriptionrt   ru   rP   _descriptionsr)   r   r"   r"   r#   r7   *  s    z#AuthorityInformationAccess.__init__r   c                 C   s   d | jS )Nz <AuthorityInformationAccess({})>rL   r   r(   r"   r"   r#   rS   6  s    z#AuthorityInformationAccess.__repr__c                 C   s   t |tstS | j|jkS r%   )r   r   ra   r   rb   r"   r"   r#   rd   9  s    
z!AuthorityInformationAccess.__eq__c                 C   s
   | |k S r%   r"   rb   r"   r"   r#   re   ?  s    z!AuthorityInformationAccess.__ne__c                 C   s   t t| jS r%   rg   r   r   r(   r"   r"   r#   rh   B  s    z#AuthorityInformationAccess.__hash__N)r<   r=   r>   r   ZAUTHORITY_INFORMATION_ACCESSr5   rT   r   r7   r1   rV   rW   rX   rS   rd   re   rh   r"   r"   r"   r#   r   '  s   
r   c                   @   sT   e Zd ZejZejd dddZe	d\Z
ZZdd Zdd	 Zd
d Zdd ZdS )SubjectInformationAccessr   r   c                 C   s,   t |}tdd |D s"td|| _d S )Nc                 s   s   | ]}t |tV  qd S r%   r   rp   r"   r"   r#   rs   K  s     z4SubjectInformationAccess.__init__.<locals>.<genexpr>r   r   r   r"   r"   r#   r7   I  s    z!SubjectInformationAccess.__init__r   c                 C   s   d | jS )Nz<SubjectInformationAccess({})>r   r(   r"   r"   r#   rS   U  s    z!SubjectInformationAccess.__repr__c                 C   s   t |tstS | j|jkS r%   )r   r   ra   r   rb   r"   r"   r#   rd   X  s    
zSubjectInformationAccess.__eq__c                 C   s
   | |k S r%   r"   rb   r"   r"   r#   re   ^  s    zSubjectInformationAccess.__ne__c                 C   s   t t| jS r%   r   r(   r"   r"   r#   rh   a  s    z!SubjectInformationAccess.__hash__N)r<   r=   r>   r   ZSUBJECT_INFORMATION_ACCESSr5   rT   r   r7   r1   rV   rW   rX   rS   rd   re   rh   r"   r"   r"   r#   r   F  s   
r   c                   @   sP   e Zd ZeedddZdd Zdd Zdd	 Zd
d Z	e
dZe
dZdS )r   )access_methodaccess_locationc                 C   s4   t |tstdt |ts$td|| _|| _d S )Nz)access_method must be an ObjectIdentifierz%access_location must be a GeneralName)r   r   rP   r   _access_method_access_location)r)   r   r   r"   r"   r#   r7   f  s    

zAccessDescription.__init__c                 C   s
   d | S )NzY<AccessDescription(access_method={0.access_method}, access_location={0.access_location})>r   r(   r"   r"   r#   rS   r  s    zAccessDescription.__repr__c                 C   s&   t |tstS | j|jko$| j|jkS r%   )r   r   ra   r   r   rb   r"   r"   r#   rd   x  s
    

zAccessDescription.__eq__c                 C   s
   | |k S r%   r"   rb   r"   r"   r#   re     s    zAccessDescription.__ne__c                 C   s   t | j| jfS r%   )rg   r   r   r(   r"   r"   r#   rh     s    zAccessDescription.__hash__r   r   N)r<   r=   r>   r   r   r7   rS   rd   re   rh   r   ri   r   r   r"   r"   r"   r#   r   e  s    	
r   c                   @   s\   e Zd ZejZeeje	 dddZ
edZedZdd Zdd	 Zd
d Zdd ZdS )BasicConstraints)capath_lengthc                 C   sX   t |tstd|d k	r&|s&td|d k	rHt |tr@|dk rHtd|| _|| _d S )Nzca must be a boolean valuez)path_length must be None when ca is Falser   z2path_length must be a non-negative integer or None)r   boolrP   r   r^   _ca_path_length)r)   r   r   r"   r"   r#   r7     s    
zBasicConstraints.__init__r   r   c                 C   s
   d | S )Nz:<BasicConstraints(ca={0.ca}, path_length={0.path_length})>r   r(   r"   r"   r#   rS     s    zBasicConstraints.__repr__c                 C   s&   t |tstS | j|jko$| j|jkS r%   )r   r   ra   r   r   rb   r"   r"   r#   rd     s    
zBasicConstraints.__eq__c                 C   s
   | |k S r%   r"   rb   r"   r"   r#   re     s    zBasicConstraints.__ne__c                 C   s   t | j| jfS r%   )rg   r   r   r(   r"   r"   r#   rh     s    zBasicConstraints.__hash__N)r<   r=   r>   r   ZBASIC_CONSTRAINTSr5   r   rT   r   r^   r7   r   ri   r   r   rS   rd   re   rh   r"   r"   r"   r#   r     s   

r   c                   @   sJ   e Zd ZejZedddZe	dZ
dd Zdd Zd	d
 Zdd ZdS )DeltaCRLIndicatorrZ   c                 C   s   t |tstd|| _d S r\   r]   r`   r"   r"   r#   r7     s    
zDeltaCRLIndicator.__init__r_   c                 C   s   t |tstS | j|jkS r%   )r   r   ra   r[   rb   r"   r"   r#   rd     s    
zDeltaCRLIndicator.__eq__c                 C   s
   | |k S r%   r"   rb   r"   r"   r#   re     s    zDeltaCRLIndicator.__ne__c                 C   s
   t | jS r%   rf   r(   r"   r"   r#   rh     s    zDeltaCRLIndicator.__hash__c                 C   s
   d | S )Nz.<DeltaCRLIndicator(crl_number={0.crl_number})>r   r(   r"   r"   r#   rS     s    zDeltaCRLIndicator.__repr__N)r<   r=   r>   r   ZDELTA_CRL_INDICATORr5   r^   r7   r   ri   r[   rd   re   rh   rS   r"   r"   r"   r#   r     s   
r   c                   @   sT   e Zd ZejZejd dddZe	d\Z
ZZdd Zdd	 Zd
d Zdd ZdS )CRLDistributionPointsDistributionPointdistribution_pointsc                 C   s,   t |}tdd |D s"td|| _d S )Nc                 s   s   | ]}t |tV  qd S r%   r   r   rp   r"   r"   r#   rs     s    z1CRLDistributionPoints.__init__.<locals>.<genexpr>?distribution_points must be a list of DistributionPoint objectsrt   ru   rP   _distribution_pointsr)   r   r"   r"   r#   r7     s    zCRLDistributionPoints.__init__r   c                 C   s   d | jS )Nz<CRLDistributionPoints({})>rL   r   r(   r"   r"   r#   rS     s    zCRLDistributionPoints.__repr__c                 C   s   t |tstS | j|jkS r%   )r   r   ra   r   rb   r"   r"   r#   rd     s    
zCRLDistributionPoints.__eq__c                 C   s
   | |k S r%   r"   rb   r"   r"   r#   re     s    zCRLDistributionPoints.__ne__c                 C   s   t t| jS r%   rg   r   r   r(   r"   r"   r#   rh     s    zCRLDistributionPoints.__hash__N)r<   r=   r>   r   ZCRL_DISTRIBUTION_POINTSr5   rT   r   r7   r1   rV   rW   rX   rS   rd   re   rh   r"   r"   r"   r#   r     s   
r   c                   @   sT   e Zd ZejZejd dddZe	d\Z
ZZdd Zdd	 Zd
d Zdd ZdS )FreshestCRLr   r   c                 C   s,   t |}tdd |D s"td|| _d S )Nc                 s   s   | ]}t |tV  qd S r%   r   rp   r"   r"   r#   rs     s    z'FreshestCRL.__init__.<locals>.<genexpr>r   r   r   r"   r"   r#   r7     s    zFreshestCRL.__init__r   c                 C   s   d | jS )Nz<FreshestCRL({})>r   r(   r"   r"   r#   rS   	  s    zFreshestCRL.__repr__c                 C   s   t |tstS | j|jkS r%   )r   r   ra   r   rb   r"   r"   r#   rd     s    
zFreshestCRL.__eq__c                 C   s
   | |k S r%   r"   rb   r"   r"   r#   re     s    zFreshestCRL.__ne__c                 C   s   t t| jS r%   r   r(   r"   r"   r#   rh     s    zFreshestCRL.__hash__N)r<   r=   r>   r   ZFRESHEST_CRLr5   rT   r   r7   r1   rV   rW   rX   rS   rd   re   rh   r"   r"   r"   r#   r     s   
r   c                   @   s   e Zd Zejeje  eje ejejd  ejeje  dddZ	dd Z
dd Zd	d
 Zdd ZedZedZedZedZdS )r   ReasonFlags)	full_namerelative_namereasons
crl_issuerc                 C   s   |r|rt d|r6t|}tdd |D s6td|rLt|tsLtd|rrt|}tdd |D srtd|rt|trtdd |D std	|rtj|kstj	|krt d
|r|s|s|st d|| _
|| _|| _|| _d S )NzOYou cannot provide both full_name and relative_name, at least one must be None.c                 s   s   | ]}t |tV  qd S r%   ro   rp   r"   r"   r#   rs   )  s     z-DistributionPoint.__init__.<locals>.<genexpr>z/full_name must be a list of GeneralName objectsz1relative_name must be a RelativeDistinguishedNamec                 s   s   | ]}t |tV  qd S r%   ro   rp   r"   r"   r#   rs   6  s     z2crl_issuer must be None or a list of general namesc                 s   s   | ]}t |tV  qd S r%   r   r   rp   r"   r"   r#   rs   =  s     z0reasons must be None or frozenset of ReasonFlagszLunspecified and remove_from_crl are not valid reasons in a DistributionPointzPYou must supply crl_issuer, full_name, or relative_name when reasons is not None)r   rt   ru   rP   r   r   	frozensetr   unspecifiedremove_from_crl
_full_name_relative_name_reasons_crl_issuer)r)   r   r   r   r   r"   r"   r#   r7     sV    
zDistributionPoint.__init__c                 C   s
   d | S )Nz}<DistributionPoint(full_name={0.full_name}, relative_name={0.relative_name}, reasons={0.reasons}, crl_issuer={0.crl_issuer})>r   r(   r"   r"   r#   rS   U  s    zDistributionPoint.__repr__c                 C   s>   t |tstS | j|jko<| j|jko<| j|jko<| j|jkS r%   )r   r   ra   r   r   r   r   rb   r"   r"   r#   rd   \  s    



zDistributionPoint.__eq__c                 C   s
   | |k S r%   r"   rb   r"   r"   r#   re   g  s    zDistributionPoint.__ne__c                 C   sH   | j d k	rt| j }nd }| jd k	r0t| j}nd }t|| j| j|fS r%   )r   r   r   rg   r   r   )r)   fnr   r"   r"   r#   rh   j  s    

zDistributionPoint.__hash__r   r   r   r   N)r<   r=   r>   rT   r   r   r   r   	FrozenSetr7   rS   rd   re   rh   r   ri   r   r   r   r   r"   r"   r"   r#   r     s   ;


r   c                   @   s4   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S )r   r   ZkeyCompromiseZcACompromiseZaffiliationChanged
supersededZcessationOfOperationZcertificateHoldZprivilegeWithdrawnZaACompromiseZremoveFromCRLN)r<   r=   r>   r   Zkey_compromiseZca_compromiseZaffiliation_changedr   Zcessation_of_operationZcertificate_holdZprivilege_withdrawnZaa_compromiser   r"   r"   r"   r#   r   }  s   r   c                   @   sb   e Zd ZejZeje eje dddZ	dd Z
dd Zdd	 Zd
d ZedZedZdS )PolicyConstraints)require_explicit_policyinhibit_policy_mappingc                 C   s\   |d k	rt |tstd|d k	r4t |ts4td|d krL|d krLtd|| _|| _d S )Nz>require_explicit_policy must be a non-negative integer or Nonez=inhibit_policy_mapping must be a non-negative integer or NonezSAt least one of require_explicit_policy and inhibit_policy_mapping must not be None)r   r^   rP   r   _require_explicit_policy_inhibit_policy_mapping)r)   r   r   r"   r"   r#   r7     s(    
 
 zPolicyConstraints.__init__c                 C   s
   d | S )Nz{<PolicyConstraints(require_explicit_policy={0.require_explicit_policy}, inhibit_policy_mapping={0.inhibit_policy_mapping})>r   r(   r"   r"   r#   rS     s    zPolicyConstraints.__repr__c                 C   s&   t |tstS | j|jko$| j|jkS r%   )r   r   ra   r   r   rb   r"   r"   r#   rd     s
    

zPolicyConstraints.__eq__c                 C   s
   | |k S r%   r"   rb   r"   r"   r#   re     s    zPolicyConstraints.__ne__c                 C   s   t | j| jfS r%   )rg   r   r   r(   r"   r"   r#   rh     s    
zPolicyConstraints.__hash__r   r   N)r<   r=   r>   r   ZPOLICY_CONSTRAINTSr5   rT   r   r^   r7   rS   rd   re   rh   r   ri   r   r   r"   r"   r"   r#   r     s   	r   c                   @   sT   e Zd ZejZejd dddZe	d\Z
ZZdd Zdd	 Zd
d Zdd ZdS )CertificatePoliciesPolicyInformation)policiesc                 C   s,   t |}tdd |D s"td|| _d S )Nc                 s   s   | ]}t |tV  qd S r%   )r   r   rp   r"   r"   r#   rs     s     z/CertificatePolicies.__init__.<locals>.<genexpr>z;Every item in the policies list must be a PolicyInformation)rt   ru   rP   	_policies)r)   r   r"   r"   r#   r7     s    zCertificatePolicies.__init__r   c                 C   s   d | jS )Nz<CertificatePolicies({})>)rL   r   r(   r"   r"   r#   rS     s    zCertificatePolicies.__repr__c                 C   s   t |tstS | j|jkS r%   )r   r   ra   r   rb   r"   r"   r#   rd     s    
zCertificatePolicies.__eq__c                 C   s
   | |k S r%   r"   rb   r"   r"   r#   re     s    zCertificatePolicies.__ne__c                 C   s   t t| jS r%   )rg   r   r   r(   r"   r"   r#   rh     s    zCertificatePolicies.__hash__N)r<   r=   r>   r   ZCERTIFICATE_POLICIESr5   rT   r   r7   r1   rV   rW   rX   rS   rd   re   rh   r"   r"   r"   r#   r     s   
r   c                   @   sf   e Zd Zeejejejedf   dddZ	dd Z
dd Zd	d
 Zdd ZedZedZdS )r   
UserNotice)policy_identifierpolicy_qualifiersc                 C   sH   t |tstd|| _|r>t|}tdd |D s>td|| _d S )Nz-policy_identifier must be an ObjectIdentifierc                 s   s   | ]}t |ttfV  qd S r%   )r   r?   r   rp   r"   r"   r#   rs     s    z-PolicyInformation.__init__.<locals>.<genexpr>zMpolicy_qualifiers must be a list of strings and/or UserNotice objects or None)r   r   rP   _policy_identifierrt   ru   _policy_qualifiers)r)   r   r   r"   r"   r#   r7     s    
zPolicyInformation.__init__c                 C   s
   d | S )Nze<PolicyInformation(policy_identifier={0.policy_identifier}, policy_qualifiers={0.policy_qualifiers})>r   r(   r"   r"   r#   rS     s    zPolicyInformation.__repr__c                 C   s&   t |tstS | j|jko$| j|jkS r%   )r   r   ra   r   r   rb   r"   r"   r#   rd     s
    

zPolicyInformation.__eq__c                 C   s
   | |k S r%   r"   rb   r"   r"   r#   re     s    zPolicyInformation.__ne__c                 C   s(   | j d k	rt| j }nd }t| j|fS r%   )r   r   rg   r   )r)   Zpqr"   r"   r#   rh     s    
zPolicyInformation.__hash__r   r   N)r<   r=   r>   r   rT   r   r   Unionr?   r7   rS   rd   re   rh   r   ri   r   r   r"   r"   r"   r#   r     s   	
r   c                   @   s\   e Zd Zejd eje dddZdd Zdd Zd	d
 Z	dd Z
edZedZdS )r   NoticeReference)notice_referenceexplicit_textc                 C   s&   |rt |tstd|| _|| _d S )Nz2notice_reference must be None or a NoticeReference)r   r   rP   _notice_reference_explicit_text)r)   r   r   r"   r"   r#   r7   !  s     zUserNotice.__init__c                 C   s
   d | S )NzV<UserNotice(notice_reference={0.notice_reference}, explicit_text={0.explicit_text!r})>r   r(   r"   r"   r#   rS   0  s    zUserNotice.__repr__c                 C   s&   t |tstS | j|jko$| j|jkS r%   )r   r   ra   r   r   rb   r"   r"   r#   rd   6  s
    

zUserNotice.__eq__c                 C   s
   | |k S r%   r"   rb   r"   r"   r#   re   ?  s    zUserNotice.__ne__c                 C   s   t | j| jfS r%   )rg   r   r   r(   r"   r"   r#   rh   B  s    zUserNotice.__hash__r   r   N)r<   r=   r>   rT   r   r?   r7   rS   rd   re   rh   r   ri   r   r   r"   r"   r"   r#   r      s   	
r   c                   @   s\   e Zd Zeje eje dddZdd Z	dd Z
dd	 Zd
d ZedZedZdS )r   )organizationnotice_numbersc                 C   s2   || _ t|}tdd |D s(td|| _d S )Nc                 s   s   | ]}t |tV  qd S r%   )r   r^   rp   r"   r"   r#   rs   Q  s     z+NoticeReference.__init__.<locals>.<genexpr>z)notice_numbers must be a list of integers)_organizationrt   ru   rP   _notice_numbers)r)   r   r   r"   r"   r#   r7   J  s
    zNoticeReference.__init__c                 C   s
   d | S )NzU<NoticeReference(organization={0.organization!r}, notice_numbers={0.notice_numbers})>r   r(   r"   r"   r#   rS   V  s    zNoticeReference.__repr__c                 C   s&   t |tstS | j|jko$| j|jkS r%   )r   r   ra   r   r   rb   r"   r"   r#   rd   \  s
    

zNoticeReference.__eq__c                 C   s
   | |k S r%   r"   rb   r"   r"   r#   re   e  s    zNoticeReference.__ne__c                 C   s   t | jt| jfS r%   )rg   r   r   r   r(   r"   r"   r#   rh   h  s    zNoticeReference.__hash__r   r   N)r<   r=   r>   rT   r   r?   r   r^   r7   rS   rd   re   rh   r   ri   r   r   r"   r"   r"   r#   r   I  s   	
r   c                   @   sT   e Zd ZejZeje dddZ	e
d\ZZZdd Zdd Zd	d
 Zdd ZdS )ExtendedKeyUsage)usagesc                 C   s,   t |}tdd |D s"td|| _d S )Nc                 s   s   | ]}t |tV  qd S r%   )r   r   rp   r"   r"   r#   rs   t  s     z,ExtendedKeyUsage.__init__.<locals>.<genexpr>z9Every item in the usages list must be an ObjectIdentifier)rt   ru   rP   _usages)r)   r   r"   r"   r#   r7   r  s    zExtendedKeyUsage.__init__r   c                 C   s   d | jS )Nz<ExtendedKeyUsage({})>)rL   r   r(   r"   r"   r#   rS   }  s    zExtendedKeyUsage.__repr__c                 C   s   t |tstS | j|jkS r%   )r   r   ra   r   rb   r"   r"   r#   rd     s    
zExtendedKeyUsage.__eq__c                 C   s
   | |k S r%   r"   rb   r"   r"   r#   re     s    zExtendedKeyUsage.__ne__c                 C   s   t t| jS r%   )rg   r   r   r(   r"   r"   r#   rh     s    zExtendedKeyUsage.__hash__N)r<   r=   r>   r   ZEXTENDED_KEY_USAGEr5   rT   r   r   r7   r1   rV   rW   rX   rS   rd   re   rh   r"   r"   r"   r#   r   o  s   	r   c                   @   s2   e Zd ZejZdd Zdd Zdd Zdd Z	d	S )
OCSPNoCheckc                 C   s   t |tstS dS NT)r   r   ra   rb   r"   r"   r#   rd     s    
zOCSPNoCheck.__eq__c                 C   s
   | |k S r%   r"   rb   r"   r"   r#   re     s    zOCSPNoCheck.__ne__c                 C   s   t tS r%   )rg   r   r(   r"   r"   r#   rh     s    zOCSPNoCheck.__hash__c                 C   s   dS )Nz<OCSPNoCheck()>r"   r(   r"   r"   r#   rS     s    zOCSPNoCheck.__repr__N)
r<   r=   r>   r   ZOCSP_NO_CHECKr5   rd   re   rh   rS   r"   r"   r"   r#   r     s
   r   c                   @   s2   e Zd ZejZdd Zdd Zdd Zdd Z	d	S )
PrecertPoisonc                 C   s   t |tstS dS r   )r   r   ra   rb   r"   r"   r#   rd     s    
zPrecertPoison.__eq__c                 C   s
   | |k S r%   r"   rb   r"   r"   r#   re     s    zPrecertPoison.__ne__c                 C   s   t tS r%   )rg   r   r(   r"   r"   r#   rh     s    zPrecertPoison.__hash__c                 C   s   dS )Nz<PrecertPoison()>r"   r(   r"   r"   r#   rS     s    zPrecertPoison.__repr__N)
r<   r=   r>   r   ZPRECERT_POISONr5   rd   re   rh   rS   r"   r"   r"   r#   r     s
   r   c                   @   sT   e Zd ZejZejd dddZe	d\Z
ZZdd Zdd	 Zd
d Zdd ZdS )
TLSFeatureTLSFeatureType)featuresc                 C   s8   t |}tdd |D r&t|dkr.td|| _d S )Nc                 s   s   | ]}t |tV  qd S r%   )r   r   rp   r"   r"   r#   rs     s     z&TLSFeature.__init__.<locals>.<genexpr>r   z@features must be a list of elements from the TLSFeatureType enum)rt   ru   r&   rP   	_features)r)   r   r"   r"   r#   r7     s    
zTLSFeature.__init__r   c                 C   s
   d | S )Nz$<TLSFeature(features={0._features})>r   r(   r"   r"   r#   rS     s    zTLSFeature.__repr__c                 C   s   t |tstS | j|jkS r%   )r   r   ra   r   rb   r"   r"   r#   rd     s    
zTLSFeature.__eq__c                 C   s
   | |k S r%   r"   rb   r"   r"   r#   re     s    zTLSFeature.__ne__c                 C   s   t t| jS r%   )rg   r   r   r(   r"   r"   r#   rh     s    zTLSFeature.__hash__N)r<   r=   r>   r   ZTLS_FEATUREr5   rT   r   r7   r1   rV   rW   rX   rS   rd   re   rh   r"   r"   r"   r#   r     s   r   c                   @   s   e Zd ZdZdZdS )r         N)r<   r=   r>   Zstatus_requestZstatus_request_v2r"   r"   r"   r#   r     s   r   c                 C   s   i | ]}|j |qS r"   rQ   rp   r"   r"   r#   
<dictcomp>  s      r   c                   @   sJ   e Zd ZejZedddZdd Zdd Z	dd	 Z
d
d ZedZdS )InhibitAnyPolicy)
skip_certsc                 C   s,   t |tstd|dk r"td|| _d S )Nzskip_certs must be an integerr   z)skip_certs must be a non-negative integer)r   r^   rP   r   _skip_certs)r)   r   r"   r"   r#   r7     s
    
zInhibitAnyPolicy.__init__c                 C   s
   d | S )Nz-<InhibitAnyPolicy(skip_certs={0.skip_certs})>r   r(   r"   r"   r#   rS     s    zInhibitAnyPolicy.__repr__c                 C   s   t |tstS | j|jkS r%   )r   r   ra   r   rb   r"   r"   r#   rd     s    
zInhibitAnyPolicy.__eq__c                 C   s
   | |k S r%   r"   rb   r"   r"   r#   re     s    zInhibitAnyPolicy.__ne__c                 C   s
   t | jS r%   )rg   r   r(   r"   r"   r#   rh     s    zInhibitAnyPolicy.__hash__r   N)r<   r=   r>   r   ZINHIBIT_ANY_POLICYr5   r^   r7   rS   rd   re   rh   r   ri   r   r"   r"   r"   r#   r     s   	r   c                
   @   s   e Zd ZejZeeeeeeeeed	ddZe	dZ
e	dZe	dZe	dZe	dZe	d	Ze	d
Zedd Zedd Zdd Zdd Zdd Zdd ZdS )KeyUsage)	digital_signaturecontent_commitmentkey_enciphermentdata_enciphermentkey_agreementkey_cert_signcrl_signencipher_onlydecipher_onlyc
           
      C   sN   |s|s|	rt d|| _|| _|| _|| _|| _|| _|| _|| _|	| _	d S )NzKencipher_only and decipher_only can only be true when key_agreement is true)
r   _digital_signature_content_commitment_key_encipherment_data_encipherment_key_agreement_key_cert_sign	_crl_sign_encipher_only_decipher_only)
r)   r   r   r   r   r   r   r   r   r   r"   r"   r#   r7     s    zKeyUsage.__init__r   r   r   r   r   r   r   c                 C   s   | j stdn| jS d S )Nz7encipher_only is undefined unless key_agreement is true)r   r   r   r(   r"   r"   r#   r   (  s
    zKeyUsage.encipher_onlyc                 C   s   | j stdn| jS d S )Nz7decipher_only is undefined unless key_agreement is true)r   r   r   r(   r"   r"   r#   r   1  s
    zKeyUsage.decipher_onlyc                 C   s<   z| j }| j}W n tk
r,   d}d}Y nX d| ||S )NFa-  <KeyUsage(digital_signature={0.digital_signature}, content_commitment={0.content_commitment}, key_encipherment={0.key_encipherment}, data_encipherment={0.data_encipherment}, key_agreement={0.key_agreement}, key_cert_sign={0.key_cert_sign}, crl_sign={0.crl_sign}, encipher_only={1}, decipher_only={2})>)r   r   r   rL   )r)   r   r   r"   r"   r#   rS   :  s    

  zKeyUsage.__repr__c                 C   sz   t |tstS | j|jkox| j|jkox| j|jkox| j|jkox| j|jkox| j|jkox| j	|j	kox| j
|j
kox| j|jkS r%   )r   r   ra   r   r   r   r   r   r   r   r   r   rb   r"   r"   r#   rd   O  s&    








zKeyUsage.__eq__c                 C   s
   | |k S r%   r"   rb   r"   r"   r#   re   _  s    zKeyUsage.__ne__c              
   C   s,   t | j| j| j| j| j| j| j| j| j	f	S r%   )
rg   r   r   r   r   r   r   r   r   r   r(   r"   r"   r#   rh   b  s    zKeyUsage.__hash__N)r<   r=   r>   r   Z	KEY_USAGEr5   r   r7   r   ri   r   r   r   r   r   r   r   propertyr   r   rS   rd   re   rh   r"   r"   r"   r#   r     s4   








r   c                   @   sv   e Zd ZejZejeje	  ejeje	  dddZ
dd Zdd Zdd	 Zd
d Zdd ZedZedZdS )NameConstraints)permitted_subtreesexcluded_subtreesc                 C   s   |d k	r4t |}tdd |D s*td| | |d k	rht |}tdd |D s^td| | |d kr|d krtd|| _|| _d S )Nc                 s   s   | ]}t |tV  qd S r%   ro   rp   r"   r"   r#   rs   |  s     z+NameConstraints.__init__.<locals>.<genexpr>z@permitted_subtrees must be a list of GeneralName objects or Nonec                 s   s   | ]}t |tV  qd S r%   ro   rp   r"   r"   r#   rs     s     z?excluded_subtrees must be a list of GeneralName objects or NonezIAt least one of permitted_subtrees and excluded_subtrees must not be None)rt   ru   rP   _validate_ip_namer   _permitted_subtrees_excluded_subtrees)r)   r   r   r"   r"   r#   r7   u  s(    

zNameConstraints.__init__c                 C   s&   t |tstS | j|jko$| j|jkS r%   )r   r   ra   r   r   rb   r"   r"   r#   rd     s
    

zNameConstraints.__eq__c                 C   s
   | |k S r%   r"   rb   r"   r"   r#   re     s    zNameConstraints.__ne__c                 C   s   t dd |D rtdd S )Nc                 s   s.   | ]&}t |to$t |jtjtjf V  qd S r%   )r   r   rQ   	ipaddressIPv4NetworkIPv6Network)rq   namer"   r"   r#   rs     s   
 
z4NameConstraints._validate_ip_name.<locals>.<genexpr>zGIPAddress name constraints must be an IPv4Network or IPv6Network object)anyrP   )r)   treer"   r"   r#   r     s    z!NameConstraints._validate_ip_namec                 C   s
   d | S )Nze<NameConstraints(permitted_subtrees={0.permitted_subtrees}, excluded_subtrees={0.excluded_subtrees})>r   r(   r"   r"   r#   rS     s    zNameConstraints.__repr__c                 C   s@   | j d k	rt| j }nd }| jd k	r0t| j}nd }t||fS r%   )r   r   r   rg   )r)   Zpsesr"   r"   r#   rh     s    

zNameConstraints.__hash__r   r   N)r<   r=   r>   r   ZNAME_CONSTRAINTSr5   rT   r   r   r   r7   rd   re   r   rS   rh   r   ri   r   r   r"   r"   r"   r#   r   r  s   "	
r   c                   @   s\   e Zd ZeeedddZedZ	edZ
edZdd Zd	d
 Zdd Zdd ZdS )rH   )r5   criticalrQ   c                 C   s:   t |tstdt |ts$td|| _|| _|| _d S )Nz2oid argument must be an ObjectIdentifier instance.z critical must be a boolean value)r   r   rP   r   _oid	_critical_value)r)   r5   r  rQ   r"   r"   r#   r7     s    

zExtension.__init__r  r  r	  c                 C   s
   d | S )Nz@<Extension(oid={0.oid}, critical={0.critical}, value={0.value})>r   r(   r"   r"   r#   rS     s    zExtension.__repr__c                 C   s2   t |tstS | j|jko0| j|jko0| j|jkS r%   )r   rH   ra   r5   r  rQ   rb   r"   r"   r#   rd     s    


zExtension.__eq__c                 C   s
   | |k S r%   r"   rb   r"   r"   r#   re     s    zExtension.__ne__c                 C   s   t | j| j| jfS r%   )rg   r5   r  rQ   r(   r"   r"   r#   rh     s    zExtension.__hash__N)r<   r=   r>   r   r   rB   r7   r   ri   r5   r  rQ   rS   rd   re   rh   r"   r"   r"   r#   rH     s     



rH   c                   @   sb   e Zd Zeje dddZed\ZZ	Z
eje dddZdd	 Zd
d Zdd Zdd ZdS )GeneralNamesgeneral_namesc                 C   s,   t |}tdd |D s"td|| _d S )Nc                 s   s   | ]}t |tV  qd S r%   ro   rp   r"   r"   r#   rs     s     z(GeneralNames.__init__.<locals>.<genexpr>z^Every item in the general_names list must be an object conforming to the GeneralName interface)rt   ru   rP   _general_namesr)   r  r"   r"   r#   r7     s    zGeneralNames.__init__r  typec                    s0    fdd| D } t kr(dd |D }t|S )Nc                 3   s   | ]}t | r|V  qd S r%   )r   rq   ir  r"   r#   rs     s     
 z3GeneralNames.get_values_for_type.<locals>.<genexpr>c                 s   s   | ]}|j V  qd S r%   r   r  r"   r"   r#   rs     s     )r   rt   )r)   r  Zobjsr"   r  r#   get_values_for_type  s    z GeneralNames.get_values_for_typec                 C   s   d | jS )Nz<GeneralNames({})>rL   r  r(   r"   r"   r#   rS     s    zGeneralNames.__repr__c                 C   s   t |tstS | j|jkS r%   )r   r
  ra   r  rb   r"   r"   r#   rd     s    
zGeneralNames.__eq__c                 C   s
   | |k S r%   r"   rb   r"   r"   r#   re     s    zGeneralNames.__ne__c                 C   s   t t| jS r%   )rg   r   r  r(   r"   r"   r#   rh     s    zGeneralNames.__hash__N)r<   r=   r>   rT   r   r   r7   r1   rV   rW   rX   Typer  rS   rd   re   rh   r"   r"   r"   r#   r
    s   
	r
  c                   @   s\   e Zd ZejZeje dddZ	e
d\ZZZdd Zdd Zd	d
 Zdd Zdd ZdS )SubjectAlternativeNamer  c                 C   s   t || _d S r%   r
  r  r  r"   r"   r#   r7     s    zSubjectAlternativeName.__init__r  c                 C   s   | j |S r%   r  r  r)   r  r"   r"   r#   r     s    z*SubjectAlternativeName.get_values_for_typec                 C   s   d | jS )Nz<SubjectAlternativeName({})>r  r(   r"   r"   r#   rS   #  s    zSubjectAlternativeName.__repr__c                 C   s   t |tstS | j|jkS r%   )r   r  ra   r  rb   r"   r"   r#   rd   &  s    
zSubjectAlternativeName.__eq__c                 C   s
   | |k S r%   r"   rb   r"   r"   r#   re   ,  s    zSubjectAlternativeName.__ne__c                 C   s
   t | jS r%   rg   r  r(   r"   r"   r#   rh   /  s    zSubjectAlternativeName.__hash__N)r<   r=   r>   r   ZSUBJECT_ALTERNATIVE_NAMEr5   rT   r   r   r7   r1   rV   rW   rX   r  rS   rd   re   rh   r"   r"   r"   r#   r    s   r  c                   @   s\   e Zd ZejZeje dddZ	e
d\ZZZdd Zdd Zd	d
 Zdd Zdd ZdS )IssuerAlternativeNamer  c                 C   s   t || _d S r%   r  r  r"   r"   r#   r7   6  s    zIssuerAlternativeName.__init__r  c                 C   s   | j |S r%   r  r  r"   r"   r#   r  ;  s    z)IssuerAlternativeName.get_values_for_typec                 C   s   d | jS )Nz<IssuerAlternativeName({})>r  r(   r"   r"   r#   rS   >  s    zIssuerAlternativeName.__repr__c                 C   s   t |tstS | j|jkS r%   )r   r  ra   r  rb   r"   r"   r#   rd   A  s    
zIssuerAlternativeName.__eq__c                 C   s
   | |k S r%   r"   rb   r"   r"   r#   re   G  s    zIssuerAlternativeName.__ne__c                 C   s
   t | jS r%   r  r(   r"   r"   r#   rh   J  s    zIssuerAlternativeName.__hash__N)r<   r=   r>   r   ZISSUER_ALTERNATIVE_NAMEr5   rT   r   r   r7   r1   rV   rW   rX   r  rS   rd   re   rh   r"   r"   r"   r#   r  3  s   r  c                   @   s\   e Zd ZejZeje dddZ	e
d\ZZZdd Zdd Zd	d
 Zdd Zdd ZdS )CertificateIssuerr  c                 C   s   t || _d S r%   r  r  r"   r"   r#   r7   Q  s    zCertificateIssuer.__init__r  c                 C   s   | j |S r%   r  r  r"   r"   r#   r  V  s    z%CertificateIssuer.get_values_for_typec                 C   s   d | jS )Nz<CertificateIssuer({})>r  r(   r"   r"   r#   rS   Y  s    zCertificateIssuer.__repr__c                 C   s   t |tstS | j|jkS r%   )r   r  ra   r  rb   r"   r"   r#   rd   \  s    
zCertificateIssuer.__eq__c                 C   s
   | |k S r%   r"   rb   r"   r"   r#   re   b  s    zCertificateIssuer.__ne__c                 C   s
   t | jS r%   r  r(   r"   r"   r#   rh   e  s    zCertificateIssuer.__hash__N)r<   r=   r>   r   ZCERTIFICATE_ISSUERr5   rT   r   r   r7   r1   rV   rW   rX   r  rS   rd   re   rh   r"   r"   r"   r#   r  N  s   r  c                   @   sJ   e Zd ZejZedddZdd Zdd Z	dd	 Z
d
d ZedZdS )	CRLReason)reasonc                 C   s   t |tstd|| _d S )Nz*reason must be an element from ReasonFlags)r   r   rP   _reason)r)   r  r"   r"   r#   r7   l  s    
zCRLReason.__init__c                 C   s   d | jS )Nz<CRLReason(reason={})>)rL   r  r(   r"   r"   r#   rS   r  s    zCRLReason.__repr__c                 C   s   t |tstS | j|jkS r%   )r   r  ra   r  rb   r"   r"   r#   rd   u  s    
zCRLReason.__eq__c                 C   s
   | |k S r%   r"   rb   r"   r"   r#   re   {  s    zCRLReason.__ne__c                 C   s
   t | jS r%   )rg   r  r(   r"   r"   r#   rh   ~  s    zCRLReason.__hash__r  N)r<   r=   r>   r   Z
CRL_REASONr5   r   r7   rS   rd   re   rh   r   ri   r  r"   r"   r"   r#   r  i  s   r  c                   @   sL   e Zd ZejZejdddZdd Zdd Z	dd	 Z
d
d ZedZdS )InvalidityDate)invalidity_datec                 C   s   t |tjstd|| _d S )Nz+invalidity_date must be a datetime.datetime)r   datetimerP   _invalidity_date)r)   r!  r"   r"   r#   r7     s    zInvalidityDate.__init__c                 C   s   d | jS )Nz$<InvalidityDate(invalidity_date={})>)rL   r#  r(   r"   r"   r#   rS     s    zInvalidityDate.__repr__c                 C   s   t |tstS | j|jkS r%   )r   r   ra   r!  rb   r"   r"   r#   rd     s    
zInvalidityDate.__eq__c                 C   s
   | |k S r%   r"   rb   r"   r"   r#   re     s    zInvalidityDate.__ne__c                 C   s
   t | jS r%   )rg   r!  r(   r"   r"   r#   rh     s    zInvalidityDate.__hash__r#  N)r<   r=   r>   r   ZINVALIDITY_DATEr5   r"  r7   rS   rd   re   rh   r   ri   r!  r"   r"   r"   r#   r     s   r   c                   @   sT   e Zd ZejZeje dddZ	e
d\ZZZdd Zdd Zd	d
 Zdd ZdS ))PrecertificateSignedCertificateTimestampssigned_certificate_timestampsc                 C   s,   t |}tdd |D s"td|| _d S )Nc                 s   s   | ]}t |tV  qd S r%   r   r   rq   Zsctr"   r"   r#   rs     s   zEPrecertificateSignedCertificateTimestamps.__init__.<locals>.<genexpr>YEvery item in the signed_certificate_timestamps list must be a SignedCertificateTimestamprt   ru   rP   _signed_certificate_timestampsr)   r&  r"   r"   r#   r7     s    z2PrecertificateSignedCertificateTimestamps.__init__r+  c                 C   s   d t| S )Nz/<PrecertificateSignedCertificateTimestamps({})>rL   rt   r(   r"   r"   r#   rS     s    z2PrecertificateSignedCertificateTimestamps.__repr__c                 C   s   t t| jS r%   rg   r   r+  r(   r"   r"   r#   rh     s    z2PrecertificateSignedCertificateTimestamps.__hash__c                 C   s   t |tstS | j|jkS r%   )r   r$  ra   r+  rb   r"   r"   r#   rd     s    
z0PrecertificateSignedCertificateTimestamps.__eq__c                 C   s
   | |k S r%   r"   rb   r"   r"   r#   re     s    z0PrecertificateSignedCertificateTimestamps.__ne__N)r<   r=   r>   r   Z%PRECERT_SIGNED_CERTIFICATE_TIMESTAMPSr5   rT   r   r   r7   r1   rV   rW   rX   rS   rh   rd   re   r"   r"   r"   r#   r$    s   
	r$  c                   @   sT   e Zd ZejZeje dddZ	e
d\ZZZdd Zdd Zd	d
 Zdd ZdS )SignedCertificateTimestampsr%  c                 C   s,   t |}tdd |D s"td|| _d S )Nc                 s   s   | ]}t |tV  qd S r%   r'  r(  r"   r"   r#   rs     s   z7SignedCertificateTimestamps.__init__.<locals>.<genexpr>r)  r*  r,  r"   r"   r#   r7     s    z$SignedCertificateTimestamps.__init__r+  c                 C   s   d t| S )Nz!<SignedCertificateTimestamps({})>r-  r(   r"   r"   r#   rS     s    z$SignedCertificateTimestamps.__repr__c                 C   s   t t| jS r%   r.  r(   r"   r"   r#   rh     s    z$SignedCertificateTimestamps.__hash__c                 C   s   t |tstS | j|jkS r%   )r   r/  ra   r+  rb   r"   r"   r#   rd     s    
z"SignedCertificateTimestamps.__eq__c                 C   s
   | |k S r%   r"   rb   r"   r"   r#   re     s    z"SignedCertificateTimestamps.__ne__N)r<   r=   r>   r   ZSIGNED_CERTIFICATE_TIMESTAMPSr5   rT   r   r   r7   r1   rV   rW   rX   rS   rh   rd   re   r"   r"   r"   r#   r/    s   
	r/  c                   @   sJ   e Zd ZejZedddZdd Zdd Z	dd	 Z
d
d ZedZdS )	OCSPNonce)noncec                 C   s   t |tstd|| _d S )Nznonce must be bytes)r   r   rP   _nonce)r)   r1  r"   r"   r#   r7     s    
zOCSPNonce.__init__c                 C   s   t |tstS | j|jkS r%   )r   r0  ra   r1  rb   r"   r"   r#   rd     s    
zOCSPNonce.__eq__c                 C   s
   | |k S r%   r"   rb   r"   r"   r#   re     s    zOCSPNonce.__ne__c                 C   s
   t | jS r%   )rg   r1  r(   r"   r"   r#   rh     s    zOCSPNonce.__hash__c                 C   s
   d | S )Nz<OCSPNonce(nonce={0.nonce!r})>r   r(   r"   r"   r#   rS     s    zOCSPNonce.__repr__r2  N)r<   r=   r>   r   ZNONCEr5   r   r7   rd   re   rh   rS   r   ri   r1  r"   r"   r"   r#   r0    s   r0  c                   @   s   e Zd ZejZdd Zdd Zdd Zdd Z	d	d
 Z
edZedZedZedZedZedZedZdS )IssuingDistributionPointc           	      C   s   |r(t |tr tdd |D s(td|rHtj|ks@tj|krHtdt |trpt |trpt |trpt |tsxtd||||g}t	dd |D dkrtd	t
|||||||gstd
|| _|| _|| _|| _|| _|| _|| _d S )Nc                 s   s   | ]}t |tV  qd S r%   r   rp   r"   r"   r#   rs   #  s     z4IssuingDistributionPoint.__init__.<locals>.<genexpr>z:only_some_reasons must be None or frozenset of ReasonFlagszTunspecified and remove_from_crl are not valid reasons in an IssuingDistributionPointzuonly_contains_user_certs, only_contains_ca_certs, indirect_crl and only_contains_attribute_certs must all be boolean.c                 S   s   g | ]}|r|qS r"   r"   rp   r"   r"   r#   
<listcomp>E  s      z5IssuingDistributionPoint.__init__.<locals>.<listcomp>   zOnly one of the following can be set to True: only_contains_user_certs, only_contains_ca_certs, indirect_crl, only_contains_attribute_certszCannot create empty extension: if only_contains_user_certs, only_contains_ca_certs, indirect_crl, and only_contains_attribute_certs are all False, then either full_name, relative_name, or only_some_reasons must have a value.)r   r   ru   rP   r   r   r   r   r   r&   r  _only_contains_user_certs_only_contains_ca_certs_indirect_crl_only_contains_attribute_certs_only_some_reasonsr   r   )	r)   r   r   only_contains_user_certsonly_contains_ca_certsonly_some_reasonsindirect_crlonly_contains_attribute_certsZcrl_constraintsr"   r"   r#   r7     sp    
z!IssuingDistributionPoint.__init__c                 C   s
   d | S )NaG  <IssuingDistributionPoint(full_name={0.full_name}, relative_name={0.relative_name}, only_contains_user_certs={0.only_contains_user_certs}, only_contains_ca_certs={0.only_contains_ca_certs}, only_some_reasons={0.only_some_reasons}, indirect_crl={0.indirect_crl}, only_contains_attribute_certs={0.only_contains_attribute_certs})>r   r(   r"   r"   r#   rS   g  s    z!IssuingDistributionPoint.__repr__c                 C   sb   t |tstS | j|jko`| j|jko`| j|jko`| j|jko`| j|jko`| j|jko`| j	|j	kS r%   )
r   r3  ra   r   r   r;  r<  r=  r>  r?  rb   r"   r"   r#   rd   s  s"    





zIssuingDistributionPoint.__eq__c                 C   s
   | |k S r%   r"   rb   r"   r"   r#   re     s    zIssuingDistributionPoint.__ne__c                 C   s$   t | j| j| j| j| j| j| jfS r%   )rg   r   r   r;  r<  r=  r>  r?  r(   r"   r"   r#   rh     s    z!IssuingDistributionPoint.__hash__r   r   r6  r7  r:  r8  r9  N)r<   r=   r>   r   ZISSUING_DISTRIBUTION_POINTr5   r7   rS   rd   re   rh   r   ri   r   r   r;  r<  r=  r>  r?  r"   r"   r"   r#   r3    s&   P



r3  c                   @   sP   e Zd ZeedddZedZedZ	dd Z
dd	 Zd
d Zdd ZdS )rO   )r5   rQ   c                 C   s"   t |tstd|| _|| _d S )Nzoid must be an ObjectIdentifier)r   r   rP   r  r	  )r)   r5   rQ   r"   r"   r#   r7     s    
zUnrecognizedExtension.__init__r  r	  c                 C   s
   d | S )Nz7<UnrecognizedExtension(oid={0.oid}, value={0.value!r})>r   r(   r"   r"   r#   rS     s    zUnrecognizedExtension.__repr__c                 C   s&   t |tstS | j|jko$| j|jkS r%   )r   rO   ra   r5   rQ   rb   r"   r"   r#   rd     s    
zUnrecognizedExtension.__eq__c                 C   s
   | |k S r%   r"   rb   r"   r"   r#   re     s    zUnrecognizedExtension.__ne__c                 C   s   t | j| jfS r%   )rg   r5   rQ   r(   r"   r"   r#   rh     s    zUnrecognizedExtension.__hash__N)r<   r=   r>   r   r   r7   r   ri   r5   rQ   rS   rd   re   rh   r"   r"   r"   r#   rO     s   

rO   )TrD   r"  r   r   rT   enumr   Zcryptographyr   Zcryptography.hazmat._derr   r   r   r   Zcryptography.hazmat._typesr   Zcryptography.hazmat.primitivesr	   r
   Z,cryptography.hazmat.primitives.asymmetric.ecr   Z-cryptography.hazmat.primitives.asymmetric.rsar   Z*cryptography.x509.certificate_transparencyr   Zcryptography.x509.general_namer   r   r   Zcryptography.x509.namer   Zcryptography.x509.oidr   r   r   r   r   r$   r1   	Exceptionr2   rA   ABCMetarB   objectrG   rY   rj   r}   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   Z_TLS_FEATURE_TYPE_TO_ENUMr   r   r   rH   r
  r  r  r  r  r   r$  r/  r0  r3  rO   r"   r"   r"   r#   <module>   sx   (!_&)%%d@7)&"qU+&-+ 