FS-4757 this should fix it but I am not happy with the way this is done but since polycom is one of the only phones that does this right I have no other choice
This commit is contained in:
parent
73646cbaa8
commit
8f0dbcaaf8
|
@ -1347,17 +1347,17 @@ static switch_event_t *actual_sofia_presence_event_handler(switch_event_t *event
|
||||||
uuid, mod_sofia_globals.hostname, profile->name, euser, host, euser, host);
|
uuid, mod_sofia_globals.hostname, profile->name, euser, host, euser, host);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
sofia_glue_execute_sql_callback(profile, profile->dbh_mutex, sql, sofia_presence_dialog_callback, &dh);
|
||||||
|
|
||||||
if (mod_sofia_globals.debug_presence > 0) {
|
if (mod_sofia_globals.debug_presence > 0) {
|
||||||
switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_CRIT, "CHECK SQL: %s@%s [%s]\nhits: %d\n", euser, host, sql, dh.hits);
|
switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_CRIT, "CHECK SQL: %s@%s [%s]\nhits: %d\n", euser, host, sql, dh.hits);
|
||||||
}
|
}
|
||||||
|
|
||||||
sofia_glue_execute_sql_callback(profile, profile->dbh_mutex, sql, sofia_presence_dialog_callback, &dh);
|
|
||||||
|
|
||||||
|
|
||||||
switch_safe_free(sql);
|
switch_safe_free(sql);
|
||||||
#if 0
|
|
||||||
if (hup && dh.hits > 0) {
|
if (hup && dh.hits > 0) {
|
||||||
/* sigh, mangle this packet to simulate a call that is up instead of hungup */
|
/* sigh, mangle this packet to simulate a call that is up instead of hungup */
|
||||||
|
hup = 0;
|
||||||
event->flags |= EF_UNIQ_HEADERS;
|
event->flags |= EF_UNIQ_HEADERS;
|
||||||
|
|
||||||
if (!strcasecmp(dh.state, "early")) {
|
if (!strcasecmp(dh.state, "early")) {
|
||||||
|
@ -1386,7 +1386,7 @@ static switch_event_t *actual_sofia_presence_event_handler(switch_event_t *event
|
||||||
switch_event_add_header_string(event, SWITCH_STACK_BOTTOM, "answer-state", "confirmed");
|
switch_event_add_header_string(event, SWITCH_STACK_BOTTOM, "answer-state", "confirmed");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
#endif
|
|
||||||
|
|
||||||
|
|
||||||
if (zstr(call_id) && (dh.hits && presence_source && (!strcasecmp(presence_source, "register") || switch_stristr("register", status)))) {
|
if (zstr(call_id) && (dh.hits && presence_source && (!strcasecmp(presence_source, "register") || switch_stristr("register", status)))) {
|
||||||
|
@ -2553,7 +2553,8 @@ static int sofia_presence_sub_callback(void *pArg, int argc, char **argv, char *
|
||||||
char *open_closed = NULL;
|
char *open_closed = NULL;
|
||||||
char *dialog_status = NULL;
|
char *dialog_status = NULL;
|
||||||
char *dialog_rpid = NULL;
|
char *dialog_rpid = NULL;
|
||||||
char *default_dialog = "partial";
|
//char *default_dialog = "partial";
|
||||||
|
char *default_dialog = "full";
|
||||||
const char *ct = "no/idea";
|
const char *ct = "no/idea";
|
||||||
|
|
||||||
char *to = NULL;
|
char *to = NULL;
|
||||||
|
@ -2731,9 +2732,9 @@ static int sofia_presence_sub_callback(void *pArg, int argc, char **argv, char *
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
if (user_agent && switch_stristr("snom", user_agent) && uuid) {
|
//if (user_agent && switch_stristr("snom", user_agent) && uuid) {
|
||||||
default_dialog = "full" ;
|
// default_dialog = "full" ;
|
||||||
}
|
//}
|
||||||
|
|
||||||
if (call_state && !strcasecmp(call_state, "cs_hangup")) {
|
if (call_state && !strcasecmp(call_state, "cs_hangup")) {
|
||||||
astate = "hangup";
|
astate = "hangup";
|
||||||
|
|
Loading…
Reference in New Issue