diff --git a/src/mod/endpoints/mod_sofia/mod_sofia.c b/src/mod/endpoints/mod_sofia/mod_sofia.c index 2a22925bc9..a0fa80df9b 100644 --- a/src/mod/endpoints/mod_sofia/mod_sofia.c +++ b/src/mod/endpoints/mod_sofia/mod_sofia.c @@ -28,6 +28,7 @@ * Paul D. Tinsley * Bret McDanel * Raymond Chandler + * Emmanuel Schmidbauer * * * mod_sofia.c -- SOFIA SIP Endpoint @@ -556,7 +557,7 @@ switch_status_t sofia_on_hangup(switch_core_session_t *session) } switch_log_printf(SWITCH_CHANNEL_SESSION_LOG(session), SWITCH_LOG_DEBUG, "Challenging call\n"); - sofia_reg_auth_challenge(tech_pvt->profile, tech_pvt->nh, NULL, REG_INVITE, to_host, 0); + sofia_reg_auth_challenge(tech_pvt->profile, tech_pvt->nh, NULL, REG_INVITE, to_host, 0, 0); *reason = '\0'; } break; diff --git a/src/mod/endpoints/mod_sofia/mod_sofia.h b/src/mod/endpoints/mod_sofia/mod_sofia.h index 259c585e25..1d2186657d 100644 --- a/src/mod/endpoints/mod_sofia/mod_sofia.h +++ b/src/mod/endpoints/mod_sofia/mod_sofia.h @@ -29,6 +29,7 @@ * Bret McDanel * Marcel Barbulescu * Raymond Chandler + * Emmanuel Schmidbauer * * * mod_sofia.h -- SOFIA SIP Endpoint @@ -875,7 +876,7 @@ void sofia_presence_event_handler(switch_event_t *event); void sofia_presence_cancel(void); switch_status_t config_sofia(sofia_config_t reload, char *profile_name); void sofia_reg_auth_challenge(sofia_profile_t *profile, nua_handle_t *nh, sofia_dispatch_event_t *de, - sofia_regtype_t regtype, const char *realm, int stale); + sofia_regtype_t regtype, const char *realm, int stale, long exptime); auth_res_t sofia_reg_parse_auth(sofia_profile_t *profile, sip_authorization_t const *authorization, sip_t const *sip, sofia_dispatch_event_t *de, const char *regstr, char *np, size_t nplen, char *ip, switch_event_t **v_event, diff --git a/src/mod/endpoints/mod_sofia/sofia_reg.c b/src/mod/endpoints/mod_sofia/sofia_reg.c index 75a54a601c..461eaea875 100644 --- a/src/mod/endpoints/mod_sofia/sofia_reg.c +++ b/src/mod/endpoints/mod_sofia/sofia_reg.c @@ -31,6 +31,7 @@ * David Knell <> * Eliot Gable * Leon de Rooij + * Emmanuel Schmidbauer * * * sofia_reg.c -- SOFIA SIP Endpoint (registration code) @@ -1007,7 +1008,7 @@ switch_console_callback_match_t *sofia_reg_find_reg_url_with_positive_expires_mu void sofia_reg_auth_challenge(sofia_profile_t *profile, nua_handle_t *nh, sofia_dispatch_event_t *de, - sofia_regtype_t regtype, const char *realm, int stale) + sofia_regtype_t regtype, const char *realm, int stale, long exptime) { switch_uuid_t uuid; char uuid_str[SWITCH_UUID_FORMATTED_LENGTH + 1]; @@ -1024,7 +1025,7 @@ void sofia_reg_auth_challenge(sofia_profile_t *profile, nua_handle_t *nh, sofia_ sql = switch_mprintf("insert into sip_authentication (nonce,expires,profile_name,hostname, last_nc) " "values('%q', %ld, '%q', '%q', 0)", uuid_str, - (long) switch_epoch_time_now(NULL) + (profile->nonce_ttl ? profile->nonce_ttl : DEFAULT_NONCE_TTL), + (long) switch_epoch_time_now(NULL) + (profile->nonce_ttl ? profile->nonce_ttl : DEFAULT_NONCE_TTL) + exptime, profile->name, mod_sofia_globals.hostname); switch_assert(sql != NULL); sofia_glue_execute_sql_now(profile, &sql, SWITCH_TRUE); @@ -1577,7 +1578,7 @@ uint8_t sofia_reg_handle_register(nua_t *nua, sofia_profile_t *profile, nua_hand realm = from_host; } - sofia_reg_auth_challenge(profile, nh, de, regtype, realm, stale); + sofia_reg_auth_challenge(profile, nh, de, regtype, realm, stale, exptime); if (profile->debug) { switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_DEBUG, "Send challenge for [%s@%s]\n", to_user, to_host); @@ -2960,7 +2961,7 @@ auth_res_t sofia_reg_parse_auth(sofia_profile_t *profile, #define LL_FMT "l" #endif sql = switch_mprintf("update sip_authentication set expires='%" LL_FMT "u',last_nc=%lu where nonce='%s'", - switch_epoch_time_now(NULL) + (profile->nonce_ttl ? profile->nonce_ttl : exptime + 10), ncl, nonce); + switch_epoch_time_now(NULL) + (profile->nonce_ttl ? profile->nonce_ttl : DEFAULT_NONCE_TTL) + exptime, ncl, nonce); switch_assert(sql != NULL); sofia_glue_execute_sql_now(profile, &sql, SWITCH_TRUE);