View Source ThousandIsland.Socket (Thousand Island v1.3.9)

Encapsulates a client connection's underlying socket, providing a facility to read, write, and otherwise manipulate a connection from a client.

Summary

Types

t()

A reference to a socket along with metadata describing how to use it

Functions

Closes the given socket. Note that a socket is automatically closed when the handler process which owns it terminates

Gets the given flags on the socket

Returns statistics about the connection.

Handshakes the underlying socket if it is required (as in the case of SSL sockets, for example).

Returns information about the protocol negotiated during transport handshaking (if any).

Creates a new socket struct based on the passed parameters.

Returns information in the form of t:public_key.der_encoded() about the peer certificate of the socket.

Returns information in the form of t:ThousandIsland.Transport.socket_info() about the remote end of the socket.

Returns available bytes on the given socket. Up to length bytes will be returned (0 can be passed in to get the next 'available' bytes, typically the next packet). If insufficient bytes are available, the function can wait timeout milliseconds for data to arrive.

Returns whether or not this protocol is secure.

Sends the given data (specified as a binary or an IO list) on the given socket.

Sends the contents of the given file based on the provided offset & length

Sets the given flags on the socket

Shuts down the socket in the given direction.

Returns information in the form of t:ThousandIsland.Transport.socket_info() about the local end of the socket.

Returns the telemetry span representing the lifetime of this socket

Upgrades the transport of the socket to use the specified transport module, performing any client handshaking that may be required. The passed options are blindly passed through to the new transport module.

Types

t()

@type t() :: %ThousandIsland.Socket{
  read_timeout: timeout(),
  silent_terminate_on_error: boolean(),
  socket: ThousandIsland.Transport.socket(),
  span: ThousandIsland.Telemetry.t(),
  transport_module: module()
}

A reference to a socket along with metadata describing how to use it

Functions

close(socket)

@spec close(t()) :: ThousandIsland.Transport.on_close()

Closes the given socket. Note that a socket is automatically closed when the handler process which owns it terminates

getopts(socket, options)

Gets the given flags on the socket

Errors are usually from :inet.posix(), however, SSL module defines return type as any()

getstat(socket)

Returns statistics about the connection.

handshake(socket)

@spec handshake(t()) :: ThousandIsland.Transport.on_handshake()

Handshakes the underlying socket if it is required (as in the case of SSL sockets, for example).

This is normally called internally by ThousandIsland.Handler and does not need to be called by implementations which are based on ThousandIsland.Handler

negotiated_protocol(socket)

@spec negotiated_protocol(t()) :: ThousandIsland.Transport.on_negotiated_protocol()

Returns information about the protocol negotiated during transport handshaking (if any).

new(raw_socket, server_config, span)

Creates a new socket struct based on the passed parameters.

This is normally called internally by ThousandIsland.Handler and does not need to be called by implementations which are based on ThousandIsland.Handler

peercert(socket)

@spec peercert(t()) :: ThousandIsland.Transport.on_peercert()

Returns information in the form of t:public_key.der_encoded() about the peer certificate of the socket.

peername(socket)

@spec peername(t()) :: ThousandIsland.Transport.on_peername()

Returns information in the form of t:ThousandIsland.Transport.socket_info() about the remote end of the socket.

recv(socket, length \\ 0, timeout \\ nil)

Returns available bytes on the given socket. Up to length bytes will be returned (0 can be passed in to get the next 'available' bytes, typically the next packet). If insufficient bytes are available, the function can wait timeout milliseconds for data to arrive.

secure?(socket)

@spec secure?(t()) :: boolean()

Returns whether or not this protocol is secure.

send(socket, data)

@spec send(t(), iodata()) :: ThousandIsland.Transport.on_send()

Sends the given data (specified as a binary or an IO list) on the given socket.

sendfile(socket, filename, offset, length)

Sends the contents of the given file based on the provided offset & length

setopts(socket, options)

Sets the given flags on the socket

Errors are usually from :inet.posix(), however, SSL module defines return type as any()

shutdown(socket, way)

Shuts down the socket in the given direction.

sockname(socket)

@spec sockname(t()) :: ThousandIsland.Transport.on_sockname()

Returns information in the form of t:ThousandIsland.Transport.socket_info() about the local end of the socket.

telemetry_span(socket)

@spec telemetry_span(t()) :: ThousandIsland.Telemetry.t()

Returns the telemetry span representing the lifetime of this socket

upgrade(socket, module, opts)

@spec upgrade(t(), module(), term()) :: ThousandIsland.Transport.on_upgrade()

Upgrades the transport of the socket to use the specified transport module, performing any client handshaking that may be required. The passed options are blindly passed through to the new transport module.

This is normally called internally by ThousandIsland.Handler and does not need to be called by implementations which are based on ThousandIsland.Handler