struct sofia_private {
char uuid[SWITCH_UUID_FORMATTED_LENGTH + 1];
sofia_gateway_t *gateway;
- char gateway_name[512];
+ char gateway_name[256];
+ char auth_gateway_name[256];
int destroy_nh;
int destroy_me;
int is_call;
void sofia_reg_handle_sip_r_challenge(int status,
char const *phrase,
- nua_t *nua, sofia_profile_t *profile,
- nua_handle_t *nh, switch_core_session_t *session, sofia_gateway_t *gateway, sip_t const *sip, tagi_t tags[]);
+ nua_t *nua, sofia_profile_t *profile,
+ nua_handle_t *nh, sofia_private_t *sofia_private,
+ switch_core_session_t *session, sofia_gateway_t *gateway, sip_t const *sip, tagi_t tags[]);
void sofia_reg_handle_sip_r_register(int status,
char const *phrase,
nua_t *nua, sofia_profile_t *profile, nua_handle_t *nh, sofia_private_t *sofia_private, sip_t const *sip, tagi_t tags[]);
tech_pvt = switch_core_session_get_private(session);
switch_assert(tech_pvt);
channel = switch_core_session_get_channel(tech_pvt->session);
+ if (status >= 180 && !*sofia_private->auth_gateway_name) {
+ const char *gwname = switch_channel_get_variable(channel, "sip_use_gateway");
+ if (!switch_strlen_zero(gwname)) {
+ switch_set_string(sofia_private->auth_gateway_name, gwname);
+ }
+ }
if (!tech_pvt->call_id && sip && sip->sip_call_id && sip->sip_call_id->i_id) {
tech_pvt->call_id = switch_core_session_strdup(session, sip->sip_call_id->i_id);
switch_channel_set_variable(channel, "sip_call_id", tech_pvt->call_id);
}
if (sip && (status == 401 || status == 407)) {
- sofia_reg_handle_sip_r_challenge(status, phrase, nua, profile, nh, session, gateway, sip, tags);
+ sofia_reg_handle_sip_r_challenge(status, phrase, nua, profile, nh, sofia_private, session, gateway, sip, tags);
goto done;
}
memset(sofia_private, 0, sizeof(*sofia_private));
sofia_private->is_call++;
tech_pvt->sofia_private = sofia_private;
-
+
if ((profile->pres_type)) {
sofia_presence_set_chat_hash(tech_pvt, sip);
}
void sofia_reg_handle_sip_r_challenge(int status,
char const *phrase,
- nua_t *nua, sofia_profile_t *profile, nua_handle_t *nh,
+ nua_t *nua, sofia_profile_t *profile, nua_handle_t *nh, sofia_private_t *sofia_private,
switch_core_session_t *session, sofia_gateway_t *gateway, sip_t const *sip, tagi_t tags[])
{
sip_www_authenticate_t const *authenticate = NULL;
sofia_gateway_t *var_gateway = NULL;
const char *gw_name = NULL;
+ if (sofia_private && *sofia_private->auth_gateway_name) {
+ gw_name = sofia_private->auth_gateway_name;
+ }
+
if (session) {
private_object_t *tech_pvt;
switch_channel_t *channel = switch_core_session_get_channel(session);