mirror of
https://github.com/fusionpbx/fusionpbx.git
synced 2026-01-03 18:33:49 +00:00
if $database->app_uuid is not set it would use '' in some conditions which isset would test true. This fix uses strlen instead, but also fixes number_transations app that highlighted the flaw
180 lines
6.7 KiB
PHP
180 lines
6.7 KiB
PHP
<?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>
|
|
Portions created by the Initial Developer are Copyright (C) 2008-2017
|
|
the Initial Developer. All Rights Reserved.
|
|
|
|
Contributor(s):
|
|
Matthew Vale <github@mafoo.org>
|
|
*/
|
|
include "root.php";
|
|
|
|
//define the number_translation class
|
|
if (!class_exists('number_translation')) {
|
|
class number_translation {
|
|
//variables
|
|
public $db;
|
|
public $xml;
|
|
public $json;
|
|
public $display_type;
|
|
|
|
//class constructor
|
|
public function __construct() {
|
|
//connect to the database if not connected
|
|
if (!$this->db) {
|
|
require_once "resources/classes/database.php";
|
|
$database = new database;
|
|
$database->connect();
|
|
$this->db = $database->db;
|
|
}
|
|
|
|
}
|
|
|
|
public function number_translation_exists($name) {
|
|
$sql = "select number_translation_uuid from v_number_translations ";
|
|
$sql .= "where number_translation_name = '$name' ";
|
|
$prep_statement = $this->db->prepare(check_sql($sql));
|
|
if ($prep_statement) {
|
|
$prep_statement->execute();
|
|
$result = $prep_statement->fetchAll(PDO::FETCH_ASSOC);
|
|
if (count($result)) {
|
|
return true;
|
|
}
|
|
else {
|
|
return false;
|
|
}
|
|
}
|
|
unset($sql, $prep_statement, $result);
|
|
}
|
|
|
|
public function import() {
|
|
if (strlen($this->xml) > 0) {
|
|
//convert the xml string to an xml object
|
|
$xml = simplexml_load_string($this->xml);
|
|
//convert to json
|
|
$json = json_encode($xml);
|
|
//convert to an array
|
|
$number_translation = json_decode($json, true);
|
|
}
|
|
elseif (strlen($this->json) > 0) {
|
|
//convert to an array
|
|
$number_translation = json_decode($this->json, true);
|
|
}
|
|
else {
|
|
throw new Exception("require either json or xml to import");
|
|
}
|
|
//check if the number_translation exists
|
|
if (!$this->number_translation_exists($number_translation['@attributes']['name'])) {
|
|
$permissions = new permissions;
|
|
$permissions->add('number_translation_add', 'temp');
|
|
$permissions->add('number_translation_detail_add', 'temp');
|
|
$x=0;
|
|
$array['number_translations'][$x]['number_translation_name'] = $number_translation['@attributes']['name'];
|
|
$array['number_translations'][$x]['number_translation_enabled'] = "true";
|
|
if (strlen($number_translation['@attributes']['enabled']) > 0) {
|
|
$array['number_translations'][$x]['number_translation_enabled'] = $number_translation['@attributes']['enabled'];
|
|
}
|
|
$array['number_translations'][$x]['number_translation_description'] = $number_translation['@attributes']['description'];
|
|
|
|
//loop through the condition array
|
|
$order = 5;
|
|
if (isset($number_translation['rule'])) {
|
|
foreach ($number_translation['rule'] as &$row) {
|
|
if(array_key_exists('@attributes', $row))
|
|
$row = $row['@attributes'];
|
|
$array['number_translations'][$x]['number_translation_details'][$order]['number_translation_detail_regex'] = $row['regex'];
|
|
$array['number_translations'][$x]['number_translation_details'][$order]['number_translation_detail_replace'] = $row['replace'];
|
|
$array['number_translations'][$x]['number_translation_details'][$order]['number_translation_detail_order'] = $order;
|
|
$order = $order + 5;
|
|
}
|
|
}
|
|
$database = new database;
|
|
$database->app_name = 'number_translations';
|
|
$database->app_uuid = '6ad54de6-4909-11e7-a919-92ebcb67fe33';
|
|
$database->save($array);
|
|
if ($this->display_type == "text") {
|
|
if ($database->message['code'] != '200') {
|
|
echo "number_translation:".$number_translation['@attributes']['name'].": failed: ".$database->message['message']."\n";
|
|
}
|
|
else {
|
|
echo "number_translation:".$number_translation['@attributes']['name'].": added with ".(($order/5)-1)." entries\n";
|
|
}
|
|
}
|
|
$permissions->delete('number_translation_add', 'temp');
|
|
$permissions->delete('number_translation_detail_add', 'temp');
|
|
}
|
|
unset ($this->xml, $this->json);
|
|
}
|
|
|
|
//reads number_translation details from the database to build the xml
|
|
public function xml () {
|
|
|
|
$xml = "<include>\n";
|
|
$xml .= ' <configuration name="translate.conf" description="Number Translation Rules" autogenerated="true">'."\n";
|
|
$xml .= " <profiles>\n";
|
|
|
|
$sql = "select * \n";
|
|
$sql .= "from v_number_translations \n";
|
|
$sql .= "order by \n";
|
|
$sql .= "number_translation_name asc \n";
|
|
$prep_statement = $this->db->prepare(check_sql($sql));
|
|
$prep_statement->execute();
|
|
$results = $prep_statement->fetchAll(PDO::FETCH_NAMED);
|
|
|
|
foreach ($results as $row) {
|
|
$number_translation_uuid = $row["number_translation_uuid"];
|
|
$number_translation_name = $row["number_translation_name"];
|
|
$number_translation_description = $row["number_translation_description"];
|
|
|
|
$xml .= " <profile name=\"$number_translation_name\" description=\"$number_translation_description\">\n";
|
|
|
|
$sql = "select ";
|
|
$sql .= "number_translation_detail_uuid, number_translation_detail_regex, number_translation_detail_replace, number_translation_detail_order \n";
|
|
$sql .= "from v_number_translation_details \n";
|
|
$sql .= "where number_translation_uuid = '$number_translation_uuid' \n";
|
|
$sql .= "order by \n";
|
|
$sql .= "number_translation_detail_order asc \n";
|
|
$prep_statement = $this->db->prepare(check_sql($sql));
|
|
$prep_statement->execute();
|
|
$results = $prep_statement->fetchAll(PDO::FETCH_NAMED);
|
|
foreach ($results as $row) {
|
|
$number_translation_detail_regex = $row["number_translation_detail_regex"];
|
|
$number_translation_detail_replace = $row["number_translation_detail_replace"];
|
|
|
|
$xml .= " <rule regex=\"$number_translation_detail_regex\" replace=\"$number_translation_detail_replace\"/>\n";
|
|
}
|
|
|
|
$xml .= " </profile>\n";
|
|
}
|
|
$xml .= " </profiles>\n";
|
|
$xml .= " </configuration>\n";
|
|
$xml .= "</include>";
|
|
|
|
$fout = fopen($_SESSION['switch']['conf']['dir']."/autoload_configs/translate.conf.xml","w");
|
|
fwrite($fout, $xml);
|
|
unset($xml);
|
|
fclose($fout);
|
|
|
|
$_SESSION["reload_xml"] = true;
|
|
}
|
|
} // end class
|
|
} // class_exists
|
|
|
|
?>
|