2012-06-04 16:58:40 +02:00
|
|
|
<?php
|
|
|
|
|
/*
|
|
|
|
|
FusionPBX
|
|
|
|
|
Version: MPL 1.1
|
|
|
|
|
|
|
|
|
|
The contents of this file are subject to the Mozilla Public License Version
|
|
|
|
|
1.1 (the "License"); you may not use this file except in compliance with
|
|
|
|
|
the License. You may obtain a copy of the License at
|
|
|
|
|
http://www.mozilla.org/MPL/
|
|
|
|
|
|
|
|
|
|
Software distributed under the License is distributed on an "AS IS" basis,
|
|
|
|
|
WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
|
|
|
|
|
for the specific language governing rights and limitations under the
|
|
|
|
|
License.
|
|
|
|
|
|
|
|
|
|
The Original Code is FusionPBX
|
|
|
|
|
|
|
|
|
|
The Initial Developer of the Original Code is
|
|
|
|
|
Mark J Crane <markjcrane@fusionpbx.com>
|
|
|
|
|
Copyright (C) 2010
|
|
|
|
|
All Rights Reserved.
|
|
|
|
|
|
|
|
|
|
Contributor(s):
|
|
|
|
|
Mark J Crane <markjcrane@fusionpbx.com>
|
|
|
|
|
*/
|
|
|
|
|
include "root.php";
|
|
|
|
|
|
2014-02-19 10:40:26 +01:00
|
|
|
//define the ivr_menu class
|
2013-09-11 15:06:14 +02:00
|
|
|
class ivr_menu {
|
2012-06-04 16:58:40 +02:00
|
|
|
public $db;
|
|
|
|
|
public $domain_uuid;
|
|
|
|
|
public $domain_name;
|
|
|
|
|
public $dialplan_uuid;
|
|
|
|
|
public $ivr_menu_uuid;
|
|
|
|
|
public $ivr_menu_name;
|
|
|
|
|
public $ivr_menu_extension;
|
|
|
|
|
public $ivr_menu_greet_long;
|
|
|
|
|
public $ivr_menu_greet_short;
|
|
|
|
|
public $ivr_menu_invalid_sound;
|
|
|
|
|
public $ivr_menu_exit_sound;
|
|
|
|
|
public $ivr_menu_confirm_macro;
|
|
|
|
|
public $ivr_menu_confirm_key;
|
|
|
|
|
public $ivr_menu_tts_engine;
|
|
|
|
|
public $ivr_menu_tts_voice;
|
|
|
|
|
public $ivr_menu_confirm_attempts;
|
|
|
|
|
public $ivr_menu_timeout;
|
|
|
|
|
public $ivr_menu_exit_app;
|
|
|
|
|
public $ivr_menu_exit_data;
|
|
|
|
|
public $ivr_menu_inter_digit_timeout;
|
|
|
|
|
public $ivr_menu_max_failures;
|
|
|
|
|
public $ivr_menu_max_timeouts;
|
|
|
|
|
public $ivr_menu_digit_len;
|
|
|
|
|
public $ivr_menu_direct_dial;
|
2012-08-16 00:02:13 +02:00
|
|
|
public $ivr_menu_ringback;
|
2013-02-12 12:19:52 +01:00
|
|
|
public $ivr_menu_cid_prefix;
|
2012-06-04 16:58:40 +02:00
|
|
|
public $ivr_menu_enabled;
|
|
|
|
|
public $ivr_menu_description;
|
|
|
|
|
public $ivr_menu_option_uuid;
|
|
|
|
|
public $ivr_menu_option_digits;
|
|
|
|
|
public $ivr_menu_option_action;
|
|
|
|
|
public $ivr_menu_option_param;
|
|
|
|
|
public $ivr_menu_option_order;
|
|
|
|
|
public $ivr_menu_option_description;
|
2012-06-05 09:48:41 +02:00
|
|
|
public $order_by; //array
|
2012-06-04 16:58:40 +02:00
|
|
|
|
|
|
|
|
public function __construct() {
|
2013-07-06 09:13:36 +02:00
|
|
|
require_once "resources/classes/database.php";
|
2012-06-04 16:58:40 +02:00
|
|
|
$this->app_uuid = 'a5788e9b-58bc-bd1b-df59-fff5d51253ab';
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public function __destruct() {
|
|
|
|
|
foreach ($this as $key => $value) {
|
|
|
|
|
unset($this->$key);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public function get_domain_uuid() {
|
|
|
|
|
return $this->domain_uuid;
|
|
|
|
|
}
|
2013-08-23 10:04:25 +02:00
|
|
|
|
2012-06-04 16:58:40 +02:00
|
|
|
public function set_domain_uuid($domain_uuid){
|
|
|
|
|
$this->domain_uuid = $domain_uuid;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public function get_fields($table) {
|
|
|
|
|
//get the $apps array from the installed apps from the core and mod directories
|
|
|
|
|
$config_list = glob($_SERVER["DOCUMENT_ROOT"] . PROJECT_PATH . "/*/*/app_config.php");
|
|
|
|
|
$x=0;
|
|
|
|
|
foreach ($config_list as &$config_path) {
|
|
|
|
|
include($config_path);
|
|
|
|
|
$x++;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
//update the app db array add exists true or false
|
|
|
|
|
$sql = '';
|
|
|
|
|
foreach ($apps as $x => &$app) {
|
|
|
|
|
foreach ($app['db'] as $y => &$row) {
|
|
|
|
|
if ($row['table'] == $table) {
|
|
|
|
|
//check if the column exists
|
|
|
|
|
foreach ($row['fields'] as $z => $field) {
|
|
|
|
|
if ($field['deprecated'] == "true") {
|
|
|
|
|
//skip this field
|
|
|
|
|
}
|
|
|
|
|
else {
|
|
|
|
|
if (is_array($field['name'])) {
|
|
|
|
|
$field_name = $field['name']['text'];
|
|
|
|
|
}
|
|
|
|
|
else {
|
|
|
|
|
$field_name = $field['name'];
|
|
|
|
|
}
|
|
|
|
|
if (strlen(field_name) > 0) {
|
|
|
|
|
$fields[$z]['name'] = $field_name;
|
|
|
|
|
}
|
|
|
|
|
unset($field_name);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
return $fields;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public function count() {
|
|
|
|
|
$database = new database;
|
|
|
|
|
if ($this->db) {
|
|
|
|
|
$database->db = $this->db;
|
|
|
|
|
}
|
|
|
|
|
$database->domain_uuid = $this->domain_uuid;
|
|
|
|
|
$database->table = "v_ivr_menus";
|
|
|
|
|
$database->where[0]['name'] = 'domain_uuid';
|
|
|
|
|
$database->where[0]['value'] = $this->domain_uuid;
|
|
|
|
|
$database->where[0]['operator'] = '=';
|
|
|
|
|
return $database->count();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public function find() {
|
|
|
|
|
$database = new database;
|
|
|
|
|
if ($this->db) {
|
|
|
|
|
$database->db = $this->db;
|
|
|
|
|
}
|
|
|
|
|
$database->table = "v_ivr_menus";
|
|
|
|
|
$database->where[0]['name'] = 'domain_uuid';
|
|
|
|
|
$database->where[0]['value'] = $this->domain_uuid;
|
|
|
|
|
$database->where[0]['operator'] = '=';
|
|
|
|
|
if (isset($this->ivr_menu_uuid)) {
|
|
|
|
|
$database->where[1]['name'] = 'ivr_menu_uuid';
|
|
|
|
|
$database->where[1]['value'] = $this->ivr_menu_uuid;
|
|
|
|
|
$database->where[1]['operator'] = '=';
|
|
|
|
|
}
|
|
|
|
|
if (isset($this->ivr_menu_option_uuid)) {
|
|
|
|
|
$database->where[2]['name'] = 'ivr_menu_uuid';
|
|
|
|
|
$database->where[2]['value'] = $this->ivr_menu_uuid;
|
|
|
|
|
$database->where[2]['operator'] = '=';
|
|
|
|
|
}
|
|
|
|
|
if (isset($this->order_by)) {
|
|
|
|
|
$database->order_by = $this->order_by;
|
|
|
|
|
}
|
|
|
|
|
return $database->find();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public function add() {
|
|
|
|
|
|
|
|
|
|
//add the ivr menu
|
|
|
|
|
if (strlen($this->ivr_menu_option_action) == 0) {
|
|
|
|
|
if (strlen($this->ivr_menu_extension) > 0) {
|
2012-11-25 05:21:31 +01:00
|
|
|
//set the ivr menu uuid
|
2013-08-23 10:04:25 +02:00
|
|
|
if (strlen($this->ivr_menu_uuid) == 0) {
|
|
|
|
|
$this->ivr_menu_uuid = uuid();
|
|
|
|
|
}
|
2012-11-25 05:21:31 +01:00
|
|
|
|
2012-08-04 18:34:24 +02:00
|
|
|
//ensure the dialplan_uuid has a uuid
|
|
|
|
|
if (strlen($this->dialplan_uuid) == 0) {
|
|
|
|
|
$this->dialplan_uuid = uuid();
|
|
|
|
|
}
|
2012-11-25 05:21:31 +01:00
|
|
|
|
2012-06-04 16:58:40 +02:00
|
|
|
//add the dialplan
|
|
|
|
|
$database = new database;
|
|
|
|
|
if ($this->db) {
|
|
|
|
|
$database->db = $this->db;
|
|
|
|
|
}
|
|
|
|
|
$database->table = "v_dialplans";
|
|
|
|
|
$database->fields['domain_uuid'] = $this->domain_uuid;
|
|
|
|
|
$database->fields['dialplan_uuid'] = $this->dialplan_uuid;
|
|
|
|
|
$database->fields['dialplan_name'] = $this->ivr_menu_name;
|
|
|
|
|
$database->fields['dialplan_order'] = '333';
|
|
|
|
|
$database->fields['dialplan_context'] = $_SESSION['context'];
|
|
|
|
|
$database->fields['dialplan_enabled'] = $this->ivr_menu_enabled;
|
|
|
|
|
$database->fields['dialplan_description'] = $this->ivr_menu_description;
|
|
|
|
|
$database->fields['app_uuid'] = $this->app_uuid;
|
|
|
|
|
$database->add();
|
|
|
|
|
|
|
|
|
|
//add the dialplan details
|
|
|
|
|
$detail_data = '^'.$this->ivr_menu_extension.'$';
|
|
|
|
|
$database->table = "v_dialplan_details";
|
|
|
|
|
$database->fields['domain_uuid'] = $this->domain_uuid;
|
|
|
|
|
$database->fields['dialplan_uuid'] = $this->dialplan_uuid;
|
|
|
|
|
$database->fields['dialplan_detail_uuid'] = uuid();
|
|
|
|
|
$database->fields['dialplan_detail_tag'] = 'condition'; //condition, action, antiaction
|
|
|
|
|
$database->fields['dialplan_detail_type'] = 'destination_number';
|
|
|
|
|
$database->fields['dialplan_detail_data'] = $detail_data;
|
|
|
|
|
$database->fields['dialplan_detail_order'] = '005';
|
|
|
|
|
$database->add();
|
|
|
|
|
|
2012-09-28 03:55:14 +02:00
|
|
|
$database->table = "v_dialplan_details";
|
|
|
|
|
$database->fields['domain_uuid'] = $this->domain_uuid;
|
|
|
|
|
$database->fields['dialplan_uuid'] = $this->dialplan_uuid;
|
|
|
|
|
$database->fields['dialplan_detail_uuid'] = uuid();
|
|
|
|
|
$database->fields['dialplan_detail_tag'] = 'action'; //condition, action, antiaction
|
|
|
|
|
$database->fields['dialplan_detail_type'] = 'answer';
|
|
|
|
|
$database->fields['dialplan_detail_data'] = '';
|
|
|
|
|
$database->fields['dialplan_detail_order'] = '010';
|
|
|
|
|
$database->add();
|
2012-06-04 16:58:40 +02:00
|
|
|
|
|
|
|
|
$database->table = "v_dialplan_details";
|
|
|
|
|
$database->fields['domain_uuid'] = $this->domain_uuid;
|
|
|
|
|
$database->fields['dialplan_uuid'] = $this->dialplan_uuid;
|
|
|
|
|
$database->fields['dialplan_detail_uuid'] = uuid();
|
|
|
|
|
$database->fields['dialplan_detail_tag'] = 'action'; //condition, action, antiaction
|
|
|
|
|
$database->fields['dialplan_detail_type'] = 'sleep';
|
|
|
|
|
$database->fields['dialplan_detail_data'] = '1000';
|
|
|
|
|
$database->fields['dialplan_detail_order'] = '015';
|
|
|
|
|
$database->add();
|
|
|
|
|
|
|
|
|
|
$database->table = "v_dialplan_details";
|
|
|
|
|
$database->fields['domain_uuid'] = $this->domain_uuid;
|
|
|
|
|
$database->fields['dialplan_uuid'] = $this->dialplan_uuid;
|
|
|
|
|
$database->fields['dialplan_detail_uuid'] = uuid();
|
|
|
|
|
$database->fields['dialplan_detail_tag'] = 'action'; //condition, action, antiaction
|
|
|
|
|
$database->fields['dialplan_detail_type'] = 'set';
|
|
|
|
|
$database->fields['dialplan_detail_data'] = 'hangup_after_bridge=true';
|
|
|
|
|
$database->fields['dialplan_detail_order'] = '020';
|
|
|
|
|
$database->add();
|
|
|
|
|
|
2012-08-16 00:02:13 +02:00
|
|
|
$database->table = "v_dialplan_details";
|
|
|
|
|
$database->fields['domain_uuid'] = $this->domain_uuid;
|
|
|
|
|
$database->fields['dialplan_uuid'] = $this->dialplan_uuid;
|
|
|
|
|
$database->fields['dialplan_detail_uuid'] = uuid();
|
|
|
|
|
$database->fields['dialplan_detail_tag'] = 'action'; //condition, action, antiaction
|
|
|
|
|
$database->fields['dialplan_detail_type'] = 'set';
|
|
|
|
|
if ($this->ivr_menu_ringback == "music" || $this->ivr_menu_ringback == "") {
|
|
|
|
|
$database->fields['dialplan_detail_data'] = 'ringback=${hold_music}';
|
|
|
|
|
}
|
|
|
|
|
else {
|
2012-10-21 10:14:08 +02:00
|
|
|
$database->fields['dialplan_detail_data'] = 'ringback='.$this->ivr_menu_ringback;
|
2012-08-16 00:02:13 +02:00
|
|
|
}
|
|
|
|
|
$database->fields['dialplan_detail_order'] = '025';
|
|
|
|
|
$database->add();
|
|
|
|
|
|
|
|
|
|
$database->table = "v_dialplan_details";
|
|
|
|
|
$database->fields['domain_uuid'] = $this->domain_uuid;
|
|
|
|
|
$database->fields['dialplan_uuid'] = $this->dialplan_uuid;
|
|
|
|
|
$database->fields['dialplan_detail_uuid'] = uuid();
|
|
|
|
|
$database->fields['dialplan_detail_tag'] = 'action'; //condition, action, antiaction
|
|
|
|
|
$database->fields['dialplan_detail_type'] = 'set';
|
|
|
|
|
if ($this->ivr_menu_ringback == "music" || $this->ivr_menu_ringback == "") {
|
|
|
|
|
$database->fields['dialplan_detail_data'] = 'transfer_ringback=${hold_music}';
|
|
|
|
|
}
|
|
|
|
|
else {
|
2012-10-21 10:14:08 +02:00
|
|
|
$database->fields['dialplan_detail_data'] = 'transfer_ringback='.$this->ivr_menu_ringback;
|
2012-08-16 00:02:13 +02:00
|
|
|
}
|
|
|
|
|
$database->fields['dialplan_detail_order'] = '030';
|
|
|
|
|
$database->add();
|
|
|
|
|
|
2012-06-04 16:58:40 +02:00
|
|
|
$database->table = "v_dialplan_details";
|
|
|
|
|
$database->fields['domain_uuid'] = $this->domain_uuid;
|
|
|
|
|
$database->fields['dialplan_uuid'] = $this->dialplan_uuid;
|
|
|
|
|
$database->fields['dialplan_detail_uuid'] = uuid();
|
|
|
|
|
$database->fields['dialplan_detail_tag'] = 'action'; //condition, action, antiaction
|
2012-11-24 23:01:55 +01:00
|
|
|
$database->fields['dialplan_detail_type'] = 'set';
|
|
|
|
|
$database->fields['dialplan_detail_data'] = 'ivr_menu_uuid='.$this->ivr_menu_uuid;
|
2012-08-16 00:02:13 +02:00
|
|
|
$database->fields['dialplan_detail_order'] = '035';
|
2012-06-04 16:58:40 +02:00
|
|
|
$database->add();
|
|
|
|
|
|
2012-11-24 23:01:55 +01:00
|
|
|
$database->table = "v_dialplan_details";
|
|
|
|
|
$database->fields['domain_uuid'] = $this->domain_uuid;
|
|
|
|
|
$database->fields['dialplan_uuid'] = $this->dialplan_uuid;
|
|
|
|
|
$database->fields['dialplan_detail_uuid'] = uuid();
|
|
|
|
|
$database->fields['dialplan_detail_tag'] = 'action'; //condition, action, antiaction
|
|
|
|
|
$database->fields['dialplan_detail_type'] = 'lua';
|
|
|
|
|
$database->fields['dialplan_detail_data'] = 'ivr_menu.lua';
|
|
|
|
|
$database->fields['dialplan_detail_order'] = '040';
|
|
|
|
|
$database->add();
|
|
|
|
|
|
2012-06-04 16:58:40 +02:00
|
|
|
if (strlen($this->ivr_menu_exit_app) > 0) {
|
|
|
|
|
$database->table = "v_dialplan_details";
|
|
|
|
|
$database->fields['domain_uuid'] = $this->domain_uuid;
|
|
|
|
|
$database->fields['dialplan_uuid'] = $this->dialplan_uuid;
|
|
|
|
|
$database->fields['dialplan_detail_uuid'] = uuid();
|
|
|
|
|
$database->fields['dialplan_detail_tag'] = 'action'; //condition, action, antiaction
|
|
|
|
|
$database->fields['dialplan_detail_type'] = $this->ivr_menu_exit_app;
|
|
|
|
|
$database->fields['dialplan_detail_data'] = $this->ivr_menu_exit_data;
|
2012-11-24 23:01:55 +01:00
|
|
|
$database->fields['dialplan_detail_order'] = '045';
|
2012-06-04 16:58:40 +02:00
|
|
|
$database->add();
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
//add the ivr menu
|
|
|
|
|
$database = new database;
|
|
|
|
|
if ($this->db) {
|
|
|
|
|
$database->db = $this->db;
|
|
|
|
|
}
|
|
|
|
|
$database->table = "v_ivr_menus";
|
|
|
|
|
$database->fields['domain_uuid'] = $this->domain_uuid;
|
|
|
|
|
if (strlen($this->ivr_menu_extension) > 0) {
|
|
|
|
|
$database->fields['ivr_menu_extension'] = $this->ivr_menu_extension;
|
|
|
|
|
$database->fields['dialplan_uuid'] = $this->dialplan_uuid;
|
|
|
|
|
}
|
|
|
|
|
$database->fields['ivr_menu_uuid'] = $this->ivr_menu_uuid;
|
|
|
|
|
$database->fields['ivr_menu_name'] = $this->ivr_menu_name;
|
|
|
|
|
$database->fields['ivr_menu_greet_long'] = $this->ivr_menu_greet_long;
|
|
|
|
|
$database->fields['ivr_menu_greet_short'] = $this->ivr_menu_greet_short;
|
|
|
|
|
$database->fields['ivr_menu_invalid_sound'] = $this->ivr_menu_invalid_sound;
|
|
|
|
|
$database->fields['ivr_menu_exit_sound'] = $this->ivr_menu_exit_sound;
|
|
|
|
|
$database->fields['ivr_menu_confirm_macro'] = $this->ivr_menu_confirm_macro;
|
|
|
|
|
$database->fields['ivr_menu_confirm_key'] = $this->ivr_menu_confirm_key;
|
|
|
|
|
$database->fields['ivr_menu_tts_engine'] = $this->ivr_menu_tts_engine;
|
|
|
|
|
$database->fields['ivr_menu_tts_voice'] = $this->ivr_menu_tts_voice;
|
|
|
|
|
$database->fields['ivr_menu_confirm_attempts'] = $this->ivr_menu_confirm_attempts;
|
|
|
|
|
$database->fields['ivr_menu_timeout'] = $this->ivr_menu_timeout;
|
|
|
|
|
$database->fields['ivr_menu_exit_app'] = $this->ivr_menu_exit_app;
|
|
|
|
|
$database->fields['ivr_menu_exit_data'] = $this->ivr_menu_exit_data;
|
|
|
|
|
$database->fields['ivr_menu_inter_digit_timeout'] = $this->ivr_menu_inter_digit_timeout;
|
|
|
|
|
$database->fields['ivr_menu_max_failures'] = $this->ivr_menu_max_failures;
|
|
|
|
|
$database->fields['ivr_menu_max_timeouts'] = $this->ivr_menu_max_timeouts;
|
|
|
|
|
$database->fields['ivr_menu_max_timeouts'] = $this->ivr_menu_max_timeouts;
|
|
|
|
|
$database->fields['ivr_menu_digit_len'] = $this->ivr_menu_digit_len;
|
|
|
|
|
$database->fields['ivr_menu_digit_len'] = $this->ivr_menu_digit_len;
|
|
|
|
|
$database->fields['ivr_menu_direct_dial'] = $this->ivr_menu_direct_dial;
|
2012-08-16 00:02:13 +02:00
|
|
|
$database->fields['ivr_menu_ringback'] = $this->ivr_menu_ringback;
|
2013-02-12 12:19:52 +01:00
|
|
|
$database->fields['ivr_menu_cid_prefix'] = $this->ivr_menu_cid_prefix;
|
2012-06-04 16:58:40 +02:00
|
|
|
$database->fields['ivr_menu_enabled'] = $this->ivr_menu_enabled;
|
|
|
|
|
$database->fields['ivr_menu_description'] = $this->ivr_menu_description;
|
|
|
|
|
$database->add();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
//add the ivr menu option
|
|
|
|
|
if (strlen($this->ivr_menu_option_action) > 0) {
|
|
|
|
|
$database = new database;
|
|
|
|
|
if ($this->db) {
|
|
|
|
|
$database->db = $this->db;
|
|
|
|
|
}
|
|
|
|
|
$database->table = "v_ivr_menu_options";
|
|
|
|
|
$database->fields['domain_uuid'] = $this->domain_uuid;
|
|
|
|
|
$database->fields['ivr_menu_uuid'] = $this->ivr_menu_uuid;
|
|
|
|
|
$database->fields['ivr_menu_option_uuid'] = $this->ivr_menu_option_uuid;
|
|
|
|
|
$database->fields['ivr_menu_option_digits'] = $this->ivr_menu_option_digits;
|
|
|
|
|
$database->fields['ivr_menu_option_action'] = $this->ivr_menu_option_action;
|
|
|
|
|
$database->fields['ivr_menu_option_param'] = $this->ivr_menu_option_param;
|
|
|
|
|
$database->fields['ivr_menu_option_order'] = $this->ivr_menu_option_order;
|
|
|
|
|
$database->fields['ivr_menu_option_description'] = $this->ivr_menu_option_description;
|
|
|
|
|
$database->add();
|
|
|
|
|
}
|
2013-01-16 01:26:48 +01:00
|
|
|
|
|
|
|
|
//delete the dialplan context from memcache
|
|
|
|
|
$fp = event_socket_create($_SESSION['event_socket_ip_address'], $_SESSION['event_socket_port'], $_SESSION['event_socket_password']);
|
|
|
|
|
if ($fp) {
|
|
|
|
|
$switch_cmd .= "memcache delete dialplan:".$_SESSION["context"]."@".$_SESSION['domain_name'];
|
|
|
|
|
$switch_result = event_socket_request($fp, 'api '.$switch_cmd);
|
|
|
|
|
}
|
2012-06-04 16:58:40 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public function update() {
|
|
|
|
|
|
|
|
|
|
//udate the ivr menu
|
|
|
|
|
if (strlen($this->ivr_menu_option_action) == 0) {
|
|
|
|
|
//get the dialplan uuid
|
|
|
|
|
$database = new database;
|
|
|
|
|
if ($this->db) {
|
|
|
|
|
$database->db = $this->db;
|
|
|
|
|
}
|
|
|
|
|
$database->table = "v_ivr_menus";
|
|
|
|
|
$database->where[0]['name'] = 'domain_uuid';
|
|
|
|
|
$database->where[0]['value'] = $this->domain_uuid;
|
|
|
|
|
$database->where[0]['operator'] = '=';
|
|
|
|
|
$database->where[1]['name'] = 'ivr_menu_uuid';
|
|
|
|
|
$database->where[1]['value'] = $this->ivr_menu_uuid;
|
|
|
|
|
$database->where[1]['operator'] = '=';
|
|
|
|
|
$result = $database->find();
|
|
|
|
|
foreach($result as $row) {
|
|
|
|
|
$this->dialplan_uuid = $row['dialplan_uuid'];
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
//if the extension number is empty and the dialplan exists then delete the dialplan
|
|
|
|
|
if (strlen($this->ivr_menu_extension) == 0) {
|
|
|
|
|
if (strlen($this->dialplan_uuid) > 0) {
|
|
|
|
|
//delete dialplan entry
|
|
|
|
|
$database = new database;
|
|
|
|
|
$database->table = "v_dialplan_details";
|
|
|
|
|
$database->where[0]['name'] = 'domain_uuid';
|
|
|
|
|
$database->where[0]['value'] = $this->domain_uuid;
|
|
|
|
|
$database->where[0]['operator'] = '=';
|
|
|
|
|
$database->where[1]['name'] = 'dialplan_uuid';
|
|
|
|
|
$database->where[1]['value'] = $this->dialplan_uuid;
|
|
|
|
|
$database->where[1]['operator'] = '=';
|
|
|
|
|
$database->delete();
|
|
|
|
|
|
|
|
|
|
//delete the child dialplan information
|
|
|
|
|
$database = new database;
|
|
|
|
|
$database->table = "v_dialplans";
|
|
|
|
|
$database->where[0]['name'] = 'domain_uuid';
|
|
|
|
|
$database->where[0]['value'] = $this->domain_uuid;
|
|
|
|
|
$database->where[0]['operator'] = '=';
|
|
|
|
|
$database->where[1]['name'] = 'dialplan_uuid';
|
|
|
|
|
$database->where[1]['value'] = $this->dialplan_uuid;
|
|
|
|
|
$database->where[1]['operator'] = '=';
|
|
|
|
|
$database->delete();
|
|
|
|
|
//update the table to remove the dialplan_uuid
|
|
|
|
|
$this->dialplan_uuid = '';
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
//update the ivr menu
|
2012-08-04 18:34:24 +02:00
|
|
|
if (strlen($this->dialplan_uuid) == 0) {
|
|
|
|
|
$this->dialplan_uuid = uuid();
|
|
|
|
|
}
|
2012-06-04 16:58:40 +02:00
|
|
|
$database = new database;
|
|
|
|
|
$database->table = "v_ivr_menus";
|
|
|
|
|
$database->fields['ivr_menu_uuid'] = $this->ivr_menu_uuid;
|
|
|
|
|
$database->fields['dialplan_uuid'] = $this->dialplan_uuid;
|
|
|
|
|
$database->fields['ivr_menu_name'] = $this->ivr_menu_name;
|
|
|
|
|
$database->fields['ivr_menu_extension'] = $this->ivr_menu_extension;
|
|
|
|
|
$database->fields['ivr_menu_greet_long'] = $this->ivr_menu_greet_long;
|
|
|
|
|
$database->fields['ivr_menu_greet_short'] = $this->ivr_menu_greet_short;
|
|
|
|
|
$database->fields['ivr_menu_invalid_sound'] = $this->ivr_menu_invalid_sound;
|
|
|
|
|
$database->fields['ivr_menu_exit_sound'] = $this->ivr_menu_exit_sound;
|
|
|
|
|
$database->fields['ivr_menu_confirm_macro'] = $this->ivr_menu_confirm_macro;
|
|
|
|
|
$database->fields['ivr_menu_confirm_key'] = $this->ivr_menu_confirm_key;
|
|
|
|
|
$database->fields['ivr_menu_tts_engine'] = $this->ivr_menu_tts_engine;
|
|
|
|
|
$database->fields['ivr_menu_tts_voice'] = $this->ivr_menu_tts_voice;
|
|
|
|
|
$database->fields['ivr_menu_confirm_attempts'] = $this->ivr_menu_confirm_attempts;
|
|
|
|
|
$database->fields['ivr_menu_timeout'] = $this->ivr_menu_timeout;
|
|
|
|
|
$database->fields['ivr_menu_exit_app'] = $this->ivr_menu_exit_app;
|
|
|
|
|
$database->fields['ivr_menu_exit_data'] = $this->ivr_menu_exit_data;
|
|
|
|
|
$database->fields['ivr_menu_inter_digit_timeout'] = $this->ivr_menu_inter_digit_timeout;
|
|
|
|
|
$database->fields['ivr_menu_max_failures'] = $this->ivr_menu_max_failures;
|
|
|
|
|
$database->fields['ivr_menu_max_timeouts'] = $this->ivr_menu_max_timeouts;
|
|
|
|
|
$database->fields['ivr_menu_max_timeouts'] = $this->ivr_menu_max_timeouts;
|
|
|
|
|
$database->fields['ivr_menu_digit_len'] = $this->ivr_menu_digit_len;
|
|
|
|
|
$database->fields['ivr_menu_digit_len'] = $this->ivr_menu_digit_len;
|
|
|
|
|
$database->fields['ivr_menu_direct_dial'] = $this->ivr_menu_direct_dial;
|
2012-08-16 00:02:13 +02:00
|
|
|
$database->fields['ivr_menu_ringback'] = $this->ivr_menu_ringback;
|
2013-02-12 12:19:52 +01:00
|
|
|
$database->fields['ivr_menu_cid_prefix'] = $this->ivr_menu_cid_prefix;
|
2012-06-04 16:58:40 +02:00
|
|
|
$database->fields['ivr_menu_enabled'] = $this->ivr_menu_enabled;
|
|
|
|
|
$database->fields['ivr_menu_description'] = $this->ivr_menu_description;
|
|
|
|
|
$database->where[0]['name'] = 'domain_uuid';
|
|
|
|
|
$database->where[0]['value'] = $this->domain_uuid;
|
|
|
|
|
$database->where[0]['operator'] = '=';
|
|
|
|
|
$database->where[1]['name'] = 'ivr_menu_uuid';
|
|
|
|
|
$database->where[1]['value'] = $this->ivr_menu_uuid;
|
|
|
|
|
$database->where[1]['operator'] = '=';
|
|
|
|
|
$database->update();
|
|
|
|
|
|
2012-08-04 18:34:24 +02:00
|
|
|
//check to see if the dialplan entry exists
|
|
|
|
|
$dialplan = new dialplan;
|
|
|
|
|
$dialplan->domain_uuid = $_SESSION["domain_uuid"];
|
|
|
|
|
$dialplan->dialplan_uuid = $this->dialplan_uuid;
|
|
|
|
|
$dialplan_exists = $dialplan->dialplan_exists();
|
|
|
|
|
|
|
|
|
|
//if the dialplan entry does not exist then add it
|
|
|
|
|
if (!$dialplan_exists) {
|
2012-06-04 16:58:40 +02:00
|
|
|
$database = new database;
|
|
|
|
|
$database->table = "v_dialplans";
|
|
|
|
|
$database->fields['dialplan_name'] = $this->ivr_menu_name;
|
|
|
|
|
$database->fields['dialplan_order'] = '333';
|
|
|
|
|
$database->fields['dialplan_context'] = $_SESSION['context'];
|
|
|
|
|
$database->fields['dialplan_enabled'] = $this->ivr_menu_enabled;
|
|
|
|
|
$database->fields['dialplan_description'] = $this->ivr_menu_description;
|
|
|
|
|
$database->fields['app_uuid'] = $this->app_uuid;
|
2012-07-19 00:28:14 +02:00
|
|
|
$database->fields['domain_uuid'] = $this->domain_uuid;
|
|
|
|
|
$database->fields['dialplan_uuid'] = $this->dialplan_uuid;
|
|
|
|
|
$database->add();
|
2012-08-04 18:34:24 +02:00
|
|
|
}
|
|
|
|
|
//if the dialplan entry exists then update it
|
|
|
|
|
if ($dialplan_exists && strlen($this->ivr_menu_extension) > 0) {
|
|
|
|
|
//update the dialplan
|
|
|
|
|
$database = new database;
|
|
|
|
|
$database->table = "v_dialplans";
|
|
|
|
|
$database->fields['dialplan_name'] = $this->ivr_menu_name;
|
|
|
|
|
$database->fields['dialplan_order'] = '333';
|
|
|
|
|
$database->fields['dialplan_context'] = $_SESSION['context'];
|
|
|
|
|
$database->fields['dialplan_enabled'] = $this->ivr_menu_enabled;
|
|
|
|
|
$database->fields['dialplan_description'] = $this->ivr_menu_description;
|
|
|
|
|
$database->fields['app_uuid'] = $this->app_uuid;
|
|
|
|
|
$database->fields['domain_uuid'] = $this->domain_uuid;
|
|
|
|
|
$database->fields['dialplan_uuid'] = $this->dialplan_uuid;
|
|
|
|
|
$database->where[0]['name'] = 'domain_uuid';
|
|
|
|
|
$database->where[0]['value'] = $this->domain_uuid;
|
|
|
|
|
$database->where[0]['operator'] = '=';
|
|
|
|
|
$database->where[1]['name'] = 'dialplan_uuid';
|
|
|
|
|
$database->where[1]['value'] = $this->dialplan_uuid;
|
|
|
|
|
$database->where[1]['operator'] = '=';
|
|
|
|
|
$database->update();
|
|
|
|
|
|
|
|
|
|
//delete the old dialplan details to prepare for new details
|
|
|
|
|
$database = new database;
|
|
|
|
|
$database->table = "v_dialplan_details";
|
|
|
|
|
$database->where[0]['name'] = 'domain_uuid';
|
|
|
|
|
$database->where[0]['value'] = $this->domain_uuid;
|
|
|
|
|
$database->where[0]['operator'] = '=';
|
|
|
|
|
$database->where[1]['name'] = 'dialplan_uuid';
|
|
|
|
|
$database->where[1]['value'] = $this->dialplan_uuid;
|
|
|
|
|
$database->where[1]['operator'] = '=';
|
|
|
|
|
$database->delete();
|
|
|
|
|
}
|
2012-06-04 16:58:40 +02:00
|
|
|
|
|
|
|
|
//add the dialplan details
|
|
|
|
|
$detail_data = '^'.$this->ivr_menu_extension.'$';
|
|
|
|
|
$database->table = "v_dialplan_details";
|
|
|
|
|
$database->fields['domain_uuid'] = $this->domain_uuid;
|
|
|
|
|
$database->fields['dialplan_uuid'] = $this->dialplan_uuid;
|
|
|
|
|
$database->fields['dialplan_detail_uuid'] = uuid();
|
|
|
|
|
$database->fields['dialplan_detail_tag'] = 'condition'; //condition, action, antiaction
|
|
|
|
|
$database->fields['dialplan_detail_type'] = 'destination_number';
|
|
|
|
|
$database->fields['dialplan_detail_data'] = $detail_data;
|
|
|
|
|
$database->fields['dialplan_detail_order'] = '005';
|
|
|
|
|
$database->add();
|
|
|
|
|
|
2012-09-28 03:55:14 +02:00
|
|
|
$database->table = "v_dialplan_details";
|
|
|
|
|
$database->fields['domain_uuid'] = $this->domain_uuid;
|
|
|
|
|
$database->fields['dialplan_uuid'] = $this->dialplan_uuid;
|
|
|
|
|
$database->fields['dialplan_detail_uuid'] = uuid();
|
|
|
|
|
$database->fields['dialplan_detail_tag'] = 'action'; //condition, action, antiaction
|
|
|
|
|
$database->fields['dialplan_detail_type'] = 'answer';
|
|
|
|
|
$database->fields['dialplan_detail_data'] = '';
|
|
|
|
|
$database->fields['dialplan_detail_order'] = '010';
|
|
|
|
|
$database->add();
|
2012-06-04 16:58:40 +02:00
|
|
|
|
|
|
|
|
$database->table = "v_dialplan_details";
|
|
|
|
|
$database->fields['domain_uuid'] = $this->domain_uuid;
|
|
|
|
|
$database->fields['dialplan_uuid'] = $this->dialplan_uuid;
|
|
|
|
|
$database->fields['dialplan_detail_uuid'] = uuid();
|
|
|
|
|
$database->fields['dialplan_detail_tag'] = 'action'; //condition, action, antiaction
|
|
|
|
|
$database->fields['dialplan_detail_type'] = 'sleep';
|
|
|
|
|
$database->fields['dialplan_detail_data'] = '1000';
|
|
|
|
|
$database->fields['dialplan_detail_order'] = '015';
|
|
|
|
|
$database->add();
|
|
|
|
|
|
|
|
|
|
$database->table = "v_dialplan_details";
|
|
|
|
|
$database->fields['domain_uuid'] = $this->domain_uuid;
|
|
|
|
|
$database->fields['dialplan_uuid'] = $this->dialplan_uuid;
|
|
|
|
|
$database->fields['dialplan_detail_uuid'] = uuid();
|
|
|
|
|
$database->fields['dialplan_detail_tag'] = 'action'; //condition, action, antiaction
|
|
|
|
|
$database->fields['dialplan_detail_type'] = 'set';
|
|
|
|
|
$database->fields['dialplan_detail_data'] = 'hangup_after_bridge=true';
|
|
|
|
|
$database->fields['dialplan_detail_order'] = '020';
|
|
|
|
|
$database->add();
|
|
|
|
|
|
2012-08-16 00:02:13 +02:00
|
|
|
$database->table = "v_dialplan_details";
|
|
|
|
|
$database->fields['domain_uuid'] = $this->domain_uuid;
|
|
|
|
|
$database->fields['dialplan_uuid'] = $this->dialplan_uuid;
|
|
|
|
|
$database->fields['dialplan_detail_uuid'] = uuid();
|
|
|
|
|
$database->fields['dialplan_detail_tag'] = 'action'; //condition, action, antiaction
|
|
|
|
|
$database->fields['dialplan_detail_type'] = 'set';
|
|
|
|
|
if ($this->ivr_menu_ringback == "music" || $this->ivr_menu_ringback == "") {
|
|
|
|
|
$database->fields['dialplan_detail_data'] = 'ringback=${hold_music}';
|
|
|
|
|
}
|
|
|
|
|
else {
|
2012-10-21 10:14:08 +02:00
|
|
|
$database->fields['dialplan_detail_data'] = 'ringback='.$this->ivr_menu_ringback;
|
2012-08-16 00:02:13 +02:00
|
|
|
}
|
|
|
|
|
$database->fields['dialplan_detail_order'] = '025';
|
|
|
|
|
$database->add();
|
|
|
|
|
|
|
|
|
|
$database->table = "v_dialplan_details";
|
|
|
|
|
$database->fields['domain_uuid'] = $this->domain_uuid;
|
|
|
|
|
$database->fields['dialplan_uuid'] = $this->dialplan_uuid;
|
|
|
|
|
$database->fields['dialplan_detail_uuid'] = uuid();
|
|
|
|
|
$database->fields['dialplan_detail_tag'] = 'action'; //condition, action, antiaction
|
|
|
|
|
$database->fields['dialplan_detail_type'] = 'set';
|
|
|
|
|
if ($this->ivr_menu_ringback == "music" || $this->ivr_menu_ringback == "") {
|
|
|
|
|
$database->fields['dialplan_detail_data'] = 'transfer_ringback=${hold_music}';
|
|
|
|
|
}
|
|
|
|
|
else {
|
2012-10-21 10:14:08 +02:00
|
|
|
$database->fields['dialplan_detail_data'] = 'transfer_ringback='.$this->ivr_menu_ringback;
|
2012-08-16 00:02:13 +02:00
|
|
|
}
|
|
|
|
|
$database->fields['dialplan_detail_order'] = '030';
|
|
|
|
|
$database->add();
|
|
|
|
|
|
2012-11-25 05:21:31 +01:00
|
|
|
$database->table = "v_dialplan_details";
|
|
|
|
|
$database->fields['domain_uuid'] = $this->domain_uuid;
|
|
|
|
|
$database->fields['dialplan_uuid'] = $this->dialplan_uuid;
|
|
|
|
|
$database->fields['dialplan_detail_uuid'] = uuid();
|
|
|
|
|
$database->fields['dialplan_detail_tag'] = 'action'; //condition, action, antiaction
|
|
|
|
|
$database->fields['dialplan_detail_type'] = 'set';
|
|
|
|
|
$database->fields['dialplan_detail_data'] = 'ivr_menu_uuid='.$this->ivr_menu_uuid;
|
|
|
|
|
$database->fields['dialplan_detail_order'] = '035';
|
|
|
|
|
$database->add();
|
|
|
|
|
|
|
|
|
|
$database->table = "v_dialplan_details";
|
|
|
|
|
$database->fields['domain_uuid'] = $this->domain_uuid;
|
|
|
|
|
$database->fields['dialplan_uuid'] = $this->dialplan_uuid;
|
|
|
|
|
$database->fields['dialplan_detail_uuid'] = uuid();
|
|
|
|
|
$database->fields['dialplan_detail_tag'] = 'action'; //condition, action, antiaction
|
|
|
|
|
$database->fields['dialplan_detail_type'] = 'lua';
|
|
|
|
|
$database->fields['dialplan_detail_data'] = 'ivr_menu.lua';
|
|
|
|
|
$database->fields['dialplan_detail_order'] = '040';
|
|
|
|
|
$database->add();
|
2012-06-04 16:58:40 +02:00
|
|
|
|
|
|
|
|
if (strlen($this->ivr_menu_exit_app) > 0) {
|
|
|
|
|
$database->table = "v_dialplan_details";
|
|
|
|
|
$database->fields['domain_uuid'] = $this->domain_uuid;
|
|
|
|
|
$database->fields['dialplan_uuid'] = $this->dialplan_uuid;
|
|
|
|
|
$database->fields['dialplan_detail_uuid'] = uuid();
|
|
|
|
|
$database->fields['dialplan_detail_tag'] = 'action'; //condition, action, antiaction
|
|
|
|
|
$database->fields['dialplan_detail_type'] = $this->ivr_menu_exit_app;
|
|
|
|
|
$database->fields['dialplan_detail_data'] = $this->ivr_menu_exit_data;
|
2013-05-03 08:58:13 +02:00
|
|
|
$database->fields['dialplan_detail_order'] = '045';
|
2012-06-04 16:58:40 +02:00
|
|
|
$database->add();
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
//update the ivr menu option
|
|
|
|
|
if (strlen($this->ivr_menu_option_action) > 0) {
|
|
|
|
|
$database = new database;
|
|
|
|
|
$database->table = "v_ivr_menu_options";
|
|
|
|
|
$database->fields['ivr_menu_option_digits'] = $this->ivr_menu_option_digits;
|
|
|
|
|
$database->fields['ivr_menu_option_action'] = $this->ivr_menu_option_action;
|
|
|
|
|
$database->fields['ivr_menu_option_param'] = $this->ivr_menu_option_param;
|
|
|
|
|
$database->fields['ivr_menu_option_order'] = $this->ivr_menu_option_order;
|
|
|
|
|
$database->fields['ivr_menu_option_description'] = $this->ivr_menu_option_description;
|
|
|
|
|
$database->where[0]['name'] = 'domain_uuid';
|
|
|
|
|
$database->where[0]['value'] = $this->domain_uuid;
|
|
|
|
|
$database->where[0]['operator'] = '=';
|
|
|
|
|
$database->where[1]['name'] = 'ivr_menu_uuid';
|
|
|
|
|
$database->where[1]['value'] = $this->ivr_menu_uuid;
|
|
|
|
|
$database->where[1]['operator'] = '=';
|
|
|
|
|
$database->where[2]['name'] = 'ivr_menu_option_uuid';
|
|
|
|
|
$database->where[2]['value'] = $this->ivr_menu_option_uuid;
|
|
|
|
|
$database->where[2]['operator'] = '=';
|
|
|
|
|
$database->update();
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
function delete() {
|
|
|
|
|
//create the database object
|
|
|
|
|
$database = new database;
|
|
|
|
|
if ($this->db) {
|
|
|
|
|
$database->db = $this->db;
|
|
|
|
|
}
|
|
|
|
|
//start the transaction
|
|
|
|
|
//$count = $database->db->exec("BEGIN;");
|
|
|
|
|
|
|
|
|
|
//delete the ivr menu option
|
|
|
|
|
if (strlen($this->ivr_menu_option_uuid) > 0) {
|
|
|
|
|
$database->table = "v_ivr_menu_options";
|
|
|
|
|
$database->where[0]['name'] = 'domain_uuid';
|
|
|
|
|
$database->where[0]['value'] = $this->domain_uuid;
|
|
|
|
|
$database->where[0]['operator'] = '=';
|
|
|
|
|
$database->where[1]['name'] = 'ivr_menu_option_uuid';
|
|
|
|
|
$database->where[1]['value'] = $this->ivr_menu_option_uuid;
|
|
|
|
|
$database->where[1]['operator'] = '=';
|
|
|
|
|
$database->delete();
|
|
|
|
|
unset($this->ivr_menu_option_uuid);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
//delete the ivr menu
|
|
|
|
|
if (strlen($this->ivr_menu_option_uuid) == 0) {
|
|
|
|
|
//select the dialplan entries
|
|
|
|
|
$database->table = "v_ivr_menus";
|
|
|
|
|
$database->where[0]['name'] = 'domain_uuid';
|
|
|
|
|
$database->where[0]['value'] = $this->domain_uuid;
|
|
|
|
|
$database->where[0]['operator'] = '=';
|
|
|
|
|
$database->where[1]['name'] = 'ivr_menu_uuid';
|
|
|
|
|
$database->where[1]['value'] = $this->ivr_menu_uuid;
|
|
|
|
|
$database->where[1]['operator'] = '=';
|
|
|
|
|
$result = $database->find();
|
|
|
|
|
foreach($result as $row) {
|
|
|
|
|
$this->dialplan_uuid = $row['dialplan_uuid'];
|
|
|
|
|
//delete the child dialplan information
|
|
|
|
|
$database->table = "v_dialplan_details";
|
|
|
|
|
$database->where[0]['name'] = 'domain_uuid';
|
|
|
|
|
$database->where[0]['value'] = $this->domain_uuid;
|
|
|
|
|
$database->where[0]['operator'] = '=';
|
|
|
|
|
$database->where[1]['name'] = 'dialplan_uuid';
|
|
|
|
|
$database->where[1]['value'] = $this->dialplan_uuid;
|
|
|
|
|
$database->where[1]['operator'] = '=';
|
|
|
|
|
$database->delete();
|
|
|
|
|
//delete the dialplan information
|
|
|
|
|
$database->table = "v_dialplans";
|
|
|
|
|
$database->where[0]['name'] = 'domain_uuid';
|
|
|
|
|
$database->where[0]['value'] = $this->domain_uuid;
|
|
|
|
|
$database->where[0]['operator'] = '=';
|
|
|
|
|
$database->where[1]['name'] = 'dialplan_uuid';
|
|
|
|
|
$database->where[1]['value'] = $this->dialplan_uuid;
|
|
|
|
|
$database->where[1]['operator'] = '=';
|
|
|
|
|
$database->delete();
|
|
|
|
|
}
|
|
|
|
|
|
2013-01-16 01:26:48 +01:00
|
|
|
//delete child data
|
|
|
|
|
$database->table = "v_ivr_menu_options";
|
|
|
|
|
$database->where[0]['name'] = 'domain_uuid';
|
|
|
|
|
$database->where[0]['value'] = $this->domain_uuid;
|
|
|
|
|
$database->where[0]['operator'] = '=';
|
|
|
|
|
$database->where[1]['name'] = 'ivr_menu_uuid';
|
|
|
|
|
$database->where[1]['value'] = $this->ivr_menu_uuid;
|
|
|
|
|
$database->where[1]['operator'] = '=';
|
|
|
|
|
$database->delete();
|
|
|
|
|
|
|
|
|
|
//delete parent data
|
|
|
|
|
$database->table = "v_ivr_menus";
|
|
|
|
|
$database->where[0]['name'] = 'domain_uuid';
|
|
|
|
|
$database->where[0]['value'] = $this->domain_uuid;
|
|
|
|
|
$database->where[0]['operator'] = '=';
|
|
|
|
|
$database->where[1]['name'] = 'ivr_menu_uuid';
|
|
|
|
|
$database->where[1]['value'] = $this->ivr_menu_uuid;
|
|
|
|
|
$database->where[1]['operator'] = '=';
|
|
|
|
|
$database->delete();
|
|
|
|
|
|
|
|
|
|
//delete the dialplan context from memcache
|
|
|
|
|
$fp = event_socket_create($_SESSION['event_socket_ip_address'], $_SESSION['event_socket_port'], $_SESSION['event_socket_password']);
|
|
|
|
|
if ($fp) {
|
2013-09-28 22:57:57 +02:00
|
|
|
$switch_cmd = "memcache delete dialplan:".$_SESSION["context"];
|
2013-01-16 01:26:48 +01:00
|
|
|
$switch_result = event_socket_request($fp, 'api '.$switch_cmd);
|
|
|
|
|
}
|
2012-06-04 16:58:40 +02:00
|
|
|
|
|
|
|
|
//commit the transaction
|
|
|
|
|
//$count = $database->db->exec("COMMIT;");
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
function get_xml(){
|
2014-07-18 04:06:43 +02:00
|
|
|
/*
|
2014-07-18 02:31:07 +02:00
|
|
|
//set the global variables
|
|
|
|
|
global $db;
|
|
|
|
|
|
|
|
|
|
//prepare for dialplan .xml files to be written. delete all dialplan files that are prefixed with dialplan_ and have a file extension of .xml
|
|
|
|
|
if (count($_SESSION["domains"]) > 1) {
|
|
|
|
|
$v_needle = 'v_'.$_SESSION['domain_name'].'_';
|
|
|
|
|
}
|
|
|
|
|
else {
|
|
|
|
|
$v_needle = 'v_';
|
|
|
|
|
}
|
|
|
|
|
if($dh = opendir($_SESSION['switch']['conf']['dir']."/ivr_menus/")) {
|
|
|
|
|
$files = Array();
|
|
|
|
|
while($file = readdir($dh)) {
|
|
|
|
|
if($file != "." && $file != ".." && $file[0] != '.') {
|
|
|
|
|
if(is_dir($dir . "/" . $file)) {
|
|
|
|
|
//this is a directory
|
|
|
|
|
} else {
|
|
|
|
|
if (strpos($file, $v_needle) !== false && substr($file,-4) == '.xml') {
|
|
|
|
|
//echo "file: $file<br />\n";
|
|
|
|
|
unlink($_SESSION['switch']['conf']['dir']."/ivr_menus/".$file);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
closedir($dh);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
$sql = "select * from v_ivr_menus ";
|
|
|
|
|
$sql .= "where domain_uuid = '".$_SESSION['domain_uuid']."' ";
|
|
|
|
|
$prep_statement = $db->prepare(check_sql($sql));
|
|
|
|
|
$prep_statement->execute();
|
|
|
|
|
$result = $prep_statement->fetchAll(PDO::FETCH_ASSOC);
|
|
|
|
|
$result_count = count($result);
|
|
|
|
|
unset ($prep_statement, $sql);
|
|
|
|
|
if ($result_count > 0) {
|
|
|
|
|
foreach($result as $row) {
|
|
|
|
|
$dialplan_uuid = $row["dialplan_uuid"];
|
|
|
|
|
$ivr_menu_uuid = $row["ivr_menu_uuid"];
|
|
|
|
|
$ivr_menu_name = check_str($row["ivr_menu_name"]);
|
|
|
|
|
$ivr_menu_extension = $row["ivr_menu_extension"];
|
|
|
|
|
$ivr_menu_greet_long = $row["ivr_menu_greet_long"];
|
|
|
|
|
$ivr_menu_greet_short = $row["ivr_menu_greet_short"];
|
|
|
|
|
$ivr_menu_invalid_sound = $row["ivr_menu_invalid_sound"];
|
|
|
|
|
$ivr_menu_exit_sound = $row["ivr_menu_exit_sound"];
|
|
|
|
|
$ivr_menu_confirm_macro = $row["ivr_menu_confirm_macro"];
|
|
|
|
|
$ivr_menu_confirm_key = $row["ivr_menu_confirm_key"];
|
|
|
|
|
$ivr_menu_tts_engine = $row["ivr_menu_tts_engine"];
|
|
|
|
|
$ivr_menu_tts_voice = $row["ivr_menu_tts_voice"];
|
|
|
|
|
$ivr_menu_confirm_attempts = $row["ivr_menu_confirm_attempts"];
|
|
|
|
|
$ivr_menu_timeout = $row["ivr_menu_timeout"];
|
|
|
|
|
$ivr_menu_exit_app = $row["ivr_menu_exit_app"];
|
|
|
|
|
$ivr_menu_exit_data = $row["ivr_menu_exit_data"];
|
|
|
|
|
$ivr_menu_inter_digit_timeout = $row["ivr_menu_inter_digit_timeout"];
|
|
|
|
|
$ivr_menu_max_failures = $row["ivr_menu_max_failures"];
|
|
|
|
|
$ivr_menu_max_timeouts = $row["ivr_menu_max_timeouts"];
|
|
|
|
|
$ivr_menu_digit_len = $row["ivr_menu_digit_len"];
|
|
|
|
|
$ivr_menu_direct_dial = $row["ivr_menu_direct_dial"];
|
|
|
|
|
$ivr_menu_enabled = $row["ivr_menu_enabled"];
|
|
|
|
|
$ivr_menu_description = check_str($row["ivr_menu_description"]);
|
|
|
|
|
|
|
|
|
|
//replace space with an underscore
|
|
|
|
|
$ivr_menu_name = str_replace(" ", "_", $ivr_menu_name);
|
|
|
|
|
|
|
|
|
|
//add each IVR menu to the XML config
|
|
|
|
|
$tmp = "<include>\n";
|
|
|
|
|
if (strlen($ivr_menu_description) > 0) {
|
|
|
|
|
$tmp .= " <!-- $ivr_menu_description -->\n";
|
|
|
|
|
}
|
|
|
|
|
if (count($_SESSION["domains"]) > 1) {
|
2014-07-18 04:06:43 +02:00
|
|
|
$tmp .= " <menu name=\"".$_SESSION['domains'][$_SESSION['domain_uuid']['domain_name']."-".$ivr_menu_name."\n";
|
2014-07-18 02:31:07 +02:00
|
|
|
}
|
|
|
|
|
else {
|
|
|
|
|
$tmp .= " <menu name=\"$ivr_menu_name\"\n";
|
|
|
|
|
}
|
|
|
|
|
if (stripos($ivr_menu_greet_long, 'mp3') !== false || stripos($ivr_menu_greet_long, 'wav') !== false) {
|
|
|
|
|
//found wav or mp3
|
|
|
|
|
$tmp .= " greet-long=\"".$ivr_menu_greet_long."\"\n";
|
|
|
|
|
}
|
|
|
|
|
else {
|
|
|
|
|
//not found
|
|
|
|
|
$tmp .= " greet-long=\"".$ivr_menu_greet_long."\"\n";
|
|
|
|
|
}
|
|
|
|
|
if (stripos($ivr_menu_greet_short, 'mp3') !== false || stripos($ivr_menu_greet_short, 'wav') !== false) {
|
|
|
|
|
if (strlen($ivr_menu_greet_short) > 0) {
|
|
|
|
|
$tmp .= " greet-short=\"".$ivr_menu_greet_short."\"\n";
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
else {
|
|
|
|
|
//not found
|
|
|
|
|
if (strlen($ivr_menu_greet_short) > 0) {
|
|
|
|
|
$tmp .= " greet-short=\"".$ivr_menu_greet_short."\"\n";
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
$tmp .= " invalid-sound=\"$ivr_menu_invalid_sound\"\n";
|
|
|
|
|
$tmp .= " exit-sound=\"$ivr_menu_exit_sound\"\n";
|
|
|
|
|
$tmp .= " confirm-macro=\"$ivr_menu_confirm_macro\"\n";
|
|
|
|
|
$tmp .= " confirm-key=\"$ivr_menu_confirm_key\"\n";
|
|
|
|
|
$tmp .= " tts-engine=\"$ivr_menu_tts_engine\"\n";
|
|
|
|
|
$tmp .= " tts-voice=\"$ivr_menu_tts_voice\"\n";
|
|
|
|
|
$tmp .= " confirm-attempts=\"$ivr_menu_confirm_attempts\"\n";
|
|
|
|
|
$tmp .= " timeout=\"$ivr_menu_timeout\"\n";
|
|
|
|
|
$tmp .= " inter-digit-timeout=\"$ivr_menu_inter_digit_timeout\"\n";
|
|
|
|
|
$tmp .= " max-failures=\"$ivr_menu_max_failures\"\n";
|
|
|
|
|
$tmp .= " max-timeouts=\"$ivr_menu_max_timeouts\"\n";
|
|
|
|
|
$tmp .= " digit-len=\"$ivr_menu_digit_len\">\n";
|
|
|
|
|
|
|
|
|
|
$sub_sql = "select * from v_ivr_menu_options ";
|
|
|
|
|
$sub_sql .= "where ivr_menu_uuid = '$ivr_menu_uuid' ";
|
|
|
|
|
$sub_sql .= "and domain_uuid = '".$_SESSION['domain_uuid']."' ";
|
|
|
|
|
$sub_sql .= "order by ivr_menu_option_order asc ";
|
|
|
|
|
$sub_prep_statement = $db->prepare(check_sql($sub_sql));
|
|
|
|
|
$sub_prep_statement->execute();
|
|
|
|
|
$sub_result = $sub_prep_statement->fetchAll(PDO::FETCH_ASSOC);
|
|
|
|
|
foreach ($sub_result as &$sub_row) {
|
|
|
|
|
//$ivr_menu_uuid = $sub_row["ivr_menu_uuid"];
|
|
|
|
|
$ivr_menu_option_digits = $sub_row["ivr_menu_option_digits"];
|
|
|
|
|
$ivr_menu_option_action = $sub_row["ivr_menu_option_action"];
|
|
|
|
|
$ivr_menu_option_param = $sub_row["ivr_menu_option_param"];
|
|
|
|
|
$ivr_menu_option_description = $sub_row["ivr_menu_option_description"];
|
|
|
|
|
|
|
|
|
|
$tmp .= " <entry action=\"$ivr_menu_option_action\" digits=\"$ivr_menu_option_digits\" param=\"$ivr_menu_option_param\"/>";
|
|
|
|
|
if (strlen($ivr_menu_option_description) == 0) {
|
|
|
|
|
$tmp .= "\n";
|
|
|
|
|
}
|
|
|
|
|
else {
|
|
|
|
|
$tmp .= " <!-- $ivr_menu_option_description -->\n";
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
unset ($sub_prep_statement, $sub_row);
|
|
|
|
|
|
|
|
|
|
if ($ivr_menu_direct_dial == "true") {
|
|
|
|
|
$tmp .= " <entry action=\"menu-exec-app\" digits=\"/(^\d{3,6}$)/\" param=\"transfer $1 XML ".$_SESSION["context"]."\"/>\n";
|
|
|
|
|
}
|
|
|
|
|
$tmp .= " </menu>\n";
|
|
|
|
|
$tmp .= "</include>\n";
|
|
|
|
|
|
|
|
|
|
//remove invalid characters from the file names
|
|
|
|
|
$ivr_menu_name = str_replace(" ", "_", $ivr_menu_name);
|
|
|
|
|
$ivr_menu_name = preg_replace("/[\*\:\\/\<\>\|\'\"\?]/", "", $ivr_menu_name);
|
|
|
|
|
|
|
|
|
|
//write the file
|
|
|
|
|
if (count($_SESSION["domains"]) > 1) {
|
|
|
|
|
$fout = fopen($_SESSION['switch']['conf']['dir']."/ivr_menus/v_".$_SESSION['domains'][$row['domain_uuid']]['domain_name']."_".$ivr_menu_name.".xml","w");
|
|
|
|
|
}
|
|
|
|
|
else {
|
|
|
|
|
$fout = fopen($_SESSION['switch']['conf']['dir']."/ivr_menus/v_".$ivr_menu_name.".xml","w");
|
|
|
|
|
}
|
|
|
|
|
fwrite($fout, $tmp);
|
|
|
|
|
fclose($fout);
|
|
|
|
|
}
|
|
|
|
|
}
|
2014-07-18 04:06:43 +02:00
|
|
|
*/
|
2012-06-04 16:58:40 +02:00
|
|
|
return $xml;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
function save_xml($xml){
|
|
|
|
|
return $xml;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
function xml_save_all() {
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
?>
|