Add sip_auth_username and sip_auth_password variables so mod_sofia can answer auth challenges without defining a full gateway

git-svn-id: http://svn.freeswitch.org/svn/freeswitch/trunk@12818 d0543943-73ff-0310-b7d9-9358b9ac24b2
This commit is contained in:
Mathieu Rene 2009-03-28 01:50:36 +00:00
parent 7865668eff
commit 6d87e6321b
1 changed files with 11 additions and 5 deletions

View File

@ -1371,6 +1371,9 @@ void sofia_reg_handle_sip_r_challenge(int status,
int ss_state;
sofia_gateway_t *var_gateway = NULL;
const char *gw_name = NULL;
switch_channel_t *channel = switch_core_session_get_channel(session);
const char *sip_auth_username = switch_channel_get_variable(channel, "sip_auth_username");
const char *sip_auth_password = switch_channel_get_variable(channel, "sip_auth_password");
if (sofia_private && *sofia_private->auth_gateway_name) {
gw_name = sofia_private->auth_gateway_name;
@ -1435,6 +1438,7 @@ void sofia_reg_handle_sip_r_challenge(int status,
}
}
if (!(scheme && realm)) {
@ -1442,13 +1446,15 @@ void sofia_reg_handle_sip_r_challenge(int status,
goto end;
}
if (!gateway) {
if (sip_auth_username && sip_auth_password) {
switch_snprintf(authentication, sizeof(authentication), "%s:%s:%s:%s", scheme, realm, sip_auth_username, sip_auth_password);
} else if (gateway) {
switch_snprintf(authentication, sizeof(authentication), "%s:%s:%s:%s", scheme, realm, gateway->auth_username, gateway->register_password);
} else {
switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_ERROR, "No Matching gateway found\n");
goto cancel;
goto cancel;
}
switch_snprintf(authentication, sizeof(authentication), "%s:%s:%s:%s", scheme, realm, gateway->auth_username, gateway->register_password);
if (profile->debug) {
switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_DEBUG, "Authenticating '%s' with '%s'.\n", profile->username, authentication);
}
@ -1457,7 +1463,7 @@ void sofia_reg_handle_sip_r_challenge(int status,
tl_gets(tags, NUTAG_CALLSTATE_REF(ss_state), SIPTAG_WWW_AUTHENTICATE_REF(authenticate), TAG_END());
nua_authenticate(nh, SIPTAG_EXPIRES_STR(gateway->expires_str), NUTAG_AUTH(authentication), TAG_END());
nua_authenticate(nh, SIPTAG_EXPIRES_STR(gateway ? gateway->expires_str : "3600"), NUTAG_AUTH(authentication), TAG_END());
goto end;