tweak sla presence code
git-svn-id: http://svn.freeswitch.org/svn/freeswitch/trunk@16223 d0543943-73ff-0310-b7d9-9358b9ac24b2
This commit is contained in:
parent
da20b09be7
commit
e71f66e070
|
@ -365,7 +365,7 @@ switch_status_t sofia_on_hangup(switch_core_session_t *session)
|
||||||
if (session && tech_pvt->profile->pres_type) {
|
if (session && tech_pvt->profile->pres_type) {
|
||||||
char *sql = switch_mprintf("delete from sip_dialogs where call_id='%q'", tech_pvt->call_id);
|
char *sql = switch_mprintf("delete from sip_dialogs where call_id='%q'", tech_pvt->call_id);
|
||||||
switch_assert(sql);
|
switch_assert(sql);
|
||||||
sofia_glue_execute_sql(tech_pvt->profile, &sql, SWITCH_TRUE);
|
sofia_glue_execute_sql_now(tech_pvt->profile, &sql, SWITCH_TRUE);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (tech_pvt->kick && (a_session = switch_core_session_locate(tech_pvt->kick))) {
|
if (tech_pvt->kick && (a_session = switch_core_session_locate(tech_pvt->kick))) {
|
||||||
|
@ -1215,7 +1215,7 @@ static switch_status_t sofia_receive_message(switch_core_session_t *session, swi
|
||||||
"where uuid='%s';\n", switch_str_nil(presence_id), switch_str_nil(presence_data),
|
"where uuid='%s';\n", switch_str_nil(presence_id), switch_str_nil(presence_data),
|
||||||
switch_core_session_get_uuid(session));
|
switch_core_session_get_uuid(session));
|
||||||
switch_assert(sql);
|
switch_assert(sql);
|
||||||
sofia_glue_execute_sql(tech_pvt->profile, &sql, SWITCH_TRUE);
|
sofia_glue_execute_sql_now(tech_pvt->profile, &sql, SWITCH_TRUE);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -188,6 +188,7 @@ typedef enum {
|
||||||
PFLAG_UUID_AS_CALLID,
|
PFLAG_UUID_AS_CALLID,
|
||||||
PFLAG_SCROOGE,
|
PFLAG_SCROOGE,
|
||||||
PFLAG_MANAGE_SHARED_APPEARANCE,
|
PFLAG_MANAGE_SHARED_APPEARANCE,
|
||||||
|
PFLAG_MANAGE_SHARED_APPEARANCE_SYLANTRO,
|
||||||
PFLAG_DISABLE_SRV,
|
PFLAG_DISABLE_SRV,
|
||||||
PFLAG_DISABLE_NAPTR,
|
PFLAG_DISABLE_NAPTR,
|
||||||
PFLAG_AUTOFLUSH,
|
PFLAG_AUTOFLUSH,
|
||||||
|
@ -790,6 +791,7 @@ void sofia_presence_handle_sip_i_subscribe(int status,
|
||||||
void sofia_glue_execute_sql(sofia_profile_t *profile, char **sqlp, switch_bool_t sql_already_dynamic);
|
void sofia_glue_execute_sql(sofia_profile_t *profile, char **sqlp, switch_bool_t sql_already_dynamic);
|
||||||
void sofia_glue_actually_execute_sql(sofia_profile_t *profile, char *sql, switch_mutex_t *mutex);
|
void sofia_glue_actually_execute_sql(sofia_profile_t *profile, char *sql, switch_mutex_t *mutex);
|
||||||
void sofia_glue_actually_execute_sql_trans(sofia_profile_t *profile, char *sql, switch_mutex_t *mutex);
|
void sofia_glue_actually_execute_sql_trans(sofia_profile_t *profile, char *sql, switch_mutex_t *mutex);
|
||||||
|
void sofia_glue_execute_sql_now(sofia_profile_t *profile, char **sqlp, switch_bool_t sql_already_dynamic);
|
||||||
void sofia_reg_check_expire(sofia_profile_t *profile, time_t now, int reboot);
|
void sofia_reg_check_expire(sofia_profile_t *profile, time_t now, int reboot);
|
||||||
void sofia_reg_check_gateway(sofia_profile_t *profile, time_t now);
|
void sofia_reg_check_gateway(sofia_profile_t *profile, time_t now);
|
||||||
void sofia_sub_check_gateway(sofia_profile_t *profile, time_t now);
|
void sofia_sub_check_gateway(sofia_profile_t *profile, time_t now);
|
||||||
|
|
|
@ -2774,7 +2774,10 @@ switch_status_t config_sofia(int reload, char *profile_name)
|
||||||
sofia_set_pflag(profile, PFLAG_MANAGE_SHARED_APPEARANCE);
|
sofia_set_pflag(profile, PFLAG_MANAGE_SHARED_APPEARANCE);
|
||||||
profile->pres_type = PRES_TYPE_FULL;
|
profile->pres_type = PRES_TYPE_FULL;
|
||||||
sofia_set_pflag(profile, PFLAG_MULTIREG);
|
sofia_set_pflag(profile, PFLAG_MULTIREG);
|
||||||
|
|
||||||
|
} else if (!strcasecmp(val, "sylantro")) {
|
||||||
profile->sla_contact = switch_core_sprintf(profile->pool, "sla-agent");
|
profile->sla_contact = switch_core_sprintf(profile->pool, "sla-agent");
|
||||||
|
sofia_set_pflag(profile, PFLAG_MANAGE_SHARED_APPEARANCE_SYLANTRO);
|
||||||
}
|
}
|
||||||
} else if (!strcasecmp(var, "disable-srv")) {
|
} else if (!strcasecmp(var, "disable-srv")) {
|
||||||
if (switch_true(val)) {
|
if (switch_true(val)) {
|
||||||
|
@ -3428,7 +3431,7 @@ static void sofia_handle_sip_r_invite(switch_core_session_t *session, int status
|
||||||
if (sip &&
|
if (sip &&
|
||||||
sip->sip_from && sip->sip_from->a_url && sip->sip_from->a_url->url_user && sip->sip_from->a_url->url_host &&
|
sip->sip_from && sip->sip_from->a_url && sip->sip_from->a_url->url_user && sip->sip_from->a_url->url_host &&
|
||||||
sip->sip_to && sip->sip_to->a_url && sip->sip_to->a_url->url_user && sip->sip_to->a_url->url_host) {
|
sip->sip_to && sip->sip_to->a_url && sip->sip_to->a_url->url_user && sip->sip_to->a_url->url_host) {
|
||||||
sql = switch_mprintf("select 'appearance-index=1' from sip_subscriptions where hostname='%q' and event='call-info' and "
|
sql = switch_mprintf("select 'appearance-index=1' from sip_subscriptions where expires > -1 && hostname='%q' and event='call-info' and "
|
||||||
"sub_to_user='%q' and sub_to_host='%q'",
|
"sub_to_user='%q' and sub_to_host='%q'",
|
||||||
mod_sofia_globals.hostname, sip->sip_to->a_url->url_user, sip->sip_from->a_url->url_host);
|
mod_sofia_globals.hostname, sip->sip_to->a_url->url_user, sip->sip_from->a_url->url_host);
|
||||||
sofia_glue_execute_sql2str(profile, profile->ireg_mutex, sql, buf, sizeof(buf));
|
sofia_glue_execute_sql2str(profile, profile->ireg_mutex, sql, buf, sizeof(buf));
|
||||||
|
@ -3447,8 +3450,7 @@ static void sofia_handle_sip_r_invite(switch_core_session_t *session, int status
|
||||||
switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_ERROR, "QUERY SQL %s\n", sql);
|
switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_ERROR, "QUERY SQL %s\n", sql);
|
||||||
}
|
}
|
||||||
|
|
||||||
sofia_glue_actually_execute_sql(profile, sql, profile->ireg_mutex);
|
sofia_glue_execute_sql_now(profile, &sql, SWITCH_TRUE);
|
||||||
switch_safe_free(sql);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -3729,7 +3731,8 @@ static void sofia_handle_sip_r_invite(switch_core_session_t *session, int status
|
||||||
|
|
||||||
switch_assert(sql);
|
switch_assert(sql);
|
||||||
|
|
||||||
sofia_glue_execute_sql(profile, &sql, SWITCH_TRUE);
|
sofia_glue_actually_execute_sql(profile, sql, profile->ireg_mutex);
|
||||||
|
switch_safe_free(sql);
|
||||||
|
|
||||||
}
|
}
|
||||||
} else if (status == 200 && (profile->pres_type)) {
|
} else if (status == 200 && (profile->pres_type)) {
|
||||||
|
@ -3741,7 +3744,7 @@ static void sofia_handle_sip_r_invite(switch_core_session_t *session, int status
|
||||||
"where uuid='%s';\n", astate, switch_str_nil(presence_id), switch_str_nil(presence_data),
|
"where uuid='%s';\n", astate, switch_str_nil(presence_id), switch_str_nil(presence_data),
|
||||||
switch_core_session_get_uuid(session));
|
switch_core_session_get_uuid(session));
|
||||||
switch_assert(sql);
|
switch_assert(sql);
|
||||||
sofia_glue_execute_sql(profile, &sql, SWITCH_TRUE);
|
sofia_glue_execute_sql_now(profile, &sql, SWITCH_TRUE);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -6200,7 +6203,8 @@ void sofia_handle_sip_i_invite(nua_t *nua, sofia_profile_t *profile, nua_handle_
|
||||||
|
|
||||||
switch_assert(sql);
|
switch_assert(sql);
|
||||||
|
|
||||||
sofia_glue_execute_sql(profile, &sql, SWITCH_TRUE);
|
sofia_glue_actually_execute_sql(profile, sql, profile->ireg_mutex);
|
||||||
|
switch_safe_free(sql);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -3832,7 +3832,8 @@ int sofia_glue_init_sql(sofia_profile_t *profile)
|
||||||
" presence_id VARCHAR(255),\n"
|
" presence_id VARCHAR(255),\n"
|
||||||
" presence_data VARCHAR(255),\n"
|
" presence_data VARCHAR(255),\n"
|
||||||
" call_info VARCHAR(255),\n"
|
" call_info VARCHAR(255),\n"
|
||||||
" call_info_state VARCHAR(255)\n"
|
" call_info_state VARCHAR(255),\n"
|
||||||
|
" expires INTEGER default 0\n"
|
||||||
");\n";
|
");\n";
|
||||||
|
|
||||||
char sub_sql[] =
|
char sub_sql[] =
|
||||||
|
@ -3918,7 +3919,8 @@ int sofia_glue_init_sql(sofia_profile_t *profile)
|
||||||
"create index sd_hostname on sip_dialogs (hostname)",
|
"create index sd_hostname on sip_dialogs (hostname)",
|
||||||
"create index sd_presence_data on sip_dialogs (presence_data)",
|
"create index sd_presence_data on sip_dialogs (presence_data)",
|
||||||
"create index sd_call_info on sip_dialogs (call_info)",
|
"create index sd_call_info on sip_dialogs (call_info)",
|
||||||
"create index sd_call_info on sip_dialogs (call_info_state)",
|
"create index sd_call_info_state on sip_dialogs (call_info_state)",
|
||||||
|
"create index sd_expires on sip_dialogs (expires)",
|
||||||
"create index sp_hostname on sip_presence (hostname)",
|
"create index sp_hostname on sip_presence (hostname)",
|
||||||
"create index sa_nonce on sip_authentication (nonce)",
|
"create index sa_nonce on sip_authentication (nonce)",
|
||||||
"create index sa_hostname on sip_authentication (hostname)",
|
"create index sa_hostname on sip_authentication (hostname)",
|
||||||
|
@ -3988,7 +3990,7 @@ int sofia_glue_init_sql(sofia_profile_t *profile)
|
||||||
}
|
}
|
||||||
|
|
||||||
free(test_sql);
|
free(test_sql);
|
||||||
test_sql = switch_mprintf("delete from sip_dialogs where hostname='%q' and call_info_state like '%%'", mod_sofia_globals.hostname);
|
test_sql = switch_mprintf("delete from sip_dialogs where hostname='%q' and expires > 0", mod_sofia_globals.hostname);
|
||||||
|
|
||||||
if (switch_odbc_handle_exec(odbc_dbh, test_sql, NULL) != SWITCH_ODBC_SUCCESS) {
|
if (switch_odbc_handle_exec(odbc_dbh, test_sql, NULL) != SWITCH_ODBC_SUCCESS) {
|
||||||
switch_odbc_handle_exec(odbc_dbh, "DROP TABLE sip_dialogs", NULL);
|
switch_odbc_handle_exec(odbc_dbh, "DROP TABLE sip_dialogs", NULL);
|
||||||
|
@ -4055,7 +4057,7 @@ int sofia_glue_init_sql(sofia_profile_t *profile)
|
||||||
switch_core_db_test_reactive(db, test_sql, "DROP TABLE sip_subscriptions", sub_sql);
|
switch_core_db_test_reactive(db, test_sql, "DROP TABLE sip_subscriptions", sub_sql);
|
||||||
free(test_sql);
|
free(test_sql);
|
||||||
|
|
||||||
test_sql = switch_mprintf("delete from sip_dialogs where hostname='%q' and call_info_state like '%%'", mod_sofia_globals.hostname);
|
test_sql = switch_mprintf("delete from sip_dialogs where hostname='%q' and expires > 0", mod_sofia_globals.hostname);
|
||||||
switch_core_db_test_reactive(db, test_sql, "DROP TABLE sip_dialogs", dialog_sql);
|
switch_core_db_test_reactive(db, test_sql, "DROP TABLE sip_dialogs", dialog_sql);
|
||||||
free(test_sql);
|
free(test_sql);
|
||||||
|
|
||||||
|
@ -4133,7 +4135,8 @@ int sofia_glue_init_sql(sofia_profile_t *profile)
|
||||||
switch_core_db_exec(db, "create index if not exists sd_presence_id on sip_dialogs (presence_id)", NULL, NULL, NULL);
|
switch_core_db_exec(db, "create index if not exists sd_presence_id on sip_dialogs (presence_id)", NULL, NULL, NULL);
|
||||||
switch_core_db_exec(db, "create index if not exists sd_presence_data on sip_dialogs (presence_data)", NULL, NULL, NULL);
|
switch_core_db_exec(db, "create index if not exists sd_presence_data on sip_dialogs (presence_data)", NULL, NULL, NULL);
|
||||||
switch_core_db_exec(db, "create index if not exists sd_call_info on sip_dialogs (call_info)", NULL, NULL, NULL);
|
switch_core_db_exec(db, "create index if not exists sd_call_info on sip_dialogs (call_info)", NULL, NULL, NULL);
|
||||||
switch_core_db_exec(db, "create index if not exists sd_call_info on sip_dialogs (call_info_state)", NULL, NULL, NULL);
|
switch_core_db_exec(db, "create index if not exists sd_call_info_state on sip_dialogs (call_info_state)", NULL, NULL, NULL);
|
||||||
|
switch_core_db_exec(db, "create index if not exists sd_expires on sip_dialogs (expires)", NULL, NULL, NULL);
|
||||||
|
|
||||||
switch_core_db_exec(db, "create index if not exists sp_hostname on sip_presence (hostname)", NULL, NULL, NULL);
|
switch_core_db_exec(db, "create index if not exists sp_hostname on sip_presence (hostname)", NULL, NULL, NULL);
|
||||||
|
|
||||||
|
@ -4189,6 +4192,15 @@ void sofia_glue_execute_sql(sofia_profile_t *profile, char **sqlp, switch_bool_t
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void sofia_glue_execute_sql_now(sofia_profile_t *profile, char **sqlp, switch_bool_t sql_already_dynamic)
|
||||||
|
{
|
||||||
|
sofia_glue_actually_execute_sql(profile, *sqlp, profile->ireg_mutex);
|
||||||
|
if (sql_already_dynamic) {
|
||||||
|
switch_safe_free(*sqlp);
|
||||||
|
}
|
||||||
|
*sqlp = NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
switch_cache_db_handle_t *sofia_glue_get_db_handle(sofia_profile_t *profile)
|
switch_cache_db_handle_t *sofia_glue_get_db_handle(sofia_profile_t *profile)
|
||||||
{
|
{
|
||||||
|
|
|
@ -194,7 +194,7 @@ void sofia_presence_cancel(void)
|
||||||
if ((sql = switch_mprintf(
|
if ((sql = switch_mprintf(
|
||||||
"select proto,sip_user,sip_host,sub_to_user,sub_to_host,event,contact,call_id,full_from,"
|
"select proto,sip_user,sip_host,sub_to_user,sub_to_host,event,contact,call_id,full_from,"
|
||||||
"full_via,expires,user_agent,accept,profile_name,network_ip"
|
"full_via,expires,user_agent,accept,profile_name,network_ip"
|
||||||
",-1,'unavailable','unavailable' from sip_subscriptions where event='presence' and hostname='%q'",
|
",-1,'unavailable','unavailable' from sip_subscriptions where expires > -1 and event='presence' and hostname='%q'",
|
||||||
mod_sofia_globals.hostname))) {
|
mod_sofia_globals.hostname))) {
|
||||||
switch_mutex_lock(mod_sofia_globals.hash_mutex);
|
switch_mutex_lock(mod_sofia_globals.hash_mutex);
|
||||||
for (hi = switch_hash_first(NULL, mod_sofia_globals.profile_hash); hi; hi = switch_hash_next(hi)) {
|
for (hi = switch_hash_first(NULL, mod_sofia_globals.profile_hash); hi; hi = switch_hash_next(hi)) {
|
||||||
|
@ -227,7 +227,8 @@ void sofia_presence_establish_presence(sofia_profile_t *profile)
|
||||||
|
|
||||||
if (sofia_glue_execute_sql_callback(profile, profile->ireg_mutex,
|
if (sofia_glue_execute_sql_callback(profile, profile->ireg_mutex,
|
||||||
"select sub_to_user,sub_to_host,'Online','unknown',proto from sip_subscriptions "
|
"select sub_to_user,sub_to_host,'Online','unknown',proto from sip_subscriptions "
|
||||||
"where proto='ext' or proto='user' or proto='conf'", sofia_presence_resub_callback, &h) != SWITCH_TRUE) {
|
"where expires > -1 and proto='ext' or proto='user' or proto='conf'",
|
||||||
|
sofia_presence_resub_callback, &h) != SWITCH_TRUE) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -341,13 +342,13 @@ static void actual_sofia_presence_mwi_event_handler(switch_event_t *event)
|
||||||
if (for_everyone) {
|
if (for_everyone) {
|
||||||
sql = switch_mprintf("select proto,sip_user,sip_host,sub_to_user,sub_to_host,event,contact,call_id,full_from,"
|
sql = switch_mprintf("select proto,sip_user,sip_host,sub_to_user,sub_to_host,event,contact,call_id,full_from,"
|
||||||
"full_via,expires,user_agent,accept,profile_name,network_ip"
|
"full_via,expires,user_agent,accept,profile_name,network_ip"
|
||||||
",'%q','%q' from sip_subscriptions where event='message-summary' "
|
",'%q','%q' from sip_subscriptions where expires > -1 and event='message-summary' "
|
||||||
"and sub_to_user='%q' and (sub_to_host='%q' or presence_hosts like '%%%q%%')",
|
"and sub_to_user='%q' and (sub_to_host='%q' or presence_hosts like '%%%q%%')",
|
||||||
stream.data, host, user, host, host);
|
stream.data, host, user, host, host);
|
||||||
} else if (sub_call_id) {
|
} else if (sub_call_id) {
|
||||||
sql = switch_mprintf("select proto,sip_user,sip_host,sub_to_user,sub_to_host,event,contact,call_id,full_from,"
|
sql = switch_mprintf("select proto,sip_user,sip_host,sub_to_user,sub_to_host,event,contact,call_id,full_from,"
|
||||||
"full_via,expires,user_agent,accept,profile_name,network_ip"
|
"full_via,expires,user_agent,accept,profile_name,network_ip"
|
||||||
",'%q','%q' from sip_subscriptions where event='message-summary' "
|
",'%q','%q' from sip_subscriptions where expires > -1 and event='message-summary' "
|
||||||
"and sub_to_user='%q' and (sub_to_host='%q' or presence_hosts like '%%%q%%' and call_id='%q')",
|
"and sub_to_user='%q' and (sub_to_host='%q' or presence_hosts like '%%%q%%' and call_id='%q')",
|
||||||
stream.data, host, user, host, host, sub_call_id);
|
stream.data, host, user, host, host, sub_call_id);
|
||||||
}
|
}
|
||||||
|
@ -442,7 +443,7 @@ static void actual_sofia_presence_event_handler(switch_event_t *event)
|
||||||
"from sip_subscriptions left join sip_presence on "
|
"from sip_subscriptions left join sip_presence on "
|
||||||
"(sip_subscriptions.sub_to_user=sip_presence.sip_user and sip_subscriptions.sub_to_host=sip_presence.sip_host and "
|
"(sip_subscriptions.sub_to_user=sip_presence.sip_user and sip_subscriptions.sub_to_host=sip_presence.sip_host and "
|
||||||
"sip_subscriptions.profile_name=sip_presence.profile_name) "
|
"sip_subscriptions.profile_name=sip_presence.profile_name) "
|
||||||
"where sip_subscriptions.event='presence' and sip_subscriptions.full_from like '%%%q%%'",
|
"where sip_subscriptions.expires > -1 and sip_subscriptions.event='presence' and sip_subscriptions.full_from like '%%%q%%'",
|
||||||
switch_str_nil(status), switch_str_nil(rpid), from);
|
switch_str_nil(status), switch_str_nil(rpid), from);
|
||||||
} else {
|
} else {
|
||||||
sql = switch_mprintf(
|
sql = switch_mprintf(
|
||||||
|
@ -455,7 +456,7 @@ static void actual_sofia_presence_event_handler(switch_event_t *event)
|
||||||
"from sip_subscriptions left join sip_presence on "
|
"from sip_subscriptions left join sip_presence on "
|
||||||
"(sip_subscriptions.sub_to_user=sip_presence.sip_user and sip_subscriptions.sub_to_host=sip_presence.sip_host and "
|
"(sip_subscriptions.sub_to_user=sip_presence.sip_user and sip_subscriptions.sub_to_host=sip_presence.sip_host and "
|
||||||
"sip_subscriptions.profile_name=sip_presence.profile_name) "
|
"sip_subscriptions.profile_name=sip_presence.profile_name) "
|
||||||
"where sip_subscriptions.event='presence'", switch_str_nil(status), switch_str_nil(rpid));
|
"where sip_subscriptions.expires > -1 and sip_subscriptions.event='presence'", switch_str_nil(status), switch_str_nil(rpid));
|
||||||
}
|
}
|
||||||
|
|
||||||
switch_assert(sql != NULL);
|
switch_assert(sql != NULL);
|
||||||
|
@ -615,8 +616,11 @@ static void actual_sofia_presence_event_handler(switch_event_t *event)
|
||||||
if (mod_sofia_globals.debug_sla > 1) {
|
if (mod_sofia_globals.debug_sla > 1) {
|
||||||
switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_ERROR, "STATE SQL %s\n", sql);
|
switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_ERROR, "STATE SQL %s\n", sql);
|
||||||
}
|
}
|
||||||
sofia_glue_actually_execute_sql(profile, sql, profile->ireg_mutex);
|
sofia_glue_execute_sql_now(profile, &sql, SWITCH_TRUE);
|
||||||
switch_safe_free(sql);
|
|
||||||
|
if (mod_sofia_globals.debug_sla > 1) {
|
||||||
|
switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_ERROR, "PROCESS PRESENCE EVENT\n");
|
||||||
|
}
|
||||||
|
|
||||||
sync_sla(profile, euser, host, SWITCH_TRUE, SWITCH_TRUE);
|
sync_sla(profile, euser, host, SWITCH_TRUE, SWITCH_TRUE);
|
||||||
}
|
}
|
||||||
|
@ -634,7 +638,7 @@ static void actual_sofia_presence_event_handler(switch_event_t *event)
|
||||||
"left join sip_presence on "
|
"left join sip_presence on "
|
||||||
"(sip_subscriptions.sub_to_user=sip_presence.sip_user and sip_subscriptions.sub_to_host=sip_presence.sip_host and "
|
"(sip_subscriptions.sub_to_user=sip_presence.sip_user and sip_subscriptions.sub_to_host=sip_presence.sip_host and "
|
||||||
"sip_subscriptions.profile_name=sip_presence.profile_name) "
|
"sip_subscriptions.profile_name=sip_presence.profile_name) "
|
||||||
"where (event='%q' or event='%q') and sub_to_user='%q' "
|
"where sip_subscriptions.expires > -1 and (event='%q' or event='%q') and sub_to_user='%q' "
|
||||||
"and (sub_to_host='%q' or presence_hosts like '%%%q%%') "
|
"and (sub_to_host='%q' or presence_hosts like '%%%q%%') "
|
||||||
"and (sip_subscriptions.profile_name = '%q' or sip_subscriptions.presence_hosts != sip_subscriptions.sub_to_host)",
|
"and (sip_subscriptions.profile_name = '%q' or sip_subscriptions.presence_hosts != sip_subscriptions.sub_to_host)",
|
||||||
switch_str_nil(status), switch_str_nil(rpid), host, event_type, alt_event_type, euser, host, host, profile->name))) {
|
switch_str_nil(status), switch_str_nil(rpid), host, event_type, alt_event_type, euser, host, host, profile->name))) {
|
||||||
|
@ -1591,7 +1595,7 @@ static void sync_sla(sofia_profile_t *profile, const char *to_user, const char *
|
||||||
if (unseize) {
|
if (unseize) {
|
||||||
sql = switch_mprintf("select call_id,expires,sub_to_user,sub_to_host,event "
|
sql = switch_mprintf("select call_id,expires,sub_to_user,sub_to_host,event "
|
||||||
"from sip_subscriptions "
|
"from sip_subscriptions "
|
||||||
"where hostname='%q' "
|
"where expires > -1 and hostname='%q' "
|
||||||
"and sub_to_user='%q' and sub_to_host='%q' "
|
"and sub_to_user='%q' and sub_to_host='%q' "
|
||||||
"and (event='call-info' or event='line-seize')",
|
"and (event='call-info' or event='line-seize')",
|
||||||
mod_sofia_globals.hostname,
|
mod_sofia_globals.hostname,
|
||||||
|
@ -1601,7 +1605,7 @@ static void sync_sla(sofia_profile_t *profile, const char *to_user, const char *
|
||||||
} else {
|
} else {
|
||||||
sql = switch_mprintf("select call_id,expires,sub_to_user,sub_to_host,event "
|
sql = switch_mprintf("select call_id,expires,sub_to_user,sub_to_host,event "
|
||||||
"from sip_subscriptions "
|
"from sip_subscriptions "
|
||||||
"where hostname='%q' "
|
"where expires > -1 and hostname='%q' "
|
||||||
"and sub_to_user='%q' and sub_to_host='%q' "
|
"and sub_to_user='%q' and sub_to_host='%q' "
|
||||||
"and (event='call-info')",
|
"and (event='call-info')",
|
||||||
mod_sofia_globals.hostname,
|
mod_sofia_globals.hostname,
|
||||||
|
@ -1632,7 +1636,7 @@ static void sync_sla(sofia_profile_t *profile, const char *to_user, const char *
|
||||||
if (mod_sofia_globals.debug_sla > 1) {
|
if (mod_sofia_globals.debug_sla > 1) {
|
||||||
switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_ERROR, "CLEAR SQL %s\n", sql);
|
switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_ERROR, "CLEAR SQL %s\n", sql);
|
||||||
}
|
}
|
||||||
sofia_glue_execute_sql(profile, &sql, SWITCH_TRUE);
|
sofia_glue_execute_sql_now(profile, &sql, SWITCH_TRUE);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -1881,9 +1885,7 @@ void sofia_presence_handle_sip_i_subscribe(int status,
|
||||||
switch_snprintf(exp_delta_str, sizeof(exp_delta_str), "%ld", exp_delta);
|
switch_snprintf(exp_delta_str, sizeof(exp_delta_str), "%ld", exp_delta);
|
||||||
|
|
||||||
if (sofia_test_pflag(profile, PFLAG_MULTIREG)) {
|
if (sofia_test_pflag(profile, PFLAG_MULTIREG)) {
|
||||||
//sql = switch_mprintf("delete from sip_subscriptions where call_id='%q' or (contact='%q' and event='%q')", call_id, contact_str, event);
|
sql = switch_mprintf("update sip_subscriptions set expires=-1 where call_id='%q' "
|
||||||
|
|
||||||
sql = switch_mprintf("delete from sip_subscriptions where call_id='%q' "
|
|
||||||
"or (proto='%q' and sip_user='%q' and sip_host='%q' "
|
"or (proto='%q' and sip_user='%q' and sip_host='%q' "
|
||||||
"and sub_to_user='%q' and sub_to_host='%q' and event='%q' and hostname='%q' "
|
"and sub_to_user='%q' and sub_to_host='%q' and event='%q' and hostname='%q' "
|
||||||
"and contact='%q')",
|
"and contact='%q')",
|
||||||
|
@ -1891,7 +1893,7 @@ void sofia_presence_handle_sip_i_subscribe(int status,
|
||||||
contact_str);
|
contact_str);
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
sql = switch_mprintf("delete from sip_subscriptions where "
|
sql = switch_mprintf("update sip_subscriptions set expires=-1 where "
|
||||||
"proto='%q' and sip_user='%q' and sip_host='%q' and sub_to_user='%q' and sub_to_host='%q' and event='%q' and hostname='%q'",
|
"proto='%q' and sip_user='%q' and sip_host='%q' and sub_to_user='%q' and sub_to_host='%q' and event='%q' and hostname='%q'",
|
||||||
proto, from_user, from_host, to_user, to_host, event, mod_sofia_globals.hostname);
|
proto, from_user, from_host, to_user, to_host, event, mod_sofia_globals.hostname);
|
||||||
}
|
}
|
||||||
|
@ -1930,7 +1932,7 @@ void sofia_presence_handle_sip_i_subscribe(int status,
|
||||||
proto, from_user, from_host, to_user, to_host, profile->presence_hosts ? profile->presence_hosts : to_host,
|
proto, from_user, from_host, to_user, to_host, profile->presence_hosts ? profile->presence_hosts : to_host,
|
||||||
event, contact_str, call_id, full_from, full_via,
|
event, contact_str, call_id, full_from, full_via,
|
||||||
//sofia_test_pflag(profile, PFLAG_MULTIREG) ? switch_epoch_time_now(NULL) + exp_delta : exp_delta * -1,
|
//sofia_test_pflag(profile, PFLAG_MULTIREG) ? switch_epoch_time_now(NULL) + exp_delta : exp_delta * -1,
|
||||||
(long)switch_epoch_time_now(NULL) + exp_delta,
|
(long)switch_epoch_time_now(NULL) + (exp_delta * 2),
|
||||||
full_agent, accept, profile->name,mod_sofia_globals.hostname, network_port, network_ip);
|
full_agent, accept, profile->name,mod_sofia_globals.hostname, network_port, network_ip);
|
||||||
|
|
||||||
switch_assert(sql != NULL);
|
switch_assert(sql != NULL);
|
||||||
|
@ -1941,9 +1943,7 @@ void sofia_presence_handle_sip_i_subscribe(int status,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
sofia_glue_actually_execute_sql(profile, sql, profile->ireg_mutex);
|
sofia_glue_execute_sql_now(profile, &sql, SWITCH_TRUE);
|
||||||
switch_safe_free(sql);
|
|
||||||
|
|
||||||
sstr = switch_mprintf("active;expires=%ld", exp_delta);
|
sstr = switch_mprintf("active;expires=%ld", exp_delta);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1991,7 +1991,7 @@ void sofia_presence_handle_sip_i_subscribe(int status,
|
||||||
|
|
||||||
if (nh && nh->nh_ds && nh->nh_ds->ds_usage) {
|
if (nh && nh->nh_ds && nh->nh_ds->ds_usage) {
|
||||||
//nua_dialog_usage_set_refresh_range(nh->nh_ds->ds_usage, exp_delta + SUB_OVERLAP, exp_delta + SUB_OVERLAP);
|
//nua_dialog_usage_set_refresh_range(nh->nh_ds->ds_usage, exp_delta + SUB_OVERLAP, exp_delta + SUB_OVERLAP);
|
||||||
nua_dialog_usage_set_refresh_range(nh->nh_ds->ds_usage, exp_delta, exp_delta);
|
nua_dialog_usage_set_refresh_range(nh->nh_ds->ds_usage, exp_delta * 2, exp_delta * 2);
|
||||||
}
|
}
|
||||||
|
|
||||||
nua_respond(nh, SIP_202_ACCEPTED,
|
nua_respond(nh, SIP_202_ACCEPTED,
|
||||||
|
@ -2027,7 +2027,22 @@ void sofia_presence_handle_sip_i_subscribe(int status,
|
||||||
|
|
||||||
|
|
||||||
if (!strcasecmp(event, "line-seize")) {
|
if (!strcasecmp(event, "line-seize")) {
|
||||||
sync_sla(profile, to_user, to_host, SWITCH_FALSE, SWITCH_TRUE);
|
if (mod_sofia_globals.debug_sla > 1) {
|
||||||
|
switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_ERROR, "CANCEL LINE SEIZE\n");
|
||||||
|
}
|
||||||
|
|
||||||
|
sql = switch_mprintf("delete from sip_dialogs where sip_from_user='%q' and sip_from_host='%q' and call_info_state='seized'",
|
||||||
|
to_user,
|
||||||
|
to_host
|
||||||
|
);
|
||||||
|
|
||||||
|
|
||||||
|
if (mod_sofia_globals.debug_sla > 1) {
|
||||||
|
switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_ERROR, "CLEAR SQL %s\n", sql);
|
||||||
|
}
|
||||||
|
sofia_glue_execute_sql_now(profile, &sql, SWITCH_TRUE);
|
||||||
|
|
||||||
|
sync_sla(profile, to_user, to_host, SWITCH_FALSE, SWITCH_FALSE);
|
||||||
}
|
}
|
||||||
|
|
||||||
su_free(profile->home, full_call_info);
|
su_free(profile->home, full_call_info);
|
||||||
|
@ -2063,37 +2078,30 @@ void sofia_presence_handle_sip_i_subscribe(int status,
|
||||||
if (mod_sofia_globals.debug_sla > 1) {
|
if (mod_sofia_globals.debug_sla > 1) {
|
||||||
switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_ERROR, "CLEAR SQL %s\n", sql);
|
switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_ERROR, "CLEAR SQL %s\n", sql);
|
||||||
}
|
}
|
||||||
sofia_glue_execute_sql(profile, &sql, SWITCH_TRUE);
|
sofia_glue_execute_sql_now(profile, &sql, SWITCH_TRUE);
|
||||||
|
|
||||||
sql = switch_mprintf("insert into sip_dialogs (sip_from_user,sip_from_host,call_info,call_info_state,hostname) "
|
sql = switch_mprintf("insert into sip_dialogs (sip_from_user,sip_from_host,call_info,call_info_state,hostname,expires) "
|
||||||
"values ('%q','%q','%q','seized','%q')",
|
"values ('%q','%q','%q','seized','%q',%ld)",
|
||||||
to_user,
|
to_user,
|
||||||
to_host,
|
to_host,
|
||||||
switch_str_nil(p),
|
switch_str_nil(p),
|
||||||
mod_sofia_globals.hostname
|
mod_sofia_globals.hostname,
|
||||||
|
switch_epoch_time_now(NULL) + exp_delta
|
||||||
);
|
);
|
||||||
|
|
||||||
if (mod_sofia_globals.debug_sla > 1) {
|
if (mod_sofia_globals.debug_sla > 1) {
|
||||||
switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_ERROR, "SEIZE SQL %s\n", sql);
|
switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_ERROR, "SEIZE SQL %s\n", sql);
|
||||||
}
|
}
|
||||||
sofia_glue_actually_execute_sql(profile, sql, profile->ireg_mutex);
|
sofia_glue_execute_sql_now(profile, &sql, SWITCH_TRUE);
|
||||||
switch_safe_free(sql);
|
sync_sla(profile, to_user, to_host, SWITCH_FALSE, SWITCH_FALSE);
|
||||||
sync_sla(profile, to_user, to_host, SWITCH_TRUE, SWITCH_FALSE);
|
|
||||||
|
|
||||||
su_free(profile->home, full_call_info);
|
su_free(profile->home, full_call_info);
|
||||||
}
|
}
|
||||||
}
|
} else if (!strcasecmp(event, "call-info")) {
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
if (!strcasecmp(event, "call-info")) {
|
|
||||||
sync_sla(profile, to_user, to_host, SWITCH_FALSE, SWITCH_FALSE);
|
sync_sla(profile, to_user, to_host, SWITCH_FALSE, SWITCH_FALSE);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
sent_reply++;
|
sent_reply++;
|
||||||
|
|
||||||
switch_safe_free(sstr);
|
switch_safe_free(sstr);
|
||||||
|
@ -2102,7 +2110,7 @@ void sofia_presence_handle_sip_i_subscribe(int status,
|
||||||
if ((sql = switch_mprintf(
|
if ((sql = switch_mprintf(
|
||||||
"select proto,sip_user,'%q',sub_to_user,sub_to_host,event,contact,call_id,full_from,"
|
"select proto,sip_user,'%q',sub_to_user,sub_to_host,event,contact,call_id,full_from,"
|
||||||
"full_via,expires,user_agent,accept,profile_name,network_ip"
|
"full_via,expires,user_agent,accept,profile_name,network_ip"
|
||||||
" from sip_subscriptions where event='message-summary' and sip_user='%q' "
|
" from sip_subscriptions where expires > -1 and event='message-summary' and sip_user='%q' "
|
||||||
"and (sip_host='%q' or presence_hosts like '%%%q%%')",
|
"and (sip_host='%q' or presence_hosts like '%%%q%%')",
|
||||||
to_host, to_user, to_host, to_host))) {
|
to_host, to_user, to_host, to_host))) {
|
||||||
sofia_glue_execute_sql_callback(profile, profile->ireg_mutex, sql, sofia_presence_sub_reg_callback, profile);
|
sofia_glue_execute_sql_callback(profile, profile->ireg_mutex, sql, sofia_presence_sub_reg_callback, profile);
|
||||||
|
|
|
@ -610,19 +610,30 @@ void sofia_reg_check_expire(sofia_profile_t *profile, time_t now, int reboot)
|
||||||
|
|
||||||
|
|
||||||
if (now) {
|
if (now) {
|
||||||
switch_snprintf(sql, sizeof(sql), "select call_id from sip_subscriptions where expires > 0 and expires <= %ld and hostname='%s'",
|
switch_snprintf(sql, sizeof(sql), "select call_id from sip_subscriptions where (expires = -1 or (expires > 0 and expires <= %ld)) and hostname='%s'",
|
||||||
(long) now, mod_sofia_globals.hostname);
|
(long) now, mod_sofia_globals.hostname);
|
||||||
} else {
|
} else {
|
||||||
switch_snprintf(sql, sizeof(sql), "select call_id from sip_subscriptions where expires > 0 and hostname='%s'", mod_sofia_globals.hostname);
|
switch_snprintf(sql, sizeof(sql), "select call_id from sip_subscriptions where expires >= -1 and hostname='%s'",
|
||||||
|
mod_sofia_globals.hostname);
|
||||||
}
|
}
|
||||||
|
|
||||||
sofia_glue_execute_sql_callback(profile, NULL, sql, sofia_sub_del_callback, profile);
|
sofia_glue_execute_sql_callback(profile, NULL, sql, sofia_sub_del_callback, profile);
|
||||||
|
|
||||||
if (now) {
|
if (now) {
|
||||||
switch_snprintf(sql, sizeof(sql), "delete from sip_subscriptions where expires > 0 and expires <= %ld and hostname='%s'",
|
switch_snprintf(sql, sizeof(sql), "delete from sip_subscriptions where (expires = -1 or (expires > 0 and expires <= %ld)) and hostname='%s'",
|
||||||
(long) now, mod_sofia_globals.hostname);
|
(long) now, mod_sofia_globals.hostname);
|
||||||
} else {
|
} else {
|
||||||
switch_snprintf(sql, sizeof(sql), "delete from sip_subscriptions where expires > 0 and hostname='%s'", mod_sofia_globals.hostname);
|
switch_snprintf(sql, sizeof(sql), "delete from sip_subscriptions where expires >= -1 and hostname='%s'", mod_sofia_globals.hostname);
|
||||||
|
}
|
||||||
|
|
||||||
|
sofia_glue_actually_execute_sql(profile, sql, NULL);
|
||||||
|
|
||||||
|
|
||||||
|
if (now) {
|
||||||
|
switch_snprintf(sql, sizeof(sql), "delete from sip_dialogs where (expires = -1 or (expires > 0 and expires <= %ld)) and hostname='%s'",
|
||||||
|
(long) now, mod_sofia_globals.hostname);
|
||||||
|
} else {
|
||||||
|
switch_snprintf(sql, sizeof(sql), "delete from sip_dialogs where expires >= -1 and hostname='%s'", mod_sofia_globals.hostname);
|
||||||
}
|
}
|
||||||
|
|
||||||
sofia_glue_actually_execute_sql(profile, sql, NULL);
|
sofia_glue_actually_execute_sql(profile, sql, NULL);
|
||||||
|
@ -1268,7 +1279,7 @@ uint8_t sofia_reg_handle_register(nua_t *nua, sofia_profile_t *profile, nua_hand
|
||||||
switch_event_fire(&s_event);
|
switch_event_fire(&s_event);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (*contact_str && sofia_test_pflag(profile, PFLAG_MANAGE_SHARED_APPEARANCE) && sofia_sla_supported(sip)) {
|
if (*contact_str && sofia_test_pflag(profile, PFLAG_MANAGE_SHARED_APPEARANCE_SYLANTRO)) {
|
||||||
sofia_sla_handle_register(nua, profile, sip, exptime, contact_str);
|
sofia_sla_handle_register(nua, profile, sip, exptime, contact_str);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue