View Source ExWebRTC.DataChannel (ex_webrtc v0.7.0)

Implementation of the RTCDataChannel.

Summary

Types

Options used when creating a new DataChannel.

Possible data channel order configurations.

Possible data channel states.

t()

Struct representing the DataChannel.

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 have id set to nil)