execute sql inline to avoid race

git-svn-id: http://svn.freeswitch.org/svn/freeswitch/trunk@8101 d0543943-73ff-0310-b7d9-9358b9ac24b2
This commit is contained in:
Anthony Minessale 2008-04-14 15:07:43 +00:00
parent 730feae63e
commit d1a95e5aa7
1 changed files with 11 additions and 3 deletions

View File

@ -264,19 +264,27 @@ void sofia_reg_check_expire(sofia_profile_t *profile, time_t now)
} else {
switch_snprintf(sql, sizeof(sql), "delete from sip_registrations where expires > 0");
}
sofia_glue_execute_sql(profile, &psql, SWITCH_FALSE);
sofia_glue_actually_execute_sql(profile, SWITCH_FALSE, psql, NULL);
switch_safe_free(psql);
if (now) {
switch_snprintf(sql, sizeof(sql), "delete from sip_authentication where expires > 0 and expires <= %ld", (long) now);
} else {
switch_snprintf(sql, sizeof(sql), "delete from sip_authentication where expires > 0");
}
sofia_glue_execute_sql(profile, &psql, SWITCH_FALSE);
sofia_glue_actually_execute_sql(profile, SWITCH_FALSE, psql, NULL);
switch_safe_free(psql);
if (now) {
switch_snprintf(sql, sizeof(sql), "delete from sip_subscriptions where expires > 0 and expires <= %ld", (long) now);
} else {
switch_snprintf(sql, sizeof(sql), "delete from sip_subscriptions where expires > 0");
}
sofia_glue_execute_sql(profile, &psql, SWITCH_FALSE);
sofia_glue_actually_execute_sql(profile, SWITCH_FALSE, psql, NULL);
switch_safe_free(psql);
if (now) {
switch_snprintf(sql, sizeof(sql), "select * from sip_registrations where status like '%%NATHACK%%'");