X-Git-Url: https://git.p6c8.net/jirafeau.git/blobdiff_plain/e1c30044b1fa083d89b4bf8f0265fb2785583411..62b537d70111349385342d657034a9e26731ca51:/install.php?ds=sidebyside diff --git a/install.php b/install.php index df4f106..ebda6f5 100644 --- a/install.php +++ b/install.php @@ -2,7 +2,8 @@ /* * Jirafeau, your web file repository * Copyright (C) 2008 Julien "axolotl" BERNARD - * Copyright (C) 2015 Nicola Spanti (RyDroid) + * Copyright (C) 2015 Jerome Jutteau + * Copyright (C) 2024 Jirafeau project (see AUTHORS.md) * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Affero General Public License as @@ -17,104 +18,14 @@ * You should have received a copy of the GNU Affero General Public License * along with this program. If not, see . */ -define ('JIRAFEAU_ROOT', dirname (__FILE__) . '/'); -define ('NL', "\n"); -define ('QUOTE', "'"); -define ('JIRAFEAU_CFG', JIRAFEAU_ROOT . 'lib/config.local.php'); -define ('JIRAFEAU_VAR_RAND_LENGTH', 15); +define('JIRAFEAU_ROOT', dirname(__FILE__) . '/'); -require (JIRAFEAU_ROOT . 'lib/settings.php'); -require (JIRAFEAU_ROOT . 'lib/functions.php'); -require (JIRAFEAU_ROOT . 'lib/lang.php'); +define('JIRAFEAU_CFG', JIRAFEAU_ROOT . 'lib/config.local.php'); +define('JIRAFEAU_VAR_RAND_LENGTH', 15); -/** - * Prepend used functions - **/ - -function -jirafeau_quoted ($str) -{ - return QUOTE . str_replace (QUOTE, "\'", $str) . QUOTE; -} - -function -jirafeau_export_cfg ($cfg) -{ - $content = ' true, - 'why' => $mkdir_str1 . '
' . - $path . '
' . $solution_str . - '
' . $mkdir_str2); - - foreach (array ('files', 'links', 'async', 'alias') as $subdir) - { - $subpath = $path.$subdir; - - if (!jirafeau_mkdir ($subpath) || !jirafeau_is_writable ($subpath)) - return array ('has_error' => true, - 'why' => $mkdir_str1 . '
' . - $subpath . '
' . $solution_str . - '
' . $mkdir_str2); - } - - return array ('has_error' => false, 'why' => ''); -} - -function -jirafeau_add_ending_slash ($path) -{ - return $path . ((substr ($path, -1) == '/') ? '' : '/'); -} - -function -jirafeau_fatal_error($errorText) -{ - echo '

Error

' . $errorText . '

'; - require (JIRAFEAU_ROOT . 'lib/template/footer.php'); - exit; -} +require(JIRAFEAU_ROOT . 'lib/settings.php'); +require(JIRAFEAU_ROOT . 'lib/functions.php'); +require(JIRAFEAU_ROOT . 'lib/lang.php'); /** * Check installation @@ -122,253 +33,175 @@ jirafeau_fatal_error($errorText) // Is the installation process done already? // Then there is nothing to do here → redirect to the main page. -if ($cfg['installation_done'] === true) -{ - header('Location: index.php'); - exit; +if ($cfg['installation_done'] === true) { + header('Location: index.php'); + exit; } /** * Prepare installation process **/ -require (JIRAFEAU_ROOT . 'lib/template/header.php'); +require(JIRAFEAU_ROOT . 'lib/template/header.php'); // does the local configuration file exist? -if (!file_exists (JIRAFEAU_CFG)) -{ +if (!file_exists(JIRAFEAU_CFG)) { // show an error if it is not possible to create the file - if (!@touch (JIRAFEAU_CFG)) - { - jirafeau_fatal_error( - t('The local configuration file could not be created. Create a ' . - 'lib/config.local.php file and give the write ' . - 'permission to the web server (preferred solution), or give the ' . - 'write permission to the web server on the lib ' . - 'directory.') - ); + if (!@touch(JIRAFEAU_CFG)) { + jirafeau_fatal_error(t('CONF_SOLUTION')); } } // is the local configuration writable? -if (!is_writable (JIRAFEAU_CFG) && !@chmod (JIRAFEAU_CFG, '0666')) -{ - jirafeau_fatal_error( - t('The local configuration is not writable by the web server. ' . - 'Give the write permission to the web server on the ' . - 'lib/config.local.php file.') - ); +if (!is_writable(JIRAFEAU_CFG) && !@chmod(JIRAFEAU_CFG, '0666')) { + jirafeau_fatal_error(t('CONF_SOLUTION_2')); } /** * Run trough each installation step **/ -if (isset ($_POST['step']) && isset ($_POST['next'])) -{ - switch ($_POST['step']) - { - case 1: - $cfg['lang'] = $_POST['lang']; - jirafeau_export_cfg ($cfg); - break; - - case 2: - $cfg['admin_password'] = hash('sha256', $_POST['admin_password']); - jirafeau_export_cfg ($cfg); - break; - - case 3: - $cfg['web_root'] = jirafeau_add_ending_slash ($_POST['web_root']); - $cfg['var_root'] = jirafeau_add_ending_slash ($_POST['var_root']); - jirafeau_export_cfg ($cfg); - break; - - case 4: - $cfg['web_root'] = jirafeau_add_ending_slash ($_POST['web_root']); - $cfg['var_root'] = jirafeau_add_ending_slash ($_POST['var_root']); - jirafeau_export_cfg ($cfg); - break; +if (isset($_POST['step']) && isset($_POST['next'])) { + switch ($_POST['step']) { + case 1: + if (strlen($_POST['admin_password'])) { + $cfg['admin_password'] = hash('sha256', $_POST['admin_password']); + } else { + $cfg['admin_password'] = ''; + } + jirafeau_export_cfg($cfg); + break; + + case 2: + $cfg['web_root'] = jirafeau_add_ending_slash($_POST['web_root']); + $cfg['var_root'] = jirafeau_add_ending_slash($_POST['var_root']); + jirafeau_export_cfg($cfg); + break; + + case 3: + $cfg['web_root'] = jirafeau_add_ending_slash($_POST['web_root']); + $cfg['var_root'] = jirafeau_add_ending_slash($_POST['var_root']); + jirafeau_export_cfg($cfg); + break; } - } $current = 1; -if (isset ($_POST['next'])) +if (isset($_POST['next'])) { $current = $_POST['step'] + 1; -else if (isset ($_POST['previous'])) +} elseif (isset($_POST['previous'])) { $current = $_POST['step'] - 1; -else if (isset ($_POST['retry'])) +} elseif (isset($_POST['retry'])) { $current = $_POST['step']; +} -switch ($current) -{ -case 1: -default: - ?>

" method = "post"> " />
- - - - -
- -
-

" method = "post">

+ "step" value = "1" />
+ id = "admin_password" size = "40" autocomplete = "new-password"/>
+ "" />

" method = "post">

+ "2" />
+ echo(empty($cfg['web_root']) ? jirafeau_default_web_root() : $cfg['web_root']); + ?>" size = "40" /> + echo t('DATA_DIR_EXPLAINATION'); + ?> + $len_alphanum = strlen($alphanum); + $var = 'var-'; + for ($i = 0; $i < JIRAFEAU_VAR_RAND_LENGTH; $i++) { + $var .= substr($alphanum, mt_rand(0, $len_alphanum - 1), 1); + } + echo JIRAFEAU_ROOT . $var . '/'; + } else { + echo $cfg['var_root']; + } + ?>" size = "40" />
- + echo t('PREV_STEP'); ?>" /> + " />

" method = "post">

+ "3" />

'.$err['why'].'
'.NL; - ?>

'.$err['why'].'
'.NL; ?> " />

+ "" />
'; - } - else - { - $cfg['installation_done'] = true; - jirafeau_export_cfg ($cfg); - echo '

' . - t('Jirafeau is now fully operational') . ':' . - '
' . - $cfg['web_root'].'

'; - } -break; + } else { + $cfg['installation_done'] = true; + jirafeau_export_cfg($cfg); + echo '

' . + t('JI_FONCTIONAL') . ':' . + '
' . + $cfg['web_root'].'

'; + } + break; } -require (JIRAFEAU_ROOT . 'lib/template/footer.php'); +require(JIRAFEAU_ROOT . 'lib/template/footer.php');