FS-3794 try this please
This commit is contained in:
parent
7788f3e9c4
commit
d1a9b3777c
|
@ -6266,6 +6266,7 @@ void sofia_glue_actually_execute_sql_trans(sofia_profile_t *profile, char *sql,
|
||||||
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)
|
||||||
{
|
{
|
||||||
switch_cache_db_handle_t *dbh = NULL;
|
switch_cache_db_handle_t *dbh = NULL;
|
||||||
|
char *err = NULL;
|
||||||
|
|
||||||
if (mutex) {
|
if (mutex) {
|
||||||
switch_mutex_lock(mutex);
|
switch_mutex_lock(mutex);
|
||||||
|
@ -6276,7 +6277,12 @@ void sofia_glue_actually_execute_sql(sofia_profile_t *profile, char *sql, switch
|
||||||
goto end;
|
goto end;
|
||||||
}
|
}
|
||||||
|
|
||||||
switch_cache_db_execute_sql(dbh, sql, NULL);
|
switch_cache_db_execute_sql(dbh, sql, &err);
|
||||||
|
|
||||||
|
if (err) {
|
||||||
|
switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_ERROR, "SQL ERR: [%s]\n%s\n", err, sql);
|
||||||
|
free(err);
|
||||||
|
}
|
||||||
|
|
||||||
end:
|
end:
|
||||||
|
|
||||||
|
@ -6324,7 +6330,7 @@ switch_bool_t sofia_glue_execute_sql_callback(sofia_profile_t *profile,
|
||||||
char *sofia_glue_execute_sql2str(sofia_profile_t *profile, switch_mutex_t *mutex, char *sql, char *resbuf, size_t len)
|
char *sofia_glue_execute_sql2str(sofia_profile_t *profile, switch_mutex_t *mutex, char *sql, char *resbuf, size_t len)
|
||||||
{
|
{
|
||||||
char *ret = NULL;
|
char *ret = NULL;
|
||||||
|
char *err = NULL;
|
||||||
switch_cache_db_handle_t *dbh = NULL;
|
switch_cache_db_handle_t *dbh = NULL;
|
||||||
|
|
||||||
if (!(dbh = sofia_glue_get_db_handle(profile))) {
|
if (!(dbh = sofia_glue_get_db_handle(profile))) {
|
||||||
|
@ -6336,7 +6342,12 @@ char *sofia_glue_execute_sql2str(sofia_profile_t *profile, switch_mutex_t *mutex
|
||||||
switch_mutex_lock(mutex);
|
switch_mutex_lock(mutex);
|
||||||
}
|
}
|
||||||
|
|
||||||
ret = switch_cache_db_execute_sql2str(dbh, sql, resbuf, len, NULL);
|
ret = switch_cache_db_execute_sql2str(dbh, sql, resbuf, len, &err);
|
||||||
|
|
||||||
|
if (err) {
|
||||||
|
switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_ERROR, "SQL ERR: [%s]\n%s\n", err, sql);
|
||||||
|
free(err);
|
||||||
|
}
|
||||||
|
|
||||||
if (mutex) {
|
if (mutex) {
|
||||||
switch_mutex_unlock(mutex);
|
switch_mutex_unlock(mutex);
|
||||||
|
|
|
@ -360,8 +360,8 @@ void sofia_presence_cancel(void)
|
||||||
|
|
||||||
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"
|
||||||
",-1,'unavailable','unavailable' from sip_subscriptions where version > -1 and "
|
",-1,'unavailable','unavailable' from sip_subscriptions where "
|
||||||
"expires > -1 and event='presence' and hostname='%q'",
|
"event='presence' and hostname='%q'",
|
||||||
mod_sofia_globals.hostname);
|
mod_sofia_globals.hostname);
|
||||||
|
|
||||||
|
|
||||||
|
@ -519,13 +519,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',full_to,network_ip,network_port from sip_subscriptions where version > -1 and expires > -1 and event='message-summary' "
|
",'%q',full_to,network_ip,network_port from sip_subscriptions where event='message-summary' "
|
||||||
"and sub_to_user='%q' and (sub_to_host='%q' or presence_hosts like '%%%q%%')", stream.data, user, host, host);
|
"and sub_to_user='%q' and (sub_to_host='%q' or presence_hosts like '%%%q%%')", stream.data, 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',full_to,network_ip,network_port from sip_subscriptions where version > -1 and expires > -1 and event='message-summary' "
|
",'%q',full_to,network_ip,network_port from sip_subscriptions where 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, user, host, host, sub_call_id);
|
stream.data, user, host, host, sub_call_id);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -788,12 +788,26 @@ static void do_dialog_probe(switch_event_t *event)
|
||||||
switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_INFO, "%s END DIALOG_PROBE_SQL\n\n", profile->name);
|
switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_INFO, "%s END DIALOG_PROBE_SQL\n\n", profile->name);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
sql = switch_mprintf("update sip_subscriptions set version=version+1 "
|
||||||
|
"where hostname='%q' "
|
||||||
|
"and sub_to_user='%q' and sub_to_host='%q' and (event!='dialog') and "
|
||||||
|
"call_id='%q'",
|
||||||
|
mod_sofia_globals.hostname, probe_euser, probe_host, sub_call_id);
|
||||||
|
|
||||||
|
if (mod_sofia_globals.debug_presence > 1) {
|
||||||
|
switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_DEBUG, "%s DUMP DIALOG_PROBE set version sql:\n%s\n", profile->name, sql);
|
||||||
|
}
|
||||||
|
sofia_glue_execute_sql_now(profile, &sql, SWITCH_TRUE);
|
||||||
|
switch_safe_free(sql);
|
||||||
|
|
||||||
|
|
||||||
// The dialog_probe_callback has built up the dialogs to be included in the NOTIFY.
|
// The dialog_probe_callback has built up the dialogs to be included in the NOTIFY.
|
||||||
// Now send the "full" dialog event to the triggering subscription.
|
// Now send the "full" dialog event to the triggering subscription.
|
||||||
sql = switch_mprintf("select call_id,expires,sub_to_user,sub_to_host,event,version, "
|
sql = switch_mprintf("select call_id,expires,sub_to_user,sub_to_host,event,version, "
|
||||||
"'full',full_to,full_from,contact,network_ip,network_port "
|
"'full',full_to,full_from,contact,network_ip,network_port "
|
||||||
"from sip_subscriptions "
|
"from sip_subscriptions "
|
||||||
"where expires > -1 and hostname='%q' "
|
"where hostname='%q' "
|
||||||
"and sub_to_user='%q' and sub_to_host='%q' " "and (event='dialog') and "
|
"and sub_to_user='%q' and sub_to_host='%q' " "and (event='dialog') and "
|
||||||
"call_id='%q'",
|
"call_id='%q'",
|
||||||
mod_sofia_globals.hostname, probe_euser, probe_host, sub_call_id);
|
mod_sofia_globals.hostname, probe_euser, probe_host, sub_call_id);
|
||||||
|
@ -803,17 +817,7 @@ static void do_dialog_probe(switch_event_t *event)
|
||||||
sofia_glue_execute_sql_callback(profile, profile->ireg_mutex, sql, sofia_dialog_probe_notify_callback, h4235);
|
sofia_glue_execute_sql_callback(profile, profile->ireg_mutex, sql, sofia_dialog_probe_notify_callback, h4235);
|
||||||
switch_safe_free(sql);
|
switch_safe_free(sql);
|
||||||
|
|
||||||
sql = switch_mprintf("update sip_subscriptions set version=version+1 "
|
|
||||||
"where expires > -1 and hostname='%q' "
|
|
||||||
"and sub_to_user='%q' and sub_to_host='%q' " "and (event!='dialog') and "
|
|
||||||
"call_id='%q'",
|
|
||||||
mod_sofia_globals.hostname, probe_euser, probe_host, sub_call_id);
|
|
||||||
|
|
||||||
if (mod_sofia_globals.debug_presence > 1) {
|
|
||||||
switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_DEBUG, "%s DUMP DIALOG_PROBE set version sql:\n%s\n", profile->name, sql);
|
|
||||||
}
|
|
||||||
sofia_glue_execute_sql_now(profile, &sql, SWITCH_TRUE);
|
|
||||||
switch_safe_free(sql);
|
|
||||||
|
|
||||||
sofia_glue_release_profile(profile);
|
sofia_glue_release_profile(profile);
|
||||||
switch_core_hash_destroy(&h4235->hash);
|
switch_core_hash_destroy(&h4235->hash);
|
||||||
|
@ -879,6 +883,17 @@ static void actual_sofia_presence_event_handler(switch_event_t *event)
|
||||||
}
|
}
|
||||||
|
|
||||||
if (from) {
|
if (from) {
|
||||||
|
|
||||||
|
sql = switch_mprintf("update sip_subscriptions set version=version+1 where "
|
||||||
|
"sip_subscriptions.event='presence' and sip_subscriptions.full_from like '%%%q%%'", from);
|
||||||
|
|
||||||
|
if (mod_sofia_globals.debug_presence > 1) {
|
||||||
|
switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_ERROR, "PRES SQL %s\n", sql);
|
||||||
|
}
|
||||||
|
|
||||||
|
sofia_glue_execute_sql_now(profile, &sql, SWITCH_TRUE);
|
||||||
|
|
||||||
|
|
||||||
sql = switch_mprintf("select sip_subscriptions.proto,sip_subscriptions.sip_user,sip_subscriptions.sip_host,"
|
sql = switch_mprintf("select sip_subscriptions.proto,sip_subscriptions.sip_user,sip_subscriptions.sip_host,"
|
||||||
"sip_subscriptions.sub_to_user,sip_subscriptions.sub_to_host,sip_subscriptions.event,"
|
"sip_subscriptions.sub_to_user,sip_subscriptions.sub_to_host,sip_subscriptions.event,"
|
||||||
"sip_subscriptions.contact,sip_subscriptions.call_id,sip_subscriptions.full_from,"
|
"sip_subscriptions.contact,sip_subscriptions.call_id,sip_subscriptions.full_from,"
|
||||||
|
@ -889,10 +904,20 @@ 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.version > -1 and "
|
"where "
|
||||||
"sip_subscriptions.expires > -1 and sip_subscriptions.event='presence' and sip_subscriptions.full_from like '%%%q%%'",
|
"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("update sip_subscriptions set version=version+1 where "
|
||||||
|
"sip_subscriptions.event='presence'");
|
||||||
|
|
||||||
|
if (mod_sofia_globals.debug_presence > 1) {
|
||||||
|
switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_ERROR, "PRES SQL %s\n", sql);
|
||||||
|
}
|
||||||
|
|
||||||
|
sofia_glue_execute_sql_now(profile, &sql, SWITCH_TRUE);
|
||||||
|
|
||||||
sql = switch_mprintf("select sip_subscriptions.proto,sip_subscriptions.sip_user,sip_subscriptions.sip_host,"
|
sql = switch_mprintf("select sip_subscriptions.proto,sip_subscriptions.sip_user,sip_subscriptions.sip_host,"
|
||||||
"sip_subscriptions.sub_to_user,sip_subscriptions.sub_to_host,sip_subscriptions.event,"
|
"sip_subscriptions.sub_to_user,sip_subscriptions.sub_to_host,sip_subscriptions.event,"
|
||||||
"sip_subscriptions.contact,sip_subscriptions.call_id,sip_subscriptions.full_from,"
|
"sip_subscriptions.contact,sip_subscriptions.call_id,sip_subscriptions.full_from,"
|
||||||
|
@ -903,8 +928,8 @@ 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.version > -1 and "
|
"where "
|
||||||
"sip_subscriptions.expires > -1 and sip_subscriptions.event='presence'", switch_str_nil(status),
|
"sip_subscriptions.event='presence'", switch_str_nil(status),
|
||||||
switch_str_nil(rpid));
|
switch_str_nil(rpid));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1061,6 +1086,24 @@ static void actual_sofia_presence_event_handler(switch_event_t *event)
|
||||||
|
|
||||||
if (zstr(call_id)) {
|
if (zstr(call_id)) {
|
||||||
|
|
||||||
|
sql = switch_mprintf("update sip_subscriptions set version=version+1 where "
|
||||||
|
"sip_subscriptions.event != 'line-seize' "
|
||||||
|
"and sip_subscriptions.proto='%q' and (event='%q' or event='%q') and sub_to_user='%q' and "
|
||||||
|
"(sub_to_host='%q' or sub_to_host='%q' or sub_to_host='%q' or "
|
||||||
|
"presence_hosts like '%%%q%%') and "
|
||||||
|
"(sip_subscriptions.profile_name = '%q' or presence_hosts like '%%%q%%')",
|
||||||
|
proto, event_type, alt_event_type, euser, host, profile->sipip,
|
||||||
|
profile->extsipip ? profile->extsipip : "N/A", host, profile->name, host);
|
||||||
|
|
||||||
|
|
||||||
|
if (mod_sofia_globals.debug_presence > 1) {
|
||||||
|
switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_ERROR, "PRES SQL %s\n", sql);
|
||||||
|
}
|
||||||
|
|
||||||
|
sofia_glue_execute_sql_now(profile, &sql, SWITCH_TRUE);
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
sql = switch_mprintf("select distinct sip_subscriptions.proto,sip_subscriptions.sip_user,sip_subscriptions.sip_host,"
|
sql = switch_mprintf("select distinct sip_subscriptions.proto,sip_subscriptions.sip_user,sip_subscriptions.sip_host,"
|
||||||
"sip_subscriptions.sub_to_user,sip_subscriptions.sub_to_host,sip_subscriptions.event,"
|
"sip_subscriptions.sub_to_user,sip_subscriptions.sub_to_host,sip_subscriptions.event,"
|
||||||
"sip_subscriptions.contact,sip_subscriptions.call_id,sip_subscriptions.full_from,"
|
"sip_subscriptions.contact,sip_subscriptions.call_id,sip_subscriptions.full_from,"
|
||||||
|
@ -1074,7 +1117,7 @@ static void actual_sofia_presence_event_handler(switch_event_t *event)
|
||||||
"(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.version > -1 and sip_subscriptions.expires > -1 and "
|
"where sip_subscriptions.event != 'line-seize' and "
|
||||||
"sip_subscriptions.proto='%q' and "
|
"sip_subscriptions.proto='%q' and "
|
||||||
"(event='%q' or event='%q') and sub_to_user='%q' "
|
"(event='%q' or event='%q') and sub_to_user='%q' "
|
||||||
"and (sub_to_host='%q' or sub_to_host='%q' or sub_to_host='%q' or presence_hosts like '%%%q%%') "
|
"and (sub_to_host='%q' or sub_to_host='%q' or sub_to_host='%q' or presence_hosts like '%%%q%%') "
|
||||||
|
@ -1085,6 +1128,18 @@ static void actual_sofia_presence_event_handler(switch_event_t *event)
|
||||||
event_type, alt_event_type, euser, host, profile->sipip,
|
event_type, alt_event_type, euser, host, profile->sipip,
|
||||||
profile->extsipip ? profile->extsipip : "N/A", host, profile->name, host);
|
profile->extsipip ? profile->extsipip : "N/A", host, profile->name, host);
|
||||||
} else {
|
} else {
|
||||||
|
sql = switch_mprintf("update sip_subscriptions set version=version+1 where sip_subscriptions.event != 'line-seize' and "
|
||||||
|
"sip_subscriptions.profile_name = '%q' and sip_subscriptions.call_id='%q'",
|
||||||
|
profile->name, call_id);
|
||||||
|
|
||||||
|
|
||||||
|
if (mod_sofia_globals.debug_presence > 1) {
|
||||||
|
switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_ERROR, "PRES SQL %s\n", sql);
|
||||||
|
}
|
||||||
|
|
||||||
|
sofia_glue_execute_sql_now(profile, &sql, SWITCH_TRUE);
|
||||||
|
|
||||||
|
|
||||||
sql = switch_mprintf("select distinct sip_subscriptions.proto,sip_subscriptions.sip_user,sip_subscriptions.sip_host,"
|
sql = switch_mprintf("select distinct sip_subscriptions.proto,sip_subscriptions.sip_user,sip_subscriptions.sip_host,"
|
||||||
"sip_subscriptions.sub_to_user,sip_subscriptions.sub_to_host,sip_subscriptions.event,"
|
"sip_subscriptions.sub_to_user,sip_subscriptions.sub_to_host,sip_subscriptions.event,"
|
||||||
"sip_subscriptions.contact,sip_subscriptions.call_id,sip_subscriptions.full_from,"
|
"sip_subscriptions.contact,sip_subscriptions.call_id,sip_subscriptions.full_from,"
|
||||||
|
@ -1132,14 +1187,6 @@ static void actual_sofia_presence_event_handler(switch_event_t *event)
|
||||||
sofia_glue_execute_sql_callback(profile, profile->ireg_mutex, sql, sofia_presence_sub_callback, &helper);
|
sofia_glue_execute_sql_callback(profile, profile->ireg_mutex, sql, sofia_presence_sub_callback, &helper);
|
||||||
switch_safe_free(sql);
|
switch_safe_free(sql);
|
||||||
|
|
||||||
sql = switch_mprintf("update sip_subscriptions set version=version+1 where event!='dialog' and sub_to_user='%q' "
|
|
||||||
"and (sub_to_host='%q' or presence_hosts like '%%%q%%') "
|
|
||||||
"and (profile_name = '%q' or presence_hosts != sub_to_host)",
|
|
||||||
euser, host, host, profile->name);
|
|
||||||
|
|
||||||
sofia_glue_execute_sql_now(profile, &sql, SWITCH_TRUE);
|
|
||||||
|
|
||||||
|
|
||||||
if (mod_sofia_globals.debug_presence > 0) {
|
if (mod_sofia_globals.debug_presence > 0) {
|
||||||
switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_INFO, "%s END_PRESENCE_SQL (%s)\n",
|
switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_INFO, "%s END_PRESENCE_SQL (%s)\n",
|
||||||
event->event_id == SWITCH_EVENT_PRESENCE_IN ? "IN" : "OUT", profile->name);
|
event->event_id == SWITCH_EVENT_PRESENCE_IN ? "IN" : "OUT", profile->name);
|
||||||
|
@ -2883,14 +2930,14 @@ static int sync_sla(sofia_profile_t *profile, const char *to_user, const char *t
|
||||||
if (unseize) {
|
if (unseize) {
|
||||||
sql = switch_mprintf("select call_id,expires,sub_to_user,sub_to_host,event,full_to,full_from,contact,expires,network_ip,network_port "
|
sql = switch_mprintf("select call_id,expires,sub_to_user,sub_to_host,event,full_to,full_from,contact,expires,network_ip,network_port "
|
||||||
"from sip_subscriptions "
|
"from sip_subscriptions "
|
||||||
"where version > -1 and expires > -1 and hostname='%q' "
|
"where 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 (profile_name='%q' or presence_hosts like '%%%q%%')",
|
"and (event='call-info' or event='line-seize') and (profile_name='%q' or presence_hosts like '%%%q%%')",
|
||||||
mod_sofia_globals.hostname, to_user, to_host, profile->name, to_host);
|
mod_sofia_globals.hostname, to_user, to_host, profile->name, to_host);
|
||||||
} else {
|
} else {
|
||||||
sql = switch_mprintf("select call_id,expires,sub_to_user,sub_to_host,event,full_to,full_from,contact,expires,network_ip,network_port "
|
sql = switch_mprintf("select call_id,expires,sub_to_user,sub_to_host,event,full_to,full_from,contact,expires,network_ip,network_port "
|
||||||
"from sip_subscriptions "
|
"from sip_subscriptions "
|
||||||
"where version > -1 and expires > -1 and hostname='%q' "
|
"where hostname='%q' "
|
||||||
"and sub_to_user='%q' and sub_to_host='%q' " "and (event='call-info') and "
|
"and sub_to_user='%q' and sub_to_host='%q' " "and (event='call-info') and "
|
||||||
"(profile_name='%q' or presence_hosts like '%%%q%%')",
|
"(profile_name='%q' or presence_hosts like '%%%q%%')",
|
||||||
mod_sofia_globals.hostname, to_user, to_host, profile->name, to_host);
|
mod_sofia_globals.hostname, to_user, to_host, profile->name, to_host);
|
||||||
|
@ -3090,7 +3137,7 @@ void sofia_presence_handle_sip_i_subscribe(int status,
|
||||||
sstr = switch_mprintf("active;expires=%ld", exp_delta);
|
sstr = switch_mprintf("active;expires=%ld", exp_delta);
|
||||||
|
|
||||||
sql = switch_mprintf("update sip_subscriptions "
|
sql = switch_mprintf("update sip_subscriptions "
|
||||||
"set version=0,expires=%ld,contact='%q' "
|
"set expires=%ld,contact='%q' "
|
||||||
"where call_id='%q'",
|
"where call_id='%q'",
|
||||||
(long) switch_epoch_time_now(NULL) + exp_delta, contact_str,
|
(long) switch_epoch_time_now(NULL) + exp_delta, contact_str,
|
||||||
call_id);
|
call_id);
|
||||||
|
@ -3131,8 +3178,8 @@ void sofia_presence_handle_sip_i_subscribe(int status,
|
||||||
|
|
||||||
sql = switch_mprintf("insert into sip_subscriptions "
|
sql = switch_mprintf("insert into sip_subscriptions "
|
||||||
"(proto,sip_user,sip_host,sub_to_user,sub_to_host,presence_hosts,event,contact,call_id,full_from,"
|
"(proto,sip_user,sip_host,sub_to_user,sub_to_host,presence_hosts,event,contact,call_id,full_from,"
|
||||||
"full_via,expires,user_agent,accept,profile_name,hostname,network_port,network_ip, orig_proto, full_to) "
|
"full_via,expires,user_agent,accept,profile_name,hostname,network_port,network_ip,version,orig_proto, full_to) "
|
||||||
"values ('%q','%q','%q','%q','%q','%q','%q','%q','%q','%q','%q',%ld,'%q','%q','%q','%q','%d','%q','%q','%q;tag=%q')",
|
"values ('%q','%q','%q','%q','%q','%q','%q','%q','%q','%q','%q',%ld,'%q','%q','%q','%q','%d','%q',-1,'%q','%q;tag=%q')",
|
||||||
proto, from_user, from_host, to_user, to_host, profile->presence_hosts ? profile->presence_hosts : "",
|
proto, from_user, from_host, to_user, to_host, profile->presence_hosts ? profile->presence_hosts : "",
|
||||||
event, contact_str, call_id, full_from, full_via,
|
event, contact_str, call_id, full_from, full_via,
|
||||||
(long) switch_epoch_time_now(NULL) + exp_delta,
|
(long) switch_epoch_time_now(NULL) + exp_delta,
|
||||||
|
@ -3314,8 +3361,8 @@ void sofia_presence_handle_sip_i_subscribe(int status,
|
||||||
if (!strcasecmp(event, "message-summary")) {
|
if (!strcasecmp(event, "message-summary")) {
|
||||||
if ((sql = switch_mprintf("select proto,sip_user,'%q',sub_to_user,sub_to_host,event,contact,call_id,full_from,"
|
if ((sql = switch_mprintf("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 version > -1 and "
|
" from sip_subscriptions where "
|
||||||
"expires > -1 and event='message-summary' and sip_user='%q' "
|
"event='message-summary' and sip_user='%q' "
|
||||||
"and (sip_host='%q' or presence_hosts like '%%%q%%')", to_host, to_user, to_host, to_host))) {
|
"and (sip_host='%q' or presence_hosts like '%%%q%%')", 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);
|
||||||
|
|
||||||
|
@ -3617,15 +3664,6 @@ void sofia_presence_handle_sip_i_publish(nua_t *nua, sofia_profile_t *profile, n
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!(open = !strcasecmp(open_closed, "open"))) {
|
|
||||||
sql = switch_mprintf("update sip_subscriptions set version = -1 where contact='%q'", contact_str);
|
|
||||||
} else {
|
|
||||||
sql = switch_mprintf("update sip_subscriptions set version = 0 where contact='%q'", contact_str);
|
|
||||||
}
|
|
||||||
|
|
||||||
sofia_glue_execute_sql_now(profile, &sql, SWITCH_TRUE);
|
|
||||||
|
|
||||||
|
|
||||||
if (sofia_test_pflag(profile, PFLAG_MULTIREG) && !open) {
|
if (sofia_test_pflag(profile, PFLAG_MULTIREG) && !open) {
|
||||||
count = sofia_reg_reg_count(profile, from_user, from_host);
|
count = sofia_reg_reg_count(profile, from_user, from_host);
|
||||||
}
|
}
|
||||||
|
@ -3897,17 +3935,23 @@ void sofia_presence_check_subscriptions(sofia_profile_t *profile, time_t now)
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
sql = switch_mprintf("update sip_subscriptions set version=version+1 where "
|
||||||
|
"((expires > 0 and expires <= %ld)) and profile_name='%q' and hostname='%q'",
|
||||||
|
(long) now, profile->name, mod_sofia_globals.hostname);
|
||||||
|
|
||||||
|
sofia_glue_execute_sql_now(profile, &sql, SWITCH_TRUE);
|
||||||
|
switch_safe_free(sql);
|
||||||
|
|
||||||
sql = switch_mprintf("select full_to, full_from, contact, -1, call_id, event, network_ip, network_port, "
|
sql = switch_mprintf("select full_to, full_from, contact, -1, call_id, event, network_ip, network_port, "
|
||||||
"NULL as ct, NULL as pt "
|
"NULL as ct, NULL as pt "
|
||||||
" from sip_subscriptions where (expires = -1 or (expires > 0 and expires <= %ld)) and profile_name='%q' and hostname='%q'",
|
" from sip_subscriptions where ((expires > 0 and expires <= %ld)) and profile_name='%q' and hostname='%q'",
|
||||||
(long) now, profile->name, mod_sofia_globals.hostname);
|
(long) now, profile->name, mod_sofia_globals.hostname);
|
||||||
|
|
||||||
sofia_glue_execute_sql_callback(profile, profile->ireg_mutex, sql, sofia_presence_send_sql, &cb);
|
sofia_glue_execute_sql_callback(profile, profile->ireg_mutex, sql, sofia_presence_send_sql, &cb);
|
||||||
switch_safe_free(sql);
|
switch_safe_free(sql);
|
||||||
|
|
||||||
if (cb.ttl) {
|
if (cb.ttl) {
|
||||||
sql = switch_mprintf("delete from sip_subscriptions where (expires = -1 or (expires > 0 and expires <= %ld)) "
|
sql = switch_mprintf("delete from sip_subscriptions where ((expires > 0 and expires <= %ld)) "
|
||||||
"and profile_name='%q' and hostname='%q'",
|
"and profile_name='%q' and hostname='%q'",
|
||||||
(long) now, profile->name, mod_sofia_globals.hostname);
|
(long) now, profile->name, mod_sofia_globals.hostname);
|
||||||
|
|
||||||
|
@ -3917,6 +3961,7 @@ void sofia_presence_check_subscriptions(sofia_profile_t *profile, time_t now)
|
||||||
}
|
}
|
||||||
|
|
||||||
sofia_glue_actually_execute_sql(profile, sql, profile->ireg_mutex);
|
sofia_glue_actually_execute_sql(profile, sql, profile->ireg_mutex);
|
||||||
|
switch_safe_free(sql);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -480,10 +480,15 @@ SWITCH_DECLARE(switch_odbc_status_t) switch_odbc_handle_exec(switch_odbc_handle_
|
||||||
|
|
||||||
error:
|
error:
|
||||||
|
|
||||||
|
|
||||||
if (stmt) {
|
if (stmt) {
|
||||||
err_str = switch_odbc_handle_get_error(handle, stmt);
|
err_str = switch_odbc_handle_get_error(handle, stmt);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (zstr(err_str)) {
|
||||||
|
err_str = strdup((char *)"SQL ERROR!");
|
||||||
|
}
|
||||||
|
|
||||||
if (err_str) {
|
if (err_str) {
|
||||||
if (!switch_stristr("already exists", err_str) && !switch_stristr("duplicate key name", err_str)) {
|
if (!switch_stristr("already exists", err_str) && !switch_stristr("duplicate key name", err_str)) {
|
||||||
switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_ERROR, "ERR: [%s]\n[%s]\n", sql, switch_str_nil(err_str));
|
switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_ERROR, "ERR: [%s]\n[%s]\n", sql, switch_str_nil(err_str));
|
||||||
|
@ -513,7 +518,7 @@ SWITCH_DECLARE(switch_odbc_status_t) switch_odbc_handle_callback_exec_detailed(c
|
||||||
SQLHSTMT stmt = NULL;
|
SQLHSTMT stmt = NULL;
|
||||||
SQLSMALLINT c = 0, x = 0;
|
SQLSMALLINT c = 0, x = 0;
|
||||||
SQLLEN m = 0;
|
SQLLEN m = 0;
|
||||||
char *err_str = NULL;
|
char *x_err = NULL, *err_str = NULL;
|
||||||
int result;
|
int result;
|
||||||
int err_cnt = 0;
|
int err_cnt = 0;
|
||||||
int done = 0;
|
int done = 0;
|
||||||
|
@ -523,22 +528,24 @@ SWITCH_DECLARE(switch_odbc_status_t) switch_odbc_handle_callback_exec_detailed(c
|
||||||
switch_assert(callback != NULL);
|
switch_assert(callback != NULL);
|
||||||
|
|
||||||
if (!db_is_up(handle)) {
|
if (!db_is_up(handle)) {
|
||||||
|
x_err = "DB is not up!";
|
||||||
goto error;
|
goto error;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (SQLAllocHandle(SQL_HANDLE_STMT, handle->con, &stmt) != SQL_SUCCESS) {
|
if (SQLAllocHandle(SQL_HANDLE_STMT, handle->con, &stmt) != SQL_SUCCESS) {
|
||||||
err_str = strdup("Unable to SQL allocate handle.");
|
x_err = "Unable to SQL allocate handle!";
|
||||||
goto error;
|
goto error;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (SQLPrepare(stmt, (unsigned char *) sql, SQL_NTS) != SQL_SUCCESS) {
|
if (SQLPrepare(stmt, (unsigned char *) sql, SQL_NTS) != SQL_SUCCESS) {
|
||||||
err_str = strdup("Unable to prepare SQL statement.");
|
x_err = "Unable to prepare SQL statement!";
|
||||||
goto error;
|
goto error;
|
||||||
}
|
}
|
||||||
|
|
||||||
result = SQLExecute(stmt);
|
result = SQLExecute(stmt);
|
||||||
|
|
||||||
if (result != SQL_SUCCESS && result != SQL_SUCCESS_WITH_INFO && result != SQL_NO_DATA) {
|
if (result != SQL_SUCCESS && result != SQL_SUCCESS_WITH_INFO && result != SQL_NO_DATA) {
|
||||||
|
x_err = "execute error!";
|
||||||
goto error;
|
goto error;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -598,10 +605,8 @@ SWITCH_DECLARE(switch_odbc_status_t) switch_odbc_handle_callback_exec_detailed(c
|
||||||
free(vals);
|
free(vals);
|
||||||
}
|
}
|
||||||
|
|
||||||
SQLFreeHandle(SQL_HANDLE_STMT, stmt);
|
|
||||||
stmt = NULL; /* Make sure we don't try to free this handle again */
|
|
||||||
|
|
||||||
if (!err_cnt) {
|
if (!err_cnt) {
|
||||||
|
SQLFreeHandle(SQL_HANDLE_STMT, stmt);
|
||||||
return SWITCH_ODBC_SUCCESS;
|
return SWITCH_ODBC_SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -609,7 +614,10 @@ SWITCH_DECLARE(switch_odbc_status_t) switch_odbc_handle_callback_exec_detailed(c
|
||||||
|
|
||||||
if (stmt) {
|
if (stmt) {
|
||||||
err_str = switch_odbc_handle_get_error(handle, stmt);
|
err_str = switch_odbc_handle_get_error(handle, stmt);
|
||||||
SQLFreeHandle(SQL_HANDLE_STMT, stmt);
|
}
|
||||||
|
|
||||||
|
if (zstr(err_str) && !zstr(x_err)) {
|
||||||
|
err_str = strdup(x_err);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (err_str) {
|
if (err_str) {
|
||||||
|
@ -621,6 +629,11 @@ SWITCH_DECLARE(switch_odbc_status_t) switch_odbc_handle_callback_exec_detailed(c
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (stmt) {
|
||||||
|
SQLFreeHandle(SQL_HANDLE_STMT, stmt);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
return SWITCH_ODBC_FAIL;
|
return SWITCH_ODBC_FAIL;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue