Media
Overview
The media module is responsible for establishing WebRTC sessions between the client and SFU used by OpenTalk. SFU stands for Selective Forwarding Unit and is the redistributor of the media published by each participant.
"Publishing media" means to transmit video and audio to OpenTalk via a WebRTC sendonly
session. Depending on the
use-case the media module allows for 2 different kinds of publishing sessions:
video
: (Lower bitrate) Usually low resolution and higher framerate video used for Webcams or similar with more motionscreen
: (Higher bitrate) Usually high resolution and low framerate ideal for screen share/presentations with text which must be readable
"Subscribing" to a peer in a conference means to receive video and audio via a WebRTC recvonly
session. The published
media of another participant is stored within the module-specific data in the Participant
.
The notion of presenter
is used to communicate screen share permissions.
Joining the room
JoinSuccess
When joining a room, the join_success
control event contains the module-specific fields described below.
Fields
Field | Type | Always | Description |
---|---|---|---|
is_presenter | bool | yes | Represents if the current participant has permissions for screen share |
speakers | ParticipantSpeakingState[] | yes | The list of current or previous speakers in the meeting |
force_mute | ForceMuteState | yes | The current force mute state |
Example
{
"is_presenter": true,
"speakers": [
{
"participant": "6802d547-06ff-493a-bcce-da7f3bc37248",
"is_speaking": false,
"updated_at": "2023-01-13T12:29:01Z"
},
{
"participant": "0605e657-27b8-443e-81de-31d5921e9a42",
"is_speaking": true,
"updated_at": "2023-01-13T12:37:42Z"
},
{
"participant": "69068e53-eb60-4c1d-bfc1-fc31a0dc45a3",
"is_speaking": false,
"updated_at": "2023-01-13T12:22:08Z"
}
],
"force_mute": {
"type": "enabled",
"allow_list": [
"07d32d3e-9510-49bf-82b7-e21fef9db120"
]
}
}
Joined
When joining a room, the joined
control event sent to all other participants contains the module-specific fields described below.
Fields
Field | Type | Always | Description |
---|---|---|---|
state | ParticipantMediaState | no | An object describing the current availability of media and their current mute status |
is_presenter | bool | yes | Represents if the other participant has permissions for screen share |
ParticipantMediaState:
This object represents the available media sessions and encapsulates their mute state.
Field | Type | Always | Description |
---|---|---|---|
video | MediaSessionState | no | If this field is set, the participant is publishing a video, usually a webcam (lower resolution, higher framerate) |
screen | MediaSessionState | no | If this field is set, the participant is publishing their screen (usually high resolution, low framerate) |
Example
This example shows a participant's state when publishing only their screen without audio enabled.
{
"state": {
"screen": {
"video": true,
"audio": false
}
},
"is_presenter": true
}
Commands
Publish
Create a WebRTC publish session by sending an SDP offer.
Response
A SdpAnswer will return an SDP response.
Fields
Field | Type | Required | Description |
---|---|---|---|
action | enum | yes | Must be "publish" |
sdp | string | yes | SDP Offer as a string |
target | string | yes | See Target |
media_session_type | enum | yes | See Target |
Example
{
"action": "publish",
"sdp": "v=0,....",
"target": "07d32d3e-9510-49bf-82b7-e21fef9db120",
"media_session_type": "video"
}
PublishComplete
Signal that the WebRTC publish process is complete and set the initial mute status. Other participants will be notified
by an Update
that the media is now available to be subscribed to and if the audio or video track
is muted.
If the force-mute state is enabled, the media_session_state.video.audio
field must be set to false
unless the
participant is included in the allow_list
.
Fields
Field | Type | Required | Description |
---|---|---|---|
action | enum | yes | Must be "publish_complete" |
media_session_type | enum | yes | Either "video" or "screen" |
media_session_state | MediaSessionState | yes |
Example
{
"action": "publish_complete",
"media_session_type": "video",
"media_session_state": {
"video": {
"video": true,
"audio": false
}
}
}
Unpublish
Remove/stop an existing WebRTC publish session. The WebRTC session will instantly be stopped (if not already) by the
SFU when sending this command. Other participants will be notified by an Update
that the published
media is no longer available.
Fields
Field | Type | Required | Description |
---|---|---|---|
action | enum | yes | Must be "unpublish" |
media_session_type | enum | yes | Either "video" or "screen" |
Example
{
"action": "unpublish",
"media_session_type": "video"
}
Subscribe
Request an SDP offer for the specified target (a peer participant's published media).
Response
A SdpOffer will return an SDP offer to which the client must respond to with an SdpAnswer.
Fields
Field | Type | Required | Description |
---|---|---|---|
action | enum | yes | Must be "subscribe" |
target | string | yes | See Target |
media_session_type | enum | yes | See Target |
without_video | bool | no | Can be used to opt out of the video stream for the entire WebRTC session |
Example
{
"action": "subscribe",
"target": "84a2c872-94fb-4b41-aca7-13d784c92a72",
"media_session_type": "video",
"without_video": true
}
Resubscribe
Request for a WebRTC subscribe session to be restarted, this will restart the complete negotiation process.
Response
A SdpOffer will return an SDP offer to which the client must respond to with an SdpAnswer.
Fields
Field | Type | Required | Description |
---|---|---|---|
action | enum | yes | Must be "resubscribe" |
target | string | yes | See Target |
media_session_type | enum | yes | See Target |
Example
{
"action": "resubscribe",
"target": "84a2c872-94fb-4b41-aca7-13d784c92a72",
"media_session_type": "video"
}
SdpAnswer
Complete the initial SDP negotiation of a subscription by sending an SDP answer. The SFU will begin the WebRTC/ICE
handshake and notify later via an WebrtcUp
if the establishment was successful from it's side.
Fields
Field | Type | Required | Description |
---|---|---|---|
action | enum | yes | Must be "sdp_answer" |
sdp | string | yes | SDP Answer as a string |
target | string | yes | See Target |
media_session_type | enum | yes | See Target |
Example
{
"action": "sdp_answer",
"sdp": "v=0,...",
"target": "84a2c872-94fb-4b41-aca7-13d784c92a72",
"media_session_type": "video"
}
SdpCandidate
Exchange a ICE trickle candidate with a establishing WebRTC session. This is part of the WebRTC establishment and is forwarded to the SFU.
Fields
Field | Type | Required | Description |
---|---|---|---|
action | enum | yes | Must be "sdp_candidate" |
candidate | TrickleCandidate | yes | Candidate to send |
target | string | yes | See Target |
media_session_type | enum | yes | See Target |
Example
{
"action": "sdp_candidate",
"candidate": {
"sdpMLineIndex": 0,
"candidate": "candidate:..."
},
"target": "84a2c872-94fb-4b41-aca7-13d784c92a72",
"media_session_type": "video"
}
SdpEndOfCandidates
Signal the establishing WebRTC session that there are no more ICE trickle candidates. This is part of the WebRTC establishment and is forwarded to the SFU.
Fields
Field | Type | Required | Description |
---|---|---|---|
action | enum | yes | Must be "sdp_end_of_candidates" |
target | string | yes | See Target |
media_session_type | enum | yes | See Target |
Example
{
"action": "sdp_end_of_candidates",
"target": "84a2c872-94fb-4b41-aca7-13d784c92a72",
"media_session_type": "video"
}
UpdateMediaSession
Update the mute state for a WebRTC publish session. This information is forwarded to all other participants using inside
an Update
.
If the force-mute state is enabled, the field media_session_state.audio
must be set to false
unless the participant
is included in the allow_list
.
Fields
Field | Type | Required | Description |
---|---|---|---|
action | enum | yes | Must be "update_media_session" |
media_session_type | enum | yes | Either "video" or "screen" |
media_session_state | MediaSessionState | yes | The new state for the session |
Example
{
"action": "update_media_session",
"media_session_type": "video",
"media_session_state": {
"video": {
"audio": true,
"video": true,
},
"screen": null
}
}
Configure
Configure a WebRTC subscribe session. The request is forwarded to the SFU which configured the media streams appropriately.
This is used to adjust the quality of a video stream to save on bandwidth.
Fields
Field | Type | Required | Description |
---|---|---|---|
action | enum | yes | Must be "configure" |
configuration | SubscriberConfiguration | yes | |
target | string | yes | See Target |
media_session_type | enum | yes | See Target |
SubscriberConfiguration:
Field | Type | Required | Description |
---|---|---|---|
video | bool | no | If video transmission should be enabled. This option should be used to turn off videos of participants which are out of view |
substream | int | no | Select a different substream if any are available. Substreams are usually the same video with difference in bitrate/quality, where 0 is usually the lowest quality. This options should be used to lower the quality of participants that are displayed in a smaller window. |
Example
{
"action": "configure",
"configuration": {
"video": true,
"substream": 0
},
"target": "84a2c872-94fb-4b41-aca7-13d784c92a72",
"media_session_type": "video",
}
GrantPresenterRole
Grant one or more participants the right to show their screen
Fields
Field | Type | Required | Description |
---|---|---|---|
action | enum | yes | Must be "grant_presenter_role" |
participant_ids | string[] | yes | List of participant ids to grant the presenter role |
Example
{
"action": "grant_presenter_role",
"participant_ids": [
"84a2c872-94fb-4b41-aca7-13d784c92a72",
"2375602f-c74c-4935-9933-bfd67d4e8ae5"
]
}
RevokePresenterRole
Revoke one or more participants the right to show their screen
Fields
Field | Type | Required | Description |
---|---|---|---|
action | enum | yes | Must be "revoke_presenter_role" |
participant_ids | string[] | yes | List of participant ids to revoke their presenter role |
Example
{
"action": "revoke_presenter_role",
"participant_ids": [
"84a2c872-94fb-4b41-aca7-13d784c92a72",
"2375602f-c74c-4935-9933-bfd67d4e8ae5"
]
}
ModeratorMute
Request another participant to mute their microphone.
Fields
Field | Type | Required | Description |
---|---|---|---|
action | enum | yes | Must be "moderator_mute" |
targets | string or string[] | no | Id of one or more participants to request to be muted. If missing, all participants except the sender of this message will be muted. |
force | bool | yes | We're not asking you to mute, we're telling! |
Example
Mute specific participants:
{
"action": "moderator_mute",
"targets": [
"84a2c872-94fb-4b41-aca7-13d784c92a72",
"2375602f-c74c-4935-9933-bfd67d4e8ae5"
],
"force": true
}
Mute all participants in the room except themselves:
{
"action": "moderator_mute",
"force": true
}
ModeratorEnableForceMute
Enables the force mute state which mutes all participants and disallows enabling the microphone except for participants included in the allow_list
.
Fields
Field | Type | Required | Description |
---|---|---|---|
action | enum | yes | Must be moderator_enable_force_mute |
allow_list | string[] | yes | The list of participants that are still allowed to unmute |
Example
{
"action": "moderator_enable_force_mute",
"allow_list": [
"84a2c872-94fb-4b41-aca7-13d784c92a72",
"2375602f-c74c-4935-9933-bfd67d4e8ae5"
]
}
ModeratorDisableForceMute
Disables the force-mute state and allows participants to enable their microphones again.
Fields
Field | Type | Required | Description |
---|---|---|---|
action | enum | yes | Must be moderator_disable_force_mute |
Example
{
"action": "moderator_disable_force_mute"
}
UpdateSpeakingState
Update the client's speaking state. This should be sent to the service by the client when it detects either start or end of a speaking period.
After receiving this message, the service sends out a
SpeakerUpdated
event to all participants, including the
one that changed their state.
Fields
Field | Type | Required | Description |
---|---|---|---|
action | enum | yes | Must be "update_speaking_state" |
is_speaking | bool | yes | The flag indicating whether the client states that the participant is currently speaking |
Example
{
"action": "update_speaking_state",
"is_speaking": true
}
Events
SdpAnswer
Provides an SDP answer string in response to a Publish
command.
Fields
Field | Type | Always | Description |
---|---|---|---|
message | enum | yes | Is "sdp_answer" |
sdp | string | yes | SDP Answer in a string |
source | string | yes | See Source |
media_session_type | enum | yes | See Source |