From 023c77eb63c73d964e55ced1dd7c2b1afc29ba80 Mon Sep 17 00:00:00 2001 From: Antonio Silva Date: Thu, 7 May 2020 17:52:06 +0200 Subject: [PATCH 1/3] mod_callcenter: fix tracking agent external calls - prevent multiple track per channel --- src/mod/applications/mod_callcenter/mod_callcenter.c | 6 ++++++ 1 file changed, 6 insertions(+) diff --git a/src/mod/applications/mod_callcenter/mod_callcenter.c b/src/mod/applications/mod_callcenter/mod_callcenter.c index f59b744098..54f6bd1cb9 100644 --- a/src/mod/applications/mod_callcenter/mod_callcenter.c +++ b/src/mod/applications/mod_callcenter/mod_callcenter.c @@ -3336,6 +3336,7 @@ SWITCH_STANDARD_APP(callcenter_track) char agent_status[255]; char *agent_name = NULL; char *sql = NULL; + const char *tracked_agent = NULL; if (zstr(data)) { switch_log_printf(SWITCH_CHANNEL_SESSION_LOG(session), SWITCH_LOG_ERROR, "Missing agent name\n"); @@ -3347,6 +3348,11 @@ SWITCH_STANDARD_APP(callcenter_track) return; } + if ((tracked_agent = switch_channel_get_variable(channel, "cc_tracked_agent"))) { + switch_log_printf(SWITCH_CHANNEL_SESSION_LOG(session), SWITCH_LOG_WARNING, "Already tracking agent %s in this channel.", tracked_agent); + return; + } + agent_name = switch_safe_strdup(data); switch_channel_set_variable(channel, "cc_tracked_agent", agent_name); From b69853c1ad01bc830581489e4103ea744e787923 Mon Sep 17 00:00:00 2001 From: Antonio Silva Date: Thu, 7 May 2020 17:52:06 +0200 Subject: [PATCH 2/3] mod_callcenter: fix tracking agent external calls - prevent multiple track per channel --- src/mod/applications/mod_callcenter/mod_callcenter.c | 6 ++++++ 1 file changed, 6 insertions(+) diff --git a/src/mod/applications/mod_callcenter/mod_callcenter.c b/src/mod/applications/mod_callcenter/mod_callcenter.c index f59b744098..54f6bd1cb9 100644 --- a/src/mod/applications/mod_callcenter/mod_callcenter.c +++ b/src/mod/applications/mod_callcenter/mod_callcenter.c @@ -3336,6 +3336,7 @@ SWITCH_STANDARD_APP(callcenter_track) char agent_status[255]; char *agent_name = NULL; char *sql = NULL; + const char *tracked_agent = NULL; if (zstr(data)) { switch_log_printf(SWITCH_CHANNEL_SESSION_LOG(session), SWITCH_LOG_ERROR, "Missing agent name\n"); @@ -3347,6 +3348,11 @@ SWITCH_STANDARD_APP(callcenter_track) return; } + if ((tracked_agent = switch_channel_get_variable(channel, "cc_tracked_agent"))) { + switch_log_printf(SWITCH_CHANNEL_SESSION_LOG(session), SWITCH_LOG_WARNING, "Already tracking agent %s in this channel.", tracked_agent); + return; + } + agent_name = switch_safe_strdup(data); switch_channel_set_variable(channel, "cc_tracked_agent", agent_name); From a4c657f0b176949626fe71e93478274f9d866f08 Mon Sep 17 00:00:00 2001 From: Antonio Silva Date: Fri, 8 May 2020 16:29:27 +0200 Subject: [PATCH 3/3] mod_callcenter: track agent fix missing new line in log --- src/mod/applications/mod_callcenter/mod_callcenter.c | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/src/mod/applications/mod_callcenter/mod_callcenter.c b/src/mod/applications/mod_callcenter/mod_callcenter.c index 54f6bd1cb9..ffa6138848 100644 --- a/src/mod/applications/mod_callcenter/mod_callcenter.c +++ b/src/mod/applications/mod_callcenter/mod_callcenter.c @@ -3316,10 +3316,10 @@ static switch_status_t cc_hook_state_run(switch_core_session_t *session) char *sql = NULL; agent_name = switch_channel_get_variable(channel, "cc_tracked_agent"); - switch_log_printf(SWITCH_CHANNEL_SESSION_LOG(session), SWITCH_LOG_DEBUG, "Called cc_hook_hanguphook channel %s with state %s", switch_channel_get_name(channel), switch_channel_state_name(state)); + switch_log_printf(SWITCH_CHANNEL_SESSION_LOG(session), SWITCH_LOG_DEBUG, "Called cc_hook_hanguphook channel '%s' with state '%s' \n", switch_channel_get_name(channel), switch_channel_state_name(state)); if (state == CS_HANGUP) { - switch_log_printf(SWITCH_CHANNEL_SESSION_LOG(session), SWITCH_LOG_DEBUG, "Tracked call for agent %s ended, decreasing external_calls_count", agent_name); + switch_log_printf(SWITCH_CHANNEL_SESSION_LOG(session), SWITCH_LOG_DEBUG, "Tracked call for agent '%s' ended, decreasing external_calls_count \n", agent_name); sql = switch_mprintf("UPDATE agents SET external_calls_count = external_calls_count - 1 WHERE name = '%q'", agent_name); cc_execute_sql(NULL, sql, NULL); switch_safe_free(sql); @@ -3344,12 +3344,12 @@ SWITCH_STANDARD_APP(callcenter_track) } if (cc_agent_get("status", data, agent_status, sizeof(agent_status)) != CC_STATUS_SUCCESS) { - switch_log_printf(SWITCH_CHANNEL_SESSION_LOG(session), SWITCH_LOG_WARNING, "Invalid agent %s", data); + switch_log_printf(SWITCH_CHANNEL_SESSION_LOG(session), SWITCH_LOG_WARNING, "Invalid agent '%s' \n", data); return; } if ((tracked_agent = switch_channel_get_variable(channel, "cc_tracked_agent"))) { - switch_log_printf(SWITCH_CHANNEL_SESSION_LOG(session), SWITCH_LOG_WARNING, "Already tracking agent %s in this channel.", tracked_agent); + switch_log_printf(SWITCH_CHANNEL_SESSION_LOG(session), SWITCH_LOG_WARNING, "Already tracking agent '%s' in this channel. \n", tracked_agent); return; } @@ -3363,7 +3363,7 @@ SWITCH_STANDARD_APP(callcenter_track) switch_core_event_hook_add_state_run(session, cc_hook_state_run); PROTECT_INTERFACE(app_interface); - switch_log_printf(SWITCH_CHANNEL_SESSION_LOG(session), SWITCH_LOG_DEBUG, "Tracking this call for agent %s", data); + switch_log_printf(SWITCH_CHANNEL_SESSION_LOG(session), SWITCH_LOG_DEBUG, "Tracking this call for agent '%s' \n", data); switch_safe_free(agent_name); return;