]> git.ipfire.org Git - thirdparty/freeswitch.git/commitdiff
handle state update for hangup
authorMichael Jerris <mike@jerris.com>
Tue, 30 Oct 2012 23:02:10 +0000 (19:02 -0400)
committerMichael Jerris <mike@jerris.com>
Tue, 30 Oct 2012 23:02:33 +0000 (19:02 -0400)
src/include/switch_ivr.h
src/switch_core_sqldb.c
src/switch_ivr.c

index 9299c584d9e96da441283f7524473712eb605169..06679f53d317e686db0cff04de7c8117bd113cf2 100644 (file)
@@ -927,6 +927,7 @@ SWITCH_DECLARE(switch_status_t) switch_ivr_set_user(switch_core_session_t *sessi
 SWITCH_DECLARE(switch_status_t) switch_ivr_sound_test(switch_core_session_t *session);
 SWITCH_DECLARE(void) switch_process_import(switch_core_session_t *session, switch_channel_t *peer_channel, const char *varname, const char *prefix);
 SWITCH_DECLARE(switch_bool_t) switch_ivr_uuid_exists(const char *uuid);
+SWITCH_DECLARE(switch_bool_t) switch_ivr_uuid_force_exists(const char *uuid);
 
 
 
index 3d8b43564ef3a74e17c1148d65dbb03c8dd66886..e0c60ee584627c5c495a31fad6b5182333b360df 100644 (file)
@@ -1755,7 +1755,8 @@ static char *parse_presence_data_cols(switch_event_t *event)
 
 
 #define MAX_SQL 5
-#define new_sql() switch_assert(sql_idx+1 < MAX_SQL); if (exists) sql[sql_idx++]
+#define new_sql()   switch_assert(sql_idx+1 < MAX_SQL); if (exists) sql[sql_idx++]
+#define new_sql_f() switch_assert(sql_idx+1 < MAX_SQL); if (force_exists) sql[sql_idx++]
 
 static void core_event_handler(switch_event_t *event)
 {
@@ -1763,6 +1764,7 @@ static void core_event_handler(switch_event_t *event)
        int sql_idx = 0;
        char *extra_cols;
        int exists = 1;
+       int force_exists = 1;
        char *uuid = NULL;
 
        switch_assert(event);
@@ -1784,7 +1786,10 @@ static void core_event_handler(switch_event_t *event)
        case SWITCH_EVENT_CALL_SECURE:
                {
                        if ((uuid = switch_event_get_header(event, "unique-id"))) {
-                               exists = switch_ivr_uuid_exists(uuid);
+                               force_exists = exists = switch_ivr_uuid_exists(uuid);
+                               if (!exists) {
+                                       force_exists = switch_ivr_uuid_force_exists(uuid);
+                               }
                        }
                }
                break;
@@ -2033,7 +2038,7 @@ static void core_event_handler(switch_event_t *event)
                                }
                                break;
                        default:
-                               new_sql() = switch_mprintf("update channels set state='%s' where uuid='%s'",
+                               new_sql_f() = switch_mprintf("update channels set state='%s' where uuid='%s'",
                                                                                   switch_event_get_header_nil(event, "channel-state"),
                                                                                   switch_event_get_header_nil(event, "unique-id"));
                                break;
index df5af6239187eaddd9fb2eadbf52b2bb69489b9f..eb8d4ab9e6f8f6e07c6a87020287901149d95988 100644 (file)
@@ -3209,6 +3209,19 @@ SWITCH_DECLARE(switch_bool_t) switch_ivr_uuid_exists(const char *uuid)
        return exists;
 }
 
+SWITCH_DECLARE(switch_bool_t) switch_ivr_uuid_force_exists(const char *uuid)
+{
+       switch_bool_t exists = SWITCH_FALSE;
+       switch_core_session_t *psession = NULL;
+
+       if ((psession = switch_core_session_force_locate(uuid))) {
+               switch_core_session_rwunlock(psession);
+               exists = 1;
+       }
+
+       return exists;
+}
+
 SWITCH_DECLARE(switch_status_t) switch_ivr_process_fh(switch_core_session_t *session, const char *cmd, switch_file_handle_t *fhp)
 {
     if (zstr(cmd)) {