TCPConnection¶
Constructors¶
client¶
Create a client-side plaintext connection. An optional connection_timeout
bounds the TCP Happy Eyeballs phase. If the timeout fires before
_on_connected, the connection fails with ConnectionFailedTimeout.
new ref client(
auth: TCPConnectAuth val,
host: String val,
port: String val,
from: String val,
enclosing: TCPConnectionActor ref,
ler: ClientLifecycleEventReceiver ref,
read_buffer_size: ReadBufferSize = call,
ip_version: IPVersion = reference,
connection_timeout: (ConnectionTimeout | None val) = reference)
: TCPConnection ref^
Parameters¶
- auth: TCPConnectAuth val
- host: String val
- port: String val
- from: String val
- enclosing: TCPConnectionActor ref
- ler: ClientLifecycleEventReceiver ref
- read_buffer_size: ReadBufferSize = call
- ip_version: IPVersion = reference
- connection_timeout: (ConnectionTimeout | None val) = reference
Returns¶
- TCPConnection ref^
server¶
new ref server(
auth: TCPServerAuth val,
fd': U32 val,
enclosing: TCPConnectionActor ref,
ler: ServerLifecycleEventReceiver ref,
read_buffer_size: ReadBufferSize = call)
: TCPConnection ref^
Parameters¶
- auth: TCPServerAuth val
- fd': U32 val
- enclosing: TCPConnectionActor ref
- ler: ServerLifecycleEventReceiver ref
- read_buffer_size: ReadBufferSize = call
Returns¶
- TCPConnection ref^
ssl_client¶
Create a client-side SSL connection. The SSL session is created from the
provided SSLContext. If session creation fails, the connection reports
failure asynchronously via _on_connection_failure(ConnectionFailedSSL).
An optional connection_timeout bounds the connect-to-ready phase
(TCP Happy Eyeballs + TLS handshake). If the timeout fires before
_on_connected, the connection fails with ConnectionFailedTimeout.
new ref ssl_client(
auth: TCPConnectAuth val,
ssl_ctx: SSLContext val,
host: String val,
port: String val,
from: String val,
enclosing: TCPConnectionActor ref,
ler: ClientLifecycleEventReceiver ref,
read_buffer_size: ReadBufferSize = call,
ip_version: IPVersion = reference,
connection_timeout: (ConnectionTimeout | None val) = reference)
: TCPConnection ref^
Parameters¶
- auth: TCPConnectAuth val
- ssl_ctx: SSLContext val
- host: String val
- port: String val
- from: String val
- enclosing: TCPConnectionActor ref
- ler: ClientLifecycleEventReceiver ref
- read_buffer_size: ReadBufferSize = call
- ip_version: IPVersion = reference
- connection_timeout: (ConnectionTimeout | None val) = reference
Returns¶
- TCPConnection ref^
ssl_server¶
Create a server-side SSL connection. The SSL session is created from the provided SSLContext. If session creation fails, the connection reports failure asynchronously via _on_start_failure(StartFailedSSL) and closes the fd.
new ref ssl_server(
auth: TCPServerAuth val,
ssl_ctx: SSLContext val,
fd': U32 val,
enclosing: TCPConnectionActor ref,
ler: ServerLifecycleEventReceiver ref,
read_buffer_size: ReadBufferSize = call)
: TCPConnection ref^
Parameters¶
- auth: TCPServerAuth val
- ssl_ctx: SSLContext val
- fd': U32 val
- enclosing: TCPConnectionActor ref
- ler: ServerLifecycleEventReceiver ref
- read_buffer_size: ReadBufferSize = call
Returns¶
- TCPConnection ref^
none¶
Returns¶
- TCPConnection ref^
Public Functions¶
keepalive¶
Sets the TCP keepalive timeout to approximately secs seconds. Exact
timing is OS dependent. If secs is zero, TCP keepalive is disabled. TCP
keepalive is disabled by default. This can only be set on a connected
socket.
Parameters¶
- secs: U32 val
Returns¶
- None val
set_nodelay¶
Turn Nagle on/off. Defaults to on (Nagle enabled, nodelay off). When
enabled (state = true), small writes are sent immediately without
waiting to coalesce — useful for latency-sensitive protocols. When
disabled (state = false), the OS may buffer small writes.
Returns 0 on success, or a non-zero errno on failure. Only meaningful on a connected socket — returns non-zero if the connection is not open.
Parameters¶
- state: Bool val
Returns¶
- U32 val
get_so_rcvbuf¶
Get the OS receive buffer size for this socket.
Returns a 2-tuple: (errno, value). On success, errno is 0 and value is the buffer size in bytes. On failure, errno is non-zero and value should be ignored. Only meaningful on a connected socket — returns (1, 0) if the connection is not open.
Returns¶
set_so_rcvbuf¶
Set the OS receive buffer size for this socket. The OS may round the requested size up to a minimum or clamp it to a maximum.
Returns 0 on success, or a non-zero errno on failure. Only meaningful on a connected socket — returns non-zero if the connection is not open.
Parameters¶
- bufsize: U32 val
Returns¶
- U32 val
get_so_sndbuf¶
Get the OS send buffer size for this socket.
Returns a 2-tuple: (errno, value). On success, errno is 0 and value is the buffer size in bytes. On failure, errno is non-zero and value should be ignored. Only meaningful on a connected socket — returns (1, 0) if the connection is not open.
Returns¶
set_so_sndbuf¶
Set the OS send buffer size for this socket. The OS may round the requested size up to a minimum or clamp it to a maximum.
Returns 0 on success, or a non-zero errno on failure. Only meaningful on a connected socket — returns non-zero if the connection is not open.
Parameters¶
- bufsize: U32 val
Returns¶
- U32 val
getsockopt¶
General interface to getsockopt(2) for accessing any socket option.
The option_max_size argument is the maximum number of bytes the caller
expects the kernel to return. This method allocates a buffer of that size
before calling getsockopt(2).
Returns a 2-tuple: on success, (0, data) where data is the bytes
returned by the kernel, sized to the actual length the kernel wrote. On
failure, (errno, undefined) — the second element must be ignored. Only
meaningful on a connected socket — returns (1, empty) if the connection
is not open.
For commonly-tuned options, prefer the dedicated convenience methods
(set_nodelay, get_so_rcvbuf, etc.). Do not change the socket's
non-blocking mode — lori's event-driven I/O requires non-blocking
sockets.
fun box getsockopt(
level: I32 val,
option_name: I32 val,
option_max_size: USize val = 4)
: (U32 val , Array[U8 val] iso^)
Parameters¶
Returns¶
getsockopt_u32¶
Wrapper for getsockopt(2) where the kernel returns a C uint32_t.
Returns a 2-tuple: on success, (0, value). On failure,
(errno, undefined) — the second element must be ignored. Only
meaningful on a connected socket — returns (1, 0) if the connection
is not open.
For commonly-tuned options, prefer the dedicated convenience methods
(get_so_rcvbuf, get_so_sndbuf, etc.). Do not change the socket's
non-blocking mode — lori's event-driven I/O requires non-blocking
sockets.
Parameters¶
Returns¶
setsockopt¶
General interface to setsockopt(2) for setting any socket option.
The caller is responsible for the correct size, byte contents, and
byte order of the option array for the requested level and
option_name.
Returns 0 on success, or the value of errno on failure. Only
meaningful on a connected socket — returns non-zero if the connection
is not open.
For commonly-tuned options, prefer the dedicated convenience methods
(set_nodelay, set_so_rcvbuf, etc.). Do not change the socket's
non-blocking mode — lori's event-driven I/O requires non-blocking
sockets.
Parameters¶
Returns¶
- U32 val
setsockopt_u32¶
Wrapper for setsockopt(2) where the kernel expects a C uint32_t.
Returns 0 on success, or the value of errno on failure. Only
meaningful on a connected socket — returns non-zero if the connection
is not open.
For commonly-tuned options, prefer the dedicated convenience methods
(set_nodelay, set_so_rcvbuf, etc.). Do not change the socket's
non-blocking mode — lori's event-driven I/O requires non-blocking
sockets.
Parameters¶
Returns¶
- U32 val
idle_timeout¶
Set or disable the idle timeout. Idle timeout is disabled by default.
When duration is an IdleTimeout, the timer fires when no successful
send or receive occurs for that duration, delivering
_on_idle_timeout() to the lifecycle event receiver. When duration
is None, the idle timeout is disabled.
The timer automatically re-arms after each firing until disabled or the connection closes.
Can be called before the connection is established — the value is stored and the timer starts when the connection is ready.
This is independent of TCP keepalive (keepalive()). TCP keepalive
is a transport-level probe that detects dead peers. Idle timeout is
application-level inactivity detection — it fires whether or not the
peer is alive.
If the idle timer's ASIO event subscription fails asynchronously
(e.g. ENOMEM from kevent/epoll_ctl), the timer is cancelled and
_on_idle_timer_failure() is dispatched to the lifecycle event
receiver.
Parameters¶
- duration: (IdleTimeout | None val)
Returns¶
- None val
set_timer¶
Create a one-shot timer that fires _on_timer() after the configured
duration. Returns a TimerToken on success, or a SetTimerError on
failure.
Unlike idle_timeout(), this timer has no I/O-reset behavior — it fires
unconditionally after the duration elapses, regardless of send/receive
activity. There is no automatic re-arming; call set_timer() again from
_on_timer() for repetition.
Only one user timer can be active at a time. Setting a timer while one is
already active returns SetTimerAlreadyActive — call cancel_timer()
first. This prevents silent token invalidation.
Requires the connection to be application-level connected: the connection
must be open and the initial SSL handshake (if any) must have completed.
TLS upgrades via start_tls() do not block timer creation.
The timer survives close() (graceful shutdown) but is cancelled by
hard_close().
User timers have two error paths. This method returns a
SetTimerError synchronously when preconditions prevent the timer
from being created (see the return type). When creation succeeds but
the ASIO event subscription later fails (e.g. ENOMEM from
kevent/epoll_ctl), _on_timer_failure() is dispatched to the
lifecycle event receiver.
Parameters¶
- duration: TimerDuration
Returns¶
- (TimerToken val | SetTimerError)
cancel_timer¶
Cancel an active timer. No-op if the token doesn't match the active timer (already fired, already cancelled, wrong token). Safe to call with stale tokens.
No connection state check — timers can be cancelled during graceful
shutdown (_Closing) since they remain active until hard_close().
Parameters¶
- token: TimerToken val
Returns¶
- None val
set_read_buffer_minimum¶
Set the shrink-back floor for the read buffer to exactly new_min bytes.
When the read buffer is empty and larger than the minimum, it shrinks back
to this size automatically. If the current buffer allocation is smaller
than new_min, the buffer is grown to match.
Returns ReadBufferResizeBelowBufferSize if new_min is less than the
current buffer-until value.
fun ref set_read_buffer_minimum(
new_min: ReadBufferSize)
: (ReadBufferResized val | ReadBufferResizeBelowBufferSize val)
Parameters¶
- new_min: ReadBufferSize
Returns¶
- (ReadBufferResized val | ReadBufferResizeBelowBufferSize val)
resize_read_buffer¶
Force the read buffer to exactly size' bytes, reallocating if different.
If size' is below the current minimum, the minimum is lowered to match.
Returns ReadBufferResizeBelowBufferSize if size' is less than the
current buffer-until value, or ReadBufferResizeBelowUsed if size' is
less than the amount of unprocessed data currently in the buffer.
Parameters¶
- size': ReadBufferSize
Returns¶
local_address¶
Return the local IP address. If this TCPConnection is closed then the address returned is invalid.
Returns¶
- NetAddress val
remote_address¶
Return the remote IP address. If this TCPConnection is closed then the address returned is invalid.
Returns¶
- NetAddress val
mute¶
Temporarily suspend reading off this TCPConnection until such time as
unmute is called.
Returns¶
- None val
unmute¶
Start reading off this TCPConnection again after having been muted.
Returns¶
- None val
yield_read¶
Request the read loop to exit after the current _on_received callback
returns, giving other actors a chance to run. Reading resumes automatically
in the next scheduler turn — no explicit unmute() is needed.
Call this from within _on_received() to implement application-level yield
policies (e.g. yield after N messages, after N bytes, or after a time
threshold). Unlike mute()/unmute(), which persistently stop reading
until reversed, yield_read() is a one-shot pause: the read loop resumes
on its own.
For SSL connections, yield_read() operates at TCP-read granularity. All
SSL-decrypted messages from a single TCP read are delivered before the yield
takes effect, because the inner dispatch loop runs exactly once per TCP read
when SSL is active.
Returns¶
- None val
buffer_until¶
Set the number of bytes to buffer before delivering data via
_on_received. When qty is Streaming, all available data is delivered
as it arrives.
Returns BufferSizeAboveMinimum if qty exceeds the current read
buffer minimum. Raise the buffer minimum first, then set buffer_until.
Parameters¶
- qty: (BufferSize | Streaming val)
Returns¶
close¶
Attempt to perform a graceful shutdown. Don't accept new writes.
During the connecting phase (Happy Eyeballs in progress), transitions to
_UnconnectedClosing to drain inflight connection attempts. Each
straggler event is cleaned up as it arrives. Once all inflight connections
have drained, _on_connection_failure fires.
If the connection is established and not muted, we won't finish closing until we get a zero length read. If the connection is muted, perform a hard close and shut down immediately.
Returns¶
- None val
hard_close¶
When an error happens, do a non-graceful close.
Returns¶
- None val
is_open¶
Returns¶
- Bool val
is_closed¶
Returns¶
- Bool val
is_writeable¶
Returns whether the connection can currently accept a send() call.
Checks that the state allows sends and the socket is writeable.
Returns¶
- Bool val
start_tls¶
Initiate a TLS handshake on an established plaintext connection. Returns
None when the handshake has been started, or a StartTLSError if the
upgrade cannot proceed (the connection is unchanged in that case).
Preconditions: the connection must be open, not already TLS, not muted, have no unprocessed data in the read buffer, and have no pending writes. The read buffer check prevents a man-in-the-middle from injecting pre-TLS data that the application would process as post-TLS (CVE-2021-23222).
On success, _on_tls_ready() fires when the handshake completes. During
the handshake, send() returns SendErrorNotConnected. If the handshake
fails, _on_tls_failure fires followed by _on_closed().
The host parameter is used for SNI (Server Name Indication) on client
connections. Pass an empty string for server connections or when SNI is
not needed.
Parameters¶
- ssl_ctx: SSLContext val
- host: String val = ""
Returns¶
- (None val | StartTLSError)
send¶
Send data on this connection. Accepts a single buffer (ByteSeq) or
multiple buffers (ByteSeqIter). When multiple buffers are provided,
they are sent in a single writev syscall — avoiding both per-buffer
syscall overhead and the cost of copying into a contiguous buffer.
Returns a SendToken on success, or a SendError explaining the
failure. When successful, _on_sent(token) will fire in a subsequent
behavior turn once the data has been fully handed to the OS.
Parameters¶
- data: (ByteSeq | ByteSeqIter val)
Returns¶
read_again¶
Returns¶
- None val