ice.h
Go to the documentation of this file.
1 
17 #ifndef JANUS_ICE_H
18 #define JANUS_ICE_H
19 
20 #include <glib.h>
21 #include <agent.h>
22 
23 #include "sdp.h"
24 #include "dtls.h"
25 #include "sctp.h"
26 #include "rtcp.h"
27 #include "text2pcap.h"
28 #include "utils.h"
29 #include "ip-utils.h"
30 #include "refcount.h"
31 #include "plugins/plugin.h"
32 
33 
42 void janus_ice_init(gboolean ice_lite, gboolean ice_tcp, gboolean full_trickle, gboolean ignore_mdns,
43  gboolean ipv6, uint16_t rtp_min_port, uint16_t rtp_max_port);
45 void janus_ice_deinit(void);
53 int janus_ice_test_stun_server(janus_network_address *addr, uint16_t port, uint16_t local_port, janus_network_address *public_addr, uint16_t *public_port);
58 int janus_ice_set_stun_server(gchar *stun_server, uint16_t stun_port);
66 int janus_ice_set_turn_server(gchar *turn_server, uint16_t turn_port, gchar *turn_type, gchar *turn_user, gchar *turn_pwd);
74 int janus_ice_set_turn_rest_api(gchar *api_server, gchar *api_key, gchar *api_method);
77 char *janus_ice_get_stun_server(void);
80 uint16_t janus_ice_get_stun_port(void);
83 char *janus_ice_get_turn_server(void);
86 uint16_t janus_ice_get_turn_port(void);
89 char *janus_ice_get_turn_rest_api(void);
92 void janus_ice_enable_nat_1_1(gboolean keep_private_host);
99 void janus_ice_enforce_interface(const char *ip);
103 gboolean janus_ice_is_enforced(const char *ip);
111 void janus_ice_ignore_interface(const char *ip);
115 gboolean janus_ice_is_ignored(const char *ip);
118 gboolean janus_ice_is_ice_lite_enabled(void);
121 gboolean janus_ice_is_ice_tcp_enabled(void);
124 gboolean janus_ice_is_full_trickle_enabled(void);
127 gboolean janus_ice_is_mdns_enabled(void);
130 gboolean janus_ice_is_ipv6_enabled(void);
133 void janus_set_min_nack_queue(uint16_t mnq);
136 uint16_t janus_get_min_nack_queue(void);
139 void janus_set_no_media_timer(uint timer);
142 uint janus_get_no_media_timer(void);
145 void janus_set_slowlink_threshold(uint packets);
151 void janus_set_twcc_period(uint period);
154 uint janus_get_twcc_period(void);
157 void janus_set_dscp(int dscp);
160 int janus_get_dscp(void);
163 void janus_ice_set_event_stats_period(int period);
171 void janus_ice_debugging_enable(void);
173 void janus_ice_debugging_disable(void);
178 gboolean janus_is_opaqueid_in_api_enabled(void);
179 
180 
184 const gchar *janus_get_ice_state_name(gint state);
185 
186 
195 
196 #define JANUS_ICE_HANDLE_WEBRTC_PROCESSING_OFFER (1 << 0)
197 #define JANUS_ICE_HANDLE_WEBRTC_START (1 << 1)
198 #define JANUS_ICE_HANDLE_WEBRTC_READY (1 << 2)
199 #define JANUS_ICE_HANDLE_WEBRTC_STOP (1 << 3)
200 #define JANUS_ICE_HANDLE_WEBRTC_ALERT (1 << 4)
201 #define JANUS_ICE_HANDLE_WEBRTC_NEGOTIATED (1 << 5)
202 #define JANUS_ICE_HANDLE_WEBRTC_TRICKLE (1 << 7)
203 #define JANUS_ICE_HANDLE_WEBRTC_ALL_TRICKLES (1 << 8)
204 #define JANUS_ICE_HANDLE_WEBRTC_TRICKLE_SYNCED (1 << 9)
205 #define JANUS_ICE_HANDLE_WEBRTC_DATA_CHANNELS (1 << 10)
206 #define JANUS_ICE_HANDLE_WEBRTC_CLEANING (1 << 11)
207 #define JANUS_ICE_HANDLE_WEBRTC_HAS_AUDIO (1 << 12)
208 #define JANUS_ICE_HANDLE_WEBRTC_HAS_VIDEO (1 << 13)
209 #define JANUS_ICE_HANDLE_WEBRTC_GOT_OFFER (1 << 14)
210 #define JANUS_ICE_HANDLE_WEBRTC_GOT_ANSWER (1 << 15)
211 #define JANUS_ICE_HANDLE_WEBRTC_HAS_AGENT (1 << 16)
212 #define JANUS_ICE_HANDLE_WEBRTC_ICE_RESTART (1 << 17)
213 #define JANUS_ICE_HANDLE_WEBRTC_RESEND_TRICKLES (1 << 18)
214 #define JANUS_ICE_HANDLE_WEBRTC_RFC4588_RTX (1 << 19)
215 #define JANUS_ICE_HANDLE_WEBRTC_NEW_DATACHAN_SDP (1 << 20)
216 #define JANUS_ICE_HANDLE_WEBRTC_E2EE (1 << 21)
217 
218 
221 typedef struct janus_ice_stats_info {
223  guint32 packets;
225  guint64 bytes;
229  gint64 updated;
233  guint32 nacks;
235 
238 typedef struct janus_ice_stats {
250 
254 void janus_ice_notify_hangup(janus_ice_handle *handle, const char *reason);
255 
256 
260 gboolean janus_plugin_session_is_alive(janus_plugin_session *plugin_session);
261 
262 
264 typedef struct janus_seq_info {
265  gint64 ts;
266  guint16 seq;
267  guint16 state;
272 enum {
277 };
278 
279 
283  void *session;
285  guint64 handle_id;
287  char *opaque_id;
289  char *token;
291  gint64 created;
293  void *app;
299  gint cdone;
301  GMainContext *mainctx;
303  GMainLoop *mainloop;
305  GThread *thread;
307  GSource *rtp_source, *rtcp_source, *stats_source, *twcc_source;
309  NiceAgent *agent;
313  gboolean controlling;
315  gchar *audio_mid;
317  gchar *video_mid;
319  gchar *data_mid;
321  gchar *stream_mid;
323  guint stream_id;
327  gchar *rtp_profile;
329  gchar *local_sdp;
331  gchar *remote_sdp;
333  const gchar *hangup_reason;
337  GAsyncQueue *queued_candidates;
339  GAsyncQueue *queued_packets;
343  gint last_srtp_error, last_srtp_summary;
347  volatile gint dump_packets;
353  volatile gint closepc;
355  volatile gint destroyed;
358 };
359 
365  guint stream_id;
367  gint cdone:1;
369  guint32 audio_ssrc;
371  guint32 video_ssrc;
373  guint32 video_ssrc_rtx;
375  guint32 audio_ssrc_peer, audio_ssrc_peer_new, audio_ssrc_peer_orig;
377  guint32 video_ssrc_peer[3], video_ssrc_peer_new[3], video_ssrc_peer_orig[3], video_ssrc_peer_temp;
379  guint32 video_ssrc_peer_rtx[3], video_ssrc_peer_rtx_new[3], video_ssrc_peer_rtx_orig[3];
381  char *rid[3];
383  gboolean legacy_rid;
391  GHashTable *rtx_payload_types;
393  GHashTable *clock_rates;
395  gint audio_payload_type, video_payload_type, video_rtx_payload_type;
397  char *audio_codec, *video_codec;
399  gboolean (* video_is_keyframe)(const char* buffer, int len);
401  gboolean audio_send, audio_recv, video_send, video_recv;
405  janus_rtcp_context *video_rtcp_ctx[3];
407  uint16_t nack_queue_ms;
409  GHashTable *rtx_nacked[3];
417  gint64 video_first_ntp_ts[3];
419  guint32 video_first_rtp_ts[3];
431  gint rid_ext_id, ridrtx_ext_id;
461  gchar *ruser;
463  gchar *rpass;
465  GHashTable *components;
469  gboolean noerrorlog;
473  volatile gint destroyed;
476 };
477 
478 #define LAST_SEQS_MAX_LEN 160
479 
484  guint stream_id;
488  guint state;
492  GSList *candidates;
500  gboolean process_started;
502  GSource *icestate_source;
506  GSource *dtlsrt_source;
510  gboolean do_audio_nacks;
512  gboolean do_video_nacks;
514  GQueue *audio_retransmit_buffer, *video_retransmit_buffer;
516  GHashTable *audio_retransmit_seqs, *video_retransmit_seqs;
518  guint16 rtx_seq_number;
530  janus_seq_info *last_seqs_video[3];
536  gboolean noerrorlog;
540  volatile gint destroyed;
543 };
544 
550  gint64 received;
552  char *transaction;
555 };
556 
559 
564 janus_ice_trickle *janus_ice_trickle_new(const char *transaction, json_t *candidate);
570 gint janus_ice_trickle_parse(janus_ice_handle *handle, json_t *candidate, const char **error);
575 
576 
579 
585 janus_ice_handle *janus_ice_handle_create(void *core_session, const char *opaque_id, const char *token);
592 gint janus_ice_handle_attach_plugin(void *core_session, janus_ice_handle *handle, janus_plugin *plugin);
597 gint janus_ice_handle_destroy(void *core_session, janus_ice_handle *handle);
601 void janus_ice_webrtc_hangup(janus_ice_handle *handle, const char *reason);
609 
610 
613 
632 void janus_ice_send_remb(janus_ice_handle *handle, uint32_t bitrate);
640 void janus_ice_incoming_data(janus_ice_handle *handle, char *label, char *protocol, gboolean textdata, char *buffer, int length);
645 void janus_ice_relay_sctp(janus_ice_handle *handle, char *buffer, int length);
650 
651 
654 
663 int janus_ice_setup_local(janus_ice_handle *handle, int offer, int audio, int video, int data, int trickle);
669 void janus_ice_candidates_to_sdp(janus_ice_handle *handle, janus_sdp_mline *mline, guint stream_id, guint component_id);
673 void janus_ice_add_remote_candidate(janus_ice_handle *handle, NiceCandidate *c);
678 void janus_ice_setup_remote_candidates(janus_ice_handle *handle, guint stream_id, guint component_id);
686 void janus_ice_restart(janus_ice_handle *handle);
691 
692 
697 void janus_ice_set_static_event_loops(int loops);
704 
705 #endif
guint srtp_errors_count
Count of the recent SRTP replay errors, in order to avoid spamming the logs.
Definition: ice.h:341
void janus_ice_notify_hangup(janus_ice_handle *handle, const char *reason)
Quick helper method to notify a WebRTC hangup through the Janus API.
Definition: ice.c:712
janus_ice_stats in_stats
Stats for incoming data (audio/video/data)
Definition: ice.h:532
GHashTable * clock_rates
Mapping of payload types to their clock rates, as advertised in the SDP.
Definition: ice.h:393
gboolean noerrorlog
Helper flag to avoid flooding the console with the same error all over again.
Definition: ice.h:536
void janus_ice_resend_trickles(janus_ice_handle *handle)
Method to resend all the existing candidates via trickle (e.g., after an ICE restart) ...
Definition: ice.c:3626
const gchar * hangup_reason
Reason this handle has been hung up.
Definition: ice.h:333
guint sl_lost_count_video
Last known count of lost video packets (for slow_link)
Definition: ice.h:248
guint state
libnice ICE component state
Definition: ice.h:488
gboolean video_send
Definition: ice.h:401
GHashTable * rtx_payload_types
Mapping of rtx payload types to actual media-related packet types.
Definition: ice.h:391
json_t * candidate
JSON object of the trickle candidate(s)
Definition: ice.h:554
Janus plugin data message.
Definition: plugin.h:606
int janus_ice_set_turn_rest_api(gchar *api_server, gchar *api_key, gchar *api_method)
Method to force Janus to contact a TURN REST API server to get a TURN service to use when gathering c...
Definition: ice.c:1120
gint64 retransmit_log_ts
Last time a log message about sending retransmits was printed.
Definition: ice.h:520
gchar * audio_mid
Audio mid (media ID)
Definition: ice.h:315
janus_flags webrtc_flags
Mask of WebRTC-related flags for this handle.
Definition: ice.h:297
void janus_ice_relay_data(janus_ice_handle *handle, janus_plugin_data *packet)
Core SCTP/DataChannel callback, called when a plugin has data to send to a peer.
guint32 audio_ssrc
Audio SSRC of the server for this stream.
Definition: ice.h:369
IP address related utility functions (headers)
gboolean janus_ice_is_full_trickle_enabled(void)
Method to check whether full-trickle support is enabled or not.
Definition: ice.c:88
SCTP processing for data channels (headers)
guint32 packets
Packets sent or received.
Definition: ice.h:223
gchar * local_sdp
SDP generated locally (just for debugging purposes)
Definition: ice.h:329
void janus_set_slowlink_threshold(uint packets)
Method to modify the slowlink-threshold property (i.e., the number of lost packets per seconds that s...
Definition: ice.c:432
int janus_get_dscp(void)
Method to get the current DSCP value (see above)
Definition: ice.c:467
guint32 audio_ssrc_peer_orig
Definition: ice.h:375
gint audiolevel_ext_id
Audio levels extension ID.
Definition: ice.h:433
Reference counter mechanism.
struct janus_seq_info * prev
Definition: ice.h:269
gint64 video_last_ntp_ts
Last sent video NTP timestamp.
Definition: ice.h:425
gsize janus_flags
Janus flags container.
Definition: utils.h:110
struct json_t json_t
Definition: plugin.h:236
guint nack_sent_recent_cnt
Number of NACKs sent since last log message.
Definition: ice.h:526
guint component_id
libnice ICE component ID
Definition: ice.h:486
void janus_seq_list_free(janus_seq_info **head)
Definition: ice.c:579
janus_ice_stream * stream
Janus ICE stream this component belongs to.
Definition: ice.h:482
gint64 audio_first_ntp_ts
First received audio NTP timestamp.
Definition: ice.h:413
Janus media statistics container.
Definition: ice.h:238
void janus_ice_component_destroy(janus_ice_component *component)
Method to only free resources related to a specific ICE component allocated by a Janus ICE handle...
Definition: ice.c:1565
guint32 video_ssrc_peer_temp
Definition: ice.h:377
uint16_t janus_ice_get_stun_port(void)
Method to get the STUN server port.
Definition: ice.c:45
uint16_t janus_get_min_nack_queue(void)
Method to get the current min NACK value (i.e., the minimum time window of packets per handle to stor...
Definition: ice.c:510
gboolean janus_ice_is_ice_lite_enabled(void)
Method to check whether ICE Lite mode is enabled or not (still WIP)
Definition: ice.c:76
janus_mutex mutex
Mutex to lock/unlock this component.
Definition: ice.h:538
gchar * stream_mid
Main mid (will be a pointer to one of the above)
Definition: ice.h:321
int janus_ice_set_stun_server(gchar *stun_server, uint16_t stun_port)
Method to force Janus to use a STUN server when gathering candidates.
Definition: ice.c:1024
struct janus_seq_info janus_seq_info
A helper struct for determining when to send NACKs.
janus_refcount ref
Reference counter for this instance.
Definition: ice.h:475
volatile gint closepc
Whether a close_pc was requested recently on the PeerConnection.
Definition: ice.h:353
janus_mutex mutex
Mutex to lock/unlock this stream.
Definition: ice.h:471
void janus_ice_relay_rtcp(janus_ice_handle *handle, janus_plugin_rtcp *packet)
Core RTCP callback, called when a plugin has an RTCP message to send to a peer.
Definition: ice.c:4732
NiceAgent * agent
libnice ICE agent
Definition: ice.h:309
gint64 nack_sent_log_ts
Last time a log message about sending NACKs was printed.
Definition: ice.h:524
struct janus_ice_stats janus_ice_stats
Janus media statistics container.
GAsyncQueue * queued_candidates
Queue of remote candidates that still need to be processed.
Definition: ice.h:337
char * janus_ice_get_turn_rest_api(void)
Method to get the specified TURN REST API backend, if any.
Definition: ice.c:65
Definition: ice.h:274
void janus_set_dscp(int dscp)
Method to modify the DSCP value to set, which is disabled by default.
Definition: ice.c:461
gboolean process_started
Whether the setup of remote candidates for this component has started or not.
Definition: ice.h:500
janus_refcount ref
Reference counter for this instance.
Definition: ice.h:542
Janus plugin RTP packet.
Definition: plugin.h:571
GMutex janus_mutex
Janus mutex implementation.
Definition: mutex.h:61
SDP m-line representation.
Definition: sdp-utils.h:128
Plugin-Core communication (implementation)
Janus ICE stream.
Definition: ice.h:361
gint janus_ice_handle_attach_plugin(void *core_session, janus_ice_handle *handle, janus_plugin *plugin)
Method to attach a Janus ICE handle to a plugin.
Definition: ice.c:1210
void janus_ice_webrtc_hangup(janus_ice_handle *handle, const char *reason)
Method to only hangup (e.g., DTLS alert) the WebRTC PeerConnection allocated by a Janus ICE handle...
Definition: ice.c:1383
void janus_ice_set_event_stats_period(int period)
Method to modify the event handler statistics period (i.e., the number of seconds that should pass be...
Definition: ice.c:291
ogg_stream_state * stream
Definition: pp-opus.c:32
Janus ICE component.
Definition: ice.h:480
void janus_enable_opaqueid_in_api(void)
Method to enable opaque ID in Janus API responses/events.
Definition: ice.c:108
void janus_ice_restart(janus_ice_handle *handle)
Method to restart ICE and the connectivity checks.
Definition: ice.c:3616
uint janus_get_no_media_timer(void)
Method to get the current no-media event timer (see above)
Definition: ice.c:424
gboolean janus_plugin_session_is_alive(janus_plugin_session *plugin_session)
Quick helper method to check if a plugin session associated with a Janus handle is still valid...
Definition: ice.c:607
guint32 audio_last_rtp_ts
Last sent audio RTP timestamp.
Definition: ice.h:423
GSList * candidates
GLib list of libnice remote candidates for this component.
Definition: ice.h:492
void janus_ice_add_remote_candidate(janus_ice_handle *handle, NiceCandidate *c)
Method to queue a remote candidate for processing.
Definition: ice.c:3237
gboolean janus_ice_is_ignored(const char *ip)
Method to check whether an interface/IP is currently in the ignore list for ICE (that is...
Definition: ice.c:271
guint16 transport_wide_cc_out_seq_num
Last sent transport wide seq num.
Definition: ice.h:443
gboolean janus_ice_is_ipv6_enabled(void)
Method to check whether IPv6 candidates are enabled/supported or not (still WIP)
Definition: ice.c:100
gint last_event_stats
Count of how many seconds passed since the last stats passed to event handlers.
Definition: ice.h:345
Instance of a text2pcap recorder.
Definition: text2pcap.h:49
guint16 seq
Definition: ice.h:266
janus_ice_handle * handle
Janus ICE handle this trickle candidate belongs to.
Definition: ice.h:548
gchar * remote_fingerprint
Hashed fingerprint of the peer&#39;s certificate, as parsed in SDP.
Definition: ice.h:459
GThread * thread
GLib thread for the handle and libnice.
Definition: ice.h:305
Definition: refcount.h:78
janus_ice_handle * janus_ice_handle_create(void *core_session, const char *opaque_id, const char *token)
Method to create a new Janus ICE handle.
Definition: ice.c:1175
GSList * remote_candidates
GLib list of remote candidates for this component (summary)
Definition: ice.h:496
GHashTable * components
GLib hash table of components (IDs are the keys)
Definition: ice.h:465
gint mid_ext_id
SDES mid RTP extension ID.
Definition: ice.h:429
gint cdone
Number of gathered candidates.
Definition: ice.h:299
gchar * video_mid
Video mid (media ID)
Definition: ice.h:317
void janus_ice_relay_rtp(janus_ice_handle *handle, janus_plugin_rtp *packet)
Core RTP callback, called when a plugin has an RTP packet to send to a peer.
Definition: ice.c:4568
gchar * rtp_profile
RTP profile set by caller (so that we can match it)
Definition: ice.h:327
TURN REST API client.
char * transaction
Janus API transaction ID of the original trickle request.
Definition: ice.h:552
void janus_ice_stream_destroy(janus_ice_stream *stream)
Method to only free resources related to a specific ICE stream allocated by a Janus ICE handle...
Definition: ice.c:1472
Helper to handle pending trickle candidates (e.g., when we&#39;re still waiting for an offer) ...
Definition: ice.h:546
struct janus_seq_info * next
Definition: ice.h:268
guint stream_id
libnice ICE stream ID
Definition: ice.h:484
void janus_ice_incoming_data(janus_ice_handle *handle, char *label, char *protocol, gboolean textdata, char *buffer, int length)
Plugin SCTP/DataChannel callback, called by the SCTP stack when when there&#39;s data for a plugin...
Definition: ice.c:3019
uint16_t nack_queue_ms
Size of the NACK queue (in ms), dynamically updated per the RTT.
Definition: ice.h:407
gboolean janus_ice_is_ice_tcp_enabled(void)
Method to check whether ICE-TCP support is enabled/supported or not (still WIP)
Definition: ice.c:82
gint64 created
Monotonic time of when the handle has been created.
Definition: ice.h:291
const gchar * janus_get_ice_state_name(gint state)
Helper method to get a string representation of a libnice ICE state.
Definition: ice.c:1147
void janus_ice_ignore_interface(const char *ip)
Method to add an interface/IP to the ignore list for ICE (that is, don&#39;t gather candidates) ...
Definition: ice.c:260
void janus_ice_relay_sctp(janus_ice_handle *handle, char *buffer, int length)
Core SCTP/DataChannel callback, called by the SCTP stack when when there&#39;s data to send...
Definition: ice.c:4795
gboolean do_transport_wide_cc
Whether we do transport wide cc for video.
Definition: ice.h:439
volatile gint destroyed
Atomic flag to check if this instance has been destroyed.
Definition: ice.h:355
GSList * transport_wide_received_seq_nums
GLib list of transport wide cc stats in reverse received order.
Definition: ice.h:453
gint framemarking_ext_id
Frame marking extension ID.
Definition: ice.h:437
void janus_ice_setup_remote_candidates(janus_ice_handle *handle, guint stream_id, guint component_id)
Method to handle remote candidates and start the connectivity checks.
Definition: ice.c:3251
GMainLoop * mainloop
GLib loop for the handle and libnice.
Definition: ice.h:303
GSource * dtlsrt_source
Re-transmission timer for DTLS.
Definition: ice.h:506
The plugin session and callbacks interface.
Definition: plugin.h:252
janus_refcount ref
Reference counter for this instance.
Definition: ice.h:357
GSource * twcc_source
Definition: ice.h:307
janus_plugin_session * app_handle
Opaque core/plugin session pointer.
Definition: ice.h:295
uint janus_get_slowlink_threshold(void)
Method to get the current slowlink-threshold value (see above)
Definition: ice.c:439
guint retransmit_recent_cnt
Number of retransmitted packets since last log message.
Definition: ice.h:522
RTP context, in order to make sure SSRC changes result in coherent seq/ts increases.
Definition: rtp.h:236
volatile gint destroyed
Atomic flag to check if this instance has been destroyed.
Definition: ice.h:540
janus_ice_handle * handle
Janus ICE handle this stream belongs to.
Definition: ice.h:363
Definition: ice.h:273
GHashTable * pending_nacked_cleanup
Map of the pending NACKed cleanup callback.
Definition: ice.h:411
janus_ice_stats out_stats
Stats for outgoing data (audio/video/data)
Definition: ice.h:534
void janus_ice_debugging_disable(void)
Method to disable libnice debugging (the default)
Definition: ice.c:216
RTCP processing (headers)
gint64 updated
Time we last updated the last second counter.
Definition: ice.h:229
uint16_t janus_ice_get_turn_port(void)
Method to get the TURN server port.
Definition: ice.c:59
GSList * local_candidates
GLib list of local candidates for this component (summary)
Definition: ice.h:494
GMainContext * mainctx
GLib context for the handle and libnice.
Definition: ice.h:301
void janus_ice_candidates_to_sdp(janus_ice_handle *handle, janus_sdp_mline *mline, guint stream_id, guint component_id)
Method to add local candidates to a janus_sdp SDP object representation.
Definition: ice.c:3190
uint janus_get_twcc_period(void)
Method to get the current TWCC period (see above)
Definition: ice.c:455
GQueue * video_retransmit_buffer
Definition: ice.h:514
guint stream_id
ICE Stream ID.
Definition: ice.h:323
gint64 ts
Definition: ice.h:265
gint ridrtx_ext_id
Definition: ice.h:431
void janus_ice_deinit(void)
ICE stuff de-initialization.
Definition: ice.c:884
gboolean janus_is_opaqueid_in_api_enabled(void)
Method to check whether opaque ID have to be added to Janus API responses/events. ...
Definition: ice.c:111
janus_ice_stats_info audio
Audio info.
Definition: ice.h:240
gchar * remote_hashing
Hashing algorhitm used by the peer for the DTLS certificate (e.g., "SHA-256")
Definition: ice.h:457
gchar * ruser
The ICE username for this stream.
Definition: ice.h:461
gchar * remote_sdp
SDP received by the peer (just for debugging purposes)
Definition: ice.h:331
A helper struct for determining when to send NACKs.
Definition: ice.h:264
char * janus_ice_get_stun_server(void)
Method to get the STUN server IP address.
Definition: ice.c:42
int janus_ice_test_stun_server(janus_network_address *addr, uint16_t port, uint16_t local_port, janus_network_address *public_addr, uint16_t *public_port)
Method to check whether a STUN server is reachable.
Definition: ice.c:890
void * app
Opaque application (plugin) pointer.
Definition: ice.h:293
int janus_ice_get_event_stats_period(void)
Method to get the current event handler statistics period (see above)
Definition: ice.c:294
DTLS/SRTP processing (headers)
gboolean janus_ice_is_ice_debugging_enabled(void)
Method to check whether libnice debugging has been enabled (http://nice.freedesktop.org/libnice/libnice-Debug-messages.html)
Definition: ice.c:198
guint32 transport_wide_cc_last_seq_num
Last received transport wide seq num.
Definition: ice.h:445
janus_ice_stream * stream
ICE stream.
Definition: ice.h:325
void janus_ice_trickle_destroy(janus_ice_trickle *trickle)
Helper method to destroy a janus_ice_trickle instance.
Definition: ice.c:817
gint cdone
Whether this stream is ready to be used.
Definition: ice.h:367
gboolean notified_lastsec
Whether or not we notified about lastsec issues already.
Definition: ice.h:231
gint video_rtx_payload_type
Definition: ice.h:395
gint last_srtp_summary
Definition: ice.h:343
Definition: ice.h:276
gint transport_wide_cc_ext_id
Transport wide cc rtp ext ID.
Definition: ice.h:441
guint32 audio_first_rtp_ts
First received audio RTP timestamp.
Definition: ice.h:415
Janus ICE handle.
Definition: ice.h:281
guint32 video_ssrc
Video SSRC of the server for this stream.
Definition: ice.h:371
void janus_ice_set_static_event_loops(int loops)
Method to configure the static event loops mechanism at startup.
Definition: ice.c:144
char * opaque_id
Opaque identifier, e.g., to provide inter-handle relationships to external tools. ...
Definition: ice.h:287
int janus_ice_set_turn_server(gchar *turn_server, uint16_t turn_port, gchar *turn_type, gchar *turn_user, gchar *turn_pwd)
Method to force Janus to use a TURN server when gathering candidates.
Definition: ice.c:1070
struct janus_ice_stats_info janus_ice_stats_info
Janus media statistics.
GList * video_payload_types
List of payload types we can expect for video.
Definition: ice.h:389
gboolean controlling
ICE role (controlling or controlled)
Definition: ice.h:313
GHashTable * video_retransmit_seqs
Definition: ice.h:516
Janus media statistics.
Definition: ice.h:221
gboolean do_audio_nacks
Whether we should do NACKs (in or out) for audio.
Definition: ice.h:510
void janus_ice_notify_data_ready(janus_ice_handle *handle)
Plugin SCTP/DataChannel callback, called by the SCTP stack when data can be written.
Definition: ice.c:4815
void * session
Opaque pointer to the core/peer session.
Definition: ice.h:283
guint32 nacks
Number of NACKs sent or received.
Definition: ice.h:233
gchar * rpass
The ICE password for this stream.
Definition: ice.h:463
janus_text2pcap * text2pcap
In case this session must be saved to text2pcap, the instance to dump packets to. ...
Definition: ice.h:349
gint64 component_connected
Monotonic time of when this component has successfully connected.
Definition: ice.h:490
void janus_ice_send_remb(janus_ice_handle *handle, uint32_t bitrate)
Helper core callback, called when a plugin wants to send a RTCP REMB to a peer.
Definition: ice.c:4768
int janus_ice_setup_local(janus_ice_handle *handle, int offer, int audio, int video, int data, int trickle)
Method to locally set up the ICE candidates (initialization and gathering)
Definition: ice.c:3298
Janus DTLS-SRTP handle.
Definition: dtls.h:66
janus_mutex mutex
Mutex to lock/unlock the ICE session.
Definition: ice.h:351
volatile gint destroyed
Atomic flag to check if this instance has been destroyed.
Definition: ice.h:473
janus_rtcp_context * audio_rtcp_ctx
RTCP context for the audio stream.
Definition: ice.h:403
volatile gint dump_packets
Flag to decide whether or not packets need to be dumped to a text2pcap file.
Definition: ice.h:347
guint64 bytes
Bytes sent or received.
Definition: ice.h:225
gint janus_ice_trickle_parse(janus_ice_handle *handle, json_t *candidate, const char **error)
Helper method to parse trickle candidates.
Definition: ice.c:755
GList * audio_payload_types
List of payload types we can expect for audio.
Definition: ice.h:387
Internal RTCP state context (for RR/SR)
Definition: rtcp.h:226
Structure to hold network addresses in a tagged union which should be IPv4 and IPv6 compatible...
Definition: ip-utils.h:53
Janus plugin RTCP packet.
Definition: plugin.h:589
guint32 bytes_lastsec
Bytes sent or received in the last second.
Definition: ice.h:227
char * token
Token that was used to attach the handle, if required.
Definition: ice.h:289
gint videoorientation_ext_id
Video orientation extension ID.
Definition: ice.h:435
gchar * data_mid
Data channel mid (media ID)
Definition: ice.h:319
guint64 handle_id
Handle identifier, guaranteed to be non-zero.
Definition: ice.h:285
Plugin-Gateway session mapping.
Definition: plugin.h:239
gint64 agent_created
Monotonic time of when the ICE agent has been created.
Definition: ice.h:311
void janus_ice_init(gboolean ice_lite, gboolean ice_tcp, gboolean full_trickle, gboolean ignore_mdns, gboolean ipv6, uint16_t rtp_min_port, uint16_t rtp_max_port)
ICE stuff initialization.
Definition: ice.c:830
gboolean legacy_rid
Whether we should use the legacy simulcast syntax (a=simulcast:recv rid=..) or the proper one (a=simu...
Definition: ice.h:383
guint transport_wide_cc_feedback_count
Transport wide cc rtp ext ID.
Definition: ice.h:451
GAsyncQueue * queued_packets
Queue of events in the loop and outgoing packets to send.
Definition: ice.h:339
guint32 transport_wide_cc_last_feedback_seq_num
Last transport wide seq num sent on feedback.
Definition: ice.h:447
void janus_ice_enable_nat_1_1(gboolean keep_private_host)
Helper method to force Janus to overwrite all host candidates with the public IP. ...
Definition: ice.c:226
janus_dtls_srtp * dtls
DTLS-SRTP stack.
Definition: ice.h:508
janus_seq_info * last_seqs_audio
List of recently received audio sequence numbers (as a support to NACK generation) ...
Definition: ice.h:528
GList * pending_trickles
List of pending trickle candidates (those we received before getting the JSEP offer) ...
Definition: ice.h:335
int janus_ice_get_static_event_loops(void)
Method to return the number of static event loops, if enabled.
Definition: ice.c:141
void janus_ice_enforce_interface(const char *ip)
Method to add an interface/IP to the enforce list for ICE (that is, only gather candidates from these...
Definition: ice.c:235
void janus_set_min_nack_queue(uint16_t mnq)
Method to modify the min NACK value (i.e., the minimum time window of packets per handle to store for...
Definition: ice.c:503
gint64 received
Monotonic time of when this trickle candidate has been received.
Definition: ice.h:550
gboolean do_video_nacks
Whether we should do NACKs (in or out) for video.
Definition: ice.h:512
janus_ice_component * component
ICE component.
Definition: ice.h:467
void janus_set_twcc_period(uint period)
Method to modify the TWCC feedback period (i.e., how often TWCC feedback is sent back to media sender...
Definition: ice.c:446
gboolean janus_ice_is_mdns_enabled(void)
Method to check whether mDNS resolution is enabled or not.
Definition: ice.c:94
gint64 icefailed_detected
Time of when we first detected an ICE failed (we&#39;ll need this for the timer above) ...
Definition: ice.h:504
void janus_ice_debugging_enable(void)
Method to enable libnice debugging (http://nice.freedesktop.org/libnice/libnice-Debug-messages.html)
Definition: ice.c:201
SDP processing (headers)
guint16 rtx_seq_number
Current sequence number for the RFC4588 rtx SSRC session.
Definition: ice.h:518
gint janus_ice_handle_destroy(void *core_session, janus_ice_handle *handle)
Method to destroy a Janus ICE handle.
Definition: ice.c:1286
guint16 transport_wide_cc_cycles
Transport wide cc transport seq num wrap cycles.
Definition: ice.h:449
gboolean janus_ice_is_enforced(const char *ip)
Method to check whether an interface is currently in the enforce list for ICE (that is...
Definition: ice.c:243
guint32 video_ssrc_rtx
Video retransmission SSRC of the peer for this stream.
Definition: ice.h:373
guint16 state
Definition: ice.h:267
gint64 audio_last_ntp_ts
Last sent audio NTP timestamp.
Definition: ice.h:421
guint sl_lost_count_audio
Last known count of lost audio packets (for slow_link)
Definition: ice.h:246
Dumping of RTP/RTCP packets to text2pcap or pcap format (headers)
char * janus_ice_get_turn_server(void)
Method to get the TURN server IP address.
Definition: ice.c:56
guint stream_id
libnice ICE stream ID
Definition: ice.h:365
guint32 video_last_rtp_ts
Last sent video RTP timestamp.
Definition: ice.h:427
Definition: ice.h:275
void janus_set_no_media_timer(uint timer)
Method to modify the no-media event timer (i.e., the number of seconds where no media arrives before ...
Definition: ice.c:417
GSource * icestate_source
Timer to check when we should consider ICE as failed.
Definition: ice.h:502
void janus_ice_send_pli(janus_ice_handle *handle)
Helper core callback, called when a plugin wants to send a RTCP PLI to a peer.
Definition: ice.c:4760
gchar * selected_pair
String representation of the selected pair as notified by libnice (foundations)
Definition: ice.h:498
janus_ice_stats_info data
Data info.
Definition: ice.h:244
void janus_ice_stop_static_event_loops(void)
Method to stop all the static event loops, if enabled.
Definition: ice.c:179
janus_dtls_role
DTLS roles.
Definition: dtls.h:51
char * video_codec
Definition: ice.h:397
janus_ice_trickle * janus_ice_trickle_new(const char *transaction, json_t *candidate)
Helper method to allocate a janus_ice_trickle instance.
Definition: ice.c:744
janus_dtls_role dtls_role
DTLS role of the server for this stream.
Definition: ice.h:455
guint32 bytes_lastsec_temp
Definition: ice.h:227
void janus_ice_dtls_handshake_done(janus_ice_handle *handle, janus_ice_component *component)
Callback to be notified when the DTLS handshake for a specific component has been completed...
Definition: ice.c:4829
gboolean noerrorlog
Helper flag to avoid flooding the console with the same error all over again.
Definition: ice.h:469