From 98a4b3e8123d2c86318a14141048d1b296460589 Mon Sep 17 00:00:00 2001 From: Brian West Date: Mon, 26 Apr 2010 09:57:02 -0500 Subject: [PATCH 1/6] update ignore --- .gitignore | 5 +++++ 1 file changed, 5 insertions(+) diff --git a/.gitignore b/.gitignore index 3b82069a68..b15e1de988 100644 --- a/.gitignore +++ b/.gitignore @@ -87,3 +87,8 @@ src/mod/say/mod_say_nl/Makefile src/mod/say/mod_say_th/Makefile src/mod/say/mod_say_zh/Makefile libs/curl/lib/ca-bundle.h +libs/g729/ +src/mod/codecs/mod_com_g729/ +src/mod/languages/mod_lua/mod_lua_wrap.cpp.orig +src/mod/languages/mod_perl/mod_perl_wrap.cpp.orig +src/mod/languages/mod_python/mod_python_wrap.cpp.orig From 405c966a4fb214edc0d2f2ba62dd238466551241 Mon Sep 17 00:00:00 2001 From: Brian West Date: Tue, 27 Apr 2010 13:56:37 -0500 Subject: [PATCH 2/6] evil nat scenarios --- src/mod/endpoints/mod_sofia/sofia_presence.c | 5 +++++ src/mod/endpoints/mod_sofia/sofia_reg.c | 5 +++++ 2 files changed, 10 insertions(+) diff --git a/src/mod/endpoints/mod_sofia/sofia_presence.c b/src/mod/endpoints/mod_sofia/sofia_presence.c index 2a9296bb6b..d84d764efb 100644 --- a/src/mod/endpoints/mod_sofia/sofia_presence.c +++ b/src/mod/endpoints/mod_sofia/sofia_presence.c @@ -1751,6 +1751,11 @@ void sofia_presence_handle_sip_i_subscribe(int status, } } + if (!is_nat && sip && sip->sip_via && sip->sip_via->v_port && + atoi(sip->sip_via->v_port) == 5060 && network_port != 5060 ) { + is_nat = "via port"; + } + if (!is_nat && profile->nat_acl_count) { uint32_t x = 0; int ok = 1; diff --git a/src/mod/endpoints/mod_sofia/sofia_reg.c b/src/mod/endpoints/mod_sofia/sofia_reg.c index d9c60aa5a6..1f07b944ef 100644 --- a/src/mod/endpoints/mod_sofia/sofia_reg.c +++ b/src/mod/endpoints/mod_sofia/sofia_reg.c @@ -1364,6 +1364,11 @@ void sofia_reg_handle_sip_i_register(nua_t *nua, sofia_profile_t *profile, nua_h } } + if (!is_nat && sip && sip->sip_via && sip->sip_via->v_port && + atoi(sip->sip_via->v_port) == 5060 && network_port != 5060 ) { + is_nat = "via port"; + } + if (!is_nat && profile->nat_acl_count) { uint32_t x = 0; int ok = 1; From 35b9439b8a5556d4513370c2551dec0cd63cf191 Mon Sep 17 00:00:00 2001 From: Anthony Minessale Date: Tue, 27 Apr 2010 14:22:23 -0500 Subject: [PATCH 3/6] replace don't bridge when parsing replaces header on invite --- src/mod/endpoints/mod_sofia/sofia.c | 16 +++++++++++++++- 1 file changed, 15 insertions(+), 1 deletion(-) diff --git a/src/mod/endpoints/mod_sofia/sofia.c b/src/mod/endpoints/mod_sofia/sofia.c index 3d0dc95f21..83b800a90b 100644 --- a/src/mod/endpoints/mod_sofia/sofia.c +++ b/src/mod/endpoints/mod_sofia/sofia.c @@ -6433,12 +6433,18 @@ void sofia_handle_sip_i_invite(nua_t *nua, sofia_profile_t *profile, nua_handle_ if (uuid) { switch_core_session_t *c_session = NULL; int do_conf = 0; + const char *c_app = NULL; + const char *c_data = NULL; + uuid = switch_core_session_strdup(b_session, uuid); if ((c_session = switch_core_session_locate(uuid))) { switch_channel_t *c_channel = switch_core_session_get_channel(c_session); private_object_t *c_tech_pvt = NULL; + c_app = switch_channel_get_variable(c_channel, SWITCH_CURRENT_APPLICATION_VARIABLE); + c_data = switch_channel_get_variable(c_channel, SWITCH_CURRENT_APPLICATION_DATA_VARIABLE); + if (switch_core_session_check_interface(c_session, sofia_endpoint_interface)) { c_tech_pvt = switch_core_session_get_private(c_session); } @@ -6461,7 +6467,15 @@ void sofia_handle_sip_i_invite(nua_t *nua, sofia_profile_t *profile, nua_handle_ if (do_conf) { destination_number = switch_core_session_sprintf(b_session, "answer,conference:%s@sla+flags{mintwo}", uuid); } else { - destination_number = switch_core_session_sprintf(b_session, "answer,intercept:%s", uuid); + if (one_leg && c_app) { + if (c_data) { + destination_number = switch_core_session_sprintf(b_session, "answer,%s:%s", c_app, c_data); + } else { + destination_number = switch_core_session_sprintf(b_session, "answer,%s", c_app); + } + } else { + destination_number = switch_core_session_sprintf(b_session, "answer,intercept:%s", uuid); + } } dialplan = "inline"; From 8660b6f9c1789c5efada8de126ba8e9925b021c1 Mon Sep 17 00:00:00 2001 From: Anthony Minessale Date: Tue, 27 Apr 2010 14:26:55 -0500 Subject: [PATCH 4/6] replace don't bridge when parsing replaces header on invite (also hangup) --- src/mod/endpoints/mod_sofia/sofia.c | 6 ++++++ 1 file changed, 6 insertions(+) diff --git a/src/mod/endpoints/mod_sofia/sofia.c b/src/mod/endpoints/mod_sofia/sofia.c index 83b800a90b..cc203dc1ed 100644 --- a/src/mod/endpoints/mod_sofia/sofia.c +++ b/src/mod/endpoints/mod_sofia/sofia.c @@ -6475,6 +6475,12 @@ void sofia_handle_sip_i_invite(nua_t *nua, sofia_profile_t *profile, nua_handle_ } } else { destination_number = switch_core_session_sprintf(b_session, "answer,intercept:%s", uuid); + if ((c_session = switch_core_session_locate(uuid))) { + switch_channel_t *c_channel = switch_core_session_get_channel(c_session); + + switch_channel_hangup(c_channel, SWITCH_CAUSE_ATTENDED_TRANSFER); + switch_core_session_rwunlock(c_session); + } } } From f818399a7231a102bd42db3bedcadd9e6baaa084 Mon Sep 17 00:00:00 2001 From: cypromis Date: Tue, 27 Apr 2010 22:22:21 +0200 Subject: [PATCH 5/6] Typo in specfile change date --- freeswitch.spec | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/freeswitch.spec b/freeswitch.spec index 3522c8c0d0..37b00dc92a 100644 --- a/freeswitch.spec +++ b/freeswitch.spec @@ -616,7 +616,7 @@ fi %config(noreplace) %attr(0640, freeswitch, daemon) %{prefix}/conf/lang/ru/dir/*.xml %changelog -* Fr Apr 23 2010 - michal.bielicki@seventhsignal.de +* Fri Apr 23 2010 - michal.bielicki@seventhsignal.de - bumped spec file vrersion up to 1.0.7-trunk for trunk - added skinny dialplan stuff to specfile * Sun Mar 28 2010 - michal.bielicki@seventhsignal.de From 19dca2e3e9f5cb9024192e71a9cf1c96d2517c47 Mon Sep 17 00:00:00 2001 From: Anthony Minessale Date: Tue, 27 Apr 2010 16:52:29 -0500 Subject: [PATCH 6/6] add callee id to events and add global param verbose-channel-events and fsctl verbose_events [on|off] to globally configure verbose events --- conf/autoload_configs/switch.conf.xml | 2 + src/include/switch_types.h | 6 +- .../applications/mod_commands/mod_commands.c | 10 +++ src/switch_caller.c | 8 ++ src/switch_channel.c | 6 +- src/switch_core.c | 77 +++++++++++++------ 6 files changed, 82 insertions(+), 27 deletions(-) diff --git a/conf/autoload_configs/switch.conf.xml b/conf/autoload_configs/switch.conf.xml index ff44243303..03bc993372 100644 --- a/conf/autoload_configs/switch.conf.xml +++ b/conf/autoload_configs/switch.conf.xml @@ -72,6 +72,8 @@ + + diff --git a/src/include/switch_types.h b/src/include/switch_types.h index 7e9f6ae42b..a3a9599b62 100644 --- a/src/include/switch_types.h +++ b/src/include/switch_types.h @@ -248,7 +248,8 @@ typedef enum { SCF_EARLY_HANGUP = (1 << 7), SCF_CALIBRATE_CLOCK = (1 << 8), SCF_USE_HEAVY_TIMING = (1 << 9), - SCF_USE_CLOCK_RT = (1 << 10) + SCF_USE_CLOCK_RT = (1 << 10), + SCF_VERBOSE_EVENTS = (1 << 11) } switch_core_flag_enum_t; typedef uint32_t switch_core_flag_t; @@ -1494,7 +1495,8 @@ typedef enum { SCSC_CALIBRATE_CLOCK, SCSC_SAVE_HISTORY, SCSC_CRASH, - SCSC_MIN_IDLE_CPU + SCSC_MIN_IDLE_CPU, + SCSC_VERBOSE_EVENTS } switch_session_ctl_t; typedef enum { diff --git a/src/mod/applications/mod_commands/mod_commands.c b/src/mod/applications/mod_commands/mod_commands.c index 6dc2d8c913..fa8246d44f 100644 --- a/src/mod/applications/mod_commands/mod_commands.c +++ b/src/mod/applications/mod_commands/mod_commands.c @@ -1500,6 +1500,16 @@ SWITCH_STANDARD_API(ctl_function) } else if (!strcasecmp(argv[0], "crash")) { switch_core_session_ctl(SCSC_CRASH, NULL); stream->write_function(stream, "+OK\n"); + } else if (!strcasecmp(argv[0], "verbose_events")) { + arg = -1; + if (argv[1]) { + arg = switch_true(argv[1]); + } + + switch_core_session_ctl(SCSC_VERBOSE_EVENTS, &arg); + + stream->write_function(stream, "+OK verbose_events is %s \n", arg ? "on" : "off"); + } else if (!strcasecmp(argv[0], "save_history")) { switch_core_session_ctl(SCSC_SAVE_HISTORY, NULL); stream->write_function(stream, "+OK\n"); diff --git a/src/switch_caller.c b/src/switch_caller.c index 16c03f7144..b611b09ebd 100644 --- a/src/switch_caller.c +++ b/src/switch_caller.c @@ -271,6 +271,14 @@ SWITCH_DECLARE(void) switch_caller_profile_event_set_data(switch_caller_profile_ switch_snprintf(header_name, sizeof(header_name), "%s-Caller-ID-Number", prefix); switch_event_add_header_string(event, SWITCH_STACK_BOTTOM, header_name, caller_profile->caller_id_number); } + if (!zstr(caller_profile->callee_id_name)) { + switch_snprintf(header_name, sizeof(header_name), "%s-Callee-ID-Name", prefix); + switch_event_add_header_string(event, SWITCH_STACK_BOTTOM, header_name, caller_profile->callee_id_name); + } + if (!zstr(caller_profile->callee_id_number)) { + switch_snprintf(header_name, sizeof(header_name), "%s-Callee-ID-Number", prefix); + switch_event_add_header_string(event, SWITCH_STACK_BOTTOM, header_name, caller_profile->callee_id_number); + } if (!zstr(caller_profile->network_addr)) { switch_snprintf(header_name, sizeof(header_name), "%s-Network-Addr", prefix); switch_event_add_header_string(event, SWITCH_STACK_BOTTOM, header_name, caller_profile->network_addr); diff --git a/src/switch_channel.c b/src/switch_channel.c index e08bc4f63a..b826da45d5 100644 --- a/src/switch_channel.c +++ b/src/switch_channel.c @@ -1677,11 +1677,13 @@ SWITCH_DECLARE(void) switch_channel_event_set_basic_data(switch_channel_t *chann SWITCH_DECLARE(void) switch_channel_event_set_extended_data(switch_channel_t *channel, switch_event_t *event) { switch_event_header_t *hi; - int x; + int x, global_verbos_events = 0; switch_mutex_lock(channel->profile_mutex); - if (switch_channel_test_flag(channel, CF_VERBOSE_EVENTS) || + switch_core_session_ctl(SCSC_VERBOSE_EVENTS, &global_verbos_events); + + if (global_verbos_events || switch_channel_test_flag(channel, CF_VERBOSE_EVENTS) || event->event_id == SWITCH_EVENT_CHANNEL_CREATE || event->event_id == SWITCH_EVENT_CHANNEL_ORIGINATE || event->event_id == SWITCH_EVENT_CHANNEL_UUID || diff --git a/src/switch_core.c b/src/switch_core.c index 78296ebe7b..3dfcdb239f 100644 --- a/src/switch_core.c +++ b/src/switch_core.c @@ -1448,6 +1448,13 @@ static void switch_load_core_config(const char *file) switch_time_set_matrix(switch_true(var)); } else if (!strcasecmp(var, "max-sessions") && !zstr(val)) { switch_core_session_limit(atoi(val)); + } else if (!strcasecmp(var, "verbose-channel-events") && !zstr(val)) { + int v = switch_true(val); + if (v) { + switch_set_flag((&runtime), SCF_VERBOSE_EVENTS); + } else { + switch_clear_flag((&runtime), SCF_VERBOSE_EVENTS); + } } else if (!strcasecmp(var, "min-idle-cpu") && !zstr(val)) { switch_core_min_idle_cpu(atof(val)); } else if (!strcasecmp(var, "tipping-point") && !zstr(val)) { @@ -1639,12 +1646,29 @@ SWITCH_DECLARE(uint32_t) switch_core_debug_level(void) SWITCH_DECLARE(int32_t) switch_core_session_ctl(switch_session_ctl_t cmd, void *val) { int *intval = (int *) val; + int oldintval = 0, newintval = 0; + + if (intval) { + oldintval = *intval; + } if (switch_test_flag((&runtime), SCF_SHUTTING_DOWN)) { return -1; } switch (cmd) { + case SCSC_VERBOSE_EVENTS: + if (intval) { + if (oldintval > -1) { + if (oldintval) { + switch_set_flag((&runtime), SCF_VERBOSE_EVENTS); + } else { + switch_clear_flag((&runtime), SCF_VERBOSE_EVENTS); + } + } + newintval = switch_test_flag((&runtime), SCF_VERBOSE_EVENTS); + } + break; case SCSC_CALIBRATE_CLOCK: switch_time_calibrate_clock(); break; @@ -1656,10 +1680,10 @@ SWITCH_DECLARE(int32_t) switch_core_session_ctl(switch_session_ctl_t cmd, void * break; case SCSC_SYNC_CLOCK: switch_time_sync(); - *intval = 0; + newintval = 0; break; case SCSC_PAUSE_INBOUND: - if (*intval) { + if (oldintval) { switch_set_flag((&runtime), SCF_NO_NEW_SESSIONS); } else { switch_clear_flag((&runtime), SCF_NO_NEW_SESSIONS); @@ -1710,7 +1734,7 @@ SWITCH_DECLARE(int32_t) switch_core_session_ctl(switch_session_ctl_t cmd, void * win_shutdown(); #endif - if (*intval) { + if (oldintval) { switch_set_flag((&runtime), SCF_RESTART); switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_INFO, "Restarting\n"); } else { @@ -1732,7 +1756,7 @@ SWITCH_DECLARE(int32_t) switch_core_session_ctl(switch_session_ctl_t cmd, void * win_shutdown(); #endif - if (*intval) { + if (oldintval) { switch_set_flag((&runtime), SCF_RESTART); switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_INFO, "Restarting\n"); } else { @@ -1744,62 +1768,69 @@ SWITCH_DECLARE(int32_t) switch_core_session_ctl(switch_session_ctl_t cmd, void * runtime.running = 0; break; case SCSC_CHECK_RUNNING: - *intval = runtime.running; + newintval = runtime.running; break; case SCSC_LOGLEVEL: - if (*intval > -1) { - runtime.hard_log_level = *intval; + if (oldintval > -1) { + runtime.hard_log_level = oldintval; } if (runtime.hard_log_level > SWITCH_LOG_DEBUG) { runtime.hard_log_level = SWITCH_LOG_DEBUG; } - *intval = runtime.hard_log_level; + newintval = runtime.hard_log_level; break; case SCSC_DEBUG_LEVEL: - if (*intval > -1) { - if (*intval > 10) - *intval = 10; - runtime.debug_level = *intval; + if (oldintval > -1) { + if (oldintval > 10) + newintval = 10; + runtime.debug_level = oldintval; } - *intval = runtime.debug_level; + newintval = runtime.debug_level; break; case SCSC_MIN_IDLE_CPU: { double *dval = (double *) val; - *dval = switch_core_min_idle_cpu(*dval); + if (dval) { + *dval = switch_core_min_idle_cpu(*dval); + } + intval = NULL; } break; case SCSC_MAX_SESSIONS: - *intval = switch_core_session_limit(*intval); + newintval = switch_core_session_limit(oldintval); break; case SCSC_LAST_SPS: - *intval = runtime.sps_last; + newintval = runtime.sps_last; break; case SCSC_MAX_DTMF_DURATION: - *intval = switch_core_max_dtmf_duration(*intval); + newintval = switch_core_max_dtmf_duration(oldintval); break; case SCSC_MIN_DTMF_DURATION: - *intval = switch_core_min_dtmf_duration(*intval); + newintval = switch_core_min_dtmf_duration(oldintval); break; case SCSC_DEFAULT_DTMF_DURATION: - *intval = switch_core_default_dtmf_duration(*intval); + newintval = switch_core_default_dtmf_duration(oldintval); break; case SCSC_SPS: switch_mutex_lock(runtime.throttle_mutex); - if (*intval > 0) { - runtime.sps_total = *intval; + if (oldintval > 0) { + runtime.sps_total = oldintval; } - *intval = runtime.sps_total; + newintval = runtime.sps_total; switch_mutex_unlock(runtime.throttle_mutex); break; case SCSC_RECLAIM: switch_core_memory_reclaim_all(); - *intval = 0; + newintval = 0; break; } + if (intval) { + *intval = newintval; + } + return 0; }