false,
'messages' => ['session clean, page refresh...']
];
return;
}
// recover smtp settings
if (isset($_POST['smtp_tab_selected'])) {
$_POST = array_merge($_POST, $_POST[$_POST['smtp_tab_selected']]);
}
/**
* Check php version
*
* If less than minimum we refuse to install.
*/
if (check_php_version() === -1) {
$msg = 'The recommended PHP version to install SuiteCRM is ';
$msg .= constant('SUITECRM_PHP_REC_VERSION') . '
';
$msg .= 'Although the minimum PHP version required is ';
$msg .= constant('SUITECRM_PHP_MIN_VERSION') . ', ';
$msg .= 'is not recommended due to the large number of fixed bugs, including security fixes, ';
$msg .= 'released in the more modern versions.
';
$msg .= 'You are using PHP version ' . constant('PHP_VERSION') . ', which is EOL: http://php.net/eol.php.
';
$msg .= 'Please consider upgrading your PHP version. Instructions on http://php.net/migration70. ';
$installResult = [
'success' => false,
'messages' => [$msg]
];
return;
}
$session_id = session_id();
if (empty($session_id)) {
@session_start();
}
$GLOBALS['installing'] = true;
define('SUGARCRM_IS_INSTALLING', $GLOBALS['installing']);
$GLOBALS['sql_queries'] = 0;
require_once('include/SugarLogger/LoggerManager.php');
require_once('sugar_version.php');
require_once('suitecrm_version.php');
require_once('install/install_utils.php');
require_once('install/install_defaults.php');
require_once('include/TimeDate.php');
require_once('include/Localization/Localization.php');
require_once('include/SugarTheme/SugarTheme.php');
require_once('include/utils/LogicHook.php');
require_once('data/SugarBean.php');
require_once('include/entryPoint.php');
//check to see if the script files need to be rebuilt, add needed variables to request array
$_REQUEST['root_directory'] = getcwd();
$_REQUEST['js_rebuild_concat'] = 'rebuild';
//Set whether the install is silent or not
global $silentInstall;
$silentInstall = true;
//Todo, check if there is an instance where goto is not set, but a silent install is in place
if (isset($_REQUEST['goto']) && $_REQUEST['goto'] != 'SilentInstall') {
require_once('jssource/minify.php');
$silentInstall = false;
}
global $timedate;
$timedate = TimeDate::getInstance();
// cn: set php.ini settings at entry points
setPhpIniSettings();
global $locale;
$locale = new Localization();
$GLOBALS['log'] = LoggerManager::getLogger();
global $setup_sugar_version;
$setup_sugar_version = $suitecrm_version;
global $install_script;
$install_script = true;
///////////////////////////////////////////////////////////////////////////////
//// INSTALL RESOURCE SETUP
$css = 'install/install.css';
$icon = 'include/images/sugar_icon.ico';
$sugar_md = 'include/images/sugar_md_open.png';
$loginImage = 'include/images/suitecrm_login.png';
$common = 'install/installCommon.js';
///////////////////////////////////////////////////////////////////////////////
//// INSTALLER LANGUAGE
function getSupportedInstallLanguages()
{
$supportedLanguages = array(
'en_us' => 'English (US)',
);
if (file_exists('install/lang.config.php')) {
$config = [];
include('install/lang.config.php');
if (!empty($config['languages'])) {
foreach ($config['languages'] as $k => $v) {
if (file_exists('install/language/' . $k . '.lang.php')) {
$supportedLanguages[$k] = $v;
}
}
}
}
return $supportedLanguages;
}
global $supportedLanguages;
$supportedLanguages = getSupportedInstallLanguages();
// after install language is selected, use that pack
global $default_lang;
$default_lang = 'en_us';
if (!isset($_POST['language']) && (!isset($_SESSION['language']) && empty($_SESSION['language']))) {
if (isset($_SERVER['HTTP_ACCEPT_LANGUAGE']) && !empty($_SERVER['HTTP_ACCEPT_LANGUAGE'])) {
$lang = parseAcceptLanguage();
if (isset($supportedLanguages[$lang])) {
$_POST['language'] = $lang;
} else {
$_POST['language'] = $default_lang;
}
}
}
if (isset($_POST['language'])) {
$_SESSION['language'] = str_replace('-', '_', (string)$_POST['language']);
}
global $current_language;
$current_language = isset($_SESSION['language']) ? $_SESSION['language'] : $default_lang;
if (file_exists("install/language/{$current_language}.lang.php")) {
require_once("install/language/{$current_language}.lang.php");
} else {
require_once("install/language/{$default_lang}.lang.php");
}
global $mod_strings;
if ($current_language != 'en_us') {
$my_mod_strings = $mod_strings;
include('install/language/en_us.lang.php');
$mod_strings = sugarLangArrayMerge($mod_strings, $my_mod_strings);
}
global $app_list_strings;
$app_list_strings = return_app_list_strings_language($current_language);
//// END INSTALLER LANGUAGE
///////////////////////////////////////////////////////////////////////////////
//get the url for the helper link
global $help_url;
$help_url = get_help_button_url();
if (isset($sugar_config['installer_locked']) && $sugar_config['installer_locked'] == true) {
if (!empty($_POST['current_step']) && $_POST['current_step'] === '3' && !empty($_POST['goto']) && $_POST['goto'] === $mod_strings['LBL_NEXT']) {
session_unset();
$the_file = 'complete_install.php';
$install_status_messages[] = 'Missing install complete step';
} else {
$the_file = 'installDisabled.php';
$disabled_title = $mod_strings['LBL_DISABLED_DESCRIPTION'];
$disabled_title_2 = $mod_strings['LBL_DISABLED_TITLE_2'];
$disabled_text = <<
'installer_locked' => false,
{$mod_strings['LBL_DISABLED_DESCRIPTION_2']}
{$mod_strings['LBL_DISABLED_HELP_1']} {$mod_strings['LBL_DISABLED_HELP_2']}.
EOQ; $install_status_messages[] = $mod_strings['LBL_DISABLED_DESCRIPTION']; } $the_file = 'install/' . clean_string($the_file, 'FILE'); if (is_file($the_file)) { installerHook('pre_installFileRequire', ['the_file' => $the_file]); require($the_file); $installResult = [ 'success' => false, 'messages' => $install_status_messages ]; return; } LoggerManager::getLogger()->fatal('Install file not found: ' . $the_file); $installResult = [ 'success' => false, 'messages' => ['SuiteCRM Installation has been Disabled'] ]; return; } foreach ($installer_defaults as $key => $val) { if (!isset($_SESSION[$key])) { $_SESSION[$key] = $val; } } // always perform clean_special_arguments(); print_debug_comment(); $next_clicked = false; $next_step = 0; $workflow = array(); // If less then recommended PHP version, insert old_php.pho into workflow. if (check_php_version() === 0) { $installResult = [ 'success' => false, 'messages' => ['PHP version not supported'] ]; return; } // use a simple array to map out the steps of the installer page flow $workflow[] = 'welcome.php'; $workflow[] = 'ready.php'; // TODO-g: remove these files.. //'license.php', //'installType.php', //); $workflow[] = 'installConfig.php'; //$workflow[] = 'systemOptions.php'; //$workflow[] = 'dbConfig_a.php'; //$workflow[] = 'dbConfig_b.php'; //define web root, which will be used as default for site_url if ($_SERVER['SERVER_PORT'] == '80') { $web_root = $_SERVER['SERVER_NAME'] . $_SERVER['PHP_SELF']; } else { $web_root = $_SERVER['SERVER_NAME'] . ':' . $_SERVER['SERVER_PORT'] . $_SERVER['PHP_SELF']; } $web_root = str_replace("/install.php", "", $web_root); $web_root = "http://$web_root"; if (!isset($_SESSION['oc_install']) || $_SESSION['oc_install'] == false) { //$workflow[] = 'siteConfig_a.php'; if (isset($_SESSION['install_type']) && !empty($_SESSION['install_type']) && $_SESSION['install_type'] == 'custom') { $workflow[] = 'siteConfig_b.php'; } } else { if (is_readable('config.php')) { require_once('config.php'); } else { $installResult = [ 'success' => false, 'messages' => ['Not able to read config.php'] ]; return; } } if (empty($sugar_config['cache_dir']) && !empty($_SESSION['cache_dir'])) { $sugar_config['cache_dir'] = $_SESSION['cache_dir']; } // set the form's php var to the loaded config's var else default to sane settings if (!isset($_SESSION['setup_site_url']) || empty($_SESSION['setup_site_url'])) { if (isset($sugar_config['site_url']) && !empty($sugar_config['site_url'])) { $_SESSION['setup_site_url'] = $sugar_config['site_url']; } else { $_SESSION['setup_site_url'] = $web_root; } } if (!isset($_SESSION['setup_system_name']) || empty($_SESSION['setup_system_name'])) { $_SESSION['setup_system_name'] = 'SugarCRM'; } if (!isset($_SESSION['setup_site_session_path']) || empty($_SESSION['setup_site_session_path'])) { $_SESSION['setup_site_session_path'] = (isset($sugar_config['session_dir'])) ? $sugar_config['session_dir'] : ''; } if (!isset($_SESSION['setup_site_log_dir']) || empty($_SESSION['setup_site_log_dir'])) { $_SESSION['setup_site_log_dir'] = (isset($sugar_config['log_dir'])) ? $sugar_config['log_dir'] : '.'; } if (!isset($_SESSION['setup_site_guid']) || empty($_SESSION['setup_site_guid'])) { $_SESSION['setup_site_guid'] = (isset($sugar_config['unique_key'])) ? $sugar_config['unique_key'] : ''; } if (!isset($_SESSION['cache_dir']) || empty($_SESSION['cache_dir'])) { $_SESSION['cache_dir'] = isset($sugar_config['cache_dir']) ? $sugar_config['cache_dir'] : 'cache/'; } //$workflow[] = 'confirmSettings.php'; $workflow[] = 'perform_setup_service.php'; //$workflow[] = 'register.php'; $workflow[] = 'complete_install.php'; // increment/decrement the workflow pointer $next_step = 9999; // Add check here to see if a silent install config file exists; if so then launch silent installer if (!empty($sugar_config['installer_locked'])) { $langHeader = get_language_header(); $installResult = [ 'success' => false, 'messages' => ['Installer has been disabled'], ]; return; } $validation_errors = array(); $the_file = 'SilentInstall'; $si_errors = false; pullSilentInstallVarsIntoSession(); /* * Make sure we are using the correct unique_key. The logic * to save a custom unique_key happens lower in the process. * However because of the initial FTS check we are already * relying on this value which will not get reinitialized * when we actual need it during index creation because * SilentInstaller runs in one single process. */ if (!empty($_SESSION['setup_site_specify_guid']) && !empty($_SESSION['setup_site_guid'])) { $sugar_config['unique_key'] = $_SESSION['setup_site_guid']; } else { $sugar_config['unique_key'] = md5(create_guid()); } $validation_errors = validate_dbConfig(); if ((is_countable($validation_errors) ? count($validation_errors) : 0) > 0) { $the_file = 'dbConfig_a.php'; $si_errors = true; } $validation_errors = validate_siteConfig('a'); if ((is_countable($validation_errors) ? count($validation_errors) : 0) > 0) { $the_file = 'siteConfig_a.php'; $si_errors = true; } $validation_errors = validate_siteConfig('b'); if ((is_countable($validation_errors) ? count($validation_errors) : 0) > 0) { $the_file = 'siteConfig_b.php'; $si_errors = true; } if ($si_errors) { $installResult = [ 'success' => false, 'messages' => $validation_errors, ]; return; } require_once('jssource/minify.php'); //since this is a SilentInstall we still need to make sure that //the appropriate files are writable // config.php $result = make_writable('./config.php'); if (!$result) { $installResult = [ 'success' => false, 'messages' => ['Not able to write to /public/legacy/config.php'], ]; return; } // custom dir $result = make_writable('./custom'); if (!$result) { $installResult = [ 'success' => false, 'messages' => ['Not able to write to /public/legacy/custom'], ]; return; } // modules dir $result = recursive_make_writable('./modules'); if (!$result) { $installResult = [ 'success' => false, 'messages' => ['Not able to write to /public/legacy/modules'], ]; return; } // cache dir create_writable_dir(sugar_cached('custom_fields')); create_writable_dir(sugar_cached('dyn_lay')); create_writable_dir(sugar_cached('images')); create_writable_dir(sugar_cached('modules')); create_writable_dir(sugar_cached('layout')); create_writable_dir(sugar_cached('pdf')); create_writable_dir(sugar_cached('upload/import')); create_writable_dir(sugar_cached('xml')); create_writable_dir(sugar_cached('include/javascript')); recursive_make_writable(sugar_cached('modules')); // public dir $result = recursive_make_writable('./public'); if (!$result) { $installResult = [ 'success' => false, 'messages' => ['Not able to write to /public/legacy/public'], ]; return; } // check whether we're getting this request from a command line tool // we want to output brief messages if we're outputting to a command line tool if (!empty($validation_errors)) { $installResult = [ 'success' => false, 'messages' => $validation_errors ]; return; } $the_file = 'install/perform_setup_service.php'; if (is_file($the_file)) { installerHook('pre_installFileRequire', ['the_file' => $the_file]); $performSetupResult = []; try { require($the_file); } catch (Exception $e) { $installResult = [ 'success' => false, 'messages' => [$e->getMessage()] ]; return; } installerHook('post_installFileRequire', ['the_file' => $the_file]); if (isset($performSetupResult['success']) && $performSetupResult['success'] === false) { $installResult = $performSetupResult; return; } $installResult = [ 'success' => true, 'messages' => [] ]; return; } LoggerManager::getLogger()->fatal('Install file not found: ' . $the_file); $installResult = [ 'success' => false, 'messages' => ['Install file not found: ' . $the_file] ]; return;