Skip to main content

Happy Eyeballs

Project description

aiohappyeyeballs

CI Status Documentation Status Test coverage percentage

Poetry black pre-commit

PyPI Version Supported Python versions License


Documentation: https://aiohappyeyeballs.readthedocs.io

Source Code: https://github.com/aio-libs/aiohappyeyeballs


Happy Eyeballs

Use case

This library exists to allow connecting with Happy Eyeballs when you already have a list of addrinfo and not a DNS name.

The stdlib version of loop.create_connection() will only work when you pass in an unresolved name which is not a good fit when using DNS caching or resolving names via another method such was zeroconf.

Installation

Install this via pip (or your favourite package manager):

pip install aiohappyeyeballs

Example usage

addr_infos = await loop.getaddrinfo("example.org", 80)

socket = await start_connection(addr_infos)
socket = await start_connection(addr_infos, local_addr_infos=local_addr_infos, happy_eyeballs_delay=0.2)

transport, protocol = await loop.create_connection(
    MyProtocol, sock=socket, ...)

# Remove the first address for each family from addr_info
pop_addr_infos_interleave(addr_info, 1)

# Remove all matching address from addr_info
remove_addr_infos(addr_info, "dead::beef::")

# Convert a local_addr to local_addr_infos
local_addr_infos = addr_to_addr_infos(("127.0.0.1",0))

Credits

This package contains code from cpython and is licensed under the same terms as cpython itself.

This package was created with Copier and the browniebroke/pypackage-template project template.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

aiohappyeyeballs-2.3.2.tar.gz (11.3 kB view details)

Uploaded Source

Built Distribution

aiohappyeyeballs-2.3.2-py3-none-any.whl (11.8 kB view details)

Uploaded Python 3

File details

Details for the file aiohappyeyeballs-2.3.2.tar.gz.

File metadata

  • Download URL: aiohappyeyeballs-2.3.2.tar.gz
  • Upload date:
  • Size: 11.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/4.0.2 CPython/3.11.7

File hashes

Hashes for aiohappyeyeballs-2.3.2.tar.gz
Algorithm Hash digest
SHA256 77e15a733090547a1f5369a1287ddfc944bd30df0eb8993f585259c34b405f4e
MD5 3a8369a35fc52fdb215af75d65be5620
BLAKE2b-256 cc83f731ac54f82fc25984ee4d6abadf69b824dde03b629a1348f459e7b35d5a

See more details on using hashes here.

Provenance

File details

Details for the file aiohappyeyeballs-2.3.2-py3-none-any.whl.

File metadata

File hashes

Hashes for aiohappyeyeballs-2.3.2-py3-none-any.whl
Algorithm Hash digest
SHA256 903282fb08c8cfb3de356fd546b263248a477c99cb147e20a115e14ab942a4ae
MD5 ed49ece86ba68b166edc4f85501422c9
BLAKE2b-256 07b1d9455cf313df7b2fe6c60a871eb96801b6e8fbdc7d736f6576492b4c97b3

See more details on using hashes here.

Provenance

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page