Portions created by the Initial Developer are Copyright (C) 2008-2012 the Initial Developer. All Rights Reserved. Contributor(s): Mark J Crane */ require_once "root.php"; require_once "resources/require.php"; require_once "resources/check_auth.php"; if (permission_exists('call_center_agent_add') || permission_exists('call_center_agent_edit')) { //access granted } else { echo "access denied"; exit; } //add multi-lingual support require_once "app_languages.php"; foreach($text as $key => $value) { $text[$key] = $value[$_SESSION['domain']['language']['code']]; } //action add or update if (isset($_REQUEST["id"])) { $action = "update"; $call_center_agent_uuid = check_str($_REQUEST["id"]); } else { $action = "add"; } //get http post variables and set them to php variables if (count($_POST)>0) { $agent_name = check_str($_POST["agent_name"]); $agent_type = check_str($_POST["agent_type"]); $agent_call_timeout = check_str($_POST["agent_call_timeout"]); $agent_contact = check_str($_POST["agent_contact"]); $agent_status = check_str($_POST["agent_status"]); $agent_logout = check_str($_POST["agent_logout"]); $agent_no_answer_delay_time = check_str($_POST["agent_no_answer_delay_time"]); $agent_max_no_answer = check_str($_POST["agent_max_no_answer"]); $agent_wrap_up_time = check_str($_POST["agent_wrap_up_time"]); $agent_reject_delay_time = check_str($_POST["agent_reject_delay_time"]); $agent_busy_delay_time = check_str($_POST["agent_busy_delay_time"]); } if (count($_POST)>0 && strlen($_POST["persistformvar"]) == 0) { $msg = ''; if ($action == "update") { $call_center_agent_uuid = check_str($_POST["call_center_agent_uuid"]); } //check for all required data //if (strlen($domain_uuid) == 0) { $msg .= $text['message-required']."domain_uuid
\n"; } //if (strlen($agent_name) == 0) { $msg .= $text['message-required'].$text['label-agent_name']."
\n"; } //if (strlen($agent_type) == 0) { $msg .= $text['message-required'].$text['label-type']."
\n"; } //if (strlen($agent_call_timeout) == 0) { $msg .= $text['message-required'].$text['label-call_timeout']."
\n"; } //if (strlen($agent_contact) == 0) { $msg .= $text['message-required'].$text['label-contact']."
\n"; } //if (strlen($agent_status) == 0) { $msg .= $text['message-required'].$text['label-status']."
\n"; } //if (strlen($agent_logout) == 0) { $msg .= $text['message-required'].$text['label-agent_logout']."
\n"; } //if (strlen($agent_no_answer_delay_time) == 0) { $msg .= $text['message-required'].$text['label-no_answer_delay_time']."
\n"; } //if (strlen($agent_max_no_answer) == 0) { $msg .= $text['message-required'].$text['label-max_no_answer']."
\n"; } //if (strlen($agent_wrap_up_time) == 0) { $msg .= $text['message-required'].$text['label-wrap_up_time']."
\n"; } //if (strlen($agent_reject_delay_time) == 0) { $msg .= $text['message-required'].$text['label-reject_delay_time']."
\n"; } //if (strlen($agent_busy_delay_time) == 0) { $msg .= $text['message-required'].$text['label-busy_delay_time']."
\n"; } if (strlen($msg) > 0 && strlen($_POST["persistformvar"]) == 0) { require_once "resources/header.php"; require_once "resources/persist_form_var.php"; echo "
\n"; echo "
\n"; echo $msg."
"; echo "
\n"; persistformvar($_POST); echo "
\n"; require_once "resources/footer.php"; return; } //get and then set the complete agent_contact with the call_timeout and when necessary confirm //if you change this variable, also change resources/switch.php $tmp_confirm = "group_confirm_file=custom/press_1_to_accept_this_call.wav,group_confirm_key=1,group_confirm_read_timeout=2000,leg_timeout=".$agent_call_timeout; if(strstr($agent_contact, '}') === FALSE) { //not found if(stristr($agent_contact, 'sofia/gateway') === FALSE) { //add the call_timeout $tmp_agent_contact = "{call_timeout=".$agent_call_timeout."}".$agent_contact; } else { //add the call_timeout and confirm $tmp_agent_contact = $tmp_first.',call_timeout='.$agent_call_timeout.$tmp_last; $tmp_agent_contact = "{".$tmp_confirm.",call_timeout=".$agent_call_timeout."}".$agent_contact; echo "\n\n".$tmp_agent_contact."\n\n"; } } else { //found if(stristr($agent_contact, 'sofia/gateway') === FALSE) { //not found if(stristr($agent_contact, 'call_timeout') === FALSE) { //add the call_timeout $tmp_pos = strrpos($agent_contact, "}"); $tmp_first = substr($agent_contact, 0, $tmp_pos); $tmp_last = substr($agent_contact, $tmp_pos); $tmp_agent_contact = $tmp_first.',call_timeout='.$agent_call_timeout.$tmp_last; } else { //the string has the call timeout $tmp_agent_contact = $agent_contact; } } else { //found $tmp_pos = strrpos($agent_contact, "}"); $tmp_first = substr($agent_contact, 0, $tmp_pos); $tmp_last = substr($agent_contact, $tmp_pos); if(stristr($agent_contact, 'call_timeout') === FALSE) { //add the call_timeout and confirm $tmp_agent_contact = $tmp_first.','.$tmp_confirm.',call_timeout='.$agent_call_timeout.$tmp_last; } else { //add confirm $tmp_agent_contact = $tmp_first.','.$tmp_confirm.$tmp_last; } } } //set the user_status $sql = "update v_users set "; $sql .= "user_status = '".$agent_status."' "; $sql .= "where domain_uuid = '$domain_uuid' "; $sql .= "and username = '".$agent_name."' "; $prep_statement = $db->prepare(check_sql($sql)); $prep_statement->execute(); //add the agent //setup the event socket connection $fp = event_socket_create($_SESSION['event_socket_ip_address'], $_SESSION['event_socket_port'], $_SESSION['event_socket_password']); //add the agent using event socket if ($fp) { //add the agent $cmd = "api callcenter_config agent add ".$agent_name."@".$_SESSION['domains'][$domain_uuid]['domain_name']." ".$agent_type; $response = event_socket_request($fp, $cmd); usleep(200); //agent set contact $cmd = "api callcenter_config agent set contact ".$agent_name."@".$_SESSION['domains'][$domain_uuid]['domain_name']." ".$tmp_agent_contact; $response = event_socket_request($fp, $cmd); usleep(200); //agent set status $cmd = "api callcenter_config agent set status ".$agent_name."@".$_SESSION['domains'][$domain_uuid]['domain_name']." '".$agent_status."'"; $response = event_socket_request($fp, $cmd); usleep(200); //agent set reject_delay_time $cmd = "api callcenter_config agent set reject_delay_time ".$agent_name."@".$_SESSION['domains'][$domain_uuid]['domain_name']." ".$agent_reject_delay_time; $response = event_socket_request($fp, $cmd); usleep(200); //agent set busy_delay_time $cmd = "api callcenter_config agent set busy_delay_time ".$agent_name."@".$_SESSION['domains'][$domain_uuid]['domain_name']." ".$agent_busy_delay_time; $response = event_socket_request($fp, $cmd); //agent set no_answer_delay_time $cmd = "api callcenter_config agent set no_answer_delay_time ".$agent_name."@".$_SESSION['domains'][$domain_uuid]['domain_name']." ".$agent_no_answer_delay_time; $response = event_socket_request($fp, $cmd); //agent set max_no_answer $cmd = "api callcenter_config agent set max_no_answer ".$agent_name."@".$_SESSION['domains'][$domain_uuid]['domain_name']." ".$agent_max_no_answer; $response = event_socket_request($fp, $cmd); //agent set wrap_up_time $cmd = "api callcenter_config agent set wrap_up_time ".$agent_name."@".$_SESSION['domains'][$domain_uuid]['domain_name']." ".$agent_wrap_up_time; $response = event_socket_request($fp, $cmd); } //add or update the database if ($_POST["persistformvar"] != "true") { if ($action == "add") { //add the agent to the database $call_center_agent_uuid = uuid(); $sql = "insert into v_call_center_agents "; $sql .= "("; $sql .= "domain_uuid, "; $sql .= "call_center_agent_uuid, "; $sql .= "agent_name, "; $sql .= "agent_type, "; $sql .= "agent_call_timeout, "; $sql .= "agent_contact, "; $sql .= "agent_status, "; $sql .= "agent_logout, "; $sql .= "agent_no_answer_delay_time, "; $sql .= "agent_max_no_answer, "; $sql .= "agent_wrap_up_time, "; $sql .= "agent_reject_delay_time, "; $sql .= "agent_busy_delay_time "; $sql .= ")"; $sql .= "values "; $sql .= "("; $sql .= "'$domain_uuid', "; $sql .= "'$call_center_agent_uuid', "; $sql .= "'$agent_name', "; $sql .= "'$agent_type', "; $sql .= "'$agent_call_timeout', "; $sql .= "'$agent_contact', "; $sql .= "'$agent_status', "; $sql .= "'$agent_logout', "; $sql .= "'$agent_no_answer_delay_time', "; $sql .= "'$agent_max_no_answer', "; $sql .= "'$agent_wrap_up_time', "; $sql .= "'$agent_reject_delay_time', "; $sql .= "'$agent_busy_delay_time' "; $sql .= ")"; $db->exec(check_sql($sql)); unset($sql); //syncrhonize configuration save_call_center_xml(); $_SESSION["message"] = $text['message-add']; header("Location: call_center_agents.php"); return; } //if ($action == "add") if ($action == "update") { $sql = "update v_call_center_agents set "; $sql .= "agent_name = '$agent_name', "; $sql .= "agent_type = '$agent_type', "; $sql .= "agent_call_timeout = '$agent_call_timeout', "; $sql .= "agent_contact = '$agent_contact', "; $sql .= "agent_status = '$agent_status', "; $sql .= "agent_logout = '$agent_logout', "; $sql .= "agent_no_answer_delay_time = '$agent_no_answer_delay_time', "; $sql .= "agent_max_no_answer = '$agent_max_no_answer', "; $sql .= "agent_wrap_up_time = '$agent_wrap_up_time', "; $sql .= "agent_reject_delay_time = '$agent_reject_delay_time', "; $sql .= "agent_busy_delay_time = '$agent_busy_delay_time' "; $sql .= "where domain_uuid = '$domain_uuid'"; $sql .= "and call_center_agent_uuid = '$call_center_agent_uuid'"; $db->exec(check_sql($sql)); unset($sql); //syncrhonize configuration save_call_center_xml(); $_SESSION["message"] = $text['message-update']; header("Location: call_center_agents.php"); return; } //if ($action == "update") } //if ($_POST["persistformvar"] != "true") } //(count($_POST)>0 && strlen($_POST["persistformvar"]) == 0) //pre-populate the form if (count($_GET)>0 && $_POST["persistformvar"] != "true") { $call_center_agent_uuid = $_GET["id"]; $sql = "select * from v_call_center_agents "; $sql .= "where domain_uuid = '$domain_uuid' "; $sql .= "and call_center_agent_uuid = '$call_center_agent_uuid' "; $prep_statement = $db->prepare(check_sql($sql)); $prep_statement->execute(); $result = $prep_statement->fetchAll(PDO::FETCH_NAMED); foreach ($result as &$row) { $agent_name = $row["agent_name"]; $agent_type = $row["agent_type"]; $agent_call_timeout = $row["agent_call_timeout"]; $agent_contact = $row["agent_contact"]; $agent_status = $row["agent_status"]; $agent_logout = $row["agent_logout"]; $agent_no_answer_delay_time = $row["agent_no_answer_delay_time"]; $agent_max_no_answer = $row["agent_max_no_answer"]; $agent_wrap_up_time = $row["agent_wrap_up_time"]; $agent_reject_delay_time = $row["agent_reject_delay_time"]; $agent_busy_delay_time = $row["agent_busy_delay_time"]; break; //limit to 1 row } unset ($prep_statement); } //set default values if (strlen($agent_type) == 0) { $agent_type = "callback"; } if (strlen($agent_call_timeout) == 0) { $agent_call_timeout = 10; } if (strlen($agent_max_no_answer) == 0) { $agent_max_no_answer = "0"; } if (strlen($agent_wrap_up_time) == 0) { $agent_wrap_up_time = "10"; } if (strlen($agent_no_answer_delay_time) == 0) { $agent_no_answer_delay_time = "10"; } if (strlen($agent_reject_delay_time) == 0) { $agent_reject_delay_time = "10"; } if (strlen($agent_busy_delay_time) == 0) { $agent_busy_delay_time = "60"; } //show the header require_once "resources/header.php"; if ($action == "add") { $document['title'] = $text['title-call_center_agent_add']; } if ($action == "update") { $document['title'] = $text['title-call_center_agent_edit']; } //show the content echo "
"; echo "\n"; echo "\n"; echo " "; echo " "; echo "
\n"; echo "
"; echo "
\n"; echo "
\n"; echo "\n"; echo "\n"; if ($action == "add") { echo "\n"; } if ($action == "update") { echo "\n"; } echo "\n"; echo "\n"; echo "\n"; echo "\n"; echo "\n"; echo "\n"; echo "\n"; echo "\n"; echo "\n"; echo "\n"; echo "\n"; echo "\n"; echo "\n"; echo "\n"; echo "\n"; echo "\n"; echo "\n"; echo "\n"; echo "\n"; echo "\n"; echo "\n"; echo "\n"; echo "\n"; echo "\n"; echo "\n"; echo "\n"; echo "\n"; echo "\n"; echo "\n"; echo "\n"; echo "\n"; echo "\n"; echo "\n"; echo "\n"; echo "\n"; echo "\n"; echo "\n"; echo "\n"; echo "\n"; echo "\n"; echo "\n"; echo "\n"; echo "\n"; echo "\n"; echo "\n"; echo "\n"; echo "\n"; echo "\n"; echo "\n"; echo " \n"; echo " \n"; echo " "; echo "
".$text['header-call_center_agent_add']."".$text['header-call_center_agent_edit'].""; echo " "; echo " \n"; echo "
\n"; //echo "Call Center agents settings.

\n"; echo "
\n"; echo " ".$text['label-agent_name'].":\n"; echo "\n"; //---- Begin Select List -------------------- $sql = "SELECT * FROM v_users "; $sql .= "where domain_uuid = '$domain_uuid' "; $sql .= "and user_enabled = 'true' "; $sql .= "order by username asc "; $prep_statement = $db->prepare(check_sql($sql)); $prep_statement->execute(); echo ""; unset($sql, $result); //---- End Select List -------------------- echo "
\n"; echo $text['description-agent_name']."\n"; echo "
\n"; echo " ".$text['label-type'].":\n"; echo "\n"; echo " \n"; echo "
\n"; echo $text['description-type']."\n"; echo "
\n"; echo " ".$text['label-call_timeout'].":\n"; echo "\n"; echo " \n"; echo "
\n"; echo $text['description-call_timeout']."\n"; echo "
\n"; echo " ".$text['label-contact'].":\n"; echo "\n"; //switch_select_destination(select_type, select_label, select_name, select_value, select_style, action); switch_select_destination("call_center_contact", "", "agent_contact", $agent_contact, "", ""); echo "
\n"; echo $text['description-contact']."\n"; echo "
\n"; echo " ".$text['label-status'].":\n"; echo "\n"; echo " \n"; echo "
\n"; echo $text['description-status']."\n"; echo "
\n"; echo " ".$text['label-no_answer_delay_time'].":\n"; echo "\n"; echo " \n"; echo "
\n"; echo $text['description-no_answer_delay_time']."\n"; echo "
\n"; echo " ".$text['label-max_no_answer'].":\n"; echo "\n"; echo " \n"; echo "
\n"; echo $text['description-max_no_answer']."\n"; echo "
\n"; echo " ".$text['label-wrap_up_time'].":\n"; echo "\n"; echo " \n"; echo "
\n"; echo $text['description-wrap_up_time']."\n"; echo "
\n"; echo " ".$text['label-reject_delay_time'].":\n"; echo "\n"; echo " \n"; echo "
\n"; echo $text['description-reject_delay_time']."\n"; echo "
\n"; echo " ".$text['label-busy_delay_time'].":\n"; echo "\n"; echo " \n"; echo "
\n"; echo $text['description-busy_delay_time']."\n"; echo "
\n"; echo " ".$text['label-agent_logout'].":\n"; echo "\n"; echo " \n"; echo "
\n"; echo $text['description-agent_logout']."\n"; echo "
\n"; if ($action == "update") { echo " \n"; } echo " \n"; echo "
"; echo ""; echo "
"; echo "
"; //footer require_once "resources/footer.php"; ?>