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:
Sangchul Lee 2022-02-06 23:20:32 +09:00 committed by GStreamer Marge Bot
parent 13944cf3ee
commit dcff37722d

View file

@ -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 */