-
Notifications
You must be signed in to change notification settings - Fork 163
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
Continued TCP-ICE Improvements #245
Comments
I think the spec is also pretty specific about some situations when the inbound connections need to be dropped. I think currently we'll accept any TCP connection with the right We shouldn't drop the TCP connection during ICE restarts so that's another thing to think about. Also, I think the way priorities are calculated might need to be changed for TCP candidates. |
This addresses a few points issue of #245: - Take a net.Listener instead of having global state - Expose a net.TCPMux based API Also, the unused closeChannel was removed from tcp_mux.go
We should also provide a way to figure out which network type is currently in use by an ICE Agent. For example, there's no need for having a Jitter Buffer when TCP is in use. Perhaps there could be a function: func (a *Agent) SelectedNetworkType() (t NetworkType, ok bool` {
pair := a.getSelectedPair()
if pair == nil {
return t, false
}
return pair.local.NetworkType(), true
} And then we could expose this information in func (pc *PeerConnection) SelectedNetworkType() (t NetworkType, ok bool) {
nt, ok := pc.iceTransport.gatherer.getAgent().SelectedNetworkType()
if !ok {
return t, ok
}
t, err := NewNetworkType(nt)
return t, err != nil
} |
How would the client know when this information becomes invalid and must be recomputed? Can it only change when ICE transitions to the failed state, or can it change at any time? (I agree that this kind of information is useful, for example I'd like to ignore NACK requests on TCP connections since the data will get resent by the transport anyway. OTOH, I'd argue that you still need a jitter buffer with TCP. Due to retransmissions and head-of-line blocking, the amount of jitter is higher with TCP than with UDP. And while TCP will not reorder packets, there's still the possibility of an intermediary that does reordering. Case in point, an SFU might be proxying from UDP to TCP, so the traffic carried on the TCP connection is already reordered due to the UDP leg. Sorry for the digression.) |
Those are all very good points!
This is what I'm not sure about. If it only changes on ICE state changes, perhaps it's better to convey this information via the |
It's easier for the client to query the sender/receiver/transceiver than to keep track of the value last passed to the callback. This is analoguous to the ICE connection state, which is passed to the callback but also available directly from a PeerConnection method. |
@Sean-Der I am unblocked on my issue (was able to get Wowza to enable UDP ICE for me), but seeing as it's October and I try and do Hacktoberfest every year, this seems like a great place to contribute. I'd like to try and help implement active TCP-ICE. I've only been grappling with low level WebRTC stuff for a few weeks now so I'm not sure where to get started. If you have any guidance on parts of the code I should familiarize myself with before breaking ground, it would be much appreciated. And thanks for spearheading this project by the way, WebRTC looks scary and complicated from my perspective as an outsider to the technology but your efforts and attitude are super inspiring. |
@dgunay that is great news! I think the best place to start would be I would start with just opening a TCP Socket in TestTCPMux_Recv is a test that shows the listening side. You can copy this and then implement the connecting side. |
Fire any/all questions at me in Slack. Would love to help you get started :) |
These are a list of all the things we can do to continue improving the
tcp-ice
implementation that landed.Move tointernal
(a small root package that isn't littered with protocol details is great)net.Listener
instead of having global stateExpose aExpose a net.PacketConn based API,net.PacketConn
based APIAgent
prflx
/srflx
so TCP will be used even when UDP connectivity is possibleThe text was updated successfully, but these errors were encountered: