2017-01-31 09:56:59 +00:00
|
|
|
/* GStreamer
|
|
|
|
* Copyright (C) 2017 Matthew Waters <matthew@centricular.com>
|
|
|
|
*
|
|
|
|
* This library is free software; you can redistribute it and/or
|
|
|
|
* modify it under the terms of the GNU Library General Public
|
|
|
|
* License as published by the Free Software Foundation; either
|
|
|
|
* version 2 of the License, or (at your option) any later version.
|
|
|
|
*
|
|
|
|
* This library is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
|
|
* Library General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU Library General Public
|
|
|
|
* License along with this library; if not, write to the
|
|
|
|
* Free Software Foundation, Inc., 51 Franklin St, Fifth Floor,
|
|
|
|
* Boston, MA 02110-1301, USA.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef __GST_WEBRTC_ICE_H__
|
|
|
|
#define __GST_WEBRTC_ICE_H__
|
|
|
|
|
2022-04-18 17:55:13 +00:00
|
|
|
#include <gst/webrtc/webrtc_fwd.h>
|
2017-01-31 09:56:59 +00:00
|
|
|
|
|
|
|
G_BEGIN_DECLS
|
|
|
|
|
2022-04-18 17:55:13 +00:00
|
|
|
GST_WEBRTC_API
|
2017-01-31 09:56:59 +00:00
|
|
|
GType gst_webrtc_ice_get_type(void);
|
|
|
|
#define GST_TYPE_WEBRTC_ICE (gst_webrtc_ice_get_type())
|
|
|
|
#define GST_WEBRTC_ICE(obj) (G_TYPE_CHECK_INSTANCE_CAST((obj),GST_TYPE_WEBRTC_ICE,GstWebRTCICE))
|
|
|
|
#define GST_IS_WEBRTC_ICE(obj) (G_TYPE_CHECK_INSTANCE_TYPE((obj),GST_TYPE_WEBRTC_ICE))
|
|
|
|
#define GST_WEBRTC_ICE_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST((klass) ,GST_TYPE_WEBRTC_ICE,GstWebRTCICEClass))
|
|
|
|
#define GST_IS_WEBRTC_ICE_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE((klass) ,GST_TYPE_WEBRTC_ICE))
|
|
|
|
#define GST_WEBRTC_ICE_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS((obj) ,GST_TYPE_WEBRTC_ICE,GstWebRTCICEClass))
|
|
|
|
|
|
|
|
struct _GstWebRTCICE
|
|
|
|
{
|
2022-04-18 17:55:13 +00:00
|
|
|
GstObject parent;
|
2018-08-22 17:05:02 +00:00
|
|
|
|
2022-04-18 17:55:13 +00:00
|
|
|
GstWebRTCICEGatheringState ice_gathering_state;
|
|
|
|
GstWebRTCICEConnectionState ice_connection_state;
|
2022-08-16 01:27:06 +00:00
|
|
|
|
|
|
|
/*< protected >*/
|
2022-04-18 17:55:13 +00:00
|
|
|
guint min_rtp_port;
|
|
|
|
guint max_rtp_port;
|
2022-08-14 21:38:24 +00:00
|
|
|
|
|
|
|
gpointer _gst_reserved[GST_PADDING];
|
2017-01-31 09:56:59 +00:00
|
|
|
};
|
|
|
|
|
2021-06-30 20:01:10 +00:00
|
|
|
struct _GstWebRTCICECandidateStats
|
|
|
|
{
|
|
|
|
gchar *ipaddr;
|
|
|
|
guint port;
|
|
|
|
guint stream_id;
|
|
|
|
const gchar *type;
|
|
|
|
const gchar *proto;
|
|
|
|
const gchar *relay_proto;
|
|
|
|
guint prio;
|
|
|
|
gchar *url;
|
2022-08-14 21:38:24 +00:00
|
|
|
|
|
|
|
gpointer _gst_reserved[GST_PADDING_LARGE];
|
2021-06-30 20:01:10 +00:00
|
|
|
};
|
|
|
|
|
2022-04-18 17:55:13 +00:00
|
|
|
/**
|
|
|
|
* GstWebRTCICEOnCandidateFunc:
|
|
|
|
* @ice: The #GstWebRTCICE
|
|
|
|
* @stream_id: The stream id
|
|
|
|
* @candidate: The discovered candidate
|
|
|
|
* @user_data: User data that was set by #gst_webrtc_ice_set_on_ice_candidate
|
2022-08-14 21:38:24 +00:00
|
|
|
*
|
2022-04-18 17:55:13 +00:00
|
|
|
* Callback function to be triggered on discovery of a new candidate
|
|
|
|
* Since: 1.22
|
|
|
|
*/
|
2022-10-14 18:51:17 +00:00
|
|
|
typedef void (*GstWebRTCICEOnCandidateFunc) (GstWebRTCICE * ice, guint stream_id, const gchar * candidate, gpointer user_data);
|
2022-04-18 17:55:13 +00:00
|
|
|
|
|
|
|
struct _GstWebRTCICEClass {
|
2022-07-30 16:19:42 +00:00
|
|
|
GstObjectClass parent_class;
|
2022-08-16 12:59:00 +00:00
|
|
|
GstWebRTCICEStream * (*add_stream) (GstWebRTCICE * ice,
|
|
|
|
guint session_id);
|
|
|
|
GstWebRTCICETransport * (*find_transport) (GstWebRTCICE * ice,
|
|
|
|
GstWebRTCICEStream * stream,
|
|
|
|
GstWebRTCICEComponent component);
|
|
|
|
gboolean (*gather_candidates) (GstWebRTCICE * ice,
|
|
|
|
GstWebRTCICEStream * stream);
|
|
|
|
void (*add_candidate) (GstWebRTCICE * ice,
|
|
|
|
GstWebRTCICEStream * stream,
|
2023-02-17 16:20:37 +00:00
|
|
|
const gchar * candidate,
|
|
|
|
GstPromise * promise);
|
2022-08-16 12:59:00 +00:00
|
|
|
gboolean (*set_local_credentials) (GstWebRTCICE * ice,
|
|
|
|
GstWebRTCICEStream * stream,
|
2022-10-14 18:51:17 +00:00
|
|
|
const gchar * ufrag,
|
|
|
|
const gchar * pwd);
|
2022-08-16 12:59:00 +00:00
|
|
|
gboolean (*set_remote_credentials) (GstWebRTCICE * ice,
|
|
|
|
GstWebRTCICEStream * stream,
|
2022-10-14 18:51:17 +00:00
|
|
|
const gchar * ufrag,
|
|
|
|
const gchar * pwd);
|
2022-08-16 12:59:00 +00:00
|
|
|
gboolean (*add_turn_server) (GstWebRTCICE * ice,
|
|
|
|
const gchar * uri);
|
|
|
|
void (*set_is_controller) (GstWebRTCICE * ice,
|
|
|
|
gboolean controller);
|
|
|
|
gboolean (*get_is_controller) (GstWebRTCICE * ice);
|
|
|
|
void (*set_force_relay) (GstWebRTCICE * ice,
|
|
|
|
gboolean force_relay);
|
|
|
|
void (*set_stun_server) (GstWebRTCICE * ice,
|
|
|
|
const gchar * uri);
|
|
|
|
gchar * (*get_stun_server) (GstWebRTCICE * ice);
|
|
|
|
void (*set_turn_server) (GstWebRTCICE * ice,
|
|
|
|
const gchar * uri);
|
|
|
|
gchar * (*get_turn_server) (GstWebRTCICE * ice);
|
2020-08-31 12:04:54 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* GstWebRTCICEClass::set_http_proxy:
|
|
|
|
* @ice: a #GstWebRTCICE
|
|
|
|
* @uri: (transfer none): URI of the HTTP proxy of the form
|
|
|
|
* http://[username:password@]hostname[:port]
|
|
|
|
*
|
|
|
|
* Set HTTP Proxy to be used when connecting to TURN server.
|
|
|
|
*
|
|
|
|
* Since: 1.22
|
|
|
|
*/
|
|
|
|
void (*set_http_proxy) (GstWebRTCICE * ice,
|
|
|
|
const gchar * uri);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* GstWebRTCICEClass::get_http_proxy:
|
|
|
|
* @ice: a #GstWebRTCICE
|
|
|
|
*
|
|
|
|
* Get HTTP Proxy to be used when connecting to TURN server.
|
|
|
|
*
|
|
|
|
* Returns: (transfer full): URI of the HTTP proxy of the form
|
|
|
|
* http://[username:password@]hostname[:port]
|
|
|
|
*
|
|
|
|
* Since: 1.22
|
|
|
|
*/
|
|
|
|
gchar * (*get_http_proxy) (GstWebRTCICE * ice);
|
|
|
|
|
2022-08-16 12:59:00 +00:00
|
|
|
void (*set_tos) (GstWebRTCICE * ice,
|
|
|
|
GstWebRTCICEStream * stream,
|
|
|
|
guint tos);
|
|
|
|
void (*set_on_ice_candidate) (GstWebRTCICE * ice,
|
|
|
|
GstWebRTCICEOnCandidateFunc func,
|
|
|
|
gpointer user_data,
|
|
|
|
GDestroyNotify notify);
|
2022-08-19 13:07:50 +00:00
|
|
|
GstWebRTCICECandidateStats** (*get_local_candidates)(GstWebRTCICE * ice,
|
2022-08-16 12:59:00 +00:00
|
|
|
GstWebRTCICEStream * stream);
|
2022-08-19 13:07:50 +00:00
|
|
|
GstWebRTCICECandidateStats**(*get_remote_candidates)(GstWebRTCICE * ice,
|
2022-08-16 12:59:00 +00:00
|
|
|
GstWebRTCICEStream * stream);
|
|
|
|
gboolean (*get_selected_pair) (GstWebRTCICE * ice,
|
|
|
|
GstWebRTCICEStream * stream,
|
|
|
|
GstWebRTCICECandidateStats ** local_stats,
|
|
|
|
GstWebRTCICECandidateStats ** remote_stats);
|
2022-08-14 21:38:24 +00:00
|
|
|
gpointer _gst_reserved[GST_PADDING];
|
2017-01-31 09:56:59 +00:00
|
|
|
};
|
|
|
|
|
2022-04-18 17:55:13 +00:00
|
|
|
GST_WEBRTC_API
|
2017-01-31 09:56:59 +00:00
|
|
|
GstWebRTCICEStream * gst_webrtc_ice_add_stream (GstWebRTCICE * ice,
|
2022-08-16 12:59:00 +00:00
|
|
|
guint session_id);
|
2022-04-18 17:55:13 +00:00
|
|
|
|
|
|
|
GST_WEBRTC_API
|
2017-01-31 09:56:59 +00:00
|
|
|
GstWebRTCICETransport * gst_webrtc_ice_find_transport (GstWebRTCICE * ice,
|
2022-08-16 12:59:00 +00:00
|
|
|
GstWebRTCICEStream * stream,
|
|
|
|
GstWebRTCICEComponent component);
|
2022-04-18 17:55:13 +00:00
|
|
|
|
2017-01-31 09:56:59 +00:00
|
|
|
|
2022-04-18 17:55:13 +00:00
|
|
|
GST_WEBRTC_API
|
2017-01-31 09:56:59 +00:00
|
|
|
gboolean gst_webrtc_ice_gather_candidates (GstWebRTCICE * ice,
|
2022-08-16 12:59:00 +00:00
|
|
|
GstWebRTCICEStream * stream);
|
2022-04-18 17:55:13 +00:00
|
|
|
|
2017-01-31 09:56:59 +00:00
|
|
|
/* FIXME: GstStructure-ize the candidate */
|
2022-04-18 17:55:13 +00:00
|
|
|
GST_WEBRTC_API
|
2017-01-31 09:56:59 +00:00
|
|
|
void gst_webrtc_ice_add_candidate (GstWebRTCICE * ice,
|
2022-08-16 12:59:00 +00:00
|
|
|
GstWebRTCICEStream * stream,
|
2023-02-17 16:20:37 +00:00
|
|
|
const gchar * candidate,
|
|
|
|
GstPromise * promise);
|
2022-04-18 17:55:13 +00:00
|
|
|
|
|
|
|
GST_WEBRTC_API
|
2017-01-31 09:56:59 +00:00
|
|
|
gboolean gst_webrtc_ice_set_local_credentials (GstWebRTCICE * ice,
|
2022-08-16 12:59:00 +00:00
|
|
|
GstWebRTCICEStream * stream,
|
2022-10-14 18:51:17 +00:00
|
|
|
const gchar * ufrag,
|
|
|
|
const gchar * pwd);
|
2022-04-18 17:55:13 +00:00
|
|
|
|
|
|
|
GST_WEBRTC_API
|
2017-01-31 09:56:59 +00:00
|
|
|
gboolean gst_webrtc_ice_set_remote_credentials (GstWebRTCICE * ice,
|
2022-08-16 12:59:00 +00:00
|
|
|
GstWebRTCICEStream * stream,
|
2022-10-14 18:51:17 +00:00
|
|
|
const gchar * ufrag,
|
|
|
|
const gchar * pwd);
|
2022-04-18 17:55:13 +00:00
|
|
|
|
|
|
|
GST_WEBRTC_API
|
2018-08-22 17:05:02 +00:00
|
|
|
gboolean gst_webrtc_ice_add_turn_server (GstWebRTCICE * ice,
|
2022-08-16 12:59:00 +00:00
|
|
|
const gchar * uri);
|
2022-04-18 17:55:13 +00:00
|
|
|
|
2020-07-17 05:14:48 +00:00
|
|
|
|
2022-04-18 17:55:13 +00:00
|
|
|
GST_WEBRTC_API
|
2020-07-17 05:14:48 +00:00
|
|
|
void gst_webrtc_ice_set_is_controller (GstWebRTCICE * ice,
|
2022-08-16 12:59:00 +00:00
|
|
|
gboolean controller);
|
2022-04-18 17:55:13 +00:00
|
|
|
|
|
|
|
GST_WEBRTC_API
|
2020-07-17 05:14:48 +00:00
|
|
|
gboolean gst_webrtc_ice_get_is_controller (GstWebRTCICE * ice);
|
2022-04-18 17:55:13 +00:00
|
|
|
|
|
|
|
GST_WEBRTC_API
|
2020-07-17 05:14:48 +00:00
|
|
|
void gst_webrtc_ice_set_force_relay (GstWebRTCICE * ice,
|
2022-08-16 12:59:00 +00:00
|
|
|
gboolean force_relay);
|
2022-04-18 17:55:13 +00:00
|
|
|
|
|
|
|
GST_WEBRTC_API
|
2020-07-17 05:14:48 +00:00
|
|
|
void gst_webrtc_ice_set_stun_server (GstWebRTCICE * ice,
|
2022-08-16 12:59:00 +00:00
|
|
|
const gchar * uri);
|
2022-04-18 17:55:13 +00:00
|
|
|
|
|
|
|
GST_WEBRTC_API
|
2020-07-17 05:14:48 +00:00
|
|
|
gchar * gst_webrtc_ice_get_stun_server (GstWebRTCICE * ice);
|
2022-04-18 17:55:13 +00:00
|
|
|
|
|
|
|
GST_WEBRTC_API
|
2020-07-17 05:14:48 +00:00
|
|
|
void gst_webrtc_ice_set_turn_server (GstWebRTCICE * ice,
|
2022-08-16 12:59:00 +00:00
|
|
|
const gchar * uri);
|
2020-07-17 05:14:48 +00:00
|
|
|
|
2022-04-18 17:55:13 +00:00
|
|
|
GST_WEBRTC_API
|
|
|
|
gchar * gst_webrtc_ice_get_turn_server (GstWebRTCICE * ice);
|
2020-07-17 05:14:48 +00:00
|
|
|
|
2020-08-31 12:04:54 +00:00
|
|
|
GST_WEBRTC_API
|
|
|
|
void gst_webrtc_ice_set_http_proxy (GstWebRTCICE * ice,
|
|
|
|
const gchar * uri);
|
|
|
|
|
|
|
|
GST_WEBRTC_API
|
|
|
|
gchar * gst_webrtc_ice_get_http_proxy (GstWebRTCICE * ice);
|
|
|
|
|
2022-04-18 17:55:13 +00:00
|
|
|
GST_WEBRTC_API
|
2020-07-17 05:14:48 +00:00
|
|
|
void gst_webrtc_ice_set_on_ice_candidate (GstWebRTCICE * ice,
|
2022-08-16 12:59:00 +00:00
|
|
|
GstWebRTCICEOnCandidateFunc func,
|
|
|
|
gpointer user_data,
|
|
|
|
GDestroyNotify notify);
|
2020-07-17 05:14:48 +00:00
|
|
|
|
2022-04-18 17:55:13 +00:00
|
|
|
GST_WEBRTC_API
|
2020-07-08 21:24:36 +00:00
|
|
|
void gst_webrtc_ice_set_tos (GstWebRTCICE * ice,
|
2022-08-16 12:59:00 +00:00
|
|
|
GstWebRTCICEStream * stream,
|
|
|
|
guint tos);
|
2021-06-30 20:01:10 +00:00
|
|
|
|
2022-04-18 17:55:13 +00:00
|
|
|
GST_WEBRTC_API
|
2022-08-19 13:07:50 +00:00
|
|
|
GstWebRTCICECandidateStats** gst_webrtc_ice_get_local_candidates (GstWebRTCICE * ice,
|
2021-06-30 20:01:10 +00:00
|
|
|
GstWebRTCICEStream * stream);
|
2022-04-18 17:55:13 +00:00
|
|
|
|
|
|
|
GST_WEBRTC_API
|
2022-08-19 13:07:50 +00:00
|
|
|
GstWebRTCICECandidateStats** gst_webrtc_ice_get_remote_candidates (GstWebRTCICE * ice,
|
2021-06-30 20:01:10 +00:00
|
|
|
GstWebRTCICEStream * stream);
|
2022-04-18 17:55:13 +00:00
|
|
|
|
|
|
|
GST_WEBRTC_API
|
2021-06-30 20:01:10 +00:00
|
|
|
gboolean gst_webrtc_ice_get_selected_pair (GstWebRTCICE * ice,
|
|
|
|
GstWebRTCICEStream * stream,
|
|
|
|
GstWebRTCICECandidateStats ** local_stats,
|
|
|
|
GstWebRTCICECandidateStats ** remote_stats);
|
2022-03-26 12:36:46 +00:00
|
|
|
|
2022-04-18 17:55:13 +00:00
|
|
|
GST_WEBRTC_API
|
2022-03-26 12:36:46 +00:00
|
|
|
void gst_webrtc_ice_candidate_stats_free (GstWebRTCICECandidateStats * stats);
|
|
|
|
|
2022-08-15 15:36:25 +00:00
|
|
|
GST_WEBRTC_API
|
|
|
|
GType gst_webrtc_ice_candidate_stats_get_type (void);
|
|
|
|
|
2022-04-18 17:55:13 +00:00
|
|
|
G_DEFINE_AUTOPTR_CLEANUP_FUNC(GstWebRTCICE, gst_object_unref)
|
|
|
|
|
2022-08-15 15:36:25 +00:00
|
|
|
GST_WEBRTC_API
|
2022-08-16 12:59:00 +00:00
|
|
|
GstWebRTCICECandidateStats * gst_webrtc_ice_candidate_stats_copy (GstWebRTCICECandidateStats *stats);
|
2022-08-15 15:36:25 +00:00
|
|
|
|
2017-01-31 09:56:59 +00:00
|
|
|
G_END_DECLS
|
|
|
|
|
|
|
|
#endif /* __GST_WEBRTC_ICE_H__ */
|