generated from WebAssembly/wasi-proposal-template
-
Notifications
You must be signed in to change notification settings - Fork 23
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Showing
10 changed files
with
744 additions
and
720 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,9 +1,9 @@ | ||
|
||
/// This interface provides a value-export of the default network handle.. | ||
interface instance-network { | ||
use network.{network}; | ||
use network.{network}; | ||
|
||
/// Get a handle to the default network. | ||
instance-network: func() -> network; | ||
/// Get a handle to the default network. | ||
instance-network: func() -> network; | ||
|
||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,61 +1,61 @@ | ||
|
||
interface ip-name-lookup { | ||
use wasi:io/poll.{pollable}; | ||
use network.{network, error-code, ip-address, ip-address-family}; | ||
use wasi:io/poll.{pollable}; | ||
use network.{network, error-code, ip-address, ip-address-family}; | ||
|
||
|
||
/// Resolve an internet host name to a list of IP addresses. | ||
/// | ||
/// See the wasi-socket proposal README.md for a comparison with getaddrinfo. | ||
/// | ||
/// # Parameters | ||
/// - `name`: The name to look up. IP addresses are not allowed. Unicode domain names are automatically converted | ||
/// to ASCII using IDNA encoding. | ||
/// - `address-family`: If provided, limit the results to addresses of this specific address family. | ||
/// - `include-unavailable`: When set to true, this function will also return addresses of which the runtime | ||
/// thinks (or knows) can't be connected to at the moment. For example, this will return IPv6 addresses on | ||
/// systems without an active IPv6 interface. Notes: | ||
/// - Even when no public IPv6 interfaces are present or active, names like "localhost" can still resolve to an IPv6 address. | ||
/// - Whatever is "available" or "unavailable" is volatile and can change everytime a network cable is unplugged. | ||
/// | ||
/// This function never blocks. It either immediately fails or immediately returns successfully with a `resolve-address-stream` | ||
/// that can be used to (asynchronously) fetch the results. | ||
/// | ||
/// At the moment, the stream never completes successfully with 0 items. Ie. the first call | ||
/// to `resolve-next-address` never returns `ok(none)`. This may change in the future. | ||
/// | ||
/// # Typical errors | ||
/// - `invalid-name`: `name` is a syntactically invalid domain name. | ||
/// - `invalid-name`: `name` is an IP address. | ||
/// - `address-family-not-supported`: The specified `address-family` is not supported. (EAI_FAMILY) | ||
/// | ||
/// # References: | ||
/// - <https://pubs.opengroup.org/onlinepubs/9699919799/functions/getaddrinfo.html> | ||
/// - <https://man7.org/linux/man-pages/man3/getaddrinfo.3.html> | ||
/// - <https://learn.microsoft.com/en-us/windows/win32/api/ws2tcpip/nf-ws2tcpip-getaddrinfo> | ||
/// - <https://man.freebsd.org/cgi/man.cgi?query=getaddrinfo&sektion=3> | ||
resolve-addresses: func(network: borrow<network>, name: string, address-family: option<ip-address-family>, include-unavailable: bool) -> result<resolve-address-stream, error-code>; | ||
/// Resolve an internet host name to a list of IP addresses. | ||
/// | ||
/// See the wasi-socket proposal README.md for a comparison with getaddrinfo. | ||
/// | ||
/// # Parameters | ||
/// - `name`: The name to look up. IP addresses are not allowed. Unicode domain names are automatically converted | ||
/// to ASCII using IDNA encoding. | ||
/// - `address-family`: If provided, limit the results to addresses of this specific address family. | ||
/// - `include-unavailable`: When set to true, this function will also return addresses of which the runtime | ||
/// thinks (or knows) can't be connected to at the moment. For example, this will return IPv6 addresses on | ||
/// systems without an active IPv6 interface. Notes: | ||
/// - Even when no public IPv6 interfaces are present or active, names like "localhost" can still resolve to an IPv6 address. | ||
/// - Whatever is "available" or "unavailable" is volatile and can change everytime a network cable is unplugged. | ||
/// | ||
/// This function never blocks. It either immediately fails or immediately returns successfully with a `resolve-address-stream` | ||
/// that can be used to (asynchronously) fetch the results. | ||
/// | ||
/// At the moment, the stream never completes successfully with 0 items. Ie. the first call | ||
/// to `resolve-next-address` never returns `ok(none)`. This may change in the future. | ||
/// | ||
/// # Typical errors | ||
/// - `invalid-name`: `name` is a syntactically invalid domain name. | ||
/// - `invalid-name`: `name` is an IP address. | ||
/// - `address-family-not-supported`: The specified `address-family` is not supported. (EAI_FAMILY) | ||
/// | ||
/// # References: | ||
/// - <https://pubs.opengroup.org/onlinepubs/9699919799/functions/getaddrinfo.html> | ||
/// - <https://man7.org/linux/man-pages/man3/getaddrinfo.3.html> | ||
/// - <https://learn.microsoft.com/en-us/windows/win32/api/ws2tcpip/nf-ws2tcpip-getaddrinfo> | ||
/// - <https://man.freebsd.org/cgi/man.cgi?query=getaddrinfo&sektion=3> | ||
resolve-addresses: func(network: borrow<network>, name: string, address-family: option<ip-address-family>, include-unavailable: bool) -> result<resolve-address-stream, error-code>; | ||
|
||
resource resolve-address-stream { | ||
/// Returns the next address from the resolver. | ||
/// | ||
/// This function should be called multiple times. On each call, it will | ||
/// return the next address in connection order preference. If all | ||
/// addresses have been exhausted, this function returns `none`. | ||
/// | ||
/// This function never returns IPv4-mapped IPv6 addresses. | ||
/// | ||
/// # Typical errors | ||
/// - `name-unresolvable`: Name does not exist or has no suitable associated IP addresses. (EAI_NONAME, EAI_NODATA, EAI_ADDRFAMILY) | ||
/// - `temporary-resolver-failure`: A temporary failure in name resolution occurred. (EAI_AGAIN) | ||
/// - `permanent-resolver-failure`: A permanent failure in name resolution occurred. (EAI_FAIL) | ||
/// - `would-block`: A result is not available yet. (EWOULDBLOCK, EAGAIN) | ||
resolve-next-address: func() -> result<option<ip-address>, error-code>; | ||
resource resolve-address-stream { | ||
/// Returns the next address from the resolver. | ||
/// | ||
/// This function should be called multiple times. On each call, it will | ||
/// return the next address in connection order preference. If all | ||
/// addresses have been exhausted, this function returns `none`. | ||
/// | ||
/// This function never returns IPv4-mapped IPv6 addresses. | ||
/// | ||
/// # Typical errors | ||
/// - `name-unresolvable`: Name does not exist or has no suitable associated IP addresses. (EAI_NONAME, EAI_NODATA, EAI_ADDRFAMILY) | ||
/// - `temporary-resolver-failure`: A temporary failure in name resolution occurred. (EAI_AGAIN) | ||
/// - `permanent-resolver-failure`: A permanent failure in name resolution occurred. (EAI_FAIL) | ||
/// - `would-block`: A result is not available yet. (EWOULDBLOCK, EAGAIN) | ||
resolve-next-address: func() -> result<option<ip-address>, error-code>; | ||
|
||
/// Create a `pollable` which will resolve once the stream is ready for I/O. | ||
/// | ||
/// Note: this function is here for WASI Preview2 only. | ||
/// It's planned to be removed when `future` is natively supported in Preview3. | ||
subscribe: func() -> pollable; | ||
} | ||
/// Create a `pollable` which will resolve once the stream is ready for I/O. | ||
/// | ||
/// Note: this function is here for WASI Preview2 only. | ||
/// It's planned to be removed when `future` is natively supported in Preview3. | ||
subscribe: func() -> pollable; | ||
} | ||
} |
Oops, something went wrong.