Module spin_sdk.wit.imports.wasi_sockets_tcp_create_socket_0_2_6
Functions
def create_tcp_socket(address_family: IpAddressFamily) ‑> TcpSocket-
Expand source code
def create_tcp_socket(address_family: wasi_sockets_network_0_2_6.IpAddressFamily) -> wasi_sockets_tcp_0_2_6.TcpSocket: """ Create a new TCP socket. Similar to `socket(AF_INET or AF_INET6, SOCK_STREAM, IPPROTO_TCP)` in POSIX. On IPv6 sockets, IPV6_V6ONLY is enabled by default and can't be configured otherwise. This function does not require a network capability handle. This is considered to be safe because at time of creation, the socket is not bound to any `network` yet. Up to the moment `bind`/`connect` is called, the socket is effectively an in-memory configuration object, unable to communicate with the outside world. All sockets are non-blocking. Use the wasi-poll interface to block on asynchronous operations. # Typical errors - `not-supported`: The specified `address-family` is not supported. (EAFNOSUPPORT) - `new-socket-limit`: The new socket resource could not be created because of a system limit. (EMFILE, ENFILE) # References - <https://pubs.opengroup.org/onlinepubs/9699919799/functions/socket.html> - <https://man7.org/linux/man-pages/man2/socket.2.html> - <https://learn.microsoft.com/en-us/windows/win32/api/winsock2/nf-winsock2-wsasocketw> - <https://man.freebsd.org/cgi/man.cgi?query=socket&sektion=2> Raises: `componentize_py_types.Err(spin_sdk.wit.imports.wasi_sockets_network_0_2_6.ErrorCode)` """ raise NotImplementedErrorCreate a new TCP socket.
Similar to
socket(AF_INET or AF_INET6, SOCK_STREAM, IPPROTO_TCP)in POSIX. On IPv6 sockets, IPV6_V6ONLY is enabled by default and can't be configured otherwise.This function does not require a network capability handle. This is considered to be safe because at time of creation, the socket is not bound to any
networkyet. Up to the momentbind/connectis called, the socket is effectively an in-memory configuration object, unable to communicate with the outside world.All sockets are non-blocking. Use the wasi-poll interface to block on asynchronous operations.
Typical errors
not-supported: The specifiedaddress-familyis not supported. (EAFNOSUPPORT)new-socket-limit: The new socket resource could not be created because of a system limit. (EMFILE, ENFILE)
References
- https://pubs.opengroup.org/onlinepubs/9699919799/functions/socket.html
- https://man7.org/linux/man-pages/man2/socket.2.html
- https://learn.microsoft.com/en-us/windows/win32/api/winsock2/nf-winsock2-wsasocketw
- https://man.freebsd.org/cgi/man.cgi?query=socket&sektion=2
Raises:
componentize_py_types.Err(ErrorCode)