2012-07-17 17:56:32 +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>
|
|
|
|
|
Portions created by the Initial Developer are Copyright (C) 2008-2012
|
|
|
|
|
the Initial Developer. All Rights Reserved.
|
|
|
|
|
|
|
|
|
|
Contributor(s):
|
|
|
|
|
Mark J Crane <markjcrane@fusionpbx.com>
|
|
|
|
|
*/
|
|
|
|
|
|
2015-08-11 04:06:33 +02:00
|
|
|
global $IS_WINDOWS;
|
|
|
|
|
|
|
|
|
|
if ($IS_WINDOWS == null) {
|
|
|
|
|
if (stristr(PHP_OS, 'WIN')) { $IS_WINDOWS = true; } else { $IS_WINDOWS = false; }
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (!function_exists('correct_path')) {
|
|
|
|
|
function correct_path($p) {
|
|
|
|
|
global $IS_WINDOWS;
|
|
|
|
|
if ($IS_WINDOWS) {
|
|
|
|
|
return str_replace('/', '\\', $p);
|
|
|
|
|
}
|
|
|
|
|
return $p;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2012-08-14 23:59:45 +02:00
|
|
|
//proccess this only one time
|
|
|
|
|
if ($domains_processed == 1) {
|
2012-10-16 07:47:49 +02:00
|
|
|
|
2012-08-14 23:59:45 +02:00
|
|
|
//set the database driver
|
|
|
|
|
$sql = "select * from v_databases ";
|
|
|
|
|
$sql .= "where database_driver is null ";
|
|
|
|
|
$prep_statement = $db->prepare(check_sql($sql));
|
|
|
|
|
$prep_statement->execute();
|
|
|
|
|
$result = $prep_statement->fetchAll(PDO::FETCH_NAMED);
|
|
|
|
|
foreach ($result as &$row) {
|
|
|
|
|
$database_uuid = $row["database_uuid"];
|
|
|
|
|
$database_type = $row["database_type"];
|
|
|
|
|
$database_type_array = explode(":", $database_type);
|
|
|
|
|
if ($database_type_array[0] == "odbc") {
|
|
|
|
|
$database_driver = $database_type_array[1];
|
|
|
|
|
}
|
|
|
|
|
else {
|
|
|
|
|
$database_driver = $database_type_array[0];
|
|
|
|
|
}
|
|
|
|
|
$sql = "update v_databases set ";
|
|
|
|
|
$sql .= "database_driver = '$database_driver' ";
|
|
|
|
|
$sql .= "where database_uuid = '$database_uuid' ";
|
|
|
|
|
$db->exec(check_sql($sql));
|
|
|
|
|
unset($sql);
|
2012-07-17 17:56:32 +02:00
|
|
|
}
|
2014-07-24 00:00:03 +02:00
|
|
|
unset($prep_statement, $result);
|
2012-07-17 17:56:32 +02:00
|
|
|
|
2013-04-05 03:03:45 +02:00
|
|
|
//replace the backslash with a forward slash
|
|
|
|
|
$db_path = str_replace("\\", "/", $db_path);
|
|
|
|
|
|
2012-08-14 23:59:45 +02:00
|
|
|
if (strlen($_SESSION['switch']['scripts']['dir']) > 0) {
|
|
|
|
|
//get the odbc information
|
|
|
|
|
$sql = "select count(*) as num_rows from v_databases ";
|
|
|
|
|
$sql .= "where database_driver = 'odbc' ";
|
|
|
|
|
if (strlen($order_by)> 0) { $sql .= "order by $order_by $order "; }
|
|
|
|
|
$prep_statement = $db->prepare($sql);
|
|
|
|
|
if ($prep_statement) {
|
2012-07-17 17:56:32 +02:00
|
|
|
$prep_statement->execute();
|
2012-08-14 23:59:45 +02:00
|
|
|
$row = $prep_statement->fetch(PDO::FETCH_ASSOC);
|
2014-07-24 00:00:03 +02:00
|
|
|
unset($prep_statement);
|
2012-08-14 23:59:45 +02:00
|
|
|
if ($row['num_rows'] > 0) {
|
|
|
|
|
$odbc_num_rows = $row['num_rows'];
|
|
|
|
|
|
|
|
|
|
$sql = "select * from v_databases ";
|
|
|
|
|
$sql .= "where database_driver = 'odbc' ";
|
|
|
|
|
$prep_statement = $db->prepare(check_sql($sql));
|
|
|
|
|
$prep_statement->execute();
|
|
|
|
|
$result = $prep_statement->fetchAll(PDO::FETCH_NAMED);
|
|
|
|
|
foreach ($result as &$row) {
|
|
|
|
|
$dsn_name = $row["database_name"];
|
|
|
|
|
$dsn_username = $row["database_username"];
|
|
|
|
|
$dsn_password = $row["database_password"];
|
|
|
|
|
break; //limit to 1 row
|
|
|
|
|
}
|
|
|
|
|
unset ($prep_statement);
|
|
|
|
|
}
|
|
|
|
|
else {
|
|
|
|
|
$odbc_num_rows = '0';
|
2012-07-17 17:56:32 +02:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2012-10-16 07:47:49 +02:00
|
|
|
//get the recordings directory
|
|
|
|
|
if (strlen($_SESSION['switch']['recordings']['dir']) > 0) {
|
|
|
|
|
$sql = "select * from v_default_settings ";
|
|
|
|
|
$sql .= "where default_setting_category = 'switch' ";
|
|
|
|
|
$sql .= "and default_setting_subcategory = 'recordings' ";
|
|
|
|
|
$sql .= "and default_setting_name = 'dir' ";
|
|
|
|
|
$prep_statement = $db->prepare(check_sql($sql));
|
|
|
|
|
$prep_statement->execute();
|
|
|
|
|
$result = $prep_statement->fetchAll(PDO::FETCH_NAMED);
|
|
|
|
|
foreach ($result as &$row) {
|
|
|
|
|
$recordings_dir = $row["default_setting_value"];
|
|
|
|
|
}
|
2014-07-24 00:00:03 +02:00
|
|
|
unset($prep_statement, $result);
|
2012-10-16 07:47:49 +02:00
|
|
|
}
|
|
|
|
|
|
2012-08-14 23:59:45 +02:00
|
|
|
//config.lua
|
2015-07-13 13:04:33 +02:00
|
|
|
if (is_dir("/etc/fusionpbx")){
|
|
|
|
|
$config = "/etc/fusionpbx/config.lua";
|
|
|
|
|
} elseif (is_dir("/usr/local/etc/fusionpbx")){
|
|
|
|
|
$config = "/usr/local/etc/fusionpbx/config.lua";
|
|
|
|
|
}
|
|
|
|
|
else {
|
|
|
|
|
$config = $_SESSION['switch']['scripts']['dir']."/resources/config.lua";
|
|
|
|
|
}
|
|
|
|
|
$fout = fopen($config,"w");
|
|
|
|
|
$tmp = "\n";
|
|
|
|
|
$tmp .= "--set the variables\n";
|
|
|
|
|
if (strlen($_SESSION['switch']['sounds']['dir']) > 0) {
|
2015-08-11 04:06:33 +02:00
|
|
|
$tmp .= correct_path(" sounds_dir = [[".$_SESSION['switch']['sounds']['dir']."]];\n");
|
2015-07-13 13:04:33 +02:00
|
|
|
}
|
|
|
|
|
if (strlen($_SESSION['switch']['db']['dir']) > 0) {
|
2015-08-11 04:06:33 +02:00
|
|
|
$tmp .= correct_path(" database_dir = [[".$_SESSION['switch']['db']['dir']."]];\n");
|
2015-07-13 13:04:33 +02:00
|
|
|
}
|
|
|
|
|
if (strlen($_SESSION['switch']['recordings']['dir']) > 0) {
|
2015-08-11 04:06:33 +02:00
|
|
|
$tmp .= correct_path(" recordings_dir = [[".$recordings_dir."]];\n");
|
2015-07-13 13:04:33 +02:00
|
|
|
}
|
|
|
|
|
if (strlen($_SESSION['switch']['storage']['dir']) > 0) {
|
2015-08-11 04:06:33 +02:00
|
|
|
$tmp .= correct_path(" storage_dir = [[".$_SESSION['switch']['storage']['dir']."]];\n");
|
2015-07-13 13:04:33 +02:00
|
|
|
}
|
|
|
|
|
if (strlen($_SESSION['switch']['voicemail']['dir']) > 0) {
|
2015-08-11 04:06:33 +02:00
|
|
|
$tmp .= correct_path(" voicemail_dir = [[".$_SESSION['switch']['voicemail']['dir']."]];\n");
|
|
|
|
|
}
|
|
|
|
|
if (strlen($_SESSION['switch']['scripts']['dir']) > 0) {
|
|
|
|
|
$tmp .= correct_path(" scripts_dir = [[".$_SESSION['switch']['scripts']['dir']."]];\n");
|
2015-07-13 13:04:33 +02:00
|
|
|
}
|
2015-08-11 04:06:33 +02:00
|
|
|
$tmp .= correct_path(" php_dir = [[".PHP_BINDIR."]];\n");
|
2015-07-13 13:04:33 +02:00
|
|
|
if (substr(strtoupper(PHP_OS), 0, 3) == "WIN") {
|
|
|
|
|
$tmp .= " php_bin = \"php.exe\";\n";
|
|
|
|
|
}
|
|
|
|
|
else {
|
|
|
|
|
$tmp .= " php_bin = \"php\";\n";
|
|
|
|
|
}
|
2015-08-11 04:06:33 +02:00
|
|
|
$tmp .= correct_path(" document_root = [[".$_SERVER["DOCUMENT_ROOT"].PROJECT_PATH."]];\n");
|
2015-07-13 13:04:33 +02:00
|
|
|
$tmp .= "\n";
|
|
|
|
|
|
|
|
|
|
if ((strlen($db_type) > 0) || (strlen($dsn_name) > 0)) {
|
2013-10-22 05:18:28 +02:00
|
|
|
$tmp .= "--database information\n";
|
|
|
|
|
$tmp .= " database = {}\n";
|
|
|
|
|
$tmp .= " database[\"type\"] = \"".$db_type."\";\n";
|
|
|
|
|
$tmp .= " database[\"name\"] = \"".$db_name."\";\n";
|
2015-08-11 04:06:33 +02:00
|
|
|
$tmp .= correct_path(" database[\"path\"] = [[".$db_path."]];\n");
|
2013-10-22 05:18:28 +02:00
|
|
|
|
2015-07-13 13:04:33 +02:00
|
|
|
if (strlen($dsn_name) > 0) {
|
|
|
|
|
$tmp .= " database[\"system\"] = \"odbc://".$dsn_name.":".$dsn_username.":".$dsn_password."\";\n";
|
|
|
|
|
$tmp .= " database[\"switch\"] = \"odbc://freeswitch:".$dsn_username.":".$dsn_password."\";\n";
|
|
|
|
|
}
|
|
|
|
|
elseif ($db_type == "pgsql") {
|
2013-10-22 05:18:28 +02:00
|
|
|
if ($db_host == "localhost") { $db_host = "127.0.0.1"; }
|
2014-01-02 19:59:40 +01:00
|
|
|
$tmp .= " database[\"system\"] = \"pgsql://hostaddr=".$db_host." port=".$db_port." dbname=".$db_name." user=".$db_username." password=".$db_password." options='' application_name='".$db_name."'\";\n";
|
|
|
|
|
$tmp .= " database[\"switch\"] = \"pgsql://hostaddr=".$db_host." port=".$db_port." dbname=freeswitch user=".$db_username." password=".$db_password." options='' application_name='freeswitch'\";\n";
|
2013-10-22 05:18:28 +02:00
|
|
|
}
|
|
|
|
|
elseif ($db_type == "sqlite") {
|
|
|
|
|
$tmp .= " database[\"system\"] = \"sqlite://".$db_path."/".$db_name."\";\n";
|
|
|
|
|
$tmp .= " database[\"switch\"] = \"sqlite://".$_SESSION['switch']['db']['dir']."\";\n";
|
|
|
|
|
}
|
|
|
|
|
elseif ($db_type == "mysql") {
|
2015-07-13 13:04:33 +02:00
|
|
|
$tmp .= " database[\"system\"] = \"\";\n";
|
|
|
|
|
$tmp .= " database[\"switch\"] = \"\";\n";
|
2014-04-30 22:44:34 +02:00
|
|
|
}
|
2013-10-22 05:18:28 +02:00
|
|
|
$tmp .= "\n";
|
|
|
|
|
}
|
2015-10-08 17:34:35 +02:00
|
|
|
$tmp .= "--set defaults\n";
|
|
|
|
|
$tmp .= " expire = {}\n";
|
|
|
|
|
$tmp .= " expire[\"directory\"] = \"3600\";\n";
|
|
|
|
|
$tmp .= " expire[\"dialplan\"] = \"3600\";\n";
|
|
|
|
|
$tmp .= " expire[\"languages\"] = \"3600\";\n";
|
|
|
|
|
$tmp .= " expire[\"sofia.conf\"] = \"3600\";\n";
|
|
|
|
|
$tmp .= " expire[\"acl.conf\"] = \"3600\";\n";
|
2015-10-08 20:03:48 +02:00
|
|
|
$tmp .= "\n";
|
|
|
|
|
$tmp .= "--set xml_handler\n";
|
|
|
|
|
$tmp .= " xml_handler = {}\n";
|
|
|
|
|
$tmp .= " xml_handler[\"fs_path\"] = false;\n";
|
2015-10-08 17:34:35 +02:00
|
|
|
$tmp .= "\n";
|
|
|
|
|
$tmp .= "--set the debug options\n";
|
|
|
|
|
$tmp .= " debug[\"params\"] = false;\n";
|
|
|
|
|
$tmp .= " debug[\"sql\"] = false;\n";
|
|
|
|
|
$tmp .= " debug[\"xml_request\"] = false;\n";
|
|
|
|
|
$tmp .= " debug[\"xml_string\"] = false;\n";
|
|
|
|
|
$tmp .= " debug[\"cache\"] = false;\n";
|
|
|
|
|
$tmp .= "\n";
|
2015-07-13 13:04:33 +02:00
|
|
|
$tmp .= "--additional info\n";
|
|
|
|
|
$tmp .= " domain_count = ".count($_SESSION["domains"]).";\n";
|
2015-08-11 04:06:33 +02:00
|
|
|
$tmp .= correct_path(" temp_dir = [[".$_SESSION['server']['temp']['dir']."]];\n");
|
2015-07-13 13:04:33 +02:00
|
|
|
if (isset($_SESSION['domain']['dial_string']['text'])) {
|
|
|
|
|
$tmp .= " dial_string = \"".$_SESSION['domain']['dial_string']['text']."\";\n";
|
|
|
|
|
}
|
|
|
|
|
$tmp .= "\n";
|
|
|
|
|
$tmp .= "--include local.lua\n";
|
2015-08-11 04:06:33 +02:00
|
|
|
$tmp .= " require(\"resources.functions.file_exists\");\n";
|
2015-07-13 13:04:33 +02:00
|
|
|
$tmp .= " if (file_exists(\"/etc/fusionpbx/local.lua\")) then\n";
|
|
|
|
|
$tmp .= " dofile(\"/etc/fusionpbx/local.lua\");\n";
|
|
|
|
|
$tmp .= " elseif (file_exists(\"/usr/local/etc/fusionpbx/local.lua\")) then\n";
|
|
|
|
|
$tmp .= " dofile(\"/usr/local/etc/fusionpbx/local.lua\");\n";
|
|
|
|
|
$tmp .= " elseif (file_exists(scripts_dir..\"/resources/local.lua\")) then\n";
|
2015-08-11 04:06:33 +02:00
|
|
|
$tmp .= " require(\"resources.local\");\n";
|
2015-07-13 13:04:33 +02:00
|
|
|
$tmp .= " end\n";
|
|
|
|
|
fwrite($fout, $tmp);
|
|
|
|
|
unset($tmp);
|
|
|
|
|
fclose($fout);
|
2012-08-14 23:59:45 +02:00
|
|
|
}
|
2012-07-17 17:56:32 +02:00
|
|
|
}
|
|
|
|
|
?>
|