View Source ExWebRTC.DataChannel (ex_webrtc v0.7.0)
Implementation of the RTCDataChannel.
Summary
Types
@type options() :: [ ordered: order(), max_packet_life_time: non_neg_integer(), max_retransmits: non_neg_integer(), protocol: String.t() ]
Options used when creating a new DataChannel.
For more information refer to ExWebRTC.PeerConnection.create_data_channel/3
.
As of now, Elixir WebRTC does not support negotiated: true
option, all DataChannels need to be
negotiated in-band.
@type order() :: :ordered | :unordered
Possible data channel order configurations.
For the exact meaning, refer to the RTCDataChannel: order property.
@type ready_state() :: :connecting | :open | :closed
Possible data channel states.
Right now, Elixir WebRTC does not support :closing
state.
When you close the data channel, it goes from :open
directly to :closed
.
For the exact meaning, refer to the RTCDataChannel: readyState property.
@type ref() :: reference()
@type t() :: %ExWebRTC.DataChannel{ id: non_neg_integer() | nil, label: String.t(), max_packet_life_time: non_neg_integer() | nil, max_retransmits: non_neg_integer() | nil, ordered: order(), protocol: String.t(), ready_state: ready_state(), ref: ref() }
Struct representing the DataChannel.
All of the fields have the same meaning as in RTCDataChannel
except for ref
which is a local identifier used when refering to this DataChannel in
received messages or when calling ExWebRTC.PeerConnection.send_data/3
function.
It's worth to mention that id
and label
can be used by the other peer to identify the data
channel, althought be careful as:
label
does not have to be unique, channels can share a single label,id
is only assigned after the SCTP connection has been established (which means that DataChannels created before first negotiation will haveid
set tonil
)