-
Notifications
You must be signed in to change notification settings - Fork 5.5k
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
feat(unstable): Implement QUIC #21942
Conversation
8d2f39b
to
84747e1
Compare
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
nice API 👍
28254df
to
f7eb83e
Compare
37df306
to
aec0bb8
Compare
e208a10
to
6d9a15f
Compare
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This looks pretty good. I agree with @littledivy's comments re: ring.
I think we should consider merging this into ext/net rather than creating a new module, however.
d05ef59
to
823a8f9
Compare
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@devsnek this is fantastic work, I'm impressed how few lines of code you needed to implement that 💪
a5b1091
to
7645454
Compare
4d4f24e
to
b21790d
Compare
How hard or how long would it take to implement Webtransport with this PR ? My suggestion is : why not adding it at the same time before merging in 1.41 since WT is 76% available on the browsers. Adding a client seems "easy" enough, and a server which is upgrading the QUIC transport connection to a server (somewhat like Websocket works at the moment) |
8638073
to
c8e070f
Compare
Probably should be done in a separate PR imo. I'm really excited about this! Is there any consideration for this in deno 1.43 @bartlomieju? |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Very nicely done. Most of my suggestions are little nits. However, same as @mmastrac, I question whether this should be done as an extra module rather than within ext/net
.
Either way, can you please resolve the merge conflicts?
runtime/js/90_deno_ns.js
Outdated
connectQuic: quic.connectQuic, | ||
listenQuic: quic.listenQuic, | ||
QuicBidirectionalStream: quic.QuicBidirectionalStream, | ||
QuicConn: quic.QuicConn, | ||
QuicListener: quic.QuicListener, | ||
QuicReceiveStream: quic.QuicReceiveStream, | ||
QuicSendStream: quic.QuicSendStream, | ||
}; | ||
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
We can either include these classes in the Deno.*
namespace or make the constructors of these classes illegal. The former adds to the API surface area, but the latter enables such objects to be identified with the use of instanceof
. Which should we do? @bartlomieju
I also think we should merge it into ext/net, and if we want to make protocol that depends on QUIC then we can make module ( i.e WebTransport and Media over Quic (MoQ).. |
4fe503b
to
e2156ca
Compare
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Mostly documentation nits.
Any updates on this? @devsnek @bartlomieju |
02bc6fb
to
8e2726e
Compare
"connectQuic", | ||
"listenQuic", | ||
"QuicBidirectionalStream", | ||
"QuicConn", | ||
"QuicListener", | ||
"QuicReceiveStream", | ||
"QuicSendStream", |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Nitpick - add these to runtime/fmt_errors.rs
get_suggestions_for_terminal_errors
for better DX?
ext/net/lib.deno_net.d.ts
Outdated
/** @category Network */ | ||
export interface QuicTransportOptions { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
All these typings are missing the **UNSTABLE**: New API, yet to be vetted.
banners and @experimental
markers. @crowlKats can double check if they are marked properly
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
LGTM, 🚢 it
Implements a QUIC interface, loosely based on the WebTransport API (a future change could add the WebTransport API, built on top of this one). [quinn](https://docs.rs/quinn/latest/quinn/) is used for the underlying QUIC implementation, for a few reasons: - A cloneable "handle" api which fits quite nicely into deno resources. - Good collaboration with the rust ecosystem, especially rustls. - I like it. <!-- Before submitting a PR, please read https://deno.com/manual/contributing 1. Give the PR a descriptive title. Examples of good title: - fix(std/http): Fix race condition in server - docs(console): Update docstrings - feat(doc): Handle nested reexports Examples of bad title: - fix #7123 - update docs - fix bugs 2. Ensure there is a related issue and it is referenced in the PR text. 3. Ensure there are tests that cover the changes. 4. Ensure `cargo test` passes. 5. Ensure `./tools/format.js` passes without changing files. 6. Ensure `./tools/lint.js` passes. 7. Open as a draft PR if your work is still in progress. The CI won't run all steps, but you can add '[ci]' to a commit message to force it to. 8. If you would like to run the benchmarks on the CI, add the 'ci-bench' label. -->
Implements a QUIC interface, loosely based on the WebTransport API (a future change could add the WebTransport API, built on top of this one).
quinn is used for the underlying QUIC implementation, for a few reasons: