Stream: wasi

Topic: socket connect WITX proposal


view this post on Zulip Emiliano Lesende (May 25 2020 at 00:43):

Hello everybody. I'm new to the community, although I've been following WebAssembly for quite some time. I just started a new project that is going to be using WebAssembly. One of the requirements I have is to be able to use sockets. I know the support for sockets is not yet there so I thought I could help with that.

This is the initial WASI additions, this only covers connect for the moment. I just wanted to get a feeling as to if this is the right direction or not before I continue and do the implementation on wasi-common.

typenames.witx

;;; Socket type
(typename $socktype
  (enum
    ;;; The file descriptor or file refers to a datagram socket.
    $socket_dgram
    ;;; The file descriptor or file refers to a byte-stream socket.
    $socket_stream
  )
)

;;; IP port number
(typename $ipport u16)

;;; An IPv4 address is a 32-bit number that uniquely identifies a network interface on a machine.
(typename $ipaddr4
  (struct
    (field $n0 u8)
    (field $n1 u8)
    (field $h0 u8)
    (field $h1 u8)
  )
)
(typename $ipaddr4_array (array $ipaddr4))

;;; An IPv6 address is a 128-bit number that uniquely identifies a network interface on a machine.
(typename $ipaddr6
  (struct
    (field $n0 u16)
    (field $n1 u16)
    (field $n2 u16)
    (field $n3 u16)
    (field $h0 u16)
    (field $h1 u16)
    (field $h2 u16)
    (field $h3 u16)
  )
)
(typename $ipaddr6_array (array $ipaddr6))

wasi_snapshot_preview1.witx

;;; Resolves a hostname to one or more IPv4 addresses
  ;;; Note: This is similar to `getaddrinfo` in POSIX
  (@interface func (export "addr_resolve_ip4")
    ;;; Host to resolve
    (param $host string)
    (result $ipaddr4 $ipaddr4_array)
    (result $error $errno)
  )

  ;;; Resolves a hostname to one or more IPv6 addresses
  ;;; Note: This is similar to `getaddrinfo` in POSIX
  (@interface func (export "addr_resolve_ip6")
    ;;; Host to resolve
    (param $host string)
    (result $ipaddr6 $ipaddr6_array)
    (result $error $errno)
  )

  ;;; Open a local socket
  ;;; Note: This is similar to `socket` in POSIX using PF_UNIX
  (@interface func (export "sock_open")
    ;;; Socket type, either datagram or stream
    (param $type $socktype)
    ;;; The opened socket
    (result $fd $fd)
    (result $error $errno)
  )

  ;;; Open a IPv4 socket
  ;;; Note: This is similar to `socket` in POSIX using PF_INET
  (@interface func (export "sock_open_ip4")
    ;;; Socket type, either datagram or stream
    (param $type $socktype)
    ;;; The opened socket
    (result $fd $fd)
    (result $error $errno)
  )

  ;;; Open a IPv4 socket
  ;;; Note: This is similar to `socket` in POSIX using PF_INET6
  (@interface func (export "sock_open_ip6")
    ;;; Socket type, either datagram or stream
    (param $type $socktype)
    ;;; The opened socket
    (result $fd $fd)
    (result $error $errno)
  )

  ;;; Initiate a connection on a local socket
  ;;; Note: This is similar to `connect` in POSIX, though rather than receiving a sockaddr
  ;;; we splitted it into separate functions with different arguments.
  (@interface func (export "sock_connect")
    ;;; Socket descriptor
    (param $fd $fd)
    ;;; Address of the local socket (ex '/dev/tmp')
    (param $addr string)
    (result $error $errno)
  )

  ;;; Initiate a connection on a network socket using IPv4
  ;;; Note: This is similar to `connect` in POSIX when the sockaddr uses AF_INET
  (@interface func (export "sock_connect_ip4")
    ;;; Socket descriptor
    (param $fd $fd)
    ;;; Address of the network socket
    (param $addr $ip4)
    ;;; Port number to connect to
    (param $port $ipport)
    (result $error $errno)
  )

  ;;; Initiate a connection on a network socket using IPv4
  ;;; Note: This is similar to `connect` in POSIX when the sockaddr uses AF_INET6
  (@interface func (export "sock_connect_ip6")
    ;;; Socket descriptor
    (param $fd $fd)
    ;;; Address of the network socket
    (param $addr $ip6)
    ;;; Port number to connect to
    (param $port $ipport)
    (result $error $errno)
  )

I tried to keep the spirit of other parts of WASI such as file functions, not sure that I got it right.

view this post on Zulip Emiliano Lesende (May 25 2020 at 01:34):

I just realized that wiggle doesn't support array result elements. So I copy the approach taken for fd_readdir.

Here is the revised witx.

  ;;; Resolves a hostname to one or more IPv4 addresses.
  ;;; Note: This is similar to `getaddrinfo` in POSIX
  ;;;
  ;;; When successful, the contents of the output buffer consist of a sequence of
  ;;; IPv4 addresses. Each address entry consists of a ipaddr4_t object.
  ;;
  ;;; This function fills the output buffer as much as possible, potentially
  ;;; truncating the last address entry. It is advisable that the buffer is
  ;;; always multiple of ipaddr4_t size.
  (@interface func (export "addr_resolve_ip4")
    ;;; Host to resolve
    (param $host string)
    ;;; The buffer where IP address are stored
    (param $buf (@witx pointer u8))
    (param $buf_len $size)
    (result $error $errno)
    ;;; The number of bytes stored in the buffer. If less than the size of the buffer, no more IP addresses are available.
    (result $bufused $size)
  )

  ;;; Resolves a hostname to one or more IPv6 addresses.
  ;;; Note: This is similar to `getaddrinfo` in POSIX
  ;;;
  ;;; When successful, the contents of the output buffer consist of a sequence of
  ;;; IPv4 addresses. Each address entry consists of a ipaddr6_t object.
  ;;
  ;;; This function fills the output buffer as much as possible, potentially
  ;;; truncating the last address entry. It is advisable that the buffer is
  ;;; always multiple of ipaddr5_t size.
  (@interface func (export "addr_resolve_ip6")
    ;;; Host to resolve
    (param $host string)
    ;;; The buffer where IP address are stored
    (param $buf (@witx pointer u8))
    (param $buf_len $size)
    (result $error $errno)
    ;;; The number of bytes stored in the buffer. If less than the size of the buffer, no more IP addresses are available.
    (result $bufused $size)
  )

  ;;; Open a local socket
  ;;; Note: This is similar to `socket` in POSIX using PF_UNIX
  (@interface func (export "sock_open")
    ;;; Socket type, either datagram or stream
    (param $type $socktype)
    ;;; The opened socket
    (result $fd $fd)
    (result $error $errno)
  )

  ;;; Open a IPv4 socket
  ;;; Note: This is similar to `socket` in POSIX using PF_INET
  (@interface func (export "sock_open_ip4")
    ;;; Socket type, either datagram or stream
    (param $type $socktype)
    ;;; The opened socket
    (result $fd $fd)
    (result $error $errno)
  )

  ;;; Open a IPv4 socket
  ;;; Note: This is similar to `socket` in POSIX using PF_INET6
  (@interface func (export "sock_open_ip6")
    ;;; Socket type, either datagram or stream
    (param $type $socktype)
    ;;; The opened socket
    (result $fd $fd)
    (result $error $errno)
  )

  ;;; Initiate a connection on a local socket
  ;;; Note: This is similar to `connect` in POSIX, though rather than receiving a sockaddr
  ;;; we splitted it into separate functions with different arguments.
  (@interface func (export "sock_connect")
    ;;; Socket descriptor
    (param $fd $fd)
    ;;; Address of the local socket (ex '/dev/tmp')
    (param $addr string)
    (result $error $errno)
  )

  ;;; Initiate a connection on a network socket using IPv4
  ;;; Note: This is similar to `connect` in POSIX when the sockaddr uses AF_INET
  (@interface func (export "sock_connect_ip4")
    ;;; Socket descriptor
    (param $fd $fd)
    ;;; Address of the network socket
    (param $addr $ipaddr4)
    ;;; Port number to connect to
    (param $port $ipport)
    (result $error $errno)
  )

  ;;; Initiate a connection on a network socket using IPv4
  ;;; Note: This is similar to `connect` in POSIX when the sockaddr uses AF_INET6
  (@interface func (export "sock_connect_ip6")
    ;;; Socket descriptor
    (param $fd $fd)
    ;;; Address of the network socket
    (param $addr $ipaddr6)
    ;;; Port number to connect to
    (param $port $ipport)
    (result $error $errno)
  )

view this post on Zulip Emiliano Lesende (May 25 2020 at 01:36):

I would like to also add timeout for connect somehow, altho I am not sure as what would be the best approach for that except to make it always mandatory to provide a timeout. I guess the most natural approach would be to add a u16 there with zero being wait forever. Another note, still missing setsockopt equivalent too.

view this post on Zulip Dan Gohman (May 25 2020 at 01:42):

Hi! This is cool! I don't have a lot of time today or tomorrow to dig into this, but I wanted to quickly pop in here and say this is something we're interested in, and to feel free to ask questions and post ideas like this

view this post on Zulip Dan Gohman (May 25 2020 at 01:44):

at a quick glance, one idea: instead of having separate _ip4, _ip6, etc. variants of the functions, another option is to define union type with fields for each address type, so that applications wanting to support multiple address families don't need to have as many code paths

view this post on Zulip Emiliano Lesende (May 25 2020 at 01:46):

Yeah, I wasn't sure about splitting them up which is why I ask for feedback. I definitely didn't want to bring addrinfo, sockaddr, etc complexity. Didn't knew we had unions. I'll look into it.

view this post on Zulip Dan Gohman (May 25 2020 at 01:46):

Also as a heads up, I'll want to talk about how to fit this into WASI's capability-based security model, and I'll be happy to help figure that out when we're ready.

view this post on Zulip Dan Gohman (May 25 2020 at 01:48):

I have to head out now, but feel free to ask questions here, and I or others will answer them when we can!

view this post on Zulip Emiliano Lesende (May 25 2020 at 02:10):

@Dan Gohman Thank you. I'll be happy to chat some more. Of course we need security features. My current line of thought is a basic feature gate, either you can connect or can't. After which we need some sort of whitelisting "what" you can connect to. That one is more trickier. I mean is easy to whitelist and bunch of IP addresses, or even ranges but the problem lies on host address resolution, how can we avoid DNS spoofing I am not sure.

view this post on Zulip Emiliano Lesende (May 25 2020 at 13:53):

Ok. I've been working on this some more. Here is the revised WITX.

typenames.witx

;;; Socket type
(typename $sock_type
  (enum u8
    ;;; The file descriptor or file refers to a datagram socket.
    $socket_dgram
    ;;; The file descriptor or file refers to a byte-stream socket.
    $socket_stream
  )
)

;;; IP port number
(typename $ip_port u16)

;;; Address type
(typename $addr_type
  (enum u8
    ;;; Unix local address
    $local
    ;;; IPv4 address
    $ip4
    ;;; IPv6 address
    $ip6
  )
)

;;; A local socket address such as /dev/sock
(typename $addr_local
  (struct
    ;;; Pointer to the name of the socket
    (field $path (@witx pointer u8))
    ;;; The length of the name of the socket
    (field $path_len $size)
  )
)

;;; An IPv4 address is a 32-bit number that uniquely identifies a network interface on a machine.
(typename $addr_ip4
  (struct
    (field $n0 u8)
    (field $n1 u8)
    (field $h0 u8)
    (field $h1 u8)
  )
)

;;; An IPv6 address is a 128-bit number that uniquely identifies a network interface on a machine.
(typename $addr_ip6
  (struct
    (field $n0 u16)
    (field $n1 u16)
    (field $n2 u16)
    (field $n3 u16)
    (field $h0 u16)
    (field $h1 u16)
    (field $h2 u16)
    (field $h3 u16)
  )
)

;;; Union of all possible addresses type
(typename $addr
  (union $addr_type
    (field $local $addr_local)
    (field $ip4 $addr_ip4)
    (field $ip6 $addr_ip6)
  )
)

wasi_snapshot_preview1.witx

  ;;; Resolves a hostname to one or more IP addresses.
  ;;; Note: This is similar to `getaddrinfo` in POSIX
  ;;;
  ;;; When successful, the contents of the output buffer consist of a sequence of
  ;;; IPv4 and/or IPv6 addresses. Each address entry consists of a addr_t object.
  ;;
  ;;; This function fills the output buffer as much as possible, potentially
  ;;; truncating the last address entry. It is advisable that the buffer is
  ;;; always multiple of addr_t size.
  (@interface func (export "addr_resolve")
    ;;; Host to resolve
    (param $host string)
    ;;; The buffer where IP address are stored
    (param $buf (@witx pointer u8))
    (param $buf_len $size)
    (result $error $errno)
    ;;; The number of bytes stored in the buffer. If less than the size of the buffer, no more IP addresses are available.
    (result $bufused $size)
  )
  ;;; Open a socket
  ;;; Note: This is similar to `socket` in POSIX using PF_INET
  (@interface func (export "sock_open")
    ;;; Address type
    (param $addrtype $addr_type)
    ;;; Socket type, either datagram or stream
    (param $socktype $sock_type)
    (result $error $errno)
    ;;; The opened socket
    (result $fd $fd)
  )

  ;;; Initiate a connection on a socket to the specified address
  ;;; Note: This is similar to `connect` in POSIX
  (@interface func (export "sock_connect")
    ;;; Socket descriptor
    (param $fd $fd)
    ;;; Address of the local socket (ex '/dev/tmp')
    (param $addr $addr)
    (result $error $errno)
  )

view this post on Zulip Emiliano Lesende (May 26 2020 at 18:35):

@Dan Gohman Given our discussion about passing unions. You still think that the union is the better choice vs having individual calls per protocol? I am even not sure that we should support local sockets vs just TCP/UDP. I'm intrigued about what others think on that subject.

view this post on Zulip Dan Gohman (May 26 2020 at 18:36):

I'm curious, what would a just-TCP/UDP API look like?

view this post on Zulip Dan Gohman (May 26 2020 at 18:37):

Berkeley sockets API is so pervasive, I myself don't know what an alternative would look like.

view this post on Zulip Dan Gohman (May 26 2020 at 18:38):

If we do go with sockets, then yes, I still think pointer to union (or union, if the witx tooling adds support for it) is the way to go.

view this post on Zulip Emiliano Lesende (May 26 2020 at 18:39):

@Dan Gohman I meant higher level, akin to TcpStream in Rust. I agree with you about Sockets API, and I worry about C/C++ folks targeting WebAssembly that depend on that kind of API.

view this post on Zulip Dan Gohman (May 26 2020 at 18:40):

Even Rust's TcpStream is just a thin abstraction around Berkeley sockets.

view this post on Zulip Dan Gohman (May 26 2020 at 18:41):

Eg. SocketAddr is a Rust enum, which is just a more type-safe version of union :-)

view this post on Zulip Emiliano Lesende (May 26 2020 at 18:46):

@Dan Gohman I know it is thanks to trait magic, but you can do TcpStream::connect("rust-lang.org"). That looks high level, in the sense I don't have to go fetch addresses, open the socket, then connect, etc etc. That is what I mean by higher level. I'll keep on the current path don't worry.

view this post on Zulip Dan Gohman (May 26 2020 at 18:47):

Rust's API may be valuable to look at, because native socket APIs have accumulated a lot of flags and options, and Rust has done a lot of work to figure out which things are important

view this post on Zulip Emiliano Lesende (May 26 2020 at 18:50):

@Dan Gohman Understood. Once I have something decent and tested. What would be my next step? Should I construct a PR? What is the process?

view this post on Zulip Dan Gohman (May 26 2020 at 18:50):

Ah, I see. I think what we can say there is, even Rust retains the ability to do each of the steps separately if you want to, so we should focus on enabling that, and then we can talk about how to provide convenience functions that combine multiple steps into one

view this post on Zulip Dan Gohman (May 26 2020 at 18:51):

as a followup

view this post on Zulip Dan Gohman (May 26 2020 at 18:51):

Yeah, I think a PR would be a good next step

view this post on Zulip Josh Triplett (Jun 27 2020 at 17:38):

I don't know how well witx supports this yet, but I feel like it would be possible to use an object that "remembers" the type of the socket.

view this post on Zulip Josh Triplett (Jun 27 2020 at 17:38):

As in, you can't mismatch the socket family and the address you use.

view this post on Zulip Josh Triplett (Jun 27 2020 at 17:39):

I think that makes more sense than a union.

view this post on Zulip Josh Triplett (Jun 27 2020 at 17:43):

The C API lets you do things like pass a sockaddr_un to a TCP socket or vice versa. That seems likely to provoke unsafe bugs in implementations, to the point that we will have to make sure callers can't do that via validation before calling the underlying socket library.

view this post on Zulip Josh Triplett (Jun 27 2020 at 17:43):

And if we have to remember that anyway, let's encode it in the type system.

view this post on Zulip Josh Triplett (Jun 27 2020 at 17:46):

I can very easily imagine ways that the interface allowing mismatched calls to connect vs socket could bypass capability security.

view this post on Zulip Emiliano Lesende (Jul 02 2020 at 15:17):

@Dan Gohman I finally managed to complete the implementation. I would appreciate if you can give it a quick review before I start assembling the PR.

The repo for the WASI spec changes is here:
https://github.com/Kong/WASI/tree/feat/wasi-sockets

And the reference implementation for it, is here:
https://github.com/Kong/wasmtime/tree/feat/wasi-sockets

sock_open and addr_resolve now receive an address pool as we discussed.

WebAssembly System Interface. Contribute to Kong/WASI development by creating an account on GitHub.
Standalone JIT-style runtime for WebAssembly, using Cranelift - Kong/wasmtime

view this post on Zulip Dan Gohman (Jul 02 2020 at 15:18):

Sure. I'm in meeting atm, but I can take a look a little later today

view this post on Zulip Dan Gohman (Jul 03 2020 at 17:22):

Finally taking a look here; the wasmtime changes look like a good start!

view this post on Zulip Dan Gohman (Jul 03 2020 at 17:22):

Before submitting a PR, it's worth rebasing on main to avoid the testsuite diffs

view this post on Zulip Emiliano Lesende (Jul 03 2020 at 17:27):

Yeah, of course. All the changes are on snapshot. Should I move them to ephemeral? Or should I leave them in snapshot? Also, this would need to be split into two PRs. One for WASI spec, and the other for wasmtime.

view this post on Zulip Dan Gohman (Jul 03 2020 at 17:54):

Yeah, the WASI changes should be in ephemeral

view this post on Zulip Emiliano Lesende (Jul 06 2020 at 18:45):

@Dan Gohman So, the procedure would be:

  1. Send PR for WASI spec into ephemeral
  2. Wait for merge, and then wait for snapshot
  3. Wait for release of WASI binding for Rust
  4. Send PR for wasi-common and test-programs
    Correct?

view this post on Zulip Dan Gohman (Jul 08 2020 at 00:10):

@Emiliano Lesende Yes

view this post on Zulip Dan Gohman (Jul 08 2020 at 00:11):

One thing to be aware of is that ephemeral is currently blocked on some big modularization changes, so the timeline for the next snapshot is unclear.

view this post on Zulip Dan Gohman (Jul 08 2020 at 00:13):

However, I think we can go ahead and put experimental APIs in wasi-common without waiting for a snapshot. We can use different names for now, to avoid conflicts if there are changes during the standardization process.

view this post on Zulip Dan Gohman (Jul 08 2020 at 00:13):

I think we can put experimental APIs in the WASI bindings too, again without waiting for a snapshot. Possibly by putting them behind a feature flag.

view this post on Zulip Josh Triplett (Jul 12 2020 at 04:34):

@Emiliano Lesende What is the "address pool" fd? I don't think I understand that.

view this post on Zulip Emiliano Lesende (Jul 20 2020 at 17:16):

@Josh Triplett The address pool fd is a pool of IP addresses and ports. You need to configure that at WASI for you to be able to use the socket calls. When you create the WASI ctx you can pass in address pools which the program can then use to issue socket calls. Is a way to have some security control to know who you can connect to/listen to, without overblowing the whole system into a fully featured firewall.

view this post on Zulip Josh Triplett (Jul 20 2020 at 17:16):

Ah, that makes sense.

view this post on Zulip Emiliano Lesende (Jul 20 2020 at 17:17):

@Dan Gohman Ok. I'll see if I can make the change this week.

view this post on Zulip Josh Triplett (Jul 20 2020 at 17:18):

Following up on a question from earlier in this thread, what happens if you attempt to pass a mismatched address family and address?

view this post on Zulip Josh Triplett (Jul 20 2020 at 17:19):

(deleted)

view this post on Zulip Emiliano Lesende (Jul 20 2020 at 17:21):

Mismatched as in? What you mean?

view this post on Zulip Josh Triplett (Jul 20 2020 at 17:23):

Wrong branch of the union.

view this post on Zulip Josh Triplett (Jul 20 2020 at 17:24):

What happens if you pass an IPv6 address and a UNIX socket family, or vice versa?

view this post on Zulip Josh Triplett (Jul 20 2020 at 17:25):

With the interface posted much earlier in this thread, it seems like that would not get caught, and would get as far as the underlying library/system call.

view this post on Zulip Emiliano Lesende (Jul 20 2020 at 17:27):

At the moment there is no UNIX socket support, but having said that if you pass an IPv6 pool and you try to use an IPv4 address you will get a not capable response.

view this post on Zulip Emiliano Lesende (Jul 20 2020 at 17:28):

Is that what you where asking about?

view this post on Zulip Emiliano Lesende (Jul 20 2020 at 17:31):

Or you mean if I sock_open to an IPv6 address family and then sock_connect to an IPv4? In that case we will pass is along to the OS which in turn it will return you a EAFNOSUPPORT.

view this post on Zulip Josh Triplett (Jul 20 2020 at 17:32):

That's one possibility, and probably a more innocuous one.

view this post on Zulip Josh Triplett (Jul 20 2020 at 17:33):

I'm thinking of things like trying to create a UNIX socket but passing an IPv4 or IPv6 address.

view this post on Zulip Josh Triplett (Jul 20 2020 at 17:35):

A Unix socket address is a string-like buffer with some really strange semantics.

view this post on Zulip Josh Triplett (Jul 20 2020 at 17:36):

We likely need to do some extra validation there, but if someone can just pass an IPv6 address and have the octets interpreted as the bytes of a UNIX socket address...

view this post on Zulip Josh Triplett (Jul 20 2020 at 17:38):

I had been wondering if we could enforce a match between the address family used at sock_open and the address passed to things like connect or bind.

view this post on Zulip Josh Triplett (Jul 20 2020 at 17:39):

So that it never gets to the OS call if you try to play games like that, which means a much smaller attack surface.

view this post on Zulip Emiliano Lesende (Jul 20 2020 at 17:41):

Oh, not sure that can happen thou. Unions at WASI are tagged, which means that sock_connect knows what that address is for and when it converts it to sockaddr it will set the correct address family. Yeah granted, it will set the correct address family at the sockaddr struct level but not at the sock_open.

view this post on Zulip Josh Triplett (Jul 20 2020 at 17:42):

I missed that it was using a tagged union. I thought WITX had both tagged and untagged.

view this post on Zulip Josh Triplett (Jul 20 2020 at 17:43):

But yes, I also mean a mismatch between open and later calls like connect.

view this post on Zulip Emiliano Lesende (Jul 20 2020 at 17:43):

I don't particularly like the Berkeley socket interface either, and we could delay opening the socket until we know the address family. The reason I didn't go this route is because I was worried what it could mean when we try to implement the C calls in WASI.

view this post on Zulip Josh Triplett (Jul 20 2020 at 17:44):

I could easily imagine an OS socket implementation ignoring the mismatch between the two calls and just interpreting the buffer passed into the later call using the address family from the open call.

view this post on Zulip Josh Triplett (Jul 20 2020 at 17:45):

No, I don't think that we should delay opening the socket.

view this post on Zulip Josh Triplett (Jul 20 2020 at 17:45):

I'm more wondering if we can remember the address family that was given when opening the socket, and enforce a match ourselves, rather than relying on the operating system to do so.

view this post on Zulip Emiliano Lesende (Jul 20 2020 at 17:45):

I see. Good point. We could add that extra check, is there an OS API call to retrieve the AF? if not we could store it ourselves in the handle.

view this post on Zulip Josh Triplett (Jul 20 2020 at 17:46):

I think we should store it ourselves, perhaps by using different types of handle.

view this post on Zulip Emiliano Lesende (Jul 20 2020 at 17:46):

Agreed.

view this post on Zulip Josh Triplett (Jul 20 2020 at 17:46):

That would avoid making an extra OS call. We don't want to slow down the common case of programs behaving correctly.

view this post on Zulip Emiliano Lesende (Jul 20 2020 at 17:47):

Makes sense

view this post on Zulip Josh Triplett (Jul 20 2020 at 17:47):

Thank you. I appreciate you hearing out the concern. :)

view this post on Zulip Emiliano Lesende (Jul 20 2020 at 17:47):

Of course. Always.

view this post on Zulip Josh Triplett (Jul 20 2020 at 17:48):

Because the Berkeley sockets interface is so very C-oriented, and the sockaddr structure in particular is one of the most horrible things that people need to deal with on a regular basis in common programs, I didn't want to just trust the underlying OS to do the right thing for security.

view this post on Zulip Josh Triplett (Jul 20 2020 at 17:51):

I would be happy to review the updated patch series as soon as you have it available. Send me a link?

view this post on Zulip Emiliano Lesende (Jul 20 2020 at 17:55):

You can find the link the repos above. I'll repost it here.

view this post on Zulip Emiliano Lesende (Jul 20 2020 at 17:55):

The repo for the WASI spec changes is here:
https://github.com/Kong/WASI/tree/feat/wasi-sockets

And the reference implementation for it, is here:
https://github.com/Kong/wasmtime/tree/feat/wasi-sockets

WebAssembly System Interface. Contribute to Kong/WASI development by creating an account on GitHub.
Standalone JIT-style runtime for WebAssembly, using Cranelift - Kong/wasmtime

view this post on Zulip Josh Triplett (Jul 20 2020 at 18:27):

I meant a link when you have a new patch that enforces the match, and I'd be happy to review that. :)

view this post on Zulip Josh Triplett (Jul 20 2020 at 18:27):

I already read the patches so far.

view this post on Zulip Emiliano Lesende (Jul 20 2020 at 18:29):

Oh sure.

view this post on Zulip Emiliano Lesende (Aug 05 2020 at 18:16):

@Dan Gohman @Josh Triplett I noticed that there is a main branch now, should I switch to main for rebasing or keep it on master?

view this post on Zulip Dan Gohman (Aug 05 2020 at 18:17):

for all Bytecode Alliance repos use main

view this post on Zulip Emiliano Lesende (Aug 05 2020 at 18:17):

ok

view this post on Zulip Emiliano Lesende (Aug 05 2020 at 18:50):

@Dan Gohman it looks that main points to 0.11.0 of wasi, but the most recent published version of it is still 0.10.0+wasi-snapshot-preview1

view this post on Zulip Dan Gohman (Aug 05 2020 at 20:05):

Ah, it looks like we should publish a new version then

view this post on Zulip Emiliano Lesende (Aug 07 2020 at 17:10):

@Josh Triplett the changes you requested are in :)

view this post on Zulip Josh Triplett (Aug 07 2020 at 18:18):

@Emiliano Lesende Awesome, thanks!

view this post on Zulip Emiliano Lesende (Aug 18 2020 at 16:58):

@Josh Triplett @Dan Gohman The PR for the socket API is in. I cannot send the PR for the implementation yet. I tried to put it behind a feature flag, but there is some work which is complicated as I cannot put feature flags inside match expressions in Rust. I cannot wall everything up properly. Any idea how long it will take to make the sock API into snapshot?

view this post on Zulip Emiliano Lesende (Aug 18 2020 at 16:58):

https://github.com/WebAssembly/WASI/pull/312

This PR adds new functions for socket operations such as sock_listen, sock_bind, sock_connect, etc. It also includes a new addr_resolve function for performing DNS resolution. The PR introduces a n...

view this post on Zulip Till Schneidereit (Aug 18 2020 at 17:45):

That sounds like great progress! \o/

Would it make sense to open a PR for the implementation in its current state and then have people weigh in on how best to do the feature flag?

view this post on Zulip Emiliano Lesende (Aug 18 2020 at 18:58):

@Till Schneidereit I could do that. I guess you can also take a look here: https://github.com/Kong/wasmtime/tree/feat/wasi-sockets

Standalone JIT-style runtime for WebAssembly, using Cranelift - Kong/wasmtime

view this post on Zulip Emiliano Lesende (Aug 18 2020 at 19:00):

My issue right now, is on this match:
https://github.com/Kong/wasmtime/blob/feat/wasi-sockets/crates/wasi-common/src/sys/unix/mod.rs#L117
I need to gate that case expression since AddressPool ain't available yet until ephemeral gets merged.

Standalone JIT-style runtime for WebAssembly, using Cranelift - Kong/wasmtime

Last updated: Jan 24 2025 at 00:11 UTC