-
Notifications
You must be signed in to change notification settings - Fork 3.5k
Description
Proposal
We (Pyodide and Cloudflare workers) would like to enable socket support without relying on the websocket proxy.
This would allow us to run existing Python code that relies on sockets (e.g., HTTP clients, database clients, etc) without any modification both in client and server.
This is impossible in a Web environment (unless Direct Socket proposal is accepted #16737) as sockets are not supported.
However, in Node.js (or other JS runtimes such as Deno, Bun, or Cloudflare Workers), we can take advantage of it's native socket APIs.
Also, while the Node.js socket APIs are asynchronous, Asyncify (JSPI), can be used to pause the JS function calls to make it compatible to existing socket APIs that expects blocking on select, poll, or recv.
How is would look like
-
Add a flag such as
-sUSE_NODESOCKETthat replaces the current SOCKFS implementation
with a new implementation when the runtime environment is detected as Node.js. -
Update the socket syscalls (e.g., listen, recv, send, etc) to use JSPI or Asyncify (when available)
to block the calls until the underlying Node.js socket APIs complete.
Discussion Topics & Concerns
- Ideally, it would be great to detect the JSPI availability at runtime, so that either the synchronous version or the asynchronous version is selected at runtime. But I guess currently Asyncify does not support that.
I would be happy to implement and contribute this feature is it makes sense.
Pyodide can patch Emscripten locally for our use case, but it would be great to have this feature available upstream so that other projects can benefit from it as well.