Copyright (C) 2010 - 2019 All Rights Reserved. Contributor(s): Mark J Crane Luis Daniel Lucio Quiroz Salvatore Caruso Riccardo Granchi Errol Samuels */ include "root.php"; //define the follow me class class follow_me { public $domain_uuid; private $domain_name; public $db_type; public $follow_me_uuid; public $cid_name_prefix; public $cid_number_prefix; public $accountcode; public $follow_me_enabled; public $follow_me_caller_id_uuid; public $follow_me_ignore_busy; public $outbound_caller_id_name; public $outbound_caller_id_number; private $extension; private $number_alias; private $toll_allow; public $destination_data_1; public $destination_type_1; public $destination_delay_1; public $destination_prompt_1; public $destination_timeout_1; public $destination_data_2; public $destination_type_2; public $destination_delay_2; public $destination_prompt_2; public $destination_timeout_2; public $destination_data_3; public $destination_type_3; public $destination_delay_3; public $destination_prompt_3; public $destination_timeout_3; public $destination_data_4; public $destination_type_4; public $destination_delay_4; public $destination_prompt_4; public $destination_timeout_4; public $destination_data_5; public $destination_type_5; public $destination_delay_5; public $destination_prompt_5; public $destination_timeout_5; public $destination_timeout = 0; public $destination_order = 1; public function add() { //set the global variable global $db; //add a new follow me $sql = "insert into v_follow_me "; $sql .= "("; $sql .= "domain_uuid, "; $sql .= "follow_me_uuid, "; $sql .= "cid_name_prefix, "; if (strlen($this->cid_number_prefix) > 0) { $sql .= "cid_number_prefix, "; } $sql .= "follow_me_caller_id_uuid, "; $sql .= "follow_me_enabled, "; $sql .= "follow_me_ignore_busy "; $sql .= ")"; $sql .= "values "; $sql .= "("; $sql .= "'$this->domain_uuid', "; $sql .= "'$this->follow_me_uuid', "; $sql .= "'$this->cid_name_prefix', "; if (strlen($this->cid_number_prefix) > 0) { $sql .= "'$this->cid_number_prefix', "; } if (strlen($this->follow_me_caller_id_uuid) > 0) { $sql .= "'$this->follow_me_caller_id_uuid', "; } else { $sql .= 'null, '; } $sql .= "'$this->follow_me_enabled', "; $sql .= "'$this->follow_me_ignore_busy' "; $sql .= ")"; if ($v_debug) { echo $sql."
"; } $db->exec(check_sql($sql)); unset($sql); $this->follow_me_destinations(); } //end function public function update() { //set the global variable global $db; //update follow me table $sql = "update v_follow_me set "; $sql .= "follow_me_enabled = '$this->follow_me_enabled', "; $sql .= "follow_me_ignore_busy = '$this->follow_me_ignore_busy', "; $sql .= "cid_name_prefix = '$this->cid_name_prefix', "; if (strlen($this->follow_me_caller_id_uuid) > 0) { $sql .= "follow_me_caller_id_uuid = '$this->follow_me_caller_id_uuid', "; } else { $sql .= "follow_me_caller_id_uuid = null, "; } $sql .= "cid_number_prefix = '$this->cid_number_prefix' "; $sql .= "where domain_uuid = '$this->domain_uuid' "; $sql .= "and follow_me_uuid = '$this->follow_me_uuid' "; $db->exec(check_sql($sql)); unset($sql); $this->follow_me_destinations(); } //end function public function follow_me_destinations() { //set the global variable global $db; //prepare insert statement $stmt = $db->prepare( "insert into v_follow_me_destinations(" . "follow_me_destination_uuid," . "domain_uuid," . "follow_me_uuid," . "follow_me_destination," . "follow_me_timeout," . "follow_me_delay," . "follow_me_prompt," . "follow_me_order" . ") values(?,?,?,?,?,?,?,?)" ); //delete related follow me destinations $sql = "delete from v_follow_me_destinations where follow_me_uuid = '$this->follow_me_uuid' "; $db->exec(check_sql($sql)); //insert the follow me destinations if (strlen($this->destination_data_1) > 0) { $stmt->execute(array( uuid(), $this->domain_uuid, $this->follow_me_uuid, $this->destination_data_1, $this->destination_timeout_1, $this->destination_delay_1, $this->destination_prompt_1, '1' )); $this->destination_order++; } if (strlen($this->destination_data_2) > 0) { $stmt->execute(array( uuid(), $this->domain_uuid, $this->follow_me_uuid, $this->destination_data_2, $this->destination_timeout_2, $this->destination_delay_2, $this->destination_prompt_2, '2' )); $this->destination_order++; } if (strlen($this->destination_data_3) > 0) { $stmt->execute(array( uuid(), $this->domain_uuid, $this->follow_me_uuid, $this->destination_data_3, $this->destination_timeout_3, $this->destination_delay_3, $this->destination_prompt_3, '3' )); $this->destination_order++; } if (strlen($this->destination_data_4) > 0) { $stmt->execute(array( uuid(), $this->domain_uuid, $this->follow_me_uuid, $this->destination_data_4, $this->destination_timeout_4, $this->destination_delay_4, $this->destination_prompt_4, '4' )); $this->destination_order++; } if (strlen($this->destination_data_5) > 0) { $stmt->execute(array( uuid(), $this->domain_uuid, $this->follow_me_uuid, $this->destination_data_5, $this->destination_timeout_5, $this->destination_delay_5, $this->destination_prompt_5, '5' )); $this->destination_order++; } unset($stmt); } //function public function set() { //set the global variable global $db; //determine whether to update the dial string $sql = "select * from v_extensions "; $sql .= "where domain_uuid = '".$this->domain_uuid."' "; $sql .= "and extension_uuid = '".$this->extension_uuid."' "; $prep_statement = $db->prepare(check_sql($sql)); $prep_statement->execute(); $result = $prep_statement->fetchAll(PDO::FETCH_NAMED); if (is_array($result)) foreach ($result as &$row) { $this->extension = $row["extension"]; $this->accountcode = $row["accountcode"]; $this->toll_allow = $row["toll_allow"]; $this->number_alias = $row["number_alias"]; $this->outbound_caller_id_name = $row["outbound_caller_id_name"]; $this->outbound_caller_id_number = $row["outbound_caller_id_number"]; } //determine whether to update the dial string $sql = "select d.domain_name, f.* from v_follow_me as f, v_domains as d "; $sql .= "where f.domain_uuid = '".$this->domain_uuid."' "; $sql .= "and f.follow_me_uuid = '".$this->follow_me_uuid."' "; $sql .= "and d.domain_uuid = f.domain_uuid "; $prep_statement = $db->prepare(check_sql($sql)); $prep_statement->execute(); $result = $prep_statement->fetchAll(PDO::FETCH_NAMED); if (is_array($result)) { foreach ($result as &$row) { $follow_me_uuid = $row["follow_me_uuid"]; $this->domain_name = $row["domain_name"]; $this->follow_me_enabled = $row["follow_me_enabled"]; $this->cid_name_prefix = $row["cid_name_prefix"]; $this->cid_number_prefix = $row["cid_number_prefix"]; } } unset ($prep_statement); //set the extension dial string $sql = "select * from v_follow_me_destinations "; $sql .= "where follow_me_uuid = '".$this->follow_me_uuid."' "; $sql .= "order by follow_me_order asc "; $prep_statement_2 = $db->prepare(check_sql($sql)); $prep_statement_2->execute(); $result = $prep_statement_2->fetchAll(PDO::FETCH_NAMED); /* $dial_string_caller_id_name = "\${effective_caller_id_name}"; $dial_string_caller_id_number = "\${effective_caller_id_number}"; if (strlen($this->follow_me_caller_id_uuid) > 0) { $sql_caller = "select destination_number, destination_description, destination_caller_id_number, destination_caller_id_name "; $sql_caller .= "from v_destinations "; $sql_caller .= "where domain_uuid = '$this->domain_uuid' "; $sql_caller .= "and destination_type = 'inbound' "; $sql_caller .= "and destination_uuid = '$this->follow_me_caller_id_uuid'"; $prep_statement_caller = $db->prepare($sql_caller); if ($prep_statement_caller) { $prep_statement_caller->execute(); $row_caller = $prep_statement_caller->fetch(PDO::FETCH_ASSOC); $caller_id_number = $row_caller['destination_caller_id_number']; if(strlen($caller_id_number) == 0){ $caller_id_number = $row_caller['destination_number']; } $caller_id_name = $row_caller['destination_caller_id_name']; if(strlen($caller_id_name) == 0){ $caller_id_name = $row_caller['destination_description']; } } } */ $x = 0; if (is_array($result)) foreach ($result as &$row) { if ($x > 0) { $dial_string .= ","; } //determine if the destination is a local sip user $sql = "select extension, number_alias from v_extensions "; $sql .= "where domain_uuid = '".$this->domain_uuid."' "; $sql .= "and (extension = '".$row["follow_me_destination"]."' "; $sql .= "or number_alias = '".$row["follow_me_destination"]."') "; $field = $db->query($sql)->fetch(PDO::FETCH_ASSOC); if (isset($field['extension'])) { if (is_numeric($field['extension'])) { $presence_id = $field['extension']; } else { $presence_id = $field['number_alias']; } $variables[] = "presence_id=".$presence_id."@".$this->domain_name; if ($row["follow_me_prompt"] == "1") { $variables[] = "group_confirm_key=exec"; $variables[] = "group_confirm_file=lua confirm.lua"; $variables[] = "confirm=true"; } if ($this->follow_me_ignore_busy != 'true') { $variables[] = "fail_on_single_reject=USER_BUSY"; } //accountcode if (strlen($this->accountcode) == 0) { $variables[] = "sip_h_X-accountcode=\${accountcode}"; } else { $variables[] = "sip_h_X-accountcode=".$this->accountcode; $variables[] = "accountcode=".$this->accountcode; } //toll allow if ($this->toll_allow != '') { $variables[] = "toll_allow=''".str_replace(",", "\,", $this->toll_allow)."''"; } $variables[] = "instant_ringback=true"; $variables[] = "ignore_early_media=true"; $variables[] = "domain_uuid=".$this->domain_uuid; $variables[] = "sip_invite_domain=".$this->domain_name; $variables[] = "domain_name=".$this->domain_name; $variables[] = "domain=".$this->domain_name; $variables[] = "extension_uuid=".$this->extension_uuid; $variables[] = "leg_delay_start=".$row["follow_me_delay"]; $variables[] = "originate_delay_start=".$row["follow_me_delay"]; $variables[] = "leg_timeout=".$row["follow_me_timeout"]; $dial_string .= "[".implode(",", $variables)."]\${sofia_contact(*/".$row["follow_me_destination"]."@".$this->domain_name.")}"; //$dial_string .= "[".implode(",", $variables)."]user/".$row["follow_me_destination"]."@".$this->domain_name; //$dial_string .= "loopback/export:".implode("\,export:", $variables)."\,transfer:".$row["follow_me_destination"]."/".$this->domain_name."/inline"; unset($variables); } else { if (is_numeric($this->extension)) { $presence_id = $this->extension; } else { $presence_id = $this->number_alias; } $variables[] = "presence_id=".$presence_id."@".$this->domain_name; //set the caller id if ($_SESSION['follow_me']['outbound_caller_id']['boolean'] == "true") { if (strlen($this->outbound_caller_id_name) > 0) { $variables[] = "origination_caller_id_name=".$this->cid_name_prefix.$this->outbound_caller_id_name; $variables[] = "effective_caller_id_name=".$this->cid_name_prefix.$this->outbound_caller_id_name; } if (strlen($this->outbound_caller_id_number) > 0) { $variables[] = "origination_caller_id_number=".$this->cid_number_prefix.$this->outbound_caller_id_number; $variables[] = "effective_caller_id_number=".$this->cid_number_prefix.$this->outbound_caller_id_number; } } else { if ($_SESSION['domain']['bridge']['text'] == "loopback") { //set the outbound caller id number if the caller id number is a user $variables[] = "origination_caller_id_number=\${cond(\${from_user_exists} == true ? ".$this->outbound_caller_id_number." : \${origination_caller_id_number})}"; $variables[] = "effective_caller_id_number=\${cond(\${from_user_exists} == true ? ".$this->outbound_caller_id_number." : \${effective_caller_id_number})}"; $variables[] = "origination_caller_id_name=\${cond(\${from_user_exists} == true ? ".$this->outbound_caller_id_name." : \${origination_caller_id_name})}"; $variables[] = "effective_caller_id_name=\${cond(\${from_user_exists} == true ? ".$this->outbound_caller_id_name." : \${effective_caller_id_name})}"; } else { $variables[] .="origination_caller_id_number=\${cond(\${from_user_exists} == true ? \${outbound_caller_id_number} : )}"; $variables[] .="effective_caller_id_number=\${cond(\${from_user_exists} == true ? \${outbound_caller_id_number} : )}"; $variables[] .="origination_caller_id_name=\${cond(\${from_user_exists} == true ? \${outbound_caller_id_name} : )}"; $variables[] .="effective_caller_id_name=\${cond(\${from_user_exists} == true ? \${outbound_caller_id_name} : )}"; } } //accountcode if (strlen($this->accountcode) == 0) { $variables[] = "sip_h_X-accountcode=\${accountcode}"; } else { $variables[] = "sip_h_X-accountcode=".$this->accountcode; $variables[] = "accountcode=".$this->accountcode; } //toll allow if ($this->toll_allow != '') { $variables[] = "toll_allow=''".str_replace(",", "\,", $this->toll_allow)."''"; } if ($this->follow_me_ignore_busy != 'true') { $variables[] = "fail_on_single_reject=USER_BUSY"; } if ($row["follow_me_prompt"] == "1") { $variables[] = "group_confirm_key=exec"; $variables[] = "group_confirm_file=lua confirm.lua"; $variables[] = "confirm=true"; } $variables[] = "instant_ringback=true"; $variables[] = "ignore_early_media=true"; $variables[] = "domain_uuid=".$this->domain_uuid; $variables[] = "sip_invite_domain=".$this->domain_name; $variables[] = "domain_name=".$this->domain_name; //$variables[] = "domain=".$this->domain_name; $variables[] = "extension_uuid=".$this->extension_uuid; $variables[] = "leg_delay_start=".$row["follow_me_delay"]; $variables[] = "originate_delay_start=".$row["follow_me_delay"]; $variables[] = "sleep=".($row["follow_me_delay"] * 1000); $variables[] = "leg_timeout=".$row["follow_me_timeout"]; if (is_numeric($row["follow_me_destination"])) { if ($_SESSION['domain']['bridge']['text'] == "outbound" || $_SESSION['domain']['bridge']['text'] == "bridge") { $bridge = outbound_route_to_bridge ($this->domain_uuid, $row["follow_me_destination"]); $dial_string .= "[".implode(",", $variables)."]".$bridge[0]; } elseif ($_SESSION['domain']['bridge']['text'] == "loopback") { $variables[] = "is_follow_me_loopback=true"; //$dial_string .= "loopback/".$row["follow_me_destination"]."/".$this->domain_name; $dial_string .= "loopback/export:".implode("\,export:", $variables)."\,transfer:".$row["follow_me_destination"]."/".$this->domain_name."/inline"; } elseif ($_SESSION['domain']['bridge']['text'] == "lcr") { $dial_string .= "[".implode(",", $variables)."]lcr/".$_SESSION['lcr']['profile']['text']."/".$this->domain_name."/".$row["follow_me_destination"]; } else { //$dial_string .= "loopback/".$row["follow_me_destination"]."/".$this->domain_name; $dial_string .= "loopback/export:".implode("\,export:", $variables)."\,transfer:".$row["follow_me_destination"]."/".$this->domain_name."/inline"; } } else { $dial_string .= $row["follow_me_destination"]; } } $x++; } //$dial_string = str_replace(",]", "]", $dial_string); $this->dial_string = "{ignore_early_media=true}".$dial_string; unset($variables); //get the extension_uuid $parameters['follow_me_uuid'] = $this->follow_me_uuid; $sql = "select extension_uuid from v_extensions "; $sql .= "where follow_me_uuid = :follow_me_uuid "; $database = new database; $result = $database->execute($sql, $parameters); $message = $database->message; $extension_uuid = $result[0]['extension_uuid']; //add the dialplan permission $p = new permissions; $p->add("follow_me_edit", 'temp'); $p->add("extension_edit", 'temp'); //add follow me to the array $array['follow_me'][0]["follow_me_uuid"] = $this->follow_me_uuid; $array['follow_me'][0]["domain_uuid"] = $this->domain_uuid; $array['follow_me'][0]["dial_string"] = $this->dial_string; //is follow me enabled $dial_string = ''; if ($this->follow_me_enabled == "true") { $dial_string = $this->dial_string; } //add extensions to the array $array['extensions'][0]["extension_uuid"] = $extension_uuid; $array['extensions'][0]["dial_domain"] = $this->domain_uuid; $array['extensions'][0]["dial_string"] = $dial_string; $array['extensions'][0]["follow_me_destinations"] = $dial_string; $array['extensions'][0]["follow_me_enabled"] = $this->follow_me_enabled; //save the destination $database = new database; $database->app_name = 'follow_me'; $database->app_uuid = '19806921-e8ed-dcff-b325-dd3e5da4959d'; $database->save($array); $dialplan_response = $database->message; //remove the temporary permission $p->delete("follow_me_edit", 'temp'); $p->delete("extension_edit", 'temp'); } //function } //class ?>