diff --git a/src/mod/endpoints/mod_sofia/mod_sofia.h b/src/mod/endpoints/mod_sofia/mod_sofia.h index 1a457b2421..0aac47ec6e 100644 --- a/src/mod/endpoints/mod_sofia/mod_sofia.h +++ b/src/mod/endpoints/mod_sofia/mod_sofia.h @@ -266,6 +266,7 @@ typedef enum { PFLAG_FIRE_MESSAGE_EVENTS, PFLAG_SEND_DISPLAY_UPDATE, PFLAG_RUNNING_TRANS, + PFLAG_SOCKET_TCP_KEEPALIVE, PFLAG_TCP_KEEPALIVE, PFLAG_TCP_PINGPONG, PFLAG_TCP_PING2PONG, @@ -695,6 +696,7 @@ struct sofia_profile { switch_port_t ws_port; char *wss_ip; switch_port_t wss_port; + int socket_tcp_keepalive; int tcp_keepalive; int tcp_pingpong; int tcp_ping2pong; diff --git a/src/mod/endpoints/mod_sofia/sofia.c b/src/mod/endpoints/mod_sofia/sofia.c index ccceababb0..c870ef7b6c 100644 --- a/src/mod/endpoints/mod_sofia/sofia.c +++ b/src/mod/endpoints/mod_sofia/sofia.c @@ -2551,6 +2551,8 @@ void *SWITCH_THREAD_FUNC sofia_profile_thread_run(switch_thread_t *thread, void TPTAG_PINGPONG(profile->tcp_ping2pong)), TAG_IF(sofia_test_pflag(profile, PFLAG_DISABLE_SRV503), NTATAG_SRV_503(0)), + TAG_IF(sofia_test_pflag(profile, PFLAG_SOCKET_TCP_KEEPALIVE), + TPTAG_KEEPALIVE(profile->socket_tcp_keepalive)), TAG_IF(sofia_test_pflag(profile, PFLAG_TCP_KEEPALIVE), TPTAG_KEEPALIVE(profile->tcp_keepalive)), NTATAG_DEFAULT_PROXY(profile->outbound_proxy), @@ -3833,6 +3835,9 @@ switch_status_t config_sofia(sofia_config_t reload, char *profile_name) } else if (!strcasecmp(var, "sip-capture") && switch_true(val)) { sofia_set_flag(profile, TFLAG_CAPTURE); nua_set_params(profile->nua, TPTAG_CAPT(mod_sofia_globals.capture_server), TAG_END()); + } else if (!strcasecmp(var, "socket-tcp-keepalive") && !zstr(val)) { + profile->socket_tcp_keepalive = atoi(val); + sofia_set_pflag(profile, PFLAG_SOCKET_TCP_KEEPALIVE); } else if (!strcasecmp(var, "tcp-keepalive") && !zstr(val)) { profile->tcp_keepalive = atoi(val); sofia_set_pflag(profile, PFLAG_TCP_KEEPALIVE);