-
-
Notifications
You must be signed in to change notification settings - Fork 1k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Web Serial binding #2271
Comments
💯 incredibly interested. I think your design decisions are pretty sound too. |
Cool, good to hear, I'll begin working on a PR. How do you see the package hierarchy being organised? I was thinking of a bindings package, plus maybe a Thoughts here much appreciated. |
Let's start with I've had an idea around changing the api of the bindings that actually might make it a little easier to get it into the main package. (I'm on mobile so it's hard to find the issue, bindings v2 or something) But I think once we have a working bindings package we can figure that out. |
@jacobrosenthal thoughts on donating the @monteslu you'll want to know about this =) |
Here are links to some potentially associated "issues", in case it helps: |
@jaz303 happy to help on this whenever you're ready |
i was working on the same thing and got the conclusion that it adds zero benefits for all cases that i spotted. the main problem is requestPort waits for user input while nodejs does not need to do so |
There's a lot of code that isn't getting the port that would benefit from taking a web serial source. You're not going to have an isomorphic app but you will have isomorphic libraries. |
@reconbot i did not see that in any code that i got the only thing that was usefull was porting the SerialPort Event Emitter API to the Web that is what i did i turned the "while port.read()" WebAPI into a emitter with on Data. on End. I do see nothing that we can improve inside this project. The Main diff out of lib view is the web stream implementation which is already ported to nodejs. https://www.npmjs.com/package/web-streams-polyfill. to be more exact: |
Yet another WebSerial bindings: https://github.com/Azq2/node-serialport-bindings-webserial |
Thats the wrong direction in general i guess. Web Streams got nativ in nodejs now and do in fact replace the old node:streams api's both got aligned to work via the iterateable @symbol so in both versions webStreams and nodeStreams for of loops will do the trick Readable and Writeable got exposed since node 19+ global without import same as in browser context. They are the webstream implementations also helpers got created and shipped to convert streams into both directions. |
@frank-dspeed I think this is not directly relevant to WebSerial. In this issue we just want binding which allows us to use serial ports both in browsers and Node.js without great changes in the code. @reconbot What about official |
FWIW, I started working on this a few years ago but ran into some blockers. See this discussion. I'd be happy to have that work revived. |
It's still just as good as an idea |
This already done: https://github.com/Azq2/node-serialport-bindings-webserial |
💥 Proposal
What feature you'd like to see
Hello! I've been working on a Web Serial binding for node-serialport and would like gauge interest in getting it merged into the official repo. The current status of the project is that it is working with a simple echo client, and all methods except
flush()
are implemented.Motivation
A unified interface to access serial ports between node.js and the web allows code to be shared between CLI applications and web GUIs that communicate with serial devices. My specific use-case is allowing my port of the SAM-BA bootloader client to be deployed on the web.
I believe implementing a Web Serial binding for
node-serialport
is preferable to the reverse approach of adaptingnode-serialport
to work with WHATWG Streams due to the relative simplicity of the Node streams interface, and the slow uptake of WHATWG streams within Node.Pitch
Current usage:
A final implementation would ideally detect a browser environment and set the binding automatically.
I've deliberately left the acquisition of the serial port (
navigator.serial.requestPort()
) out of scope of the binding as it's web specific and should be dealt with in the application's own platform abstraction. The staticlist()
method remains, and returns a list of ports already visible to the browser.The text was updated successfully, but these errors were encountered: