Module socketutil

This module contains miscellaneous helper functions specific to our usage of LuaSocket/LuaSec.

Functions

set_timeout (block_timeout, total_timeout) Update the timeout values.
reset_timeout () Reset timeout values to LuaSocket defaults.
file_sink (handle, io_err) Custom version of ltn12.sink.file that honors total_timeout

Fields

LARGE_BLOCK_TIMEOUT Common timeout values Large content
TIMEOUT_CODE Various timeout return codes


Functions

set_timeout (block_timeout, total_timeout)
Update the timeout values. Note that this only affects socket polling, c.f., LuaSocket's timeout_getretry @ src/timeout.c & usage in src/usocket.c Moreover, the timeout is actually reset between polls (via timeoutmarkstart, e.g. in buffermeth_receive). So, in practice, this timeout only helps very bad connections (on one end or the other), and you'd be hard-pressed to ever hit the total timeout, since the starting point is reset extremely often. In our case, we want to enforce an actual limit on how much time we're willing to block for, start to finish. We do that via the custom sinks below, which will start ticking as soon as the first chunk of data is received. To simplify, in most cases, the socket timeout matters before we receive data, and the sink timeout once we've started receiving data (at which point the socket timeout is reset every chunk). In practice, that means you don't want to set block_timeout too low, as that's what the socket timeout will end up using most of the time. Note that name resolution happens earlier and one level lower (e.g., glibc), so name resolution delays will fall outside of these timeouts.

Parameters:

  • block_timeout
  • total_timeout
reset_timeout ()
Reset timeout values to LuaSocket defaults.
file_sink (handle, io_err)
Custom version of ltn12.sink.file that honors total_timeout

Parameters:

  • handle
  • io_err

Fields

LARGE_BLOCK_TIMEOUT
Common timeout values Large content
TIMEOUT_CODE
Various timeout return codes
generated by LDoc 1.5.0 Last updated 2024-09-19 16:40:47