package conduit
Install
Dune Dependency
Authors
Maintainers
Sources
sha256=58eabf878fe2a5612f5a4f2b484ff749a5febbea3b3ceeb9af43ac235f2b2445
sha512=ab8ee5c2b9d879869181d5dfe111aefeefaa10063d89f21d5fc6023e8a7b83738b246dcadce7d583f5b8e918026cdb73cc66b32a8d5c2f874966fa37d5e67719
doc/index.html
Introduction
The Conduit
library abstracts the concerns of establishing connections to peers that may be running within the same host (e.g. in another virtual machine) or on a remote host via TCP. It consists of:
- The
Conduit
module with basic type definitions for endpoints - OS-specific modules for establishing individual connections
- The
Resolver
module for mapping URIs to endpoints - OS-specific name resolvers that use available resolution mechanisms
Connection Establishment
Connections are created by identifying remote nodes using an endp value. To ensure portability, the endpoints are translated into concrete connections by separate modules that target Lwt_unix
, Async
and Mirage
. This lets those backends use the appropriate local technique for creating the connection (such as using OpenSSL on Unix, or a pure OCaml TLS+TCP implementation on Mirage, or some other combination).
The modules dealing with connection establishment are:
Conduit_lwt_unix
Conduit_async
Conduit_mirage
Name Resolution
This deals with resolving URIs into a list of endp addresses that can then be connected to by the connection establishment modules.
All of the name resolvers conform to the Resolver.S
module type. The OS-specific implementations of this interface are:
Resolver_lwt
Resolver_lwt_unix
Resolver_mirage
Mirage Connections
On Mirage, the networking stack is configured via the application of functors to satisfy various signatures. Some of the available functors are:
Conduit_xenstore
Conduit_localhost
indexlist