FS-3685 this was just a typo but once i fixed it, i realized this code is pretty messed up and might need to be redone, I cleaned it up the best i could for now but I did not write this feature so I am not to confident that it should be used in production
This commit is contained in:
parent
42c69c04fb
commit
8cf839690f
|
@ -3211,6 +3211,7 @@ void sofia_presence_handle_sip_r_subscribe(int status,
|
||||||
/* Update the subscription status for the subscription */
|
/* Update the subscription status for the subscription */
|
||||||
switch (status) {
|
switch (status) {
|
||||||
case 200:
|
case 200:
|
||||||
|
case 202:
|
||||||
/* TODO: in the spec it is possible for the other side to change the original expiry time,
|
/* TODO: in the spec it is possible for the other side to change the original expiry time,
|
||||||
* this needs to be researched (eg, what sip header this information will be in) and implemented.
|
* this needs to be researched (eg, what sip header this information will be in) and implemented.
|
||||||
* Although, since it seems the sofia stack is pretty much handling the subscription expiration
|
* Although, since it seems the sofia stack is pretty much handling the subscription expiration
|
||||||
|
|
|
@ -65,6 +65,65 @@ static void sofia_reg_new_handle(sofia_gateway_t *gateway_ptr, int attach)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void sofia_reg_new_sub_handle(sofia_gateway_t *gateway_ptr, int attach)
|
||||||
|
{
|
||||||
|
char *user_via = NULL;
|
||||||
|
char *register_host = sofia_glue_get_register_host(gateway_ptr->register_proxy);
|
||||||
|
int ss_state = nua_callstate_authenticating;
|
||||||
|
|
||||||
|
/* check for NAT and place a Via header if necessary (hostname or non-local IP) */
|
||||||
|
if (register_host && sofia_glue_check_nat(gateway_ptr->profile, register_host)) {
|
||||||
|
user_via = sofia_glue_create_external_via(NULL, gateway_ptr->profile, gateway_ptr->register_transport);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (gateway_ptr->sub_nh) {
|
||||||
|
nua_handle_bind(gateway_ptr->sub_nh, NULL);
|
||||||
|
nua_handle_destroy(gateway_ptr->sub_nh);
|
||||||
|
gateway_ptr->sub_nh = NULL;
|
||||||
|
sofia_private_free(gateway_ptr->sofia_private);
|
||||||
|
}
|
||||||
|
|
||||||
|
gateway_ptr->sub_nh = nua_handle(gateway_ptr->profile->nua, NULL,
|
||||||
|
NUTAG_URL(gateway_ptr->register_proxy),
|
||||||
|
TAG_IF(user_via, SIPTAG_VIA_STR(user_via)),
|
||||||
|
SIPTAG_TO_STR(gateway_ptr->register_to),
|
||||||
|
NUTAG_CALLSTATE_REF(ss_state), SIPTAG_FROM_STR(gateway_ptr->register_from), TAG_END());
|
||||||
|
if (attach) {
|
||||||
|
if (!gateway_ptr->sofia_private) {
|
||||||
|
gateway_ptr->sofia_private = malloc(sizeof(*gateway_ptr->sofia_private));
|
||||||
|
switch_assert(gateway_ptr->sofia_private);
|
||||||
|
}
|
||||||
|
memset(gateway_ptr->sofia_private, 0, sizeof(*gateway_ptr->sofia_private));
|
||||||
|
|
||||||
|
gateway_ptr->sofia_private->gateway = gateway_ptr;
|
||||||
|
nua_handle_bind(gateway_ptr->sub_nh, gateway_ptr->sofia_private);
|
||||||
|
}
|
||||||
|
|
||||||
|
switch_safe_free(register_host);
|
||||||
|
switch_safe_free(user_via);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void sofia_reg_kill_sub(sofia_gateway_t *gateway_ptr)
|
||||||
|
{
|
||||||
|
|
||||||
|
if (gateway_ptr->sub_nh) {
|
||||||
|
nua_handle_bind(gateway_ptr->sub_nh, NULL);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (gateway_ptr->state != SUB_STATE_SUBED && gateway_ptr->state != SUB_STATE_UNSUBSCRIBE) {
|
||||||
|
if (gateway_ptr->sub_nh) {
|
||||||
|
nua_handle_destroy(gateway_ptr->sub_nh);
|
||||||
|
gateway_ptr->sub_nh = NULL;
|
||||||
|
}
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (gateway_ptr->sub_nh) {
|
||||||
|
switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_NOTICE, "UN-Subbing %s\n", gateway_ptr->name);
|
||||||
|
nua_unsubscribe(gateway_ptr->sub_nh, NUTAG_URL(gateway_ptr->register_url), TAG_END());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
static void sofia_reg_kill_reg(sofia_gateway_t *gateway_ptr)
|
static void sofia_reg_kill_reg(sofia_gateway_t *gateway_ptr)
|
||||||
{
|
{
|
||||||
|
|
||||||
|
@ -106,6 +165,8 @@ void sofia_reg_fire_custom_gateway_state_event(sofia_gateway_t *gateway, int sta
|
||||||
void sofia_reg_unregister(sofia_profile_t *profile)
|
void sofia_reg_unregister(sofia_profile_t *profile)
|
||||||
{
|
{
|
||||||
sofia_gateway_t *gateway_ptr;
|
sofia_gateway_t *gateway_ptr;
|
||||||
|
sofia_gateway_subscription_t *gw_sub_ptr;
|
||||||
|
|
||||||
switch_mutex_lock(mod_sofia_globals.hash_mutex);
|
switch_mutex_lock(mod_sofia_globals.hash_mutex);
|
||||||
for (gateway_ptr = profile->gateways; gateway_ptr; gateway_ptr = gateway_ptr->next) {
|
for (gateway_ptr = profile->gateways; gateway_ptr; gateway_ptr = gateway_ptr->next) {
|
||||||
|
|
||||||
|
@ -121,6 +182,12 @@ void sofia_reg_unregister(sofia_profile_t *profile)
|
||||||
sofia_reg_kill_reg(gateway_ptr);
|
sofia_reg_kill_reg(gateway_ptr);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
for (gw_sub_ptr = gateway_ptr->subscriptions; gw_sub_ptr; gw_sub_ptr = gw_sub_ptr->next) {
|
||||||
|
if (gw_sub_ptr->state == SUB_STATE_SUBED) {
|
||||||
|
sofia_reg_kill_sub(gateway_ptr);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
switch_mutex_unlock(mod_sofia_globals.hash_mutex);
|
switch_mutex_unlock(mod_sofia_globals.hash_mutex);
|
||||||
}
|
}
|
||||||
|
@ -139,25 +206,13 @@ void sofia_sub_check_gateway(sofia_profile_t *profile, time_t now)
|
||||||
sofia_gateway_subscription_t *gw_sub_ptr;
|
sofia_gateway_subscription_t *gw_sub_ptr;
|
||||||
|
|
||||||
for (gw_sub_ptr = gateway_ptr->subscriptions; gw_sub_ptr; gw_sub_ptr = gw_sub_ptr->next) {
|
for (gw_sub_ptr = gateway_ptr->subscriptions; gw_sub_ptr; gw_sub_ptr = gw_sub_ptr->next) {
|
||||||
int ss_state = nua_callstate_authenticating;
|
|
||||||
sub_state_t ostate = gw_sub_ptr->state;
|
sub_state_t ostate = gw_sub_ptr->state;
|
||||||
char *user_via = NULL;
|
|
||||||
char *register_host = NULL;
|
|
||||||
|
|
||||||
if (!now) {
|
if (!now) {
|
||||||
gw_sub_ptr->state = ostate = SUB_STATE_UNSUBED;
|
gw_sub_ptr->state = ostate = SUB_STATE_UNSUBED;
|
||||||
gw_sub_ptr->expires_str = "0";
|
gw_sub_ptr->expires_str = "0";
|
||||||
}
|
}
|
||||||
|
|
||||||
register_host = sofia_glue_get_register_host(gateway_ptr->register_proxy);
|
|
||||||
|
|
||||||
/* check for NAT and place a Via header if necessary (hostname or non-local IP) */
|
|
||||||
if (register_host && sofia_glue_check_nat(gateway_ptr->profile, register_host)) {
|
|
||||||
user_via = sofia_glue_create_external_via(NULL, gateway_ptr->profile, gateway_ptr->register_transport);
|
|
||||||
}
|
|
||||||
|
|
||||||
switch_safe_free(register_host);
|
|
||||||
|
|
||||||
switch (ostate) {
|
switch (ostate) {
|
||||||
case SUB_STATE_NOSUB:
|
case SUB_STATE_NOSUB:
|
||||||
break;
|
break;
|
||||||
|
@ -167,37 +222,17 @@ void sofia_sub_check_gateway(sofia_profile_t *profile, time_t now)
|
||||||
break;
|
break;
|
||||||
case SUB_STATE_UNSUBSCRIBE:
|
case SUB_STATE_UNSUBSCRIBE:
|
||||||
gw_sub_ptr->state = SUB_STATE_NOSUB;
|
gw_sub_ptr->state = SUB_STATE_NOSUB;
|
||||||
|
sofia_reg_kill_sub(gateway_ptr);
|
||||||
/* not tested .. */
|
|
||||||
nua_unsubscribe(gateway_ptr->nh,
|
|
||||||
NUTAG_URL(gateway_ptr->register_url),
|
|
||||||
TAG_IF(user_via, SIPTAG_VIA_STR(user_via)),
|
|
||||||
SIPTAG_EVENT_STR(gw_sub_ptr->event),
|
|
||||||
SIPTAG_ACCEPT_STR(gw_sub_ptr->content_type),
|
|
||||||
SIPTAG_TO_STR(gateway_ptr->register_from),
|
|
||||||
SIPTAG_FROM_STR(gateway_ptr->register_from), SIPTAG_CONTACT_STR(gateway_ptr->register_contact), TAG_NULL());
|
|
||||||
|
|
||||||
break;
|
break;
|
||||||
case SUB_STATE_UNSUBED:
|
case SUB_STATE_UNSUBED:
|
||||||
gateway_ptr->sub_nh = nua_handle(gateway_ptr->profile->nua, NULL,
|
|
||||||
NUTAG_URL(gateway_ptr->register_proxy),
|
sofia_reg_new_sub_handle(gateway_ptr, 1);
|
||||||
TAG_IF(user_via, SIPTAG_VIA_STR(user_via)),
|
|
||||||
SIPTAG_TO_STR(gateway_ptr->register_to),
|
|
||||||
NUTAG_CALLSTATE_REF(ss_state), SIPTAG_FROM_STR(gateway_ptr->register_from), TAG_END());
|
|
||||||
switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_DEBUG, "subscribing to [%s] on gateway [%s]\n", gw_sub_ptr->event, gateway_ptr->name);
|
switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_DEBUG, "subscribing to [%s] on gateway [%s]\n", gw_sub_ptr->event, gateway_ptr->name);
|
||||||
|
|
||||||
gateway_ptr->sofia_private = malloc(sizeof(*gateway_ptr->sofia_private));
|
|
||||||
switch_assert(gateway_ptr->sofia_private);
|
|
||||||
|
|
||||||
memset(gateway_ptr->sofia_private, 0, sizeof(*gateway_ptr->sofia_private));
|
|
||||||
|
|
||||||
gateway_ptr->sofia_private->gateway = gateway_ptr;
|
|
||||||
nua_handle_bind(gateway_ptr->nh, gateway_ptr->sofia_private);
|
|
||||||
|
|
||||||
if (now) {
|
if (now) {
|
||||||
nua_subscribe(gateway_ptr->sub_nh,
|
nua_subscribe(gateway_ptr->sub_nh,
|
||||||
NUTAG_URL(gateway_ptr->register_url),
|
NUTAG_URL(gateway_ptr->register_url),
|
||||||
TAG_IF(user_via, SIPTAG_VIA_STR(user_via)),
|
|
||||||
SIPTAG_EVENT_STR(gw_sub_ptr->event),
|
SIPTAG_EVENT_STR(gw_sub_ptr->event),
|
||||||
SIPTAG_ACCEPT_STR(gw_sub_ptr->content_type),
|
SIPTAG_ACCEPT_STR(gw_sub_ptr->content_type),
|
||||||
SIPTAG_TO_STR(gateway_ptr->register_from),
|
SIPTAG_TO_STR(gateway_ptr->register_from),
|
||||||
|
@ -209,7 +244,6 @@ void sofia_sub_check_gateway(sofia_profile_t *profile, time_t now)
|
||||||
} else {
|
} else {
|
||||||
nua_unsubscribe(gateway_ptr->sub_nh,
|
nua_unsubscribe(gateway_ptr->sub_nh,
|
||||||
NUTAG_URL(gateway_ptr->register_url),
|
NUTAG_URL(gateway_ptr->register_url),
|
||||||
TAG_IF(user_via, SIPTAG_VIA_STR(user_via)),
|
|
||||||
SIPTAG_EVENT_STR(gw_sub_ptr->event),
|
SIPTAG_EVENT_STR(gw_sub_ptr->event),
|
||||||
SIPTAG_ACCEPT_STR(gw_sub_ptr->content_type),
|
SIPTAG_ACCEPT_STR(gw_sub_ptr->content_type),
|
||||||
SIPTAG_FROM_STR(gateway_ptr->register_from),
|
SIPTAG_FROM_STR(gateway_ptr->register_from),
|
||||||
|
@ -232,7 +266,7 @@ void sofia_sub_check_gateway(sofia_profile_t *profile, time_t now)
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
switch_safe_free(user_via);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
switch_mutex_unlock(profile->gw_mutex);
|
switch_mutex_unlock(profile->gw_mutex);
|
||||||
|
@ -1681,7 +1715,7 @@ uint8_t sofia_reg_handle_register(nua_t *nua, sofia_profile_t *profile, nua_hand
|
||||||
(reg_count == 1 && sofia_test_pflag(profile, PFLAG_MESSAGE_QUERY_ON_FIRST_REGISTER))) {
|
(reg_count == 1 && sofia_test_pflag(profile, PFLAG_MESSAGE_QUERY_ON_FIRST_REGISTER))) {
|
||||||
if (switch_event_create(&s_mwi_event, SWITCH_EVENT_MESSAGE_QUERY) == SWITCH_STATUS_SUCCESS) {
|
if (switch_event_create(&s_mwi_event, SWITCH_EVENT_MESSAGE_QUERY) == SWITCH_STATUS_SUCCESS) {
|
||||||
switch_event_add_header(s_mwi_event, SWITCH_STACK_BOTTOM, "Message-Account", "sip:%s@%s", mwi_user, mwi_host);
|
switch_event_add_header(s_mwi_event, SWITCH_STACK_BOTTOM, "Message-Account", "sip:%s@%s", mwi_user, mwi_host);
|
||||||
switch_event_add_header_string(s_mwi_event, SWITCH_STACK_BOTTOM, "VM-Sofia-Profile", profile->name);
|
switch_event_add_header_string(s_mwi_event, SWITCH_STACK_BOTTOM, "VM-Sofia-Pofile", profile->name);
|
||||||
switch_event_add_header_string(s_mwi_event, SWITCH_STACK_BOTTOM, "VM-Call-ID", call_id);
|
switch_event_add_header_string(s_mwi_event, SWITCH_STACK_BOTTOM, "VM-Call-ID", call_id);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue