package happy-eyeballs-mirage

  1. Overview
  2. Docs
Connecting to a remote host via IP version 4 or 6 using Mirage

Install

Dune Dependency

Authors

Maintainers

Sources

happy-eyeballs-0.3.0.tbz
sha256=a60ea0a1ef7d160a6fd62d63991b9e84e35ca5a9c07e5c7fa035e0fd428bb69e
sha512=0c43180c635c1ac807bd6a2abbb0403afca646870936baa451f6eadcd37d1b32ceea916d7b441b190392c4b32d32292bf6196de00faa198e2e8e59c3b4fdef56

Description

Happy eyeballs is an implementation of RFC 8305 which specifies how to connect to a remote host using either IP protocol version 4 or IP protocol version 6. This uses Lwt and Mirage for side effects.

Published: 21 Mar 2022

README

happy eyeballs -- connecting to a remote host

RFC 8305 describes how to connect to a remote host, given that the host may have multiple addresses (IPv4 and IPv6, via DNS A and AAAA resource records), and the local host may have connectivity via IPv4 only, IPv6 only, or both. The preference is to use IPv6.

This package implements the given RFC in its core (Happy_eyeballs module). In addition, the Happy_eyeballs_lwt is a Lwt implementation using Unix.

The implemented state machine is kept in-sync with the code (source: happy_eyeballs.dot at the root of this repository).

It is licensed under the ISC license.

Installation:

opam install happy-eyeballs happy-eyeballs-lwt happy-eyeballs-mirage

Dependencies (14)

  1. mirage-time >= "2.0.0"
  2. mirage-random >= "2.0.0" & < "4.0.0"
  3. tcpip >= "7.0.0"
  4. mirage-clock >= "3.0.0"
  5. lwt
  6. logs
  7. fmt
  8. ipaddr
  9. domain-name
  10. dns-client >= "6.2.0" & < "7.0.0"
  11. duration
  12. happy-eyeballs = version
  13. dune >= "2.0.0"
  14. ocaml >= "4.08.0"

Dev Dependencies

None

Used by (3)

  1. git-mirage = "3.7.1" | >= "3.8.1"
  2. mimic-happy-eyeballs < "0.0.8"
  3. sendmail-mirage

Conflicts

None

OCaml

Innovation. Community. Security.