]> git.mxchange.org Git - friendica.git/blobdiff - src/Module/Install.php
Merge pull request #7848 from annando/mail-hooks
[friendica.git] / src / Module / Install.php
index d1a35c1518597eff9e631ec1a15a6818f9ac8981..71547ad51e4778250fcf84ad2fbc43224fd31cf5 100644 (file)
@@ -5,8 +5,11 @@ namespace Friendica\Module;
 use Friendica\App;
 use Friendica\BaseModule;
 use Friendica\Core;
+use Friendica\Core\Config\Cache\ConfigCache;
 use Friendica\Core\L10n;
 use Friendica\Core\Renderer;
+use Friendica\Network\HTTPException;
+use Friendica\Util\BasePath;
 use Friendica\Util\Strings;
 use Friendica\Util\Temporal;
 
@@ -17,17 +20,21 @@ class Install extends BaseModule
         */
        const SYSTEM_CHECK = 1;
        /**
-        * Step two - Database configuration
+        * Step two - Base information
         */
-       const DATABASE_CONFIG = 2;
+       const BASE_CONFIG = 2;
        /**
-        * Step three - Adapat site settings
+        * Step three - Database configuration
         */
-       const SITE_SETTINGS = 3;
+       const DATABASE_CONFIG = 3;
        /**
-        * Step four - All steps finished
+        * Step four - Adapt site settings
         */
-       const FINISHED = 4;
+       const SITE_SETTINGS = 4;
+       /**
+        * Step five - All steps finished
+        */
+       const FINISHED = 5;
 
        /**
         * @var int The current step of the wizard
@@ -39,79 +46,113 @@ class Install extends BaseModule
         */
        private static $installer;
 
-       public static function init()
+       public static function init(array $parameters = [])
        {
                $a = self::getApp();
 
+               if (!$a->getMode()->isInstall()) {
+                       throw new HTTPException\ForbiddenException();
+               }
+
                // route: install/testrwrite
                // $baseurl/install/testrwrite to test if rewrite in .htaccess is working
+               // @TODO: Replace with parameter from router
                if ($a->getArgumentValue(1, '') == 'testrewrite') {
                        // Status Code 204 means that it worked without content
-                       Core\System::httpExit(204);
+                       throw new HTTPException\NoContentException();
                }
 
+               self::$installer = new Core\Installer();
+
+               // get basic installation information and save them to the config cache
+               $configCache = $a->getConfigCache();
+               $basePath = new BasePath($a->getBasePath());
+               self::$installer->setUpCache($configCache, $basePath->getPath());
+
                // We overwrite current theme css, because during install we may not have a working mod_rewrite
                // so we may not have a css at all. Here we set a static css file for the install procedure pages
                Renderer::$theme['stylesheet'] = $a->getBaseURL() . '/view/install/style.css';
 
-               self::$installer = new Core\Installer();
-               self::$currentWizardStep = defaults($_POST, 'pass', self::SYSTEM_CHECK);
+               self::$currentWizardStep = ($_POST['pass'] ?? '') ?: self::SYSTEM_CHECK;
        }
 
-       public static function post()
+       public static function post(array $parameters = [])
        {
-               $a = self::getApp();
+               $a           = self::getApp();
+               $configCache = $a->getConfigCache();
 
                switch (self::$currentWizardStep) {
                        case self::SYSTEM_CHECK:
+                       case self::BASE_CONFIG:
+                               self::checkSetting($configCache, $_POST, 'config', 'php_path');
+                               break;
+
                        case self::DATABASE_CONFIG:
-                               // Nothing to do in these steps
+                               self::checkSetting($configCache, $_POST, 'config', 'php_path');
+
+                               self::checkSetting($configCache, $_POST, 'config', 'hostname');
+                               self::checkSetting($configCache, $_POST, 'system', 'ssl_policy');
+                               self::checkSetting($configCache, $_POST, 'system', 'basepath');
+                               self::checkSetting($configCache, $_POST, 'system', 'urlpath');
                                break;
 
                        case self::SITE_SETTINGS:
-                               $dbhost  = Strings::escapeTags(trim(defaults($_POST, 'dbhost', Core\Installer::DEFAULT_HOST)));
-                               $dbuser  = Strings::escapeTags(trim(defaults($_POST, 'dbuser', '')));
-                               $dbpass  = Strings::escapeTags(trim(defaults($_POST, 'dbpass', '')));
-                               $dbdata  = Strings::escapeTags(trim(defaults($_POST, 'dbdata', '')));
+                               self::checkSetting($configCache, $_POST, 'config', 'php_path');
+
+                               self::checkSetting($configCache, $_POST, 'config', 'hostname');
+                               self::checkSetting($configCache, $_POST, 'system', 'ssl_policy');
+                               self::checkSetting($configCache, $_POST, 'system', 'basepath');
+                               self::checkSetting($configCache, $_POST, 'system', 'urlpath');
+
+                               self::checkSetting($configCache, $_POST, 'database', 'hostname', Core\Installer::DEFAULT_HOST);
+                               self::checkSetting($configCache, $_POST, 'database', 'username', '');
+                               self::checkSetting($configCache, $_POST, 'database', 'password', '');
+                               self::checkSetting($configCache, $_POST, 'database', 'database', '');
 
                                // If we cannot connect to the database, return to the previous step
-                               if (!self::$installer->checkDB($dbhost, $dbuser, $dbpass, $dbdata)) {
+                               if (!self::$installer->checkDB($a->getDBA())) {
                                        self::$currentWizardStep = self::DATABASE_CONFIG;
                                }
 
                                break;
 
                        case self::FINISHED:
-                               $urlpath   = $a->getURLPath();
-                               $dbhost    = Strings::escapeTags(trim(defaults($_POST, 'dbhost', Core\Installer::DEFAULT_HOST)));
-                               $dbuser    = Strings::escapeTags(trim(defaults($_POST, 'dbuser', '')));
-                               $dbpass    = Strings::escapeTags(trim(defaults($_POST, 'dbpass', '')));
-                               $dbdata    = Strings::escapeTags(trim(defaults($_POST, 'dbdata', '')));
-                               $timezone  = Strings::escapeTags(trim(defaults($_POST, 'timezone', Core\Installer::DEFAULT_TZ)));
-                               $language  = Strings::escapeTags(trim(defaults($_POST, 'language', Core\Installer::DEFAULT_LANG)));
-                               $adminmail = Strings::escapeTags(trim(defaults($_POST, 'adminmail', '')));
+                               self::checkSetting($configCache, $_POST, 'config', 'php_path');
+
+                               self::checkSetting($configCache, $_POST, 'config', 'hostname');
+                               self::checkSetting($configCache, $_POST, 'system', 'ssl_policy');
+                               self::checkSetting($configCache, $_POST, 'system', 'basepath');
+                               self::checkSetting($configCache, $_POST, 'system', 'urlpath');
+
+                               self::checkSetting($configCache, $_POST, 'database', 'hostname', Core\Installer::DEFAULT_HOST);
+                               self::checkSetting($configCache, $_POST, 'database', 'username', '');
+                               self::checkSetting($configCache, $_POST, 'database', 'password', '');
+                               self::checkSetting($configCache, $_POST, 'database', 'database', '');
+
+                               self::checkSetting($configCache, $_POST, 'system', 'default_timezone', Core\Installer::DEFAULT_TZ);
+                               self::checkSetting($configCache, $_POST, 'system', 'language', Core\Installer::DEFAULT_LANG);
+                               self::checkSetting($configCache, $_POST, 'config', 'admin_email', '');
 
                                // If we cannot connect to the database, return to the Database config wizard
-                               if (!self::$installer->checkDB($dbhost, $dbuser, $dbpass, $dbdata)) {
+                               if (!self::$installer->checkDB($a->getDBA())) {
                                        self::$currentWizardStep = self::DATABASE_CONFIG;
                                        return;
                                }
 
-                               $phpath = self::$installer->getPHPPath();
-
-                               if (!self::$installer->createConfig($phpath, $urlpath, $dbhost, $dbuser, $dbpass, $dbdata, $timezone, $language, $adminmail, $a->getBasePath())) {
+                               if (!self::$installer->createConfig($configCache)) {
                                        return;
                                }
 
-                               self::$installer->installDatabase();
+                               self::$installer->installDatabase($configCache->get('system', 'basepath'));
 
                                break;
                }
        }
 
-       public static function content()
+       public static function content(array $parameters = [])
        {
-               $a = self::getApp();
+               $a           = self::getApp();
+               $configCache = $a->getConfigCache();
 
                $output = '';
 
@@ -119,107 +160,132 @@ class Install extends BaseModule
 
                switch (self::$currentWizardStep) {
                        case self::SYSTEM_CHECK:
-                               $phppath = defaults($_POST, 'phpath', null);
+                               $php_path = $configCache->get('config', 'php_path');
+
+                               $status = self::$installer->checkEnvironment($a->getBaseURL(), $php_path);
+
+                               $tpl    = Renderer::getMarkupTemplate('install_checks.tpl');
+                               $output .= Renderer::replaceMacros($tpl, [
+                                       '$title'       => $install_title,
+                                       '$pass'        => L10n::t('System check'),
+                                       '$checks'      => self::$installer->getChecks(),
+                                       '$passed'      => $status,
+                                       '$see_install' => L10n::t('Please see the file "INSTALL.txt".'),
+                                       '$next'        => L10n::t('Next'),
+                                       '$reload'      => L10n::t('Check again'),
+                                       '$php_path'    => $php_path,
+                               ]);
+                               break;
 
-                               $status = self::$installer->checkEnvironment($a->getBaseURL(), $phppath);
+                       case self::BASE_CONFIG:
+                               $ssl_choices = [
+                                       App\BaseURL::SSL_POLICY_NONE     => L10n::t("No SSL policy, links will track page SSL state"),
+                                       App\BaseURL::SSL_POLICY_FULL     => L10n::t("Force all links to use SSL"),
+                                       App\BaseURL::SSL_POLICY_SELFSIGN => L10n::t("Self-signed certificate, use SSL for local links only \x28discouraged\x29")
+                               ];
 
-                               $tpl = Renderer::getMarkupTemplate('install_checks.tpl');
+                               $tpl    = Renderer::getMarkupTemplate('install_base.tpl');
                                $output .= Renderer::replaceMacros($tpl, [
-                                       '$title'                => $install_title,
-                                       '$pass'                 => L10n::t('System check'),
-                                       '$checks'               => self::$installer->getChecks(),
-                                       '$passed'               => $status,
-                                       '$see_install'  => L10n::t('Please see the file "INSTALL.txt".'),
-                                       '$next'                 => L10n::t('Next'),
-                                       '$reload'               => L10n::t('Check again'),
-                                       '$phpath'               => $phppath,
-                                       '$baseurl'              => $a->getBaseURL()
+                                       '$title'      => $install_title,
+                                       '$pass'       => L10n::t('Base settings'),
+                                       '$ssl_policy' => ['system-ssl_policy',
+                                               L10n::t("SSL link policy"),
+                                               $configCache->get('system', 'ssl_policy'),
+                                               L10n::t("Determines whether generated links should be forced to use SSL"),
+                                               $ssl_choices],
+                                       '$hostname'   => ['config-hostname',
+                                               L10n::t('Host name'),
+                                               $configCache->get('config', 'hostname'),
+                                               L10n::t('Overwrite this field in case the determinated hostname isn\'t right, otherweise leave it as is.'),
+                                               'required'],
+                                       '$basepath'   => ['system-basepath',
+                                               L10n::t("Base path to installation"),
+                                               $configCache->get('system', 'basepath'),
+                                               L10n::t("If the system cannot detect the correct path to your installation, enter the correct path here. This setting should only be set if you are using a restricted system and symbolic links to your webroot."),
+                                               'required'],
+                                       '$urlpath'    => ['system-urlpath',
+                                               L10n::t('Sub path of the URL'),
+                                               $configCache->get('system', 'urlpath'),
+                                               L10n::t('Overwrite this field in case the sub path determination isn\'t right, otherwise leave it as is. Leaving this field blank means the installation is at the base URL without sub path.'),
+                                               ''],
+                                       '$php_path'   => $configCache->get('config', 'php_path'),
+                                       '$submit'     => L10n::t('Submit'),
                                ]);
                                break;
 
                        case self::DATABASE_CONFIG:
-                               $dbhost    = Strings::escapeTags(trim(defaults($_POST, 'dbhost'   , Core\Installer::DEFAULT_HOST)));
-                               $dbuser    = Strings::escapeTags(trim(defaults($_POST, 'dbuser'   , ''                          )));
-                               $dbpass    = Strings::escapeTags(trim(defaults($_POST, 'dbpass'   , ''                          )));
-                               $dbdata    = Strings::escapeTags(trim(defaults($_POST, 'dbdata'   , ''                          )));
-                               $phpath    = Strings::escapeTags(trim(defaults($_POST, 'phpath'   , ''                          )));
-                               $adminmail = Strings::escapeTags(trim(defaults($_POST, 'adminmail', ''                          )));
-
-                               $tpl = Renderer::getMarkupTemplate('install_db.tpl');
+                               $tpl    = Renderer::getMarkupTemplate('install_db.tpl');
                                $output .= Renderer::replaceMacros($tpl, [
-                                       '$title'        => $install_title,
-                                       '$pass'         => L10n::t('Database connection'),
-                                       '$info_01'      => L10n::t('In order to install Friendica we need to know how to connect to your database.'),
-                                       '$info_02'      => L10n::t('Please contact your hosting provider or site administrator if you have questions about these settings.'),
-                                       '$info_03'      => L10n::t('The database you specify below should already exist. If it does not, please create it before continuing.'),
-                                       'checks'        => self::$installer->getChecks(),
-                                       '$dbhost'       => ['dbhost',
-                                                                       L10n::t('Database Server Name'),
-                                                                       $dbhost,
-                                                                       '',
-                                                                       'required'],
-                                       '$dbuser'       => ['dbuser',
-                                                                       L10n::t('Database Login Name'),
-                                                                       $dbuser,
-                                                                       '',
-                                                                       'required',
-                                                                       'autofocus'],
-                                       '$dbpass'       => ['dbpass',
-                                                                       L10n::t('Database Login Password'),
-                                                                       $dbpass,
-                                                                       L10n::t("For security reasons the password must not be empty"),
-                                                                       'required'],
-                                       '$dbdata'       => ['dbdata',
-                                                                       L10n::t('Database Name'),
-                                                                       $dbdata,
-                                                                       '',
-                                                                       'required'],
-                                       '$adminmail' => ['adminmail',
-                                                                       L10n::t('Site administrator email address'),
-                                                                       $adminmail,
-                                                                       L10n::t('Your account email address must match this in order to use the web admin panel.'),
-                                                                       'required',
-                                                                       'autofocus',
-                                                                       'email'],
-                                       '$lbl_10'       => L10n::t('Please select a default timezone for your website'),
-                                       '$baseurl'      => $a->getBaseURL(),
-                                       '$phpath'       => $phpath,
-                                       '$submit'       => L10n::t('Submit')
+                                       '$title'      => $install_title,
+                                       '$pass'       => L10n::t('Database connection'),
+                                       '$info_01'    => L10n::t('In order to install Friendica we need to know how to connect to your database.'),
+                                       '$info_02'    => L10n::t('Please contact your hosting provider or site administrator if you have questions about these settings.'),
+                                       '$info_03'    => L10n::t('The database you specify below should already exist. If it does not, please create it before continuing.'),
+                                       'checks'      => self::$installer->getChecks(),
+                                       '$hostname'   => $configCache->get('config', 'hostname'),
+                                       '$ssl_policy' => $configCache->get('system', 'ssl_policy'),
+                                       '$basepath'   => $configCache->get('system', 'basepath'),
+                                       '$urlpath'    => $configCache->get('system', 'urlpath'),
+                                       '$dbhost'     => ['database-hostname',
+                                               L10n::t('Database Server Name'),
+                                               $configCache->get('database', 'hostname'),
+                                               '',
+                                               'required'],
+                                       '$dbuser'     => ['database-username',
+                                               L10n::t('Database Login Name'),
+                                               $configCache->get('database', 'username'),
+                                               '',
+                                               'required',
+                                               'autofocus'],
+                                       '$dbpass'     => ['database-password',
+                                               L10n::t('Database Login Password'),
+                                               $configCache->get('database', 'password'),
+                                               L10n::t("For security reasons the password must not be empty"),
+                                               'required'],
+                                       '$dbdata'     => ['database-database',
+                                               L10n::t('Database Name'),
+                                               $configCache->get('database', 'database'),
+                                               '',
+                                               'required'],
+                                       '$lbl_10'     => L10n::t('Please select a default timezone for your website'),
+                                       '$php_path'   => $configCache->get('config', 'php_path'),
+                                       '$submit'     => L10n::t('Submit')
                                ]);
                                break;
 
                        case self::SITE_SETTINGS:
-                               $dbhost = Strings::escapeTags(trim(defaults($_POST, 'dbhost', Core\Installer::DEFAULT_HOST)));
-                               $dbuser = Strings::escapeTags(trim(defaults($_POST, 'dbuser', ''                          )));
-                               $dbpass = Strings::escapeTags(trim(defaults($_POST, 'dbpass', ''                          )));
-                               $dbdata = Strings::escapeTags(trim(defaults($_POST, 'dbdata', ''                          )));
-                               $phpath = Strings::escapeTags(trim(defaults($_POST, 'phpath', ''                          )));
-
-                               $adminmail = Strings::escapeTags(trim(defaults($_POST, 'adminmail', '')));
-
-                               $timezone = defaults($_POST, 'timezone', Core\Installer::DEFAULT_TZ);
                                /* Installed langs */
                                $lang_choices = L10n::getAvailableLanguages();
 
-                               $tpl = Renderer::getMarkupTemplate('install_settings.tpl');
+                               $tpl    = Renderer::getMarkupTemplate('install_settings.tpl');
                                $output .= Renderer::replaceMacros($tpl, [
-                                       '$title'                => $install_title,
-                                       '$checks'               => self::$installer->getChecks(),
-                                       '$pass'                 => L10n::t('Site settings'),
-                                       '$dbhost'               => $dbhost,
-                                       '$dbuser'               => $dbuser,
-                                       '$dbpass'               => $dbpass,
-                                       '$dbdata'               => $dbdata,
-                                       '$phpath'               => $phpath,
-                                       '$adminmail'    => ['adminmail', L10n::t('Site administrator email address'), $adminmail, L10n::t('Your account email address must match this in order to use the web admin panel.'), 'required', 'autofocus', 'email'],
-                                       '$timezone'     => Temporal::getTimezoneField('timezone', L10n::t('Please select a default timezone for your website'), $timezone, ''),
-                                       '$language'     => ['language',
-                                                                               L10n::t('System Language:'),
-                                                                               Core\Installer::DEFAULT_LANG,
-                                                                               L10n::t('Set the default language for your Friendica installation interface and to send emails.'),
-                                                                               $lang_choices],
-                                       '$baseurl'              => $a->getBaseURL(),
-                                       '$submit'               => L10n::t('Submit')
+                                       '$title'      => $install_title,
+                                       '$checks'     => self::$installer->getChecks(),
+                                       '$pass'       => L10n::t('Site settings'),
+                                       '$hostname'   => $configCache->get('config', 'hostname'),
+                                       '$ssl_policy' => $configCache->get('system', 'ssl_policy'),
+                                       '$basepath'   => $configCache->get('system', 'basepath'),
+                                       '$urlpath'    => $configCache->get('system', 'urlpath'),
+                                       '$dbhost'     => $configCache->get('database', 'hostname'),
+                                       '$dbuser'     => $configCache->get('database', 'username'),
+                                       '$dbpass'     => $configCache->get('database', 'password'),
+                                       '$dbdata'     => $configCache->get('database', 'database'),
+                                       '$adminmail'  => ['config-admin_email',
+                                               L10n::t('Site administrator email address'),
+                                               $configCache->get('config', 'admin_email'),
+                                               L10n::t('Your account email address must match this in order to use the web admin panel.'),
+                                               'required', 'autofocus', 'email'],
+                                       '$timezone'   => Temporal::getTimezoneField('system-default_timezone',
+                                               L10n::t('Please select a default timezone for your website'),
+                                               $configCache->get('system', 'default_timezone'),
+                                               ''),
+                                       '$language'   => ['system-language',
+                                               L10n::t('System Language:'),
+                                               $configCache->get('system', 'language'),
+                                               L10n::t('Set the default language for your Friendica installation interface and to send emails.'),
+                                               $lang_choices],
+                                       '$php_path'   => $configCache->get('config', 'php_path'),
+                                       '$submit'     => L10n::t('Submit')
                                ]);
                                break;
 
@@ -227,12 +293,12 @@ class Install extends BaseModule
                                $db_return_text = "";
 
                                if (count(self::$installer->getChecks()) == 0) {
-                                       $txt = '<p style="font-size: 130%;">';
-                                       $txt .= L10n::t('Your Friendica site database has been installed.') . EOL;
+                                       $txt            = '<p style="font-size: 130%;">';
+                                       $txt            .= L10n::t('Your Friendica site database has been installed.') . EOL;
                                        $db_return_text .= $txt;
                                }
 
-                               $tpl = Renderer::getMarkupTemplate('install_finished.tpl');
+                               $tpl    = Renderer::getMarkupTemplate('install_finished.tpl');
                                $output .= Renderer::replaceMacros($tpl, [
                                        '$title'  => $install_title,
                                        '$checks' => self::$installer->getChecks(),
@@ -259,10 +325,30 @@ class Install extends BaseModule
                $baseurl = $a->getBaseUrl();
                return
                        L10n::t('<h1>What next</h1>')
-                       . "<p>".L10n::t('IMPORTANT: You will need to [manually] setup a scheduled task for the worker.')
+                       . "<p>" . L10n::t('IMPORTANT: You will need to [manually] setup a scheduled task for the worker.')
                        . L10n::t('Please see the file "INSTALL.txt".')
                        . "</p><p>"
                        . L10n::t('Go to your new Friendica node <a href="%s/register">registration page</a> and register as new user. Remember to use the same email you have entered as administrator email. This will allow you to enter the site admin panel.', $baseurl)
                        . "</p>";
        }
+
+       /**
+        * Checks the $_POST settings and updates the config Cache for it
+        *
+        * @param ConfigCache $configCache The current config cache
+        * @param array       $post        The $_POST data
+        * @param string      $cat         The category of the setting
+        * @param string      $key         The key of the setting
+        * @param null|string $default     The default value
+        */
+       private static function checkSetting(ConfigCache $configCache, array $post, $cat, $key, $default = null)
+       {
+               $configCache->set($cat, $key,
+                       Strings::escapeTags(
+                               trim(($post[sprintf('%s-%s', $cat, $key)] ?? '') ?:
+                                               ($default ?? $configCache->get($cat, $key))
+                               )
+                       )
+               );
+       }
 }