fusionpbx/core/upgrade/upgrade_menu.php

463 lines
14 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-2023
the Initial Developer. All Rights Reserved.
Contributor(s):
Mark J Crane <markjcrane@fusionpbx.com>
Tim Fry <tim.fry@hotmail.com>
*/
//check the permission
defined('STDIN') or die('Unauthorized');
//include files
require_once dirname(__DIR__, 2) . "/resources/require.php";
//create a database connection using default config
$config = config::load();
$database = database::new(['config' => $config]);
//load global defaults
$settings = new settings(['database' => $database]);
//get the language code from global defaults
$language_code = $settings->get('domain', 'language');
//get the software name
$software_name = $settings->get('theme', 'title');
//set the scope for text to be used in any function
global $text, $display_type;
//add multi-lingual support
$language = new text;
$text = $language->get($language_code, 'core/upgrade');
//output to text type instead of html
$display_type = 'text';
//run
show_upgrade_menu();
/**
* Show upgrade menu
* @global type $text
* @global type $software_name
*/
function show_upgrade_menu() {
global $text, $software_name, $settings;
//error_reporting(E_ALL);
$line = str_repeat('-', strlen($text['title-cli_upgrade']) + 2);
while (true) {
echo "\n";
echo "+{$line}+\n";
echo "| {$text['title-cli_upgrade']} |\n";
echo "+{$line}+\n";
echo "version: "; show_software_version();
echo "\n";
echo "1) {$text['label-upgrade_source']} - {$text['description-update_all_source_files']}\n";
echo " 1a) " . $software_name . " - Update Main Software Only \n";
echo " 1b) {$text['label-update_external_repositories']} - {$text['description-repositories']}\n";
echo "2) {$text['label-schema']} - {$text['description-upgrade_schema']}\n";
echo " 2b) {$text['label-upgrade_data_types']} - {$text['description-upgrade_data_types']}\n";
echo "3) {$text['label-upgrade_apps']} - {$text['description-upgrade_apps']}\n";
echo "4) {$text['label-upgrade_menu']} - {$text['description-upgrade_menu']}\n";
echo "5) {$text['label-upgrade_permissions']} - {$text['description-upgrade_permissions']}\n";
echo "6) {$text['label-update_filesystem_permissions']} - {$text['description-update_filesystem_permissions']}\n";
echo "7) {$text['label-all_of_the_above']} - {$text['description-all_of_the_above']}\n";
echo "0) Exit\n";
echo "\n";
echo "Choice: ";
$choice = readline();
switch ($choice) {
case 1:
do_upgrade_code();
do_upgrade_code_submodules();
do_upgrade_auto_loader();
break;
case '1a':
do_upgrade_code();
do_upgrade_auto_loader();
break;
case '1b':
do_upgrade_code_submodules();
do_upgrade_auto_loader();
break;
case 2:
do_upgrade_schema();
break;
case '2b':
do_upgrade_schema(true);
break;
case 3:
do_upgrade_auto_loader();
do_upgrade_domains();
break;
case 4:
do_upgrade_auto_loader();
do_upgrade_menu();
break;
case 5:
do_upgrade_auto_loader();
do_upgrade_permissions();
break;
case 6:
do_upgrade_auto_loader();
do_filesystem_permissions($text, $settings);
break;
case 7:
do_upgrade_code();
do_upgrade_auto_loader();
do_upgrade_schema();
do_upgrade_domains();
do_upgrade_menu();
do_upgrade_permissions();
do_filesystem_permissions($text, $settings);
break;
case 9:
break;
case 0:
case 'q':
exit();
}
}
}
/**
* Rebuild the cache file
* @global type $text
*/
function do_upgrade_auto_loader() {
global $text;
//remove temp file
unlink(sys_get_temp_dir() . '/' . auto_loader::FILE);
//create a new instance of the autoloader
$loader = new auto_loader();
//reload the classes
$loader->reload_classes();
echo "{$text['label-reloaded_classes']}\n";
//re-create cache file
if ($loader->update_cache()) {
echo "{$text['label-updated_cache']}\n";
}
}
/**
* Update file system permissions
*/
function do_filesystem_permissions($text, settings $settings) {
echo ($text['label-header1'] ?? "Root account or sudo account must be used for this option") . "\n";
echo ($text['label-header2'] ?? "This option is used for resetting the permissions on the filesystem after executing commands using the root user account") . "\n";
if (is_root_user()) {
$directories = [];
//get the fusionpbx folder
$project_root = dirname(__DIR__, 2);
//adjust the project root
$directories[] = $project_root;
//adjust the /etc/freeswitch
$directories[] = $settings->get('switch', 'conf', null);
$directories[] = $settings->get('switch', 'call_center', null); //normally in conf but can be different
$directories[] = $settings->get('switch', 'dialplan', null); //normally in conf but can be different
$directories[] = $settings->get('switch', 'directory', null); //normally in conf but can be different
$directories[] = $settings->get('switch', 'languages', null); //normally in conf but can be different
$directories[] = $settings->get('switch', 'sip_profiles', null); //normally in conf but can be different
//adjust the /usr/share/freeswitch/{scripts,sounds}
$directories[] = $settings->get('switch', 'scripts', null);
$directories[] = $settings->get('switch', 'sounds', null);
//adjust the /var/lib/freeswitch/{db,recordings,storage,voicemail}
$directories[] = $settings->get('switch', 'db', null);
$directories[] = $settings->get('switch', 'recordings', null);
$directories[] = $settings->get('switch', 'storage', null);
$directories[] = $settings->get('switch', 'voicemail', null); //normally included in storage but can be different
//only set the xml_cdr directory permissions
$log_directory = $settings->get('switch', 'log', null);
if ($log_directory !== null) {
$directories[] = $log_directory . '/xml_cdr';
}
//update the auto_loader cache permissions file
$directories[] = sys_get_temp_dir() . '/' . auto_loader::FILE;
//execute chown command for each directory
foreach ($directories as $dir) {
if ($dir !== null) {
//notify user
echo "chown -R www-data:www-data $dir\n";
//execute
exec("chown -R www-data:www-data $dir");
}
}
} else {
echo ($text['label-not_running_as_root'] ?? "Not root user - operation skipped")."\n";
}
}
function is_root_user(): bool {
return posix_getuid() === 0;
}
function current_user(): ?string {
return posix_getpwuid(posix_getuid())['name'] ?? null;
}
//show the upgrade type
function show_software_version() {
echo software::version() . "\n";
}
/**
* Upgrade the source folder
* @return type
*/
function do_upgrade_code() {
//assume failed
$result = ['result' => false, 'message' => 'Failed'];
//global $conf;
if (defined('PROJECT_ROOT')) {
$result = git_pull(PROJECT_ROOT);
if (!empty($result['message']) && is_array($result['message'])) {
echo implode("\n", $result['message']);
echo "\n";
}
}
return;
}
/**
* Upgrade any of the git submodules
* @global type $text
*/
function do_upgrade_code_submodules() {
global $text;
$updateable_repos = git_find_repos(dirname(__DIR__, 2)."/app");
$messages = [];
foreach ($updateable_repos as $repo => $apps) {
$git_result = git_pull($repo);
if ($git_result['result']) {
$messages[$repo] = $text['message-optional_apps_upgrade_source_cli'] . (!empty($git_result['message']) && is_array($git_result['message']) ? ' - '.implode("\n", $git_result['message']) : '');
}
else {
if (!empty($git_result['message']) && is_array($git_result['message'])) {
$message = "ERROR:\n" . implode("\n", $git_result['message']);
} else {
$message = $git_result['message'];
}
$messages[$repo] = $text['message-optional_apps_upgrade_source_failed_cli'] . " - " . $message;
}
}
foreach ($messages as $repo => $message) {
echo $repo.": ".$message."\n";
}
}
/**
* Execute all app_defaults.php files
*/
function do_upgrade_domains() {
$domain = new domains;
$domain->display_type = 'text';
$domain->upgrade();
}
/**
* Upgrade schema and/or data_types
*/
function do_upgrade_schema(bool $data_types = false) {
//get the database schema put it into an array then compare and update the database as needed.
$obj = new schema;
$obj->data_types = $data_types;
echo $obj->schema('text');
}
/**
* Restore the default menu
*/
function do_upgrade_menu() {
global $included, $sel_menu, $menu_uuid, $menu_language;
//get the menu uuid and language
$sql = "select menu_uuid, menu_language from v_menus ";
$sql .= "where menu_name = :menu_name ";
$parameters['menu_name'] = 'default';
$database = new database;
$row = $database->select($sql, $parameters, 'row');
if (is_array($row) && sizeof($row) != 0) {
$menu_uuid = $row["menu_uuid"];
$menu_language = $row["menu_language"];
}
unset($sql, $parameters, $row);
//show the menu
if (isset($argv[2]) && $argv[2] == 'view') {
print_r($_SESSION["menu"]);
}
//set the menu back to default
if (!isset($argv[2]) || $argv[2] == 'default') {
//restore the menu
$included = true;
require_once dirname(__DIR__, 2) . "/core/menu/menu_restore_default.php";
unset($sel_menu);
$text = (new text)->get(null, 'core/upgrade');
//send message to the console
echo $text['message-upgrade_menu'] . "\n";
}
}
/**
* Restore the default permissions
*/
function do_upgrade_permissions() {
global $included;
//default the permissions
$included = true;
require_once dirname(__DIR__, 2) . "/core/groups/permissions_default.php";
//send message to the console
$text = (new text)->get(null, 'core/upgrade');
echo $text['message-upgrade_permissions'] . "\n";
}
/**
* Default upgrade schema and app defaults
*/
function do_upgrade_defaults() {
//add multi-lingual support
$language = new text;
$text = $language->get(null, 'core/upgrade');
echo "\n";
echo $text['label-upgrade'] . "\n";
echo "-----------------------------------------\n";
echo "\n";
echo $text['label-database'] . "\n";
//make sure the database schema and installation have performed all necessary tasks
$obj = new schema;
echo $obj->schema("text");
//run all app_defaults.php files
$domain = new domains;
$domain->display_type = 'text';
$domain->upgrade();
echo "\n";
}
/**
* Load the old config.php file
* @return type
*/
function load_config_php() {
//if the config file doesn't exist and the config.php does exist use it to write a new config file
//include the config.php
include "/etc/fusionpbx/config.php";
//set the default config file location
if (stristr(PHP_OS, 'BSD')) {
$config_path = '/usr/local/etc/fusionpbx';
$config_file = $config_path . '/config.conf';
$document_root = '/usr/local/www/fusionpbx';
$conf_dir = '/usr/local/etc/freeswitch';
$sounds_dir = '/usr/share/freeswitch/sounds';
$database_dir = '/var/lib/freeswitch/db';
$recordings_dir = '/var/lib/freeswitch/recordings';
$storage_dir = '/var/lib/freeswitch/storage';
$voicemail_dir = '/var/lib/freeswitch/storage/voicemail';
$scripts_dir = '/usr/share/freeswitch/scripts';
}
if (stristr(PHP_OS, 'Linux')) {
$config_path = '/etc/fusionpbx/';
$config_file = $config_path . '/config.conf';
$document_root = '/var/www/fusionpbx';
$conf_dir = '/etc/freeswitch';
$sounds_dir = '/usr/share/freeswitch/sounds';
$database_dir = '/var/lib/freeswitch/db';
$recordings_dir = '/var/lib/freeswitch/recordings';
$storage_dir = '/var/lib/freeswitch/storage';
$voicemail_dir = '/var/lib/freeswitch/storage/voicemail';
$scripts_dir = '/usr/share/freeswitch/scripts';
}
//make the config directory
if (isset($config_path)) {
system('mkdir -p ' . $config_path);
} else {
echo "config directory not found\n";
exit;
}
//build the config file
$conf = "\n";
$conf .= "#database system settings\n";
$conf .= "database.0.type = " . $db_type . "\n";
$conf .= "database.0.host = " . $db_host . "\n";
$conf .= "database.0.port = " . $db_port . "\n";
$conf .= "database.0.sslmode = prefer\n";
$conf .= "database.0.name = " . $db_name . "\n";
$conf .= "database.0.username = " . $db_username . "\n";
$conf .= "database.0.password = " . $db_password . "\n";
$conf .= "\n";
$conf .= "#database switch settings\n";
$conf .= "database.1.type = sqlite\n";
$conf .= "database.1.path = " . $database_dir . "\n";
$conf .= "database.1.name = core.db\n";
$conf .= "\n";
$conf .= "#general settings\n";
$conf .= "document.root = " . $document_root . "\n";
$conf .= "project.path =\n";
$conf .= "temp.dir = /tmp\n";
$conf .= "php.dir = " . PHP_BINDIR . "\n";
$conf .= "php.bin = php\n";
$conf .= "\n";
$conf .= "#cache settings\n";
$conf .= "cache.method = file\n";
$conf .= "cache.location = /var/cache/fusionpbx\n";
$conf .= "cache.settings = true\n";
$conf .= "\n";
$conf .= "#switch settings\n";
$conf .= "switch.conf.dir = " . $conf_dir . "\n";
$conf .= "switch.sounds.dir = " . $sounds_dir . "\n";
$conf .= "switch.database.dir = " . $database_dir . "\n";
$conf .= "switch.recordings.dir = " . $recordings_dir . "\n";
$conf .= "switch.storage.dir = " . $storage_dir . "\n";
$conf .= "switch.voicemail.dir = " . $voicemail_dir . "\n";
$conf .= "switch.scripts.dir = " . $scripts_dir . "\n";
$conf .= "\n";
$conf .= "#switch xml handler\n";
$conf .= "xml_handler.fs_path = false\n";
$conf .= "xml_handler.reg_as_number_alias = false\n";
$conf .= "xml_handler.number_as_presence_id = true\n";
$conf .= "\n";
$conf .= "#error reporting hide all errors\n";
$conf .= "error.reporting = user\n";
//write the config file
$file_handle = fopen($config_file, "w");
if (!$file_handle) {
return;
}
fwrite($file_handle, $conf);
fclose($file_handle);
}