FS-8031: [dtls] Fix delayed DTLS media due to changing ICE candidates
This commit is contained in:
parent
c321261f06
commit
2f2e29226f
|
@ -373,6 +373,7 @@ struct switch_rtp {
|
||||||
char *local_host_str;
|
char *local_host_str;
|
||||||
char *remote_host_str;
|
char *remote_host_str;
|
||||||
char *eff_remote_host_str;
|
char *eff_remote_host_str;
|
||||||
|
switch_time_t first_stun;
|
||||||
switch_time_t last_stun;
|
switch_time_t last_stun;
|
||||||
uint32_t samples_per_interval;
|
uint32_t samples_per_interval;
|
||||||
uint32_t samples_per_second;
|
uint32_t samples_per_second;
|
||||||
|
@ -844,6 +845,7 @@ static void handle_ice(switch_rtp_t *rtp_session, switch_rtp_ice_t *ice, void *d
|
||||||
uint32_t *pri = NULL;
|
uint32_t *pri = NULL;
|
||||||
int is_rtcp = ice == &rtp_session->rtcp_ice;
|
int is_rtcp = ice == &rtp_session->rtcp_ice;
|
||||||
uint32_t elapsed;
|
uint32_t elapsed;
|
||||||
|
switch_time_t ref_point;
|
||||||
|
|
||||||
//if (rtp_session->flags[SWITCH_RTP_FLAG_VIDEO]) {
|
//if (rtp_session->flags[SWITCH_RTP_FLAG_VIDEO]) {
|
||||||
// switch_log_printf(SWITCH_CHANNEL_SESSION_LOG(rtp_session->session), SWITCH_LOG_WARNING, "WTF OK %s CALL\n", rtp_type(rtp_session));
|
// switch_log_printf(SWITCH_CHANNEL_SESSION_LOG(rtp_session->session), SWITCH_LOG_WARNING, "WTF OK %s CALL\n", rtp_type(rtp_session));
|
||||||
|
@ -875,15 +877,22 @@ static void handle_ice(switch_rtp_t *rtp_session, switch_rtp_ice_t *ice, void *d
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!rtp_session->last_stun) {
|
rtp_session->last_stun = switch_micro_time_now();
|
||||||
elapsed = 0;
|
|
||||||
} else {
|
if (!rtp_session->first_stun) {
|
||||||
elapsed = (unsigned int) ((switch_micro_time_now() - rtp_session->last_stun) / 1000);
|
rtp_session->first_stun = rtp_session->last_stun;
|
||||||
}
|
}
|
||||||
|
|
||||||
end_buf = buf + ((sizeof(buf) > packet->header.length) ? packet->header.length : sizeof(buf));
|
if (ice->last_ok) {
|
||||||
|
ref_point = ice->last_ok;
|
||||||
|
} else {
|
||||||
|
ref_point = rtp_session->first_stun;
|
||||||
|
}
|
||||||
|
|
||||||
rtp_session->last_stun = switch_micro_time_now();
|
elapsed = (unsigned int) ((switch_micro_time_now() - ref_point) / 1000);
|
||||||
|
|
||||||
|
|
||||||
|
end_buf = buf + ((sizeof(buf) > packet->header.length) ? packet->header.length : sizeof(buf));
|
||||||
|
|
||||||
switch_stun_packet_first_attribute(packet, attr);
|
switch_stun_packet_first_attribute(packet, attr);
|
||||||
switch_log_printf(SWITCH_CHANNEL_SESSION_LOG(rtp_session->session), SWITCH_LOG_DEBUG8, "STUN PACKET TYPE: %s\n",
|
switch_log_printf(SWITCH_CHANNEL_SESSION_LOG(rtp_session->session), SWITCH_LOG_DEBUG8, "STUN PACKET TYPE: %s\n",
|
||||||
|
@ -1130,7 +1139,7 @@ static void handle_ice(switch_rtp_t *rtp_session, switch_rtp_ice_t *ice, void *d
|
||||||
char ipbuf[25];
|
char ipbuf[25];
|
||||||
switch_sockaddr_t *from_addr = rtp_session->from_addr;
|
switch_sockaddr_t *from_addr = rtp_session->from_addr;
|
||||||
switch_socket_t *sock_output = rtp_session->sock_output;
|
switch_socket_t *sock_output = rtp_session->sock_output;
|
||||||
uint8_t hosts_set = 0;
|
uint8_t do_adj = 0;
|
||||||
switch_time_t now = switch_micro_time_now();
|
switch_time_t now = switch_micro_time_now();
|
||||||
|
|
||||||
if (is_rtcp) {
|
if (is_rtcp) {
|
||||||
|
@ -1152,53 +1161,40 @@ static void handle_ice(switch_rtp_t *rtp_session, switch_rtp_ice_t *ice, void *d
|
||||||
remote_ip = switch_get_addr(ipbuf, sizeof(ipbuf), from_addr);
|
remote_ip = switch_get_addr(ipbuf, sizeof(ipbuf), from_addr);
|
||||||
switch_stun_packet_attribute_add_xor_binded_address(rpacket, (char *) remote_ip, switch_sockaddr_get_port(from_addr));
|
switch_stun_packet_attribute_add_xor_binded_address(rpacket, (char *) remote_ip, switch_sockaddr_get_port(from_addr));
|
||||||
|
|
||||||
if (switch_cmp_addr(from_addr, ice->addr)) {
|
|
||||||
ice->last_ok = now;
|
|
||||||
} else {
|
|
||||||
if (!ice->last_ok || (now - ice->last_ok) > 3000000) {
|
|
||||||
hosts_set++;
|
|
||||||
host = switch_get_addr(buf, sizeof(buf), from_addr);
|
|
||||||
port = switch_sockaddr_get_port(from_addr);
|
|
||||||
host2 = switch_get_addr(buf2, sizeof(buf2), ice->addr);
|
|
||||||
port2 = switch_sockaddr_get_port(ice->addr);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if ((ice->type & ICE_VANILLA)) {
|
if ((ice->type & ICE_VANILLA)) {
|
||||||
switch_stun_packet_attribute_add_integrity(rpacket, ice->pass);
|
switch_stun_packet_attribute_add_integrity(rpacket, ice->pass);
|
||||||
switch_stun_packet_attribute_add_fingerprint(rpacket);
|
switch_stun_packet_attribute_add_fingerprint(rpacket);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (hosts_set) {
|
bytes = switch_stun_packet_length(rpacket);
|
||||||
//switch_sockaddr_info_get(&ice->addr, host, SWITCH_UNSPEC, port, 0, rtp_session->pool);
|
|
||||||
|
|
||||||
switch_log_printf(SWITCH_CHANNEL_SESSION_LOG(rtp_session->session), SWITCH_LOG_NOTICE,
|
host = switch_get_addr(buf, sizeof(buf), from_addr);
|
||||||
"Auto Changing %s stun/%s/dtls port from %s:%u to %s:%u\n", rtp_type(rtp_session), is_rtcp ? "rtcp" : "rtp",
|
port = switch_sockaddr_get_port(from_addr);
|
||||||
host2, port2,
|
host2 = switch_get_addr(buf2, sizeof(buf2), ice->addr);
|
||||||
host, port);
|
port2 = switch_sockaddr_get_port(ice->addr);
|
||||||
|
|
||||||
switch_rtp_change_ice_dest(rtp_session, ice, host, port);
|
|
||||||
|
if (switch_cmp_addr(from_addr, ice->addr)) {
|
||||||
ice->last_ok = now;
|
ice->last_ok = now;
|
||||||
|
} else {
|
||||||
|
if (elapsed >= 3000 || (elapsed >= 500 && (rtp_session->dtls->state != DS_READY || !ice->ready || !ice->rready))) {
|
||||||
|
do_adj++;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
bytes = switch_stun_packet_length(rpacket);
|
if ((ice->type & ICE_VANILLA) && ice->ice_params && do_adj) {
|
||||||
|
|
||||||
if (!ice->rready && (ice->type & ICE_VANILLA) && ice->ice_params && hosts_set && !switch_cmp_addr(from_addr, ice->addr)) {
|
|
||||||
int i = 0;
|
int i = 0;
|
||||||
|
|
||||||
ice->missed_count = 0;
|
ice->missed_count = 0;
|
||||||
ice->rready = 1;
|
ice->rready = 1;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
for (i = 0; i <= ice->ice_params->cand_idx[ice->proto]; i++) {
|
for (i = 0; i <= ice->ice_params->cand_idx[ice->proto]; i++) {
|
||||||
if (ice->ice_params->cands[i][ice->proto].con_port == port) {
|
if (ice->ice_params->cands[i][ice->proto].con_port == port) {
|
||||||
if (!strcmp(ice->ice_params->cands[i][ice->proto].con_addr, host) &&
|
if (!strcmp(ice->ice_params->cands[i][ice->proto].con_addr, host) &&
|
||||||
!strcmp(ice->ice_params->cands[i][ice->proto].cand_type, "relay")) {
|
!strcmp(ice->ice_params->cands[i][ice->proto].cand_type, "relay")) {
|
||||||
|
|
||||||
if (rtp_session->last_stun && elapsed < 5000) {
|
if (elapsed < 1000) {
|
||||||
switch_log_printf(SWITCH_CHANNEL_SESSION_LOG(rtp_session->session), SWITCH_LOG_WARNING,
|
switch_log_printf(SWITCH_CHANNEL_SESSION_LOG(rtp_session->session), SWITCH_LOG_WARNING,
|
||||||
"Skiping RELAY stun/%s/dtls port change from %s:%u to %s:%u\n", is_rtcp ? "rtcp" : "rtp",
|
"Skiping RELAY stun/%s/dtls port change from %s:%u to %s:%u\n", is_rtcp ? "rtcp" : "rtp",
|
||||||
host2, port2,
|
host2, port2,
|
||||||
|
@ -1218,6 +1214,7 @@ static void handle_ice(switch_rtp_t *rtp_session, switch_rtp_ice_t *ice, void *d
|
||||||
host, port);
|
host, port);
|
||||||
|
|
||||||
switch_rtp_change_ice_dest(rtp_session, ice, host, port);
|
switch_rtp_change_ice_dest(rtp_session, ice, host, port);
|
||||||
|
ice->last_ok = now;
|
||||||
}
|
}
|
||||||
|
|
||||||
switch_socket_sendto(sock_output, from_addr, 0, (void *) rpacket, &bytes);
|
switch_socket_sendto(sock_output, from_addr, 0, (void *) rpacket, &bytes);
|
||||||
|
@ -2686,6 +2683,7 @@ SWITCH_DECLARE(void) switch_rtp_reset(switch_rtp_t *rtp_session)
|
||||||
rtp_session->ts = 0;
|
rtp_session->ts = 0;
|
||||||
memset(&rtp_session->ts_norm, 0, sizeof(rtp_session->ts_norm));
|
memset(&rtp_session->ts_norm, 0, sizeof(rtp_session->ts_norm));
|
||||||
|
|
||||||
|
rtp_session->last_stun = rtp_session->first_stun = 0;
|
||||||
|
|
||||||
rtp_session->rtcp_sent_packets = 0;
|
rtp_session->rtcp_sent_packets = 0;
|
||||||
rtp_session->rtcp_last_sent = 0;
|
rtp_session->rtcp_last_sent = 0;
|
||||||
|
|
Loading…
Reference in New Issue