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

Expose "SetReadDeadline" and "SetDeadline" from this package #127

Closed
mission-liao opened this issue Dec 18, 2020 · 3 comments · Fixed by #128
Closed

Expose "SetReadDeadline" and "SetDeadline" from this package #127

mission-liao opened this issue Dec 18, 2020 · 3 comments · Fixed by #128

Comments

@mission-liao
Copy link
Contributor

Summary

  • Expose SetReadDeadline from ReadStreamSRTP and ReadStreamSRTCP.
  • Expose SetWriteDeadline from WriteStreamSRTP and WriteStreamSRTCP

Motivation

To make the packet I/O of pion/webrtc cancelable without closing peer-connection, including RTP and RTCP packets.

Additional context

I've spent some time to trace this package, and below is an implementation plan. Please kindly correct me if it's wrong.

  • expose SetReadDeadline for ReadStreamSRTP via ReadStreamSRTP.buffer.
  • expose SetReadDeadline for ReadStreamSRTCP via ReadStreamSRTCP.buffer.
  • expose SetWriteDeadline for WriteStreamSRTP via session.nextConn.
  • expose SetWriteDeadline for WriteStreamSRTCP via session.nextConn.

What I didn't investigate is the way to test the implementation, feel free to give me some advise/reference if any.

@mission-liao
Copy link
Contributor Author

mission-liao commented Dec 18, 2020

@Sean-Der would love to get your feedback and take over the implementation part.

@Sean-Der
Copy link
Member

@mission-liao I am 100% in support of this! This is an instant merge from me :)

Test wise I think it is ok to set a Timelimit on the test 5 seconds and set a small ReadDeadline. If the test times out it will cause a fail.

@mission-liao
Copy link
Contributor Author

Cool, would integrate this part to pion/webrtc package later.

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

Successfully merging a pull request may close this issue.

2 participants