|
|
|
@ -339,6 +339,9 @@ SWITCH_DECLARE(uint32_t) switch_core_media_get_video_fps(switch_core_session_t *
|
|
|
|
|
fps = switch_round_to_step(smh->vid_frames / (now - smh->vid_started), 5);
|
|
|
|
|
if (fps < 15) fps = 15;
|
|
|
|
|
|
|
|
|
|
smh->vid_started = switch_epoch_time_now(NULL);
|
|
|
|
|
smh->vid_frames = 1;
|
|
|
|
|
|
|
|
|
|
return fps;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
@ -2885,7 +2888,8 @@ static void clear_ice(switch_core_session_t *session, switch_media_type_t type)
|
|
|
|
|
engine->ice_in.chosen[1] = 0;
|
|
|
|
|
engine->ice_in.is_chosen[0] = 0;
|
|
|
|
|
engine->ice_in.is_chosen[1] = 0;
|
|
|
|
|
engine->ice_in.cand_idx = 0;
|
|
|
|
|
engine->ice_in.cand_idx[0] = 0;
|
|
|
|
|
engine->ice_in.cand_idx[1] = 0;
|
|
|
|
|
memset(&engine->ice_in, 0, sizeof(engine->ice_in));
|
|
|
|
|
engine->remote_rtcp_port = 0;
|
|
|
|
|
|
|
|
|
@ -3094,22 +3098,24 @@ static switch_bool_t ip_possible(switch_media_handle_t *smh, const char *ip)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
//?
|
|
|
|
|
static void check_ice(switch_media_handle_t *smh, switch_media_type_t type, sdp_session_t *sdp, sdp_media_t *m)
|
|
|
|
|
static switch_status_t check_ice(switch_media_handle_t *smh, switch_media_type_t type, sdp_session_t *sdp, sdp_media_t *m)
|
|
|
|
|
{
|
|
|
|
|
switch_rtp_engine_t *engine = &smh->engines[type];
|
|
|
|
|
sdp_attribute_t *attr;
|
|
|
|
|
int i = 0, got_rtcp_mux = 0;
|
|
|
|
|
const char *val;
|
|
|
|
|
int ice_seen = 0, cid = 0, ai = 0;
|
|
|
|
|
|
|
|
|
|
if (engine->ice_in.is_chosen[0] && engine->ice_in.is_chosen[1] && !switch_channel_test_flag(smh->session->channel, CF_REINVITE)) {
|
|
|
|
|
return;
|
|
|
|
|
return SWITCH_STATUS_SUCCESS;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
engine->ice_in.chosen[0] = 0;
|
|
|
|
|
engine->ice_in.chosen[1] = 0;
|
|
|
|
|
engine->ice_in.is_chosen[0] = 0;
|
|
|
|
|
engine->ice_in.is_chosen[1] = 0;
|
|
|
|
|
engine->ice_in.cand_idx = 0;
|
|
|
|
|
engine->ice_in.cand_idx[0] = 0;
|
|
|
|
|
engine->ice_in.cand_idx[1] = 0;
|
|
|
|
|
|
|
|
|
|
if (m) {
|
|
|
|
|
attr = m->m_attributes;
|
|
|
|
@ -3121,8 +3127,6 @@ static void check_ice(switch_media_handle_t *smh, switch_media_type_t type, sdp_
|
|
|
|
|
char *data;
|
|
|
|
|
char *fields[15];
|
|
|
|
|
int argc = 0, j = 0;
|
|
|
|
|
int cid = 0;
|
|
|
|
|
int pass_acl = 0;
|
|
|
|
|
|
|
|
|
|
if (zstr(attr->a_name)) {
|
|
|
|
|
continue;
|
|
|
|
@ -3130,6 +3134,7 @@ static void check_ice(switch_media_handle_t *smh, switch_media_type_t type, sdp_
|
|
|
|
|
|
|
|
|
|
if (!strcasecmp(attr->a_name, "ice-ufrag")) {
|
|
|
|
|
engine->ice_in.ufrag = switch_core_session_strdup(smh->session, attr->a_value);
|
|
|
|
|
ice_seen++;
|
|
|
|
|
} else if (!strcasecmp(attr->a_name, "ice-pwd")) {
|
|
|
|
|
engine->ice_in.pwd = switch_core_session_strdup(smh->session, attr->a_value);
|
|
|
|
|
} else if (!strcasecmp(attr->a_name, "ice-options")) {
|
|
|
|
@ -3185,169 +3190,105 @@ static void check_ice(switch_media_handle_t *smh, switch_media_type_t type, sdp_
|
|
|
|
|
|
|
|
|
|
argc = switch_split(data, ' ', fields);
|
|
|
|
|
|
|
|
|
|
if (argc < 5 || engine->ice_in.cand_idx >= MAX_CAND - 1) {
|
|
|
|
|
cid = fields[1] ? atoi(fields[1]) - 1 : 0;
|
|
|
|
|
|
|
|
|
|
if (argc < 5 || engine->ice_in.cand_idx[cid] >= MAX_CAND - 1) {
|
|
|
|
|
switch_log_printf(SWITCH_CHANNEL_SESSION_LOG(smh->session), SWITCH_LOG_WARNING, "Invalid data\n");
|
|
|
|
|
continue;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
cid = atoi(fields[1]) - 1;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
for (i = 0; i < argc; i++) {
|
|
|
|
|
switch_log_printf(SWITCH_CHANNEL_SESSION_LOG(smh->session), SWITCH_LOG_DEBUG1, "CAND %d [%s]\n", i, fields[i]);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (!ip_possible(smh, fields[4])) {
|
|
|
|
|
switch_log_printf(SWITCH_CHANNEL_SESSION_LOG(smh->session), SWITCH_LOG_DEBUG,
|
|
|
|
|
"Checking Candidate cid: %d proto: %s type: %s addr: %s:%s\n", cid+1, fields[2], fields[7], fields[4], fields[5]);
|
|
|
|
|
|
|
|
|
|
pass_acl = 0;
|
|
|
|
|
|
|
|
|
|
for (i = 0; i < engine->cand_acl_count; i++) {
|
|
|
|
|
if (switch_check_network_list_ip(fields[4], engine->cand_acl[i])) {
|
|
|
|
|
pass_acl = 1;
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (!engine->ice_in.is_chosen[cid] && ip_possible(smh, fields[4]) && pass_acl) {
|
|
|
|
|
engine->ice_in.chosen[cid] = engine->ice_in.cand_idx;
|
|
|
|
|
engine->ice_in.is_chosen[cid] = 1;
|
|
|
|
|
|
|
|
|
|
switch_log_printf(SWITCH_CHANNEL_SESSION_LOG(smh->session), SWITCH_LOG_NOTICE,
|
|
|
|
|
"Choose %s Candidate cid: %d proto: %s type: %s addr: %s:%s\n",
|
|
|
|
|
"Drop %s Candidate cid: %d proto: %s type: %s addr: %s:%s (no network path)\n",
|
|
|
|
|
type == SWITCH_MEDIA_TYPE_VIDEO ? "video" : "audio",
|
|
|
|
|
cid+1, fields[2], fields[7], fields[4], fields[5]);
|
|
|
|
|
ip_choose_family(smh, fields[4]);
|
|
|
|
|
} else {
|
|
|
|
|
switch_log_printf(SWITCH_CHANNEL_SESSION_LOG(smh->session), SWITCH_LOG_NOTICE,
|
|
|
|
|
switch_log_printf(SWITCH_CHANNEL_SESSION_LOG(smh->session), SWITCH_LOG_DEBUG,
|
|
|
|
|
"Save %s Candidate cid: %d proto: %s type: %s addr: %s:%s\n",
|
|
|
|
|
type == SWITCH_MEDIA_TYPE_VIDEO ? "video" : "audio",
|
|
|
|
|
cid+1, fields[2], fields[7], fields[4], fields[5]);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
engine->ice_in.cands[engine->ice_in.cand_idx][cid].foundation = switch_core_session_strdup(smh->session, fields[0]);
|
|
|
|
|
engine->ice_in.cands[engine->ice_in.cand_idx][cid].component_id = atoi(fields[1]);
|
|
|
|
|
engine->ice_in.cands[engine->ice_in.cand_idx][cid].transport = switch_core_session_strdup(smh->session, fields[2]);
|
|
|
|
|
engine->ice_in.cands[engine->ice_in.cand_idx][cid].priority = atol(fields[3]);
|
|
|
|
|
engine->ice_in.cands[engine->ice_in.cand_idx][cid].con_addr = switch_core_session_strdup(smh->session, fields[4]);
|
|
|
|
|
engine->ice_in.cands[engine->ice_in.cand_idx][cid].con_port = (switch_port_t)atoi(fields[5]);
|
|
|
|
|
|
|
|
|
|
engine->ice_in.cands[engine->ice_in.cand_idx[cid]][cid].foundation = switch_core_session_strdup(smh->session, fields[0]);
|
|
|
|
|
engine->ice_in.cands[engine->ice_in.cand_idx[cid]][cid].component_id = atoi(fields[1]);
|
|
|
|
|
engine->ice_in.cands[engine->ice_in.cand_idx[cid]][cid].transport = switch_core_session_strdup(smh->session, fields[2]);
|
|
|
|
|
engine->ice_in.cands[engine->ice_in.cand_idx[cid]][cid].priority = atol(fields[3]);
|
|
|
|
|
engine->ice_in.cands[engine->ice_in.cand_idx[cid]][cid].con_addr = switch_core_session_strdup(smh->session, fields[4]);
|
|
|
|
|
engine->ice_in.cands[engine->ice_in.cand_idx[cid]][cid].con_port = (switch_port_t)atoi(fields[5]);
|
|
|
|
|
|
|
|
|
|
j = 6;
|
|
|
|
|
|
|
|
|
|
while(j < argc && fields[j+1]) {
|
|
|
|
|
if (!strcasecmp(fields[j], "typ")) {
|
|
|
|
|
engine->ice_in.cands[engine->ice_in.cand_idx][cid].cand_type = switch_core_session_strdup(smh->session, fields[j+1]);
|
|
|
|
|
engine->ice_in.cands[engine->ice_in.cand_idx[cid]][cid].cand_type = switch_core_session_strdup(smh->session, fields[j+1]);
|
|
|
|
|
} else if (!strcasecmp(fields[j], "raddr")) {
|
|
|
|
|
engine->ice_in.cands[engine->ice_in.cand_idx][cid].raddr = switch_core_session_strdup(smh->session, fields[j+1]);
|
|
|
|
|
engine->ice_in.cands[engine->ice_in.cand_idx[cid]][cid].raddr = switch_core_session_strdup(smh->session, fields[j+1]);
|
|
|
|
|
} else if (!strcasecmp(fields[j], "rport")) {
|
|
|
|
|
engine->ice_in.cands[engine->ice_in.cand_idx][cid].rport = (switch_port_t)atoi(fields[j+1]);
|
|
|
|
|
engine->ice_in.cands[engine->ice_in.cand_idx[cid]][cid].rport = (switch_port_t)atoi(fields[j+1]);
|
|
|
|
|
} else if (!strcasecmp(fields[j], "generation")) {
|
|
|
|
|
engine->ice_in.cands[engine->ice_in.cand_idx][cid].generation = switch_core_session_strdup(smh->session, fields[j+1]);
|
|
|
|
|
engine->ice_in.cands[engine->ice_in.cand_idx[cid]][cid].generation = switch_core_session_strdup(smh->session, fields[j+1]);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
j += 2;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (engine->ice_in.is_chosen[cid]) {
|
|
|
|
|
engine->ice_in.cands[engine->ice_in.chosen[cid]][cid].ready++;
|
|
|
|
|
engine->ice_in.cand_idx[cid]++;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
engine->ice_in.cand_idx++;
|
|
|
|
|
}
|
|
|
|
|
for (cid = 0; cid < 2; cid++) {
|
|
|
|
|
switch_log_printf(SWITCH_CHANNEL_SESSION_LOG(smh->session), SWITCH_LOG_DEBUG, "Searching for %s candidate.\n", cid ? "rtcp" : "rtp");
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
for (ai = 0; ai < engine->cand_acl_count; ai++) {
|
|
|
|
|
for (i = 0; i < engine->ice_in.cand_idx[cid]; i++) {
|
|
|
|
|
if (switch_check_network_list_ip(engine->ice_in.cands[i][cid].con_addr, engine->cand_acl[ai])) {
|
|
|
|
|
switch_log_printf(SWITCH_CHANNEL_SESSION_LOG(smh->session), SWITCH_LOG_DEBUG,
|
|
|
|
|
"Choose %s candidate, index %d, %s:%d\n", cid ? "rtcp" : "rtp", i,
|
|
|
|
|
engine->ice_in.cands[i][cid].con_addr, engine->ice_in.cands[i][cid].con_port);
|
|
|
|
|
|
|
|
|
|
/* still no candidates, so start searching for some based on sane deduction */
|
|
|
|
|
engine->ice_in.chosen[cid] = i;
|
|
|
|
|
engine->ice_in.is_chosen[cid] = 1;
|
|
|
|
|
engine->ice_in.cands[i][cid].ready++;
|
|
|
|
|
ip_choose_family(smh, engine->ice_in.cands[i][cid].con_addr);
|
|
|
|
|
|
|
|
|
|
/* look for candidates on the same network */
|
|
|
|
|
if (!engine->ice_in.is_chosen[0] || !engine->ice_in.is_chosen[1]) {
|
|
|
|
|
for (i = 0; i <= engine->ice_in.cand_idx && (!engine->ice_in.is_chosen[0] || !engine->ice_in.is_chosen[1]); i++) {
|
|
|
|
|
if (!engine->ice_in.is_chosen[0] && engine->ice_in.cands[i][0].component_id == 1 &&
|
|
|
|
|
!engine->ice_in.cands[i][0].rport && ip_possible(smh, engine->ice_in.cands[i][0].con_addr) &&
|
|
|
|
|
switch_check_network_list_ip(engine->ice_in.cands[i][0].con_addr, "localnet.auto")) {
|
|
|
|
|
engine->ice_in.chosen[0] = i;
|
|
|
|
|
engine->ice_in.is_chosen[0] = 1;
|
|
|
|
|
engine->ice_in.cands[engine->ice_in.chosen[0]][0].ready++;
|
|
|
|
|
ip_choose_family(smh, engine->ice_in.cands[i][0].con_addr);
|
|
|
|
|
switch_log_printf(SWITCH_CHANNEL_SESSION_LOG(smh->session), SWITCH_LOG_NOTICE,
|
|
|
|
|
"No %s RTP candidate found; defaulting to the first local one.\n", type2str(type));
|
|
|
|
|
}
|
|
|
|
|
if (!engine->ice_in.is_chosen[1] && engine->ice_in.cands[i][1].component_id == 2 &&
|
|
|
|
|
!engine->ice_in.cands[i][1].rport && ip_possible(smh, engine->ice_in.cands[i][1].con_addr) &&
|
|
|
|
|
switch_check_network_list_ip(engine->ice_in.cands[i][1].con_addr, "localnet.auto")) {
|
|
|
|
|
engine->ice_in.chosen[1] = i;
|
|
|
|
|
if (cid == 0 && got_rtcp_mux && engine->ice_in.cand_idx[1] < MAX_CAND) {
|
|
|
|
|
|
|
|
|
|
switch_log_printf(SWITCH_CHANNEL_SESSION_LOG(smh->session), SWITCH_LOG_DEBUG,
|
|
|
|
|
"Choose same candidate, index %d, for rtcp based on rtcp-mux attribute %s:%d\n", engine->ice_in.cand_idx[1],
|
|
|
|
|
engine->ice_in.cands[i][cid].con_addr, engine->ice_in.cands[i][cid].con_port);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
engine->ice_in.cands[engine->ice_in.cand_idx[1]][1] = engine->ice_in.cands[i][0];
|
|
|
|
|
engine->ice_in.chosen[1] = engine->ice_in.cand_idx[1];
|
|
|
|
|
engine->ice_in.is_chosen[1] = 1;
|
|
|
|
|
engine->ice_in.cands[engine->ice_in.chosen[1]][1].ready++;
|
|
|
|
|
switch_log_printf(SWITCH_CHANNEL_SESSION_LOG(smh->session),SWITCH_LOG_NOTICE,
|
|
|
|
|
"No %s RTCP candidate found; defaulting to the first local one.\n", type2str(type));
|
|
|
|
|
engine->ice_in.cand_idx[1]++;
|
|
|
|
|
|
|
|
|
|
goto done_choosing;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
goto next_cid;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* look for candidates with srflx */
|
|
|
|
|
if (!engine->ice_in.is_chosen[0] || !engine->ice_in.is_chosen[1]) {
|
|
|
|
|
for (i = 0; i <= engine->ice_in.cand_idx && (!engine->ice_in.is_chosen[0] || !engine->ice_in.is_chosen[1]); i++) {
|
|
|
|
|
if (!engine->ice_in.is_chosen[0] &&
|
|
|
|
|
engine->ice_in.cands[i][0].component_id == 1 && engine->ice_in.cands[i][0].rport && ip_possible(smh, engine->ice_in.cands[i][0].con_addr)) {
|
|
|
|
|
engine->ice_in.chosen[0] = i;
|
|
|
|
|
engine->ice_in.chosen[1] = 1;
|
|
|
|
|
engine->ice_in.cands[engine->ice_in.chosen[0]][0].ready++;
|
|
|
|
|
ip_choose_family(smh, engine->ice_in.cands[i][0].con_addr);
|
|
|
|
|
switch_log_printf(SWITCH_CHANNEL_SESSION_LOG(smh->session), SWITCH_LOG_NOTICE,
|
|
|
|
|
"No %s RTP candidate found; defaulting to the first srflx one.\n", type2str(type));
|
|
|
|
|
}
|
|
|
|
|
if (!engine->ice_in.is_chosen[1] && engine->ice_in.cands[i][1].component_id == 2 && engine->ice_in.cands[i][1].rport &&
|
|
|
|
|
ip_possible(smh, engine->ice_in.cands[i][1].con_addr)) {
|
|
|
|
|
engine->ice_in.chosen[1] = i;
|
|
|
|
|
engine->ice_in.is_chosen[1] = 1;
|
|
|
|
|
engine->ice_in.cands[engine->ice_in.chosen[1]][1].ready++;
|
|
|
|
|
switch_log_printf(SWITCH_CHANNEL_SESSION_LOG(smh->session),SWITCH_LOG_NOTICE,
|
|
|
|
|
"No %s RTCP candidate found; defaulting to the first srflx one.\n", type2str(type));
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
next_cid:
|
|
|
|
|
|
|
|
|
|
continue;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Got RTP but not RTCP, probably mux */
|
|
|
|
|
if (engine->ice_in.is_chosen[0] && !engine->ice_in.is_chosen[1] && got_rtcp_mux) {
|
|
|
|
|
engine->ice_in.chosen[1] = engine->ice_in.chosen[0];
|
|
|
|
|
engine->ice_in.is_chosen[1] = 1;
|
|
|
|
|
done_choosing:
|
|
|
|
|
|
|
|
|
|
memcpy(&engine->ice_in.cands[engine->ice_in.chosen[1]][1], &engine->ice_in.cands[engine->ice_in.chosen[0]][0],
|
|
|
|
|
sizeof(engine->ice_in.cands[engine->ice_in.chosen[0]][0]));
|
|
|
|
|
engine->ice_in.cands[engine->ice_in.chosen[1]][1].ready++;
|
|
|
|
|
|
|
|
|
|
switch_log_printf(SWITCH_CHANNEL_SESSION_LOG(smh->session), SWITCH_LOG_NOTICE,
|
|
|
|
|
"No %s RTCP candidate found; defaulting to the same as RTP [%s:%d]\n", type2str(type),
|
|
|
|
|
engine->ice_in.cands[engine->ice_in.chosen[1]][1].con_addr, engine->ice_in.cands[engine->ice_in.chosen[1]][1].con_port);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* look for any candidates and hope for auto-adjust */
|
|
|
|
|
if (!engine->ice_in.is_chosen[0] || !engine->ice_in.is_chosen[1]) {
|
|
|
|
|
for (i = 0; i <= engine->ice_in.cand_idx && (!engine->ice_in.is_chosen[0] || !engine->ice_in.is_chosen[1]); i++) {
|
|
|
|
|
if (!engine->ice_in.is_chosen[0] && engine->ice_in.cands[i][0].component_id == 1 && ip_possible(smh, engine->ice_in.cands[i][0].con_addr)) {
|
|
|
|
|
engine->ice_in.chosen[0] = i;
|
|
|
|
|
engine->ice_in.is_chosen[0] = 1;
|
|
|
|
|
engine->ice_in.cands[engine->ice_in.chosen[0]][0].ready++;
|
|
|
|
|
ip_choose_family(smh, engine->ice_in.cands[i][0].con_addr);
|
|
|
|
|
switch_log_printf(SWITCH_CHANNEL_SESSION_LOG(smh->session), SWITCH_LOG_NOTICE,
|
|
|
|
|
"No %s RTP candidate found; defaulting to the first one.\n", type2str(type));
|
|
|
|
|
}
|
|
|
|
|
if (!engine->ice_in.is_chosen[1] && engine->ice_in.cands[i][1].component_id == 2) {
|
|
|
|
|
engine->ice_in.chosen[1] = i;
|
|
|
|
|
engine->ice_in.is_chosen[1] = 1;
|
|
|
|
|
engine->ice_in.cands[engine->ice_in.chosen[1]][1].ready++;
|
|
|
|
|
switch_log_printf(SWITCH_CHANNEL_SESSION_LOG(smh->session), SWITCH_LOG_NOTICE,
|
|
|
|
|
"No %s RTCP candidate found; defaulting to the first one.\n", type2str(type));
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (!engine->ice_in.is_chosen[0] || !engine->ice_in.is_chosen[1]) {
|
|
|
|
|
/* PUNT */
|
|
|
|
|
switch_log_printf(SWITCH_CHANNEL_SESSION_LOG(smh->session), SWITCH_LOG_DEBUG, "%s no suitable candidates found.\n",
|
|
|
|
|
switch_channel_get_name(smh->session->channel));
|
|
|
|
|
return;
|
|
|
|
|
return SWITCH_STATUS_FALSE;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
for (i = 0; i < 2; i++) {
|
|
|
|
@ -3362,8 +3303,8 @@ static void check_ice(switch_media_handle_t *smh, switch_media_type_t type, sdp_
|
|
|
|
|
if (engine->ice_in.cands[engine->ice_in.chosen[0]][0].con_addr && engine->ice_in.cands[engine->ice_in.chosen[0]][0].con_port) {
|
|
|
|
|
char tmp[80] = "";
|
|
|
|
|
engine->cur_payload_map->remote_sdp_ip = switch_core_session_strdup(smh->session, (char *) engine->ice_in.cands[engine->ice_in.chosen[0]][0].con_addr);
|
|
|
|
|
switch_log_printf(SWITCH_CHANNEL_SESSION_LOG(smh->session), SWITCH_LOG_NOTICE,
|
|
|
|
|
"setting remote %s ice addr to %s:%d based on candidate\n", type2str(type),
|
|
|
|
|
switch_log_printf(SWITCH_CHANNEL_SESSION_LOG(smh->session), SWITCH_LOG_DEBUG,
|
|
|
|
|
"setting remote %s ice addr to index %d %s:%d based on candidate\n", type2str(type), engine->ice_in.chosen[0],
|
|
|
|
|
engine->ice_in.cands[engine->ice_in.chosen[0]][0].con_addr, engine->ice_in.cands[engine->ice_in.chosen[0]][0].con_port);
|
|
|
|
|
engine->ice_in.cands[engine->ice_in.chosen[0]][0].ready++;
|
|
|
|
|
|
|
|
|
@ -3377,24 +3318,13 @@ static void check_ice(switch_media_handle_t *smh, switch_media_type_t type, sdp_
|
|
|
|
|
smh->mparams->remote_ip = engine->cur_payload_map->remote_sdp_ip;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (engine->remote_rtcp_port) {
|
|
|
|
|
engine->remote_rtcp_port = engine->cur_payload_map->remote_sdp_port;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
switch_snprintf(tmp, sizeof(tmp), "%d", engine->cur_payload_map->remote_sdp_port);
|
|
|
|
|
switch_channel_set_variable(smh->session->channel, SWITCH_REMOTE_MEDIA_IP_VARIABLE, engine->cur_payload_map->remote_sdp_ip);
|
|
|
|
|
switch_snprintf(tmp, sizeof(tmp), "%d", engine->ice_in.cands[engine->ice_in.chosen[0]][0].con_port);
|
|
|
|
|
switch_channel_set_variable(smh->session->channel, SWITCH_REMOTE_MEDIA_IP_VARIABLE, engine->ice_in.cands[engine->ice_in.chosen[0]][0].con_addr);
|
|
|
|
|
switch_channel_set_variable(smh->session->channel, SWITCH_REMOTE_MEDIA_PORT_VARIABLE, tmp);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (engine->ice_in.cands[engine->ice_in.chosen[1]][1].con_port) {
|
|
|
|
|
if (engine->rtcp_mux) {
|
|
|
|
|
engine->ice_in.cands[engine->ice_in.chosen[1]][1].con_port = engine->ice_in.cands[engine->ice_in.chosen[0]][0].con_port;
|
|
|
|
|
engine->ice_in.cands[engine->ice_in.chosen[1]][1].con_addr = engine->ice_in.cands[engine->ice_in.chosen[0]][0].con_addr;
|
|
|
|
|
switch_log_printf(SWITCH_CHANNEL_SESSION_LOG(smh->session), SWITCH_LOG_NOTICE,
|
|
|
|
|
"Asked by candidate to set remote rtcp %s addr to %s:%d but this is rtcp-mux so no thanks\n", type2str(type),
|
|
|
|
|
engine->ice_in.cands[engine->ice_in.chosen[1]][1].con_addr, engine->ice_in.cands[engine->ice_in.chosen[1]][1].con_port);
|
|
|
|
|
} else {
|
|
|
|
|
switch_log_printf(SWITCH_CHANNEL_SESSION_LOG(smh->session), SWITCH_LOG_NOTICE,
|
|
|
|
|
switch_log_printf(SWITCH_CHANNEL_SESSION_LOG(smh->session), SWITCH_LOG_DEBUG,
|
|
|
|
|
"Setting remote rtcp %s addr to %s:%d based on candidate\n", type2str(type),
|
|
|
|
|
engine->ice_in.cands[engine->ice_in.chosen[1]][1].con_addr, engine->ice_in.cands[engine->ice_in.chosen[1]][1].con_port);
|
|
|
|
|
engine->remote_rtcp_ice_port = engine->ice_in.cands[engine->ice_in.chosen[1]][1].con_port;
|
|
|
|
@ -3402,7 +3332,6 @@ static void check_ice(switch_media_handle_t *smh, switch_media_type_t type, sdp_
|
|
|
|
|
|
|
|
|
|
engine->remote_rtcp_port = engine->ice_in.cands[engine->ice_in.chosen[1]][1].con_port;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (m && !got_rtcp_mux) {
|
|
|
|
@ -3489,6 +3418,9 @@ static void check_ice(switch_media_handle_t *smh, switch_media_type_t type, sdp_
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
return ice_seen ? SWITCH_STATUS_SUCCESS : SWITCH_STATUS_BREAK;
|
|
|
|
|
}
|
|
|
|
|
#ifdef _MSC_VER
|
|
|
|
|
#pragma warning(pop)
|
|
|
|
@ -4358,8 +4290,11 @@ SWITCH_DECLARE(uint8_t) switch_core_media_negotiate_sdp(switch_core_session_t *s
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (switch_core_media_set_codec(session, 0, smh->mparams->codec_flags) == SWITCH_STATUS_SUCCESS) {
|
|
|
|
|
if (check_ice(smh, SWITCH_MEDIA_TYPE_AUDIO, sdp, m) == SWITCH_STATUS_FALSE) {
|
|
|
|
|
match = 0;
|
|
|
|
|
} else {
|
|
|
|
|
got_audio = 1;
|
|
|
|
|
check_ice(smh, SWITCH_MEDIA_TYPE_AUDIO, sdp, m);
|
|
|
|
|
}
|
|
|
|
|
} else {
|
|
|
|
|
match = 0;
|
|
|
|
|
}
|
|
|
|
@ -4632,7 +4567,9 @@ SWITCH_DECLARE(uint8_t) switch_core_media_negotiate_sdp(switch_core_session_t *s
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (switch_core_media_set_video_codec(session, 0) == SWITCH_STATUS_SUCCESS) {
|
|
|
|
|
check_ice(smh, SWITCH_MEDIA_TYPE_VIDEO, sdp, m);
|
|
|
|
|
if (check_ice(smh, SWITCH_MEDIA_TYPE_VIDEO, sdp, m) != SWITCH_STATUS_SUCCESS) {
|
|
|
|
|
vmatch = 0;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
@ -5067,7 +5004,7 @@ SWITCH_DECLARE(switch_status_t) switch_core_session_start_video_thread(switch_co
|
|
|
|
|
return SWITCH_STATUS_FALSE;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
switch_log_printf(SWITCH_CHANNEL_SESSION_LOG(session), SWITCH_LOG_NOTICE, "%s Starting Video thread\n", switch_core_session_get_name(session));
|
|
|
|
|
switch_log_printf(SWITCH_CHANNEL_SESSION_LOG(session), SWITCH_LOG_DEBUG, "%s Starting Video thread\n", switch_core_session_get_name(session));
|
|
|
|
|
|
|
|
|
|
if (v_engine->rtp_session) {
|
|
|
|
|
switch_rtp_set_default_payload(v_engine->rtp_session, v_engine->cur_payload_map->agreed_pt);
|
|
|
|
|