send another presence event on calls that were cancelled from LOSE_RACE to fix winnable race in Broadsoft SCA
This commit is contained in:
parent
a8f01d5bc6
commit
59f6654e96
|
@ -2004,7 +2004,7 @@ static void sync_sla(sofia_profile_t *profile, const char *to_user, const char *
|
||||||
switch_core_hash_init(&sh->hash, sh->pool);
|
switch_core_hash_init(&sh->hash, sh->pool);
|
||||||
|
|
||||||
sql = switch_mprintf("select sip_from_user,sip_from_host,call_info,call_info_state,uuid from sip_dialogs "
|
sql = switch_mprintf("select sip_from_user,sip_from_host,call_info,call_info_state,uuid from sip_dialogs "
|
||||||
"where hostname='%q' and ((sip_from_user='%q' and sip_from_host='%q') or presence_id='%q@%q')",
|
"where call_info_state is not null and hostname='%q' and ((sip_from_user='%q' and sip_from_host='%q') or presence_id='%q@%q')",
|
||||||
mod_sofia_globals.hostname, to_user, to_host, to_user, to_host);
|
mod_sofia_globals.hostname, to_user, to_host, to_user, to_host);
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -2539,6 +2539,7 @@ SWITCH_DECLARE(switch_channel_state_t) switch_channel_perform_hangup(switch_chan
|
||||||
|
|
||||||
|
|
||||||
if (hangup_cause == SWITCH_CAUSE_LOSE_RACE) {
|
if (hangup_cause == SWITCH_CAUSE_LOSE_RACE) {
|
||||||
|
switch_channel_presence(channel, "unknown", "cancelled", NULL);
|
||||||
switch_channel_set_variable(channel, "presence_call_info", NULL);
|
switch_channel_set_variable(channel, "presence_call_info", NULL);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue