]> git.ipfire.org Git - thirdparty/freeswitch.git/commitdiff
FS-4676 --resolve
authorAnthony Minessale <anthm@freeswitch.org>
Tue, 9 Oct 2012 18:50:11 +0000 (13:50 -0500)
committerAnthony Minessale <anthm@freeswitch.org>
Tue, 9 Oct 2012 18:50:11 +0000 (13:50 -0500)
src/mod/endpoints/mod_sofia/sofia_presence.c
src/switch_channel.c
src/switch_core_state_machine.c

index eea01d50a56255696217ed34aaf224509e0daf32..f03584f1c34fb136fd4d371f49dd7a16d6bdd38c 100644 (file)
@@ -4185,7 +4185,7 @@ void sofia_presence_handle_sip_i_publish(nua_t *nua, sofia_profile_t *profile, n
                                                rpid = act->child->name;
                                        }
                                }
-                               if (zstr(note_txt)) note_txt = rpid;
+                               if (zstr(note_txt)) note_txt = "Available";
                        }
 
                        if (!strcasecmp(open_closed, "closed")) {
index 5606d81fe0af5ada94b4e8a7d8a64518a673918a..6e4c6078224ae773a25a5fa42f9131370f08e808 100644 (file)
@@ -1952,10 +1952,6 @@ SWITCH_DECLARE(switch_channel_state_t) switch_channel_perform_set_running_state(
 
        channel->running_state = state;
 
-       if (state == CS_ROUTING || state == CS_HANGUP) {
-               switch_channel_presence(channel, "unknown", (const char *) state_names[state], NULL);
-       }
-
        if (state <= CS_DESTROY) {
                switch_event_t *event;
 
@@ -2942,11 +2938,6 @@ SWITCH_DECLARE(switch_channel_state_t) switch_channel_perform_hangup(switch_chan
                switch_mutex_unlock(channel->state_mutex);
 
 
-               if (hangup_cause == SWITCH_CAUSE_LOSE_RACE) {
-                       switch_channel_presence(channel, "unknown", "cancelled", NULL);
-                       switch_channel_set_variable(channel, "presence_call_info", NULL);
-               }
-
                switch_channel_set_callstate(channel, CCS_HANGUP);
                channel->hangup_cause = hangup_cause;
                switch_log_printf(SWITCH_CHANNEL_ID_LOG, file, func, line, switch_channel_get_uuid(channel), SWITCH_LOG_NOTICE, "Hangup %s [%s] [%s]\n",
index 0288df11a6596b2fba402eb5806875bd1e8413fc..c89e78fa5ad43cf5a44de68b41d2b4b9cd1a06bd 100644 (file)
@@ -342,6 +342,23 @@ void switch_core_state_machine_init(switch_memory_pool_t *pool)
                switch_log_printf(SWITCH_CHANNEL_SESSION_LOG(session), SWITCH_LOG_DEBUG, "(%s) State %s going to sleep\n", switch_channel_get_name(session->channel), __STATE_STR); \
        } while (silly)
 
+
+static void check_presence(switch_core_session_t *session)
+{
+       switch_channel_state_t state = switch_channel_get_running_state(session->channel);
+
+       if (state == CS_ROUTING || state == CS_HANGUP) {
+               if (switch_channel_get_cause(session->channel) == SWITCH_CAUSE_LOSE_RACE) {
+                       switch_channel_presence(session->channel, "unknown", "cancelled", NULL);
+                       switch_channel_set_variable(session->channel, "presence_call_info", NULL);
+               } else {
+                       switch_channel_presence(session->channel, "unknown", switch_channel_state_name(state), NULL);
+               }
+       }
+}
+
+
+
 SWITCH_DECLARE(void) switch_core_session_run(switch_core_session_t *session)
 {
        switch_channel_state_t state = CS_NEW, midstate = CS_DESTROY, endstate;
@@ -472,6 +489,8 @@ SWITCH_DECLARE(void) switch_core_session_run(switch_core_session_t *session)
                                break;
                        }
 
+                       check_presence(session);
+
                        if (midstate == CS_DESTROY) {
                                break;
                        }