mirror of
https://github.com/signalwire/freeswitch.git
synced 2025-08-13 17:38:59 +00:00
execute hangup state asap
git-svn-id: http://svn.freeswitch.org/svn/freeswitch/trunk@14852 d0543943-73ff-0310-b7d9-9358b9ac24b2
This commit is contained in:
@@ -413,69 +413,7 @@ SWITCH_DECLARE(void) switch_core_session_run(switch_core_session_t *session)
|
||||
goto done;
|
||||
case CS_HANGUP: /* Deactivate and end the thread */
|
||||
{
|
||||
const char *hook_var;
|
||||
switch_core_session_t *use_session = NULL;
|
||||
switch_call_cause_t cause = switch_channel_get_cause(session->channel);
|
||||
switch_call_cause_t cause_q850 = switch_channel_get_cause_q850(session->channel);
|
||||
switch_event_t *event;
|
||||
|
||||
switch_channel_set_hangup_time(session->channel);
|
||||
|
||||
switch_core_media_bug_remove_all(session);
|
||||
|
||||
switch_channel_stop_broadcast(session->channel);
|
||||
|
||||
switch_channel_set_variable(session->channel, "hangup_cause", switch_channel_cause2str(cause));
|
||||
switch_channel_set_variable_printf(session->channel, "hangup_cause_q850", "%d", cause_q850);
|
||||
switch_channel_presence(session->channel, "unknown", switch_channel_cause2str(cause), NULL);
|
||||
|
||||
switch_channel_set_timestamps(session->channel);
|
||||
|
||||
STATE_MACRO(hangup, "HANGUP");
|
||||
|
||||
hook_var = switch_channel_get_variable(session->channel, SWITCH_API_HANGUP_HOOK_VARIABLE);
|
||||
if (switch_true(switch_channel_get_variable(session->channel, SWITCH_SESSION_IN_HANGUP_HOOK_VARIABLE))) {
|
||||
use_session = session;
|
||||
}
|
||||
|
||||
if (!switch_strlen_zero(hook_var)) {
|
||||
switch_stream_handle_t stream = { 0 };
|
||||
char *cmd = switch_core_session_strdup(session, hook_var);
|
||||
char *arg = NULL;
|
||||
char *expanded = NULL;
|
||||
|
||||
if ((arg = strchr(cmd, ':')) && *(arg+1) == ':') {
|
||||
*arg++ = '\0';
|
||||
*arg++ = '\0';
|
||||
} else {
|
||||
if ((arg = strchr(cmd, ' '))) {
|
||||
*arg++ = '\0';
|
||||
}
|
||||
}
|
||||
|
||||
SWITCH_STANDARD_STREAM(stream);
|
||||
|
||||
switch_channel_get_variables(session->channel, &stream.param_event);
|
||||
switch_channel_event_set_data(session->channel, stream.param_event);
|
||||
expanded = switch_channel_expand_variables(session->channel, arg);
|
||||
|
||||
switch_api_execute(cmd, expanded, use_session, &stream);
|
||||
|
||||
switch_log_printf(SWITCH_CHANNEL_SESSION_LOG(session), SWITCH_LOG_DEBUG, "Hangup Command %s(%s):\n%s\n", cmd, switch_str_nil(expanded),
|
||||
switch_str_nil((char *) stream.data));
|
||||
|
||||
if (expanded != arg) {
|
||||
switch_safe_free(expanded);
|
||||
}
|
||||
switch_safe_free(stream.data);
|
||||
}
|
||||
|
||||
if (switch_event_create(&event, SWITCH_EVENT_CHANNEL_HANGUP_COMPLETE) == SWITCH_STATUS_SUCCESS) {
|
||||
switch_event_add_header_string(event, SWITCH_STACK_BOTTOM, "Hangup-Cause", switch_channel_cause2str(cause));
|
||||
switch_channel_event_set_data(session->channel, event);
|
||||
switch_event_fire(&event);
|
||||
}
|
||||
|
||||
switch_core_session_hangup_state(session);
|
||||
switch_channel_set_state(session->channel, CS_REPORTING);
|
||||
}
|
||||
|
||||
@@ -557,6 +495,8 @@ SWITCH_DECLARE(void) switch_core_session_destroy_state(switch_core_session_t *se
|
||||
|
||||
switch_assert(session != NULL);
|
||||
switch_channel_set_running_state(session->channel, CS_DESTROY);
|
||||
switch_channel_clear_flag(session->channel, CF_TRANSFER);
|
||||
switch_channel_clear_flag(session->channel, CF_REDIRECT);
|
||||
|
||||
session->thread_running = 1;
|
||||
endpoint_interface = session->endpoint_interface;
|
||||
@@ -571,6 +511,101 @@ SWITCH_DECLARE(void) switch_core_session_destroy_state(switch_core_session_t *se
|
||||
}
|
||||
|
||||
|
||||
SWITCH_DECLARE(void) switch_core_session_hangup_state(switch_core_session_t *session)
|
||||
{
|
||||
const char *hook_var;
|
||||
switch_core_session_t *use_session = NULL;
|
||||
switch_call_cause_t cause = switch_channel_get_cause(session->channel);
|
||||
switch_call_cause_t cause_q850 = switch_channel_get_cause_q850(session->channel);
|
||||
switch_event_t *event;
|
||||
int proceed = 1;
|
||||
int global_proceed = 1;
|
||||
int do_extra_handlers = 1;
|
||||
int silly = 0;
|
||||
int index = 0;
|
||||
switch_channel_state_t state = switch_channel_get_state(session->channel), midstate = state;
|
||||
const switch_endpoint_interface_t *endpoint_interface;
|
||||
const switch_state_handler_table_t *driver_state_handler = NULL;
|
||||
const switch_state_handler_table_t *application_state_handler = NULL;
|
||||
|
||||
|
||||
if (switch_thread_self() != session->thread_id) {
|
||||
switch_log_printf(SWITCH_CHANNEL_SESSION_LOG(session), SWITCH_LOG_DEBUG, "thread mismatch skipping state handler.\n");
|
||||
return;
|
||||
}
|
||||
|
||||
if (switch_test_flag(session, SSF_HANGUP)) {
|
||||
switch_log_printf(SWITCH_CHANNEL_SESSION_LOG(session), SWITCH_LOG_DEBUG, "handler already called, skipping state handler.\n");
|
||||
return;
|
||||
}
|
||||
|
||||
endpoint_interface = session->endpoint_interface;
|
||||
switch_assert(endpoint_interface != NULL);
|
||||
|
||||
driver_state_handler = endpoint_interface->state_handler;
|
||||
switch_assert(driver_state_handler != NULL);
|
||||
|
||||
switch_channel_set_hangup_time(session->channel);
|
||||
|
||||
switch_core_media_bug_remove_all(session);
|
||||
|
||||
switch_channel_stop_broadcast(session->channel);
|
||||
|
||||
switch_channel_set_variable(session->channel, "hangup_cause", switch_channel_cause2str(cause));
|
||||
switch_channel_set_variable_printf(session->channel, "hangup_cause_q850", "%d", cause_q850);
|
||||
switch_channel_presence(session->channel, "unknown", switch_channel_cause2str(cause), NULL);
|
||||
|
||||
switch_channel_set_timestamps(session->channel);
|
||||
|
||||
STATE_MACRO(hangup, "HANGUP");
|
||||
|
||||
hook_var = switch_channel_get_variable(session->channel, SWITCH_API_HANGUP_HOOK_VARIABLE);
|
||||
if (switch_true(switch_channel_get_variable(session->channel, SWITCH_SESSION_IN_HANGUP_HOOK_VARIABLE))) {
|
||||
use_session = session;
|
||||
}
|
||||
|
||||
if (!switch_strlen_zero(hook_var)) {
|
||||
switch_stream_handle_t stream = { 0 };
|
||||
char *cmd = switch_core_session_strdup(session, hook_var);
|
||||
char *arg = NULL;
|
||||
char *expanded = NULL;
|
||||
|
||||
if ((arg = strchr(cmd, ':')) && *(arg+1) == ':') {
|
||||
*arg++ = '\0';
|
||||
*arg++ = '\0';
|
||||
} else {
|
||||
if ((arg = strchr(cmd, ' '))) {
|
||||
*arg++ = '\0';
|
||||
}
|
||||
}
|
||||
|
||||
SWITCH_STANDARD_STREAM(stream);
|
||||
|
||||
switch_channel_get_variables(session->channel, &stream.param_event);
|
||||
switch_channel_event_set_data(session->channel, stream.param_event);
|
||||
expanded = switch_channel_expand_variables(session->channel, arg);
|
||||
|
||||
switch_api_execute(cmd, expanded, use_session, &stream);
|
||||
|
||||
switch_log_printf(SWITCH_CHANNEL_SESSION_LOG(session), SWITCH_LOG_DEBUG, "Hangup Command %s(%s):\n%s\n", cmd, switch_str_nil(expanded),
|
||||
switch_str_nil((char *) stream.data));
|
||||
|
||||
if (expanded != arg) {
|
||||
switch_safe_free(expanded);
|
||||
}
|
||||
switch_safe_free(stream.data);
|
||||
}
|
||||
|
||||
if (switch_event_create(&event, SWITCH_EVENT_CHANNEL_HANGUP_COMPLETE) == SWITCH_STATUS_SUCCESS) {
|
||||
switch_event_add_header_string(event, SWITCH_STACK_BOTTOM, "Hangup-Cause", switch_channel_cause2str(cause));
|
||||
switch_channel_event_set_data(session->channel, event);
|
||||
switch_event_fire(&event);
|
||||
}
|
||||
|
||||
switch_set_flag(session, SSF_HANGUP);
|
||||
|
||||
}
|
||||
|
||||
SWITCH_DECLARE(void) switch_core_session_reporting_state(switch_core_session_t *session)
|
||||
{
|
||||
switch_channel_state_t state = switch_channel_get_state(session->channel), midstate = state;
|
||||
|
Reference in New Issue
Block a user