%PDF- %PDF-
Mini Shell

Mini Shell

Direktori : /lib/python3/dist-packages/dns/__pycache__/
Upload File :
Create Path :
Current File : //lib/python3/dist-packages/dns/__pycache__/e164.cpython-312.pyc

�

5��e��	��dZddlmZmZmZddlZddlZddlZejjd�Zefdedeejjdejjfd�Zed	fd
ejjdeejjdedefd�Z	dd
edeeejjefdeej"j$dej"j&fd�Zy)zDNS E.164 helpers.�)�Iterable�Optional�UnionNz
e164.arpa.�text�origin�returnc���|D�cgc]}|j�s�|��}}|j�tjj	dj|�|��Scc}w)a�Convert an E.164 number in textual form into a Name object whose
    value is the ENUM domain name for that number.

    Non-digits in the text are ignored, i.e. "16505551212",
    "+1.650.555.1212" and "1 (650) 555-1212" are all the same.

    *text*, a ``str``, is an E.164 number in textual form.

    *origin*, a ``dns.name.Name``, the domain in which the number
    should be constructed.  The default is ``e164.arpa.``.

    Returns a ``dns.name.Name``.
    �.)r)�isdigit�reverse�dns�name�	from_text�join)rr�d�partss    �*/usr/lib/python3/dist-packages/dns/e164.py�	from_e164rsO��"�,�1��	�	��Q�,�E�,�	�M�M�O��8�8���c�h�h�u�o�f��=�=��
-s
�A!�A!Tr�want_plus_prefixc��|�|j|�}|jD�cgc]$}|j�s�t|�dk(s�#|��&}}t|�t|j�k7rtj
j
d��|j�dj|�}|rd|z}|j�Scc}w)a�Convert an ENUM domain name into an E.164 number.

    Note that dnspython does not have any information about preferred
    number formats within national numbering plans, so all numbers are
    emitted as a simple string of digits, prefixed by a '+' (unless
    *want_plus_prefix* is ``False``).

    *name* is a ``dns.name.Name``, the ENUM domain name.

    *origin* is a ``dns.name.Name``, a domain containing the ENUM
    domain name.  The name is relativized to this domain before being
    converted to text.  If ``None``, no relativization is done.

    *want_plus_prefix* is a ``bool``.  If True, add a '+' to the beginning of
    the returned number.

    Returns a ``str``.

    �z$non-digit labels in ENUM domain name��+)
�
relativize�labelsr�lenr
�	exception�SyntaxErrorrr�decode)rrrr�dlabelsrs      r�to_e164r!4s���0�����v�&���+�+�E�Q������Q��1��q�E�G�E�
�7�|�s�4�;�;�'�'��m�m�'�'�(N�O�O��O�O���8�8�G��D���d�{���;�;�=���Fs�C�C�C�number�domains�resolverc��|�tjj�}tjj�}|D]e}t	|t
�rtjj|�}tjj||�}	|j|d�cS|�#tjj$r}||z
}Yd}~��d}~wwxYw)a~Look for NAPTR RRs for the specified number in the specified domains.

    e.g. lookup('16505551212', ['e164.dnspython.org.', 'e164.arpa.'])

    *number*, a ``str`` is the number to look for.

    *domains* is an iterable containing ``dns.name.Name`` values.

    *resolver*, a ``dns.resolver.Resolver``, is the resolver to use.  If
    ``None``, the default resolver is used.
    N�NAPTR)r
r$�get_default_resolver�NXDOMAIN�
isinstance�strrr�e164r�resolve)r"r#r$�e_nx�domain�qname�es       r�queryr1Xs���"���<�<�4�4�6���<�<� � �"�D�����f�c�"��X�X�'�'��/�F����"�"�6�6�2��	��#�#�E�7�3�3���J���|�|�$�$�	��A�I�D��	�s�B+�+C�C�C)N)�__doc__�typingrrr�
dns.exceptionr
�dns.name�dns.resolverrr�public_enum_domainr*�Namer�boolr!r$�Resolver�Answerr1�rr�<module>r=s
��$�,�,�����X�X�'�'��5��2D�>�

�>�����
�
�.�>��X�X�]�]�>�0'9�!�!�

�(�(�-�-�!��S�X�X�]�]�#�!��!�	�	!�N15����
�e�C�H�H�M�M�3�.�/�
0���s�|�|�,�,�-��	�\�\���	r

Zerion Mini Shell 1.0