Skip to content
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

[meta] Open Screen Network Protocol #345

Open
1 of 2 tasks
markafoltz opened this issue Sep 18, 2024 · 5 comments
Open
1 of 2 tasks

[meta] Open Screen Network Protocol #345

markafoltz opened this issue Sep 18, 2024 · 5 comments
Assignees

Comments

@markafoltz
Copy link
Contributor

markafoltz commented Sep 18, 2024

This will begin as everything omitted from the Open Screen Application Protocol (#341) but may evolve over time into one or more specifications.

The motivations for doing so are listed in #341.

The initial draft of the network protocol will include the SPAKE2 authentication ceremony, although it is open for discussion whether that belongs with the application protocol, the network protocol, or should be spun out into a separate specification.

The future prospects for taking up this work in one or more IETF groups will also influence the outcome.

This meta issue tracks work items to draft the network layer protocol. Additional tasks will be posted below as needed.

@markafoltz
Copy link
Contributor Author

Note, the spec name was chosen as a placeholder, and it's likely to be renamed in the future.

@markafoltz markafoltz changed the title [meta] Define Open Screen Network Protocol [meta] Open Screen Network Protocol Sep 18, 2024
@backkem
Copy link
Contributor

backkem commented Sep 20, 2024

I wanted to explore what the network protocol could look like when making an effort to maximally reuse the existing protocols in the WebRTC stack. This is just an exploration at this point. However, it could be relevant since the adoption of QUIC in the real-time space is taking time.

First off, in our LAN setting SDP 'signaling' poses challenges as it requires a side-channel, usually via a cloud service, for which there isn't an obvious alternative in the LAN setting. In addition, the ICE protocol's purpose is mostly for NAT translation. It adds little value in the LAN setting (although it also doesn't hurt). These two protocols are basically what WebRTC uses to open a communication channel between peers. In the OSNP case that would be coveted by LAN service discovery (DNS-SD) + potentially part of the agent-info exchange.

Next, the OSNP needs a communication channel to run the mutual authentication ceremony between the peers. The current specification uses QUIC for reliable delivery of the messages involved. In the excising WebRTC stack SCTP provides reliable delivery. However, for the purposes of the authentication ceremony I would instead opt to run it over DTLS (over UDP, potentially skipping ICE) directly. To ensure messages are delivered I would augment DTLS's Timeout and Retransmission scheme.

Once the connection is authenticated, SCTP can be used as a reliable transport to cary the OpenScreen Application Protocol. Optionally, SRTP can be used for media transport.

@markafoltz
Copy link
Contributor Author

My understanding is that you plan on dividing the messages in the application protocol between two different transports, one reliable and in-order (SCTP) and the other not (RTP).

One thing to evaluate is whether the application protocol is robust to messages arriving out of order. Also the application protocol does not have any provision for message retransmissions as that is assumed to be handled by the transport layer.

@backkem
Copy link
Contributor

backkem commented Sep 20, 2024

Yea, but with the remark that RTP is made specifically to transport real-time media. In other words, I'd consider handing over the media transport responsibility to an existing purpose-built protocol.

All other Application protocol messages would be transported over reliable SCTP. The QUIC equivalent would be QUIC itself for control messages and RoQ (RTP over QUIC) for (real-time) media.

@backkem

This comment was marked as outdated.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

No branches or pull requests

2 participants