__ __ __ __ _____ _ _ _____ _ _ _ | \/ | \ \ / / | __ \ (_) | | / ____| | | | | | \ / |_ __\ V / | |__) | __ ___ ____ _| |_ ___ | (___ | |__ ___| | | | |\/| | '__|> < | ___/ '__| \ \ / / _` | __/ _ \ \___ \| '_ \ / _ \ | | | | | | |_ / . \ | | | | | |\ V / (_| | || __/ ____) | | | | __/ | | |_| |_|_(_)_/ \_\ |_| |_| |_| \_/ \__,_|\__\___| |_____/|_| |_|\___V 2.1 if you need WebShell for Seo everyday contact me on Telegram Telegram Address : @jackleetFor_More_Tools:
# Copyright (C) Dnspython Contributors, see LICENSE for text of ISC license
# Copyright (C) 2003-2017 Nominum, Inc.
#
# Permission to use, copy, modify, and distribute this software and its
# documentation for any purpose with or without fee is hereby granted,
# provided that the above copyright notice and this permission notice
# appear in all copies.
#
# THE SOFTWARE IS PROVIDED "AS IS" AND NOMINUM DISCLAIMS ALL WARRANTIES
# WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
# MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL NOMINUM BE LIABLE FOR
# ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
# WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
# ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT
# OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
"""Generic Internet address helper functions."""
from typing import Any, Optional, Tuple
import socket
import dns.ipv4
import dns.ipv6
# We assume that AF_INET and AF_INET6 are always defined. We keep
# these here for the benefit of any old code (unlikely though that
# is!).
AF_INET = socket.AF_INET
AF_INET6 = socket.AF_INET6
def inet_pton(family: int, text: str) -> bytes:
"""Convert the textual form of a network address into its binary form.
*family* is an ``int``, the address family.
*text* is a ``str``, the textual address.
Raises ``NotImplementedError`` if the address family specified is not
implemented.
Returns a ``bytes``.
"""
if family == AF_INET:
return dns.ipv4.inet_aton(text)
elif family == AF_INET6:
return dns.ipv6.inet_aton(text, True)
else:
raise NotImplementedError
def inet_ntop(family: int, address: bytes) -> str:
"""Convert the binary form of a network address into its textual form.
*family* is an ``int``, the address family.
*address* is a ``bytes``, the network address in binary form.
Raises ``NotImplementedError`` if the address family specified is not
implemented.
Returns a ``str``.
"""
if family == AF_INET:
return dns.ipv4.inet_ntoa(address)
elif family == AF_INET6:
return dns.ipv6.inet_ntoa(address)
else:
raise NotImplementedError
def af_for_address(text: str) -> int:
"""Determine the address family of a textual-form network address.
*text*, a ``str``, the textual address.
Raises ``ValueError`` if the address family cannot be determined
from the input.
Returns an ``int``.
"""
try:
dns.ipv4.inet_aton(text)
return AF_INET
except Exception:
try:
dns.ipv6.inet_aton(text, True)
return AF_INET6
except Exception:
raise ValueError
def is_multicast(text: str) -> bool:
"""Is the textual-form network address a multicast address?
*text*, a ``str``, the textual address.
Raises ``ValueError`` if the address family cannot be determined
from the input.
Returns a ``bool``.
"""
try:
first = dns.ipv4.inet_aton(text)[0]
return first >= 224 and first <= 239
except Exception:
try:
first = dns.ipv6.inet_aton(text, True)[0]
return first == 255
except Exception:
raise ValueError
def is_address(text: str) -> bool:
"""Is the specified string an IPv4 or IPv6 address?
*text*, a ``str``, the textual address.
Returns a ``bool``.
"""
try:
dns.ipv4.inet_aton(text)
return True
except Exception:
try:
dns.ipv6.inet_aton(text, True)
return True
except Exception:
return False
def low_level_address_tuple(
high_tuple: Tuple[str, int], af: Optional[int] = None
) -> Any:
"""Given a "high-level" address tuple, i.e.
an (address, port) return the appropriate "low-level" address tuple
suitable for use in socket calls.
If an *af* other than ``None`` is provided, it is assumed the
address in the high-level tuple is valid and has that af. If af
is ``None``, then af_for_address will be called.
"""
address, port = high_tuple
if af is None:
af = af_for_address(address)
if af == AF_INET:
return (address, port)
elif af == AF_INET6:
i = address.find("%")
if i < 0:
# no scope, shortcut!
return (address, port, 0, 0)
# try to avoid getaddrinfo()
addrpart = address[:i]
scope = address[i + 1 :]
if scope.isdigit():
return (addrpart, port, 0, int(scope))
try:
return (addrpart, port, 0, socket.if_nametoindex(scope))
except AttributeError: # pragma: no cover (we can't really test this)
ai_flags = socket.AI_NUMERICHOST
((*_, tup), *_) = socket.getaddrinfo(address, port, flags=ai_flags)
return tup
else:
raise NotImplementedError(f"unknown address family {af}")
| Name | Type | Size | Permission | Actions |
|---|---|---|---|---|
| __pycache__ | Folder | 0755 |
|
|
| quic | Folder | 0755 |
|
|
| rdtypes | Folder | 0755 |
|
|
| __init__.py | File | 1.61 KB | 0644 |
|
| _asyncbackend.py | File | 1.96 KB | 0644 |
|
| _asyncio_backend.py | File | 5.03 KB | 0644 |
|
| _curio_backend.py | File | 3.48 KB | 0644 |
|
| _immutable_ctx.py | File | 2.4 KB | 0644 |
|
| _trio_backend.py | File | 3.83 KB | 0644 |
|
| asyncbackend.py | File | 2.88 KB | 0644 |
|
| asyncquery.py | File | 24.68 KB | 0644 |
|
| asyncresolver.py | File | 10.24 KB | 0644 |
|
| dnssec.py | File | 42.17 KB | 0644 |
|
| dnssectypes.py | File | 1.76 KB | 0644 |
|
| e164.py | File | 3.88 KB | 0644 |
|
| edns.py | File | 13.69 KB | 0644 |
|
| entropy.py | File | 4.14 KB | 0644 |
|
| enum.py | File | 3.17 KB | 0644 |
|
| exception.py | File | 5.45 KB | 0644 |
|
| flags.py | File | 2.69 KB | 0644 |
|
| grange.py | File | 2.1 KB | 0644 |
|
| immutable.py | File | 1.79 KB | 0644 |
|
| inet.py | File | 4.9 KB | 0644 |
|
| ipv4.py | File | 2.02 KB | 0644 |
|
| ipv6.py | File | 6.05 KB | 0644 |
|
| message.py | File | 60.38 KB | 0644 |
|
| name.py | File | 33.62 KB | 0644 |
|
| namedict.py | File | 3.91 KB | 0644 |
|
| node.py | File | 12.37 KB | 0644 |
|
| opcode.py | File | 2.67 KB | 0644 |
|
| py.typed | File | 0 B | 0644 |
|
| query.py | File | 48.02 KB | 0644 |
|
| rcode.py | File | 4.06 KB | 0644 |
|
| rdata.py | File | 29.07 KB | 0644 |
|
| rdataclass.py | File | 2.91 KB | 0644 |
|
| rdataset.py | File | 16.67 KB | 0644 |
|
| rdatatype.py | File | 7.17 KB | 0644 |
|
| renderer.py | File | 10.42 KB | 0644 |
|
| resolver.py | File | 61.92 KB | 0644 |
|
| reversename.py | File | 3.74 KB | 0644 |
|
| rrset.py | File | 8.97 KB | 0644 |
|
| serial.py | File | 3.52 KB | 0644 |
|
| set.py | File | 8.88 KB | 0644 |
|
| tokenizer.py | File | 23.03 KB | 0644 |
|
| transaction.py | File | 21.12 KB | 0644 |
|
| tsig.py | File | 11.19 KB | 0644 |
|
| tsigkeyring.py | File | 2.58 KB | 0644 |
|
| ttl.py | File | 2.91 KB | 0644 |
|
| update.py | File | 11.96 KB | 0644 |
|
| version.py | File | 1.88 KB | 0644 |
|
| versioned.py | File | 11.5 KB | 0644 |
|
| win32util.py | File | 8.84 KB | 0644 |
|
| wire.py | File | 2.76 KB | 0644 |
|
| xfr.py | File | 12.96 KB | 0644 |
|
| zone.py | File | 49.86 KB | 0644 |
|
| zonefile.py | File | 26.84 KB | 0644 |
|
| zonetypes.py | File | 690 B | 0644 |
|