Your IP : 3.12.153.240


Current Path : /usr/lib/python3.6/site-packages/dns/__pycache__/
Upload File :
Current File : //usr/lib/python3.6/site-packages/dns/__pycache__/name.cpython-36.pyc

3

�Of�r�@s�dZddlmZddlZddlZddlZddlZyddlZdZ	Wne
k
rXdZ	YnXddlZddl
ZddlmZmZmZmZmZy
ejZWn.ek
r�ddejd	�>d
dZYnXdZdZd
ZdZdZGd
d�dejj�ZGdd�dejj�ZGdd�dejj �Z!Gdd�dejj �Z"Gdd�dejj#�Z$Gdd�dejj �Z%Gdd�dejj�Z&Gdd�dejj#�Z'Gdd�dejj#�Z(Gdd �d ejj#�Z)Gd!d"�d"ejj#�Z*Gd#d$�d$e+�Z,Gd%d&�d&e,�Z-Gd'd(�d(e,�Z.e/d)�Z0d*Z1e-d�Z2e-d�Z3e2Z4e.dddd�Z5e.dddd�Z6e.dddd�Z7e.dddd�Z8e5Z9d+d,�Z:d-d.�Z;d/d0�Z<Gd1d2�d2e+�Z=e=d3g�Z>e=g�Z?e>dfd4d5�Z@e>dfd6d7�ZAd8d9�ZBdS):z�DNS Names.

@var root: The DNS root name.
@type root: dns.name.Name object
@var empty: The empty DNS name.
@type empty: dns.name.Name object
�)�BytesIONTF�)�long�binary_type�	text_type�unichr�maybe_decode��P���c@seZdZdZdS)�
EmptyLabelzA DNS label is empty.N)�__name__�
__module__�__qualname__�__doc__�rr�/usr/lib/python3.6/name.pyr4src@seZdZdZdS)�	BadEscapez8An escaped code in a text format of DNS name is invalid.N)rrrrrrrrr9src@seZdZdZdS)�
BadPointerz=A DNS compression pointer points forward instead of backward.N)rrrrrrrrr>src@seZdZdZdS)�BadLabelTypez2The label type in DNS name wire format is unknown.N)rrrrrrrrrCsrc@seZdZdZdS)�NeedAbsoluteNameOrOriginzvAn attempt was made to convert a non-absolute name to
    wire when there was also a non-absolute (or missing) origin.N)rrrrrrrrrHsrc@seZdZdZdS)�NameTooLongz A DNS name is > 255 octets long.N)rrrrrrrrrNsrc@seZdZdZdS)�LabelTooLongz A DNS label is > 63 octets long.N)rrrrrrrrrSsrc@seZdZdZdS)�AbsoluteConcatenationz]An attempt was made to append anything other than the
    empty name to an absolute DNS name.N)rrrrrrrrrXsrc@seZdZdZdS)�NoParentzMAn attempt was made to get the parent of the root name
    or the empty name.N)rrrrrrrrr^src@seZdZdZdS)�
NoIDNA2008zLIDNA 2008 processing was requested but the idna module is not
    available.N)rrrrrrrrrcsrc@seZdZdZedg�ZdZdS)�
IDNAExceptionz$IDNA processing raised an exception.�idna_exceptionz+IDNA processing exception: {idna_exception}N)rrrr�setZsupp_kwargsZfmtrrrrris
rc@s8eZdZdZdd�Zdd�Zdd�Zdd	�Zd
d�ZdS)
�	IDNACodecz.Abstract base class for IDNA encoder/decoders.cCsdS)Nr)�selfrrr�__init__tszIDNACodec.__init__cCs|j�jd�S)Nsxn--)�lower�
startswith)r"�labelrrr�is_idnawszIDNACodec.is_idnacCs"x|D]}t|�dkrdSqWdS)N�FT)�ord)r"r&�crrr�is_all_asciizs
zIDNACodec.is_all_asciicCst�dS)N)�NotImplementedError)r"r&rrr�encode�szIDNACodec.encodecCs`|j|�rPy|dd�jd�}WqXtk
rL}zt|d��WYdd}~XqXXnt|�}t|�S)Nr
Zpunycode)r)r'�decode�	Exceptionrr�	_escapify)r"r&�errrr.�s
zIDNACodec.decodeN)	rrrrr#r'r+r-r.rrrrr!psr!cs6eZdZdZd	�fdd�	Zdd�Z�fdd�Z�ZS)
�
IDNA2003CodeczIDNA 2003 encoder/decoder.Fcstt|�j�||_dS)aInitialize the IDNA 2003 encoder/decoder.
        @param strict_decode: If True, then IDNA2003 checking is done when
        decoding.  This can cause failures if the name was encoded with
        IDNA2008.  The default is False.
        @type strict_decode: bool
        N)�superr2r#�
strict_decode)r"r4)�	__class__rrr#�szIDNA2003Codec.__init__cCs6|dkrdSytjj|�Stk
r0t�YnXdS)N��)�	encodings�idnaZToASCII�UnicodeErrorr)r"r&rrrr-�szIDNA2003Codec.encodecsd|jstt|�j|�S|dkr"dSyttjj|��Stk
r^}zt	|d��WYdd}~XnXdS)Nr7r6)r)
r4r3r2r.r0r8r9Z	ToUnicoder/r)r"r&r1)r5rrr.�szIDNA2003Codec.decode)F)rrrrr#r-r.�
__classcell__rr)r5rr2�s
r2cs6eZdZdZd	�fdd�	Zdd�Z�fdd�Z�ZS)
�
IDNA2008CodeczIDNA 2008 encoder/decoder.Fcs*tt|�j�||_||_||_||_dS)a�Initialize the IDNA 2008 encoder/decoder.
        @param uts_46: If True, apply Unicode IDNA compatibility processing
        as described in Unicode Technical Standard #46
        (U{http://unicode.org/reports/tr46/}).  This parameter is only
        meaningful if IDNA 2008 is in use.  If False, do not apply
        the mapping.  The default is False
        @type uts_46: bool
        @param transitional: If True, use the "transitional" mode described
        in Unicode Technical Standard #46.  This parameter is only
        meaningful if IDNA 2008 is in use.  The default is False.
        @type transitional: bool
        @param allow_pure_ascii: If True, then a label which
        consists of only ASCII characters is allowed.  This is less strict
        than regular IDNA 2008, but is also necessary for mixed names,
        e.g. a name with starting with "_sip._tcp." and ending in an IDN
        suffixm which would otherwise be disallowed.  The default is False
        @type allow_pure_ascii: bool
        @param strict_decode: If True, then IDNA2008 checking is done when
        decoding.  This can cause failures if the name was encoded with
        IDNA2003.  The default is False.
        @type strict_decode: bool
        N)r3r<r#�uts_46�transitional�allow_pure_asciir4)r"r=r>r?r4)r5rrr#�s
zIDNA2008Codec.__init__cCs�|dkrdS|jr&|j|�r&|jd�Sts.t�y |jrFtj|d|j�}tj	|�Stj
k
r|}zt|d��WYdd}~XnXdS)Nr6r7�asciiF)r)r?r+r-�have_idna_2008rr=r9�uts46_remapr>Zalabel�	IDNAErrorr)r"r&r1rrrr-�s

zIDNA2008Codec.encodecs�|jstt|�j|�S|dkr"dSts*t�y"|jr@tj|dd�}t	tj
|��Stjk
rz}zt|d��WYdd}~XnXdS)Nr7r6F)r)
r4r3r<r.rArr=r9rBr0ZulabelrCr)r"r&r1)r5rrr.�szIDNA2008Codec.decode)FFFF)rrrrr#r-r.r;rr)r5rr<�s
r<s"().;\@$z"().;\@$cCs�t|t�rzd}t|t�r |j�}xTt|�D]H}|tkrH|dt|�7}q*|dkrf|dkrf|t|�7}q*|d|7}q*W|Sd}xD|D]<}|tkr�|d|7}q�|dkr�|dt|�7}q�||7}q�W|S)zaEscape the characters in label which need it.
    @returns: the escaped string
    @rtype: stringr6�\� r(z\%03d� )	�
isinstance�bytesrr-�	bytearray�_escaped�chr�
_escaped_textr))r&�textr*rrrr0�s&


r0cCs�t|�}d}d}d}xH|D]@}t|�}||d7}|dkr>t�|dkrR|dkrR|}|d7}qW|dkrjt�|dkr�||dkr�t�dS)a/Check for empty labels in the middle of a label sequence,
    labels that are too long, and for too many labels.
    @raises NameTooLong: the name as a whole is too long
    @raises EmptyLabel: a label is empty (i.e. the root label) and appears
    in a position other than the end of the label sequencerr�?r7�N���)�lenrrr)�labels�l�total�i�jr&Zllrrr�_validate_labelss 
rWcCs(t|t�r|St|t�r |j�St�dS)N)rGrrr-�
ValueError)r&rrr�
_ensure_bytes/s


rYcsDeZdZdZdgZ�fdd�Zdd�Zdd�Zd	d
�Zdd�Z	�fd
d�Z
dd�Zdd�Zdd�Z
dd�Zdd�Zdd�Zdd�Zdd�Zdd �Zd!d"�Zd#d$�Zd%d&�Zd'd(�Zd)d*�Zd+d,�ZdLd.d/�ZdMd1d2�ZdNd3d4�ZdOd5d6�Zd7d8�Zd9d:�Zd;d<�Z d=d>�Z!d?d@�Z"dAdB�Z#dCdD�Z$dEdF�Z%dPdHdI�Z&dJdK�Z'�Z(S)Q�Namez�A DNS name.

    The dns.name.Name class represents a DNS name as a tuple of labels.
    Instances of the class are immutable.

    @ivar labels: The tuple of labels in the name. Each label is a string of
    up to 63 octets.rRcs2dd�|D�}tt|�jdt|��t|j�dS)z�Initialize a domain name from a list of labels.
        @param labels: the labels
        @type labels: any iterable whose values are strings
        cSsg|]}t|��qSr)rY)�.0�xrrr�
<listcomp>Hsz!Name.__init__.<locals>.<listcomp>rRN)r3rZ�__setattr__�tuplerWrR)r"rR)r5rrr#Csz
Name.__init__cCstd��dS)Nz+object doesn't support attribute assignment)�	TypeError)r"�name�valuerrrr^LszName.__setattr__cCs
t|j�S)N)rZrR)r"rrr�__copy__Osz
Name.__copy__cCsttj|j|��S)N)rZ�copy�deepcopyrR)r"�memorrr�__deepcopy__RszName.__deepcopy__cCs
d|jiS)NrR)rR)r"rrr�__getstate__UszName.__getstate__cs$tt|�jd|d�t|j�dS)NrR)r3rZr^rWrR)r"�state)r5rr�__setstate__XszName.__setstate__cCst|j�dko|jddkS)zXIs the most significant label of this name the root label?
        @rtype: bool
        rrr7rP)rQrR)r"rrr�is_absolute\szName.is_absolutecCst|j�dko|jddkS)z\Is this name wild?  (I.e. Is the least significant label '*'?)
        @rtype: bool
        r�*)rQrR)r"rrr�is_wildcszName.is_wildcCsJtd�}x4|jD]*}x$t|j��D]}||d>|7}q"WqWt|t�S)zHReturn a case-insensitive hash of the name.
        @rtype: int
        rr)rrRrIr$�int�maxint)r"�hr&r*rrr�__hash__js
z
Name.__hash__c
Cs*|j�}|j�}||kr0|r&tddfStddfSt|j�}t|j�}||}|dkrZ|}n|}d}d}	t}
x�|dkr�|d8}|d8}|d8}|j|j�}|j|j�}||kr�d}|	dkr�t}
|
||	fS||kr�d}|	dkr�t}
|
||	fS|	d7}	qlW|}|dk�rt}
n|dk�rt}
nt}
|
||	fS)a�Compare two names, returning a 3-tuple (relation, order, nlabels).

        I{relation} describes the relation ship between the names,
        and is one of: dns.name.NAMERELN_NONE,
        dns.name.NAMERELN_SUPERDOMAIN, dns.name.NAMERELN_SUBDOMAIN,
        dns.name.NAMERELN_EQUAL, or dns.name.NAMERELN_COMMONANCESTOR

        I{order} is < 0 if self < other, > 0 if self > other, and ==
        0 if self == other.  A relative name is always less than an
        absolute name.  If both names have the same relativity, then
        the DNSSEC order relation is used to order them.

        I{nlabels} is the number of significant labels that the two names
        have in common.
        rrrPrP)	rk�
NAMERELN_NONErQrRr$�NAMERELN_COMMONANCESTOR�NAMERELN_SUPERDOMAIN�NAMERELN_SUBDOMAIN�NAMERELN_EQUAL)
r"�otherZsabsZoabs�l1�l2ZldiffrS�orderZnlabelsZnamerelnZlabel1Zlabel2rrr�fullcompareusN








zName.fullcomparecCs(|j|�\}}}|tks |tkr$dSdS)zoIs self a subdomain of other?

        The notion of subdomain includes equality.
        @rtype: bool
        TF)r{rurv)r"rw�nr�o�nlrrr�is_subdomain�szName.is_subdomaincCs(|j|�\}}}|tks |tkr$dSdS)zqIs self a superdomain of other?

        The notion of subdomain includes equality.
        @rtype: bool
        TF)r{rtrv)r"rwr|r}r~rrr�is_superdomain�szName.is_superdomaincCstdd�|jD��S)z�Return a name which is equal to the current name, but is in
        DNSSEC canonical form.
        @rtype: dns.name.Name object
        cSsg|]}|j��qSr)r$)r[r\rrrr]�sz%Name.canonicalize.<locals>.<listcomp>)rZrR)r"rrr�canonicalize�szName.canonicalizecCs$t|t�r|j|�ddkSdSdS)NrrF)rGrZr{)r"rwrrr�__eq__�s
zName.__eq__cCs$t|t�r|j|�ddkSdSdS)NrrT)rGrZr{)r"rwrrr�__ne__�s
zName.__ne__cCs$t|t�r|j|�ddkStSdS)Nrr)rGrZr{�NotImplemented)r"rwrrr�__lt__�s
zName.__lt__cCs$t|t�r|j|�ddkStSdS)Nrr)rGrZr{r�)r"rwrrr�__le__�s
zName.__le__cCs$t|t�r|j|�ddkStSdS)Nrr)rGrZr{r�)r"rwrrr�__ge__�s
zName.__ge__cCs$t|t�r|j|�ddkStSdS)Nrr)rGrZr{r�)r"rwrrr�__gt__�s
zName.__gt__cCsd|j�dS)Nz
<DNS name �>)�__str__)r"rrr�__repr__�sz
Name.__repr__cCs
|jd�S)NF)�to_text)r"rrrr��szName.__str__FcCspt|j�dkrtd�St|j�dkr:|jddkr:td�S|rV|j�rV|jdd�}n|j}djtt|��}|S)	z�Convert name to text format.
        @param omit_final_dot: If True, don't emit the final dot (denoting the
        root label) for absolute names.  The default is False.
        @rtype: string
        r�@rr7�.N�.rP)rQrRrrk�join�mapr0)r"�omit_final_dotrS�srrrr��szName.to_textNcsxt|j�dkrdSt|j�dkr2|jddkr2dS|rN|j�rN|jdd	�}n|j}�dkr`t�dj�fdd�|D��S)
a�Convert name to Unicode text format.

        IDN ACE labels are converted to Unicode.

        @param omit_final_dot: If True, don't emit the final dot (denoting the
        root label) for absolute names.  The default is False.
        @type omit_final_dot: bool
        @param idna_codec: IDNA encoder/decoder.  If None, the
        IDNA_2003_Practical encoder/decoder is used.  The IDNA_2003_Practical
        decoder does not impose any policy, it just decodes punycode, so if
        you don't want checking for compliance, you can use this decoder for
        IDNA2008 as well.
        @type idna_codec: dns.name.IDNA
        @rtype: string
        r�@rr7r�Ncsg|]}�j|��qSr)r.)r[r\)�
idna_codecrrr])sz#Name.to_unicode.<locals>.<listcomp>rP)rQrRrk�IDNA_2003_Practicalr�)r"r�r�rSr)r�r�
to_unicodeszName.to_unicodecCsX|j�s:|dks|j�rt�t|j�}|jt|j��n|j}dd�|D�}dj|�S)aConvert name to a format suitable for digesting in hashes.

        The name is canonicalized and converted to uncompressed wire format.

        @param origin: If the name is relative and origin is not None, then
        origin will be appended to it.
        @type origin: dns.name.Name object
        @raises NeedAbsoluteNameOrOrigin: All names in wire format are
        absolute.  If self is a relative name, then an origin must be supplied;
        if it is missing, then this exception is raised
        @rtype: string
        NcSs*g|]"}tjdt|�t|�|j���qS)z!B%ds)�struct�packrQr$)r[r\rrrr]@sz&Name.to_digestable.<locals>.<listcomp>r7)rkr�listrR�extendr�)r"�originrRZdlabelsrrr�
to_digestable+s
zName.to_digestablec
Cs.|dkrt�}d}nd}|j�sR|dks2|j�r6t�t|j�}|jt|j��n|j}d}x�|D]�}t||d��}|d7}|dk	r�|j|�}	nd}	|	dk	r�d|	}
tj	d|
�}|j
|�Pqb|dk	r�t|�dkr�|j�}	|	dkr�|	||<t|�}|j
tj	d	|��|dkrb|j
|�qbW|�r*|j
�SdS)
a�Convert name to wire format, possibly compressing it.

        @param file: the file where the name is emitted (typically
        a BytesIO file).  If None, a string containing the wire name
        will be returned.
        @type file: file or None
        @param compress: The compression table.  If None (the default) names
        will not be compressed.
        @type compress: dict
        @param origin: If the name is relative and origin is not None, then
        origin will be appended to it.
        @type origin: dns.name.Name object
        @raises NeedAbsoluteNameOrOrigin: All names in wire format are
        absolute.  If self is a relative name, then an origin must be supplied;
        if it is missing, then this exception is raised
        NTFrri�z!Hi�?z!B)rrkrr�rRr�rZ�getr�r��writerQ�tell�getvalue)
r"�file�compressr�Zwant_returnrRrUr&�n�posrbr�rSrrr�to_wireDs@


zName.to_wirecCs
t|j�S)z@The length of the name (in labels).
        @rtype: int
        )rQrR)r"rrr�__len__|szName.__len__cCs
|j|S)N)rR)r"�indexrrr�__getitem__�szName.__getitem__cCs
|j|�S)N)�concatenate)r"rwrrr�__add__�szName.__add__cCs
|j|�S)N)�
relativize)r"rwrrr�__sub__�szName.__sub__cCsnt|j�}|dkr|tjjfS||kr2tjj|fS|dksB||krJtd��t|d|��t||d��fS)a(Split a name into a prefix and suffix at depth.

        @param depth: the number of labels in the suffix
        @type depth: int
        @raises ValueError: the depth was not >= 0 and <= the length of the
        name.
        @returns: the tuple (prefix, suffix)
        @rtype: tuple
        rz0depth must be >= 0 and <= the length of the nameN)rQrR�dnsra�emptyrXrZ)r"�depthrSrrr�split�s
z
Name.splitcCs:|j�rt|�dkrt�t|j�}|jt|j��t|�S)z�Return a new name which is the concatenation of self and other.
        @rtype: dns.name.Name object
        @raises AbsoluteConcatenation: self is absolute and other is
        not the empty name
        r)rkrQrr�rRr�rZ)r"rwrRrrrr��s

zName.concatenatecCs0|dk	r(|j|�r(t|dt|���S|SdS)z�If self is a subdomain of origin, return a new name which is self
        relative to origin.  Otherwise return self.
        @rtype: dns.name.Name object
        N)rrZrQ)r"r�rrrr��szName.relativizecCs|j�s|j|�S|SdS)z�If self is a relative name, return a new name which is the
        concatenation of self and origin.  Otherwise return self.
        @rtype: dns.name.Name object
        N)rkr�)r"r�rrr�derelativize�s
zName.derelativizeTcCs&|r|r|j|�S|j|�Sn|SdS)aReturn a name with the relativity desired by the caller.  If
        origin is None, then self is returned.  Otherwise, if
        relativize is true the name is relativized, and if relativize is
        false the name is derelativized.
        @rtype: dns.name.Name object
        N)r�r�)r"r�r�rrr�choose_relativity�s

zName.choose_relativitycCs&|tks|tkrt�t|jdd��S)z�Return the parent of the name.
        @rtype: dns.name.Name object
        @raises NoParent: the name is either the root name or the empty name,
        and thus has no parent.
        rN)�rootr�rrZrR)r"rrr�parent�szName.parent)F)FN)N)NNN)NT))rrrr�	__slots__r#r^rcrgrhrjrkrmrqr{rr�r�r�r�r�r�r�r�r�r�r�r�r�r�r�r�r�r�r�r�r�r�r�r�r;rr)r5rrZ7sJ	=



8

rZr7c	Cs�t|t�std��|dkp"t|t�s,td��g}d}d}d}d}|dkrLt}|dkrXd}|�rz|dkrptd	g�Sx�|D]�}|r�|dkr�|j�r�t|�}|d
7}q�||7}d}n@|j�s�t�|d9}|t|�7}|d
7}|dkr�d}|t|�7}qv|dk�r"t	|�dk�rt
�|j|j|��d}qv|dk�r:d}d}d}qv||7}qvW|�rPt�t	|�dk�rp|j|j|��n
|jd	�t	|�dk�s�|dd	k�r�|dk	�r�|j
t|j��t|�S)a�Convert unicode text into a Name object.

    Labels are encoded in IDN ACE form.

    @param text: The text to convert into a name.
    @type text: Unicode string
    @param origin: The origin to append to non-absolute names.
    @type origin: dns.name.Name
    @param idna_codec: IDNA encoder/decoder.  If None, the default IDNA 2003
    encoder/decoder is used.
    @type idna_codec: dns.name.IDNA
    @rtype: dns.name.Name object
    z0input to from_unicode() must be a unicode stringNzorigin must be a Name or Noner6Frr�r�r7r�
r�。�.�。rDT)r�r�r�r�rP)rGrrXrZ�	IDNA_2003�isdigitrnrrrQr�appendr-r�r�rR)	rMr�r�rRr&�escaping�edigitsrTr*rrr�from_unicode�sd






&r�c
Cs�t|t�rt|||�St|t�s(td��|dkp8t|t�sBtd��g}d}d}d}d}|dkrbd}|�r�|dkrztdg�Sx�t|�D]�}tjd	|�}	|�r|dkr�|	j	�r�t
|	�}|d
7}n||	7}d}nF|	j	�s�t�|d9}|t
|	�7}|d
7}|dk�r^d}|tjd	|�7}q�|	dk�r>t|�dk�r.t
�|j|�d}q�|	d
k�rVd}d}d}q�||	7}q�W|�rlt�t|�dk�r�|j|�n
|jd�t|�dk�s�|ddk�r�|dk	�r�|jt|j��t|�S)a}Convert text into a Name object.

    @param text: The text to convert into a name.
    @type text: string
    @param origin: The origin to append to non-absolute names.
    @type origin: dns.name.Name
    @param idna_codec: IDNA encoder/decoder.  If None, the default IDNA 2003
    encoder/decoder is used.
    @type idna_codec: dns.name.IDNA
    @rtype: dns.name.Name object
    z%input to from_text() must be a stringNzorigin must be a Name or Noner7Frr�r�z!Brr�r�\TrP)rGrr�rrXrZrIr�r�r�rnrrQrr�r�r�rR)
rMr�r�rRr&r�r�rTr*Zbyte_rrr�	from_text*sf








&r�cCst|t�std��tjj|�}g}|}d}||}|d7}d}x�|dkr�|dkr�|j||||�j��||7}|dkr�||7}nJ|dkr�|d@d||}|dkr�|d7}||kr�t�|}|d7}nt	�||}|d7}|dkr@|d7}q@W|jd�t
|�|fS)	a^Convert possibly compressed wire format into a Name.
    @param message: the entire DNS message
    @type message: string
    @param current: the offset of the beginning of the name from the start
    of the message
    @type current: int
    @raises dns.name.BadPointer: a compression pointer did not point backwards
    in the message
    @raises dns.name.BadLabelType: an invalid label type was encountered.
    @returns: a tuple consisting of the name that was read and the number
    of bytes of the wire format message which were consumed reading it
    @rtype: (dns.name.Name object, int) tuple
    z*input to from_wire() must be a byte stringrr�@�rN�r6)rGrrXr�ZwiredataZ
maybe_wrapr�ZunwraprrrZ)�messageZcurrentrRZbiggest_pointerZhops�countZcusedrrr�	from_wireps<




r�)Cr�iorr��sysrdZencodings.idnar8r9rA�ImportErrorZ
dns.exceptionr�Zdns.wiredataZ_compatrrrrrro�AttributeError�calcsizerrrtrurvrsZ	exception�SyntaxErrorrrZ	FormErrorrrZDNSExceptionrrrrrrr�objectr!r2r<rIrJrLr�ZIDNA_2003_Strictr�ZIDNA_2008_PracticalZIDNA_2008_UTS_46ZIDNA_2008_StrictZIDNA_2008_TransitionalZ	IDNA_2008r0rWrYrZr�r�r�r�r�rrrr�<module>st

  >*
HF

?>