mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-11 01:45:33 +00:00
webrtcice: Fix memory leaks in gst_webrtc_ice_add_candidate()
Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/1646>
This commit is contained in:
parent
13944cf3ee
commit
dcff37722d
1 changed files with 13 additions and 14 deletions
|
@ -639,25 +639,26 @@ gst_webrtc_ice_add_candidate (GstWebRTCICE * ice, GstWebRTCICEStream * stream,
|
||||||
if (!cand) {
|
if (!cand) {
|
||||||
/* might be a .local candidate */
|
/* might be a .local candidate */
|
||||||
char *prefix = NULL, *address = NULL, *postfix = NULL;
|
char *prefix = NULL, *address = NULL, *postfix = NULL;
|
||||||
char *new_addr, *new_candidate;
|
char *new_addr = NULL, *new_candidate = NULL;
|
||||||
char *new_candv[4] = { NULL, };
|
char *new_candv[4] = { NULL, };
|
||||||
|
gboolean failure = TRUE;
|
||||||
|
|
||||||
if (!get_candidate_address (candidate, &prefix, &address, &postfix)) {
|
if (!get_candidate_address (candidate, &prefix, &address, &postfix)) {
|
||||||
GST_WARNING_OBJECT (ice, "Failed to retrieve address from candidate %s",
|
GST_WARNING_OBJECT (ice, "Failed to retrieve address from candidate %s",
|
||||||
candidate);
|
candidate);
|
||||||
goto fail;
|
goto done;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!g_str_has_suffix (address, ".local")) {
|
if (!g_str_has_suffix (address, ".local")) {
|
||||||
GST_WARNING_OBJECT (ice, "candidate address \'%s\' does not end "
|
GST_WARNING_OBJECT (ice, "candidate address \'%s\' does not end "
|
||||||
"with \'.local\'", address);
|
"with \'.local\'", address);
|
||||||
goto fail;
|
goto done;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* FIXME: async */
|
/* FIXME: async */
|
||||||
if (!(new_addr = _resolve_host (ice, address))) {
|
if (!(new_addr = _resolve_host (ice, address))) {
|
||||||
GST_WARNING_OBJECT (ice, "Failed to resolve %s", address);
|
GST_WARNING_OBJECT (ice, "Failed to resolve %s", address);
|
||||||
goto fail;
|
goto done;
|
||||||
}
|
}
|
||||||
|
|
||||||
new_candv[0] = prefix;
|
new_candv[0] = prefix;
|
||||||
|
@ -671,25 +672,23 @@ gst_webrtc_ice_add_candidate (GstWebRTCICE * ice, GstWebRTCICEStream * stream,
|
||||||
cand =
|
cand =
|
||||||
nice_agent_parse_remote_candidate_sdp (ice->priv->nice_agent,
|
nice_agent_parse_remote_candidate_sdp (ice->priv->nice_agent,
|
||||||
item->nice_stream_id, new_candidate);
|
item->nice_stream_id, new_candidate);
|
||||||
g_free (new_candidate);
|
|
||||||
if (!cand) {
|
if (!cand) {
|
||||||
GST_WARNING_OBJECT (ice, "Could not parse candidate \'%s\'",
|
GST_WARNING_OBJECT (ice, "Could not parse candidate \'%s\'",
|
||||||
new_candidate);
|
new_candidate);
|
||||||
goto fail;
|
goto done;
|
||||||
}
|
}
|
||||||
|
|
||||||
g_free (prefix);
|
failure = FALSE;
|
||||||
g_free (new_addr);
|
|
||||||
g_free (postfix);
|
|
||||||
|
|
||||||
if (0) {
|
done:
|
||||||
fail:
|
|
||||||
g_free (prefix);
|
g_free (prefix);
|
||||||
g_free (address);
|
g_free (address);
|
||||||
g_free (postfix);
|
g_free (postfix);
|
||||||
|
g_free (new_addr);
|
||||||
|
g_free (new_candidate);
|
||||||
|
if (failure)
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
if (cand->component_id == 2) {
|
if (cand->component_id == 2) {
|
||||||
/* we only support rtcp-mux so rtcp candidates are useless for us */
|
/* we only support rtcp-mux so rtcp candidates are useless for us */
|
||||||
|
|
Loading…
Reference in a new issue