From f0e7a5ea1cd8763589cea7fbb460675e904951f0 Mon Sep 17 00:00:00 2001 From: Anthony Minessale Date: Mon, 14 Jan 2008 15:37:00 +0000 Subject: [PATCH] add process_cdr variable git-svn-id: http://svn.freeswitch.org/svn/freeswitch/trunk@7212 d0543943-73ff-0310-b7d9-9358b9ac24b2 --- src/switch_core_state_machine.c | 13 ++++++++++--- 1 file changed, 10 insertions(+), 3 deletions(-) diff --git a/src/switch_core_state_machine.c b/src/switch_core_state_machine.c index d2dc1e2665..97f01b5cc0 100644 --- a/src/switch_core_state_machine.c +++ b/src/switch_core_state_machine.c @@ -420,10 +420,17 @@ SWITCH_DECLARE(void) switch_core_session_run(switch_core_session_t *session) goto done; case CS_HANGUP: /* Deactivate and end the thread */ { - const char *var = NULL; + const char *var = switch_channel_get_variable(session->channel, SWITCH_PROCESS_CDR_VARIABLE); - if (!(var = switch_channel_get_variable(session->channel, SWITCH_PROCESS_CDR_VARIABLE)) || !switch_true(var)) { - do_extra_handlers = 0; + if (!switch_strlen_zero(var)) { + + if (!strcasecmp(var, "a_only") && !switch_channel_test_flag(session->channel, CF_ORIGINATOR)) { + do_extra_handlers = 0; + } else if (!strcasecmp(var, "b_only") && switch_channel_test_flag(session->channel, CF_ORIGINATOR)) { + do_extra_handlers = 0; + } else if (!switch_true(var)) { + do_extra_handlers = 0; + } } STATE_MACRO(hangup, "HANGUP");