Library
Module
Module type
Parameter
Class
Class type
module Session : sig ... end
Low-level API for working with TLS sessions. Most applications should use the high-level API below
val listen :
?buffer_age_limit:Async.Writer.buffer_age_limit ->
?max_connections:int ->
?max_accepts_per_batch:int ->
?backlog:int ->
?socket:
([ `Unconnected ], [< Async.Socket.Address.t ] as 'address) Async.Socket.t ->
on_handler_error:[ `Call of 'address -> exn -> unit | `Ignore | `Raise ] ->
Tls.Config.server ->
('address, 'listening_on) Async.Tcp.Where_to_listen.t ->
('address ->
Session.t ->
Async.Reader.t ->
Async.Writer.t ->
unit Async.Deferred.t) ->
('address, 'listening_on) Async.Tcp.Server.t Async.Deferred.t
listen
creates a Tcp.Server.t
with the requested parameters, including those specified in Tls.Config.server
. The handler function exposes the low-level Session.t
to accommodate cases like interrogating a client certificate
val connect :
?socket:([ `Unconnected ], 'addr) Async.Socket.t ->
(Tls.Config.client ->
'addr Async.Tcp.Where_to_connect.t ->
host:string option ->
(Session.t * Async.Reader.t * Async.Writer.t) Async.Deferred.Or_error.t)
Async.Tcp.with_connect_options
connect
behaves similarly to Tcp.connect
, exposing a cleartext reader and writer. Callers should ensure they close the Writer.t
and wait for the unit Deferred.t
returned by `Closed_and_flushed_downstream
to completely shut down the TLS connection
host
is used for peer name verification and should generally be provided. Passing None
will disable peer name verification unless peer_name
was provided in the Tls.Config.client
. If both are present host
overwrites peer_name
.