mirror of
https://github.com/friendica/friendica
synced 2024-12-23 02:40:17 +00:00
Refactor Installer due new BaseURL logic
This commit is contained in:
parent
96e12be26b
commit
dbb7022ca5
8 changed files with 39 additions and 75 deletions
|
@ -158,23 +158,20 @@ class Installer
|
||||||
{
|
{
|
||||||
$basepath = $configCache->get('system', 'basepath');
|
$basepath = $configCache->get('system', 'basepath');
|
||||||
|
|
||||||
$tpl = Renderer::getMarkupTemplate('local.config.tpl');
|
$tpl = Renderer::getMarkupTemplate('install/local.config.tpl');
|
||||||
$txt = Renderer::replaceMacros($tpl, [
|
$txt = Renderer::replaceMacros($tpl, [
|
||||||
'$dbhost' => $configCache->get('database', 'hostname'),
|
'$dbhost' => $configCache->get('database', 'hostname'),
|
||||||
'$dbuser' => $configCache->get('database', 'username'),
|
'$dbuser' => $configCache->get('database', 'username'),
|
||||||
'$dbpass' => $configCache->get('database', 'password'),
|
'$dbpass' => $configCache->get('database', 'password'),
|
||||||
'$dbdata' => $configCache->get('database', 'database'),
|
'$dbdata' => $configCache->get('database', 'database'),
|
||||||
|
|
||||||
'$phpath' => $configCache->get('config', 'php_path'),
|
'$phpath' => $configCache->get('config', 'php_path'),
|
||||||
'$adminmail' => $configCache->get('config', 'admin_email'),
|
'$adminmail' => $configCache->get('config', 'admin_email'),
|
||||||
'$hostname' => $configCache->get('config', 'hostname'),
|
|
||||||
|
|
||||||
'$urlpath' => $configCache->get('system', 'urlpath'),
|
'$system_url' => $configCache->get('system', 'url'),
|
||||||
'$baseurl' => $configCache->get('system', 'url'),
|
'$basepath' => $basepath,
|
||||||
'$sslpolicy' => $configCache->get('system', 'ssl_policy'),
|
'$timezone' => $configCache->get('system', 'default_timezone'),
|
||||||
'$basepath' => $basepath,
|
'$language' => $configCache->get('system', 'language'),
|
||||||
'$timezone' => $configCache->get('system', 'default_timezone'),
|
|
||||||
'$language' => $configCache->get('system', 'language'),
|
|
||||||
]);
|
]);
|
||||||
|
|
||||||
$result = file_put_contents($basepath . DIRECTORY_SEPARATOR . 'config' . DIRECTORY_SEPARATOR . 'local.config.php', $txt);
|
$result = file_put_contents($basepath . DIRECTORY_SEPARATOR . 'config' . DIRECTORY_SEPARATOR . 'local.config.php', $txt);
|
||||||
|
|
|
@ -34,6 +34,7 @@ use Friendica\Util\BasePath;
|
||||||
use Friendica\Util\Profiler;
|
use Friendica\Util\Profiler;
|
||||||
use Friendica\Util\Temporal;
|
use Friendica\Util\Temporal;
|
||||||
use Psr\Log\LoggerInterface;
|
use Psr\Log\LoggerInterface;
|
||||||
|
use GuzzleHttp\Psr7\Uri;
|
||||||
|
|
||||||
class Install extends BaseModule
|
class Install extends BaseModule
|
||||||
{
|
{
|
||||||
|
@ -73,7 +74,7 @@ class Install extends BaseModule
|
||||||
/** @var App\Mode */
|
/** @var App\Mode */
|
||||||
protected $mode;
|
protected $mode;
|
||||||
|
|
||||||
public function __construct(App $app, App\Mode $mode, L10n $l10n, App\BaseURL $baseUrl, App\Arguments $args, LoggerInterface $logger, Profiler $profiler, Response $response, Core\Installer $installer, array $server, array $parameters = [])
|
public function __construct(App $app, BasePath $basePath, App\Mode $mode, L10n $l10n, App\BaseURL $baseUrl, App\Arguments $args, LoggerInterface $logger, Profiler $profiler, Response $response, Core\Installer $installer, array $server, array $parameters = [])
|
||||||
{
|
{
|
||||||
parent::__construct($l10n, $baseUrl, $args, $logger, $profiler, $response, $server, $parameters);
|
parent::__construct($l10n, $baseUrl, $args, $logger, $profiler, $response, $server, $parameters);
|
||||||
|
|
||||||
|
@ -94,12 +95,11 @@ class Install extends BaseModule
|
||||||
|
|
||||||
// get basic installation information and save them to the config cache
|
// get basic installation information and save them to the config cache
|
||||||
$configCache = $this->app->getConfigCache();
|
$configCache = $this->app->getConfigCache();
|
||||||
$basePath = new BasePath($this->app->getBasePath());
|
|
||||||
$this->installer->setUpCache($configCache, $basePath->getPath());
|
$this->installer->setUpCache($configCache, $basePath->getPath());
|
||||||
|
|
||||||
// We overwrite current theme css, because during install we may not have a working mod_rewrite
|
// 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
|
// so we may not have a css at all. Here we set a static css file for the install procedure pages
|
||||||
Renderer::$theme['stylesheet'] = $this->baseUrl->get() . '/view/install/style.css';
|
Renderer::$theme['stylesheet'] = $this->baseUrl . '/view/install/style.css';
|
||||||
|
|
||||||
$this->currentWizardStep = ($_POST['pass'] ?? '') ?: self::SYSTEM_CHECK;
|
$this->currentWizardStep = ($_POST['pass'] ?? '') ?: self::SYSTEM_CHECK;
|
||||||
}
|
}
|
||||||
|
@ -117,19 +117,15 @@ class Install extends BaseModule
|
||||||
case self::DATABASE_CONFIG:
|
case self::DATABASE_CONFIG:
|
||||||
$this->checkSetting($configCache, $_POST, 'config', 'php_path');
|
$this->checkSetting($configCache, $_POST, 'config', 'php_path');
|
||||||
|
|
||||||
$this->checkSetting($configCache, $_POST, 'config', 'hostname');
|
|
||||||
$this->checkSetting($configCache, $_POST, 'system', 'ssl_policy');
|
|
||||||
$this->checkSetting($configCache, $_POST, 'system', 'basepath');
|
$this->checkSetting($configCache, $_POST, 'system', 'basepath');
|
||||||
$this->checkSetting($configCache, $_POST, 'system', 'urlpath');
|
$this->checkSetting($configCache, $_POST, 'system', 'url');
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case self::SITE_SETTINGS:
|
case self::SITE_SETTINGS:
|
||||||
$this->checkSetting($configCache, $_POST, 'config', 'php_path');
|
$this->checkSetting($configCache, $_POST, 'config', 'php_path');
|
||||||
|
|
||||||
$this->checkSetting($configCache, $_POST, 'config', 'hostname');
|
|
||||||
$this->checkSetting($configCache, $_POST, 'system', 'ssl_policy');
|
|
||||||
$this->checkSetting($configCache, $_POST, 'system', 'basepath');
|
$this->checkSetting($configCache, $_POST, 'system', 'basepath');
|
||||||
$this->checkSetting($configCache, $_POST, 'system', 'urlpath');
|
$this->checkSetting($configCache, $_POST, 'system', 'url');
|
||||||
|
|
||||||
$this->checkSetting($configCache, $_POST, 'database', 'hostname', Core\Installer::DEFAULT_HOST);
|
$this->checkSetting($configCache, $_POST, 'database', 'hostname', Core\Installer::DEFAULT_HOST);
|
||||||
$this->checkSetting($configCache, $_POST, 'database', 'username', '');
|
$this->checkSetting($configCache, $_POST, 'database', 'username', '');
|
||||||
|
@ -146,10 +142,8 @@ class Install extends BaseModule
|
||||||
case self::FINISHED:
|
case self::FINISHED:
|
||||||
$this->checkSetting($configCache, $_POST, 'config', 'php_path');
|
$this->checkSetting($configCache, $_POST, 'config', 'php_path');
|
||||||
|
|
||||||
$this->checkSetting($configCache, $_POST, 'config', 'hostname');
|
|
||||||
$this->checkSetting($configCache, $_POST, 'system', 'ssl_policy');
|
|
||||||
$this->checkSetting($configCache, $_POST, 'system', 'basepath');
|
$this->checkSetting($configCache, $_POST, 'system', 'basepath');
|
||||||
$this->checkSetting($configCache, $_POST, 'system', 'urlpath');
|
$this->checkSetting($configCache, $_POST, 'system', 'url');
|
||||||
|
|
||||||
$this->checkSetting($configCache, $_POST, 'database', 'hostname', Core\Installer::DEFAULT_HOST);
|
$this->checkSetting($configCache, $_POST, 'database', 'hostname', Core\Installer::DEFAULT_HOST);
|
||||||
$this->checkSetting($configCache, $_POST, 'database', 'username', '');
|
$this->checkSetting($configCache, $_POST, 'database', 'username', '');
|
||||||
|
@ -198,9 +192,9 @@ class Install extends BaseModule
|
||||||
case self::SYSTEM_CHECK:
|
case self::SYSTEM_CHECK:
|
||||||
$php_path = $configCache->get('config', 'php_path');
|
$php_path = $configCache->get('config', 'php_path');
|
||||||
|
|
||||||
$status = $this->installer->checkEnvironment($this->baseUrl->get(), $php_path);
|
$status = $this->installer->checkEnvironment($this->baseUrl, $php_path);
|
||||||
|
|
||||||
$tpl = Renderer::getMarkupTemplate('install_checks.tpl');
|
$tpl = Renderer::getMarkupTemplate('install/01_checks.tpl');
|
||||||
$output .= Renderer::replaceMacros($tpl, [
|
$output .= Renderer::replaceMacros($tpl, [
|
||||||
'$title' => $install_title,
|
'$title' => $install_title,
|
||||||
'$pass' => $this->t('System check'),
|
'$pass' => $this->t('System check'),
|
||||||
|
@ -218,43 +212,31 @@ class Install extends BaseModule
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case self::BASE_CONFIG:
|
case self::BASE_CONFIG:
|
||||||
$ssl_choices = [
|
$baseUrl = $configCache->get('system', 'url') ?
|
||||||
App\BaseURL::SSL_POLICY_NONE => $this->t("No SSL policy, links will track page SSL state"),
|
new Uri($configCache->get('system', 'url')) :
|
||||||
App\BaseURL::SSL_POLICY_FULL => $this->t("Force all links to use SSL"),
|
$this->baseUrl;
|
||||||
App\BaseURL::SSL_POLICY_SELFSIGN => $this->t("Self-signed certificate, use SSL for local links only \x28discouraged\x29")
|
|
||||||
];
|
|
||||||
|
|
||||||
$tpl = Renderer::getMarkupTemplate('install_base.tpl');
|
$tpl = Renderer::getMarkupTemplate('install/02_base_config.tpl');
|
||||||
$output .= Renderer::replaceMacros($tpl, [
|
$output .= Renderer::replaceMacros($tpl, [
|
||||||
'$title' => $install_title,
|
'$title' => $install_title,
|
||||||
'$pass' => $this->t('Base settings'),
|
'$pass' => $this->t('Base settings'),
|
||||||
'$ssl_policy' => ['system-ssl_policy',
|
|
||||||
$this->t("SSL link policy"),
|
|
||||||
$configCache->get('system', 'ssl_policy'),
|
|
||||||
$this->t("Determines whether generated links should be forced to use SSL"),
|
|
||||||
$ssl_choices],
|
|
||||||
'$hostname' => ['config-hostname',
|
|
||||||
$this->t('Host name'),
|
|
||||||
$configCache->get('config', 'hostname'),
|
|
||||||
$this->t('Overwrite this field in case the determinated hostname isn\'t right, otherweise leave it as is.'),
|
|
||||||
$this->t('Required')],
|
|
||||||
'$basepath' => ['system-basepath',
|
'$basepath' => ['system-basepath',
|
||||||
$this->t("Base path to installation"),
|
$this->t("Base path to installation"),
|
||||||
$configCache->get('system', 'basepath'),
|
$configCache->get('system', 'basepath'),
|
||||||
$this->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."),
|
$this->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."),
|
||||||
$this->t('Required')],
|
$this->t('Required')],
|
||||||
'$urlpath' => ['system-urlpath',
|
'$system_url' => ['system-url',
|
||||||
$this->t('Sub path of the URL'),
|
$this->t('The Friendica system URL'),
|
||||||
$configCache->get('system', 'urlpath'),
|
(string)$baseUrl,
|
||||||
$this->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.'),
|
$this->t('Overwrite this field in case the system URL determination isn\'t right, otherwise leave it as is.'),
|
||||||
''],
|
$this->t('Required')],
|
||||||
'$php_path' => $configCache->get('config', 'php_path'),
|
'$php_path' => $configCache->get('config', 'php_path'),
|
||||||
'$submit' => $this->t('Submit'),
|
'$submit' => $this->t('Submit'),
|
||||||
]);
|
]);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case self::DATABASE_CONFIG:
|
case self::DATABASE_CONFIG:
|
||||||
$tpl = Renderer::getMarkupTemplate('install_db.tpl');
|
$tpl = Renderer::getMarkupTemplate('install/03_database_config.tpl');
|
||||||
$output .= Renderer::replaceMacros($tpl, [
|
$output .= Renderer::replaceMacros($tpl, [
|
||||||
'$title' => $install_title,
|
'$title' => $install_title,
|
||||||
'$pass' => $this->t('Database connection'),
|
'$pass' => $this->t('Database connection'),
|
||||||
|
@ -264,10 +246,8 @@ class Install extends BaseModule
|
||||||
'$required' => $this->t('Required'),
|
'$required' => $this->t('Required'),
|
||||||
'$requirement_not_satisfied' => $this->t('Requirement not satisfied'),
|
'$requirement_not_satisfied' => $this->t('Requirement not satisfied'),
|
||||||
'$checks' => $this->installer->getChecks(),
|
'$checks' => $this->installer->getChecks(),
|
||||||
'$hostname' => $configCache->get('config', 'hostname'),
|
|
||||||
'$ssl_policy' => $configCache->get('system', 'ssl_policy'),
|
|
||||||
'$basepath' => $configCache->get('system', 'basepath'),
|
'$basepath' => $configCache->get('system', 'basepath'),
|
||||||
'$urlpath' => $configCache->get('system', 'urlpath'),
|
'$system_url' => $configCache->get('system', 'url'),
|
||||||
'$dbhost' => ['database-hostname',
|
'$dbhost' => ['database-hostname',
|
||||||
$this->t('Database Server Name'),
|
$this->t('Database Server Name'),
|
||||||
$configCache->get('database', 'hostname'),
|
$configCache->get('database', 'hostname'),
|
||||||
|
@ -299,16 +279,14 @@ class Install extends BaseModule
|
||||||
/* Installed langs */
|
/* Installed langs */
|
||||||
$lang_choices = $this->l10n->getAvailableLanguages();
|
$lang_choices = $this->l10n->getAvailableLanguages();
|
||||||
|
|
||||||
$tpl = Renderer::getMarkupTemplate('install_settings.tpl');
|
$tpl = Renderer::getMarkupTemplate('install/04_site_settings.tpl');
|
||||||
$output .= Renderer::replaceMacros($tpl, [
|
$output .= Renderer::replaceMacros($tpl, [
|
||||||
'$title' => $install_title,
|
'$title' => $install_title,
|
||||||
'$required' => $this->t('Required'),
|
'$required' => $this->t('Required'),
|
||||||
'$checks' => $this->installer->getChecks(),
|
'$checks' => $this->installer->getChecks(),
|
||||||
'$pass' => $this->t('Site settings'),
|
'$pass' => $this->t('Site settings'),
|
||||||
'$hostname' => $configCache->get('config', 'hostname'),
|
|
||||||
'$ssl_policy' => $configCache->get('system', 'ssl_policy'),
|
|
||||||
'$basepath' => $configCache->get('system', 'basepath'),
|
'$basepath' => $configCache->get('system', 'basepath'),
|
||||||
'$urlpath' => $configCache->get('system', 'urlpath'),
|
'$system_url' => $configCache->get('system', 'url'),
|
||||||
'$dbhost' => $configCache->get('database', 'hostname'),
|
'$dbhost' => $configCache->get('database', 'hostname'),
|
||||||
'$dbuser' => $configCache->get('database', 'username'),
|
'$dbuser' => $configCache->get('database', 'username'),
|
||||||
'$dbpass' => $configCache->get('database', 'password'),
|
'$dbpass' => $configCache->get('database', 'password'),
|
||||||
|
@ -341,7 +319,7 @@ class Install extends BaseModule
|
||||||
$db_return_text .= $txt;
|
$db_return_text .= $txt;
|
||||||
}
|
}
|
||||||
|
|
||||||
$tpl = Renderer::getMarkupTemplate('install_finished.tpl');
|
$tpl = Renderer::getMarkupTemplate('install/05_finished.tpl');
|
||||||
$output .= Renderer::replaceMacros($tpl, [
|
$output .= Renderer::replaceMacros($tpl, [
|
||||||
'$title' => $install_title,
|
'$title' => $install_title,
|
||||||
'$required' => $this->t('Required'),
|
'$required' => $this->t('Required'),
|
||||||
|
@ -365,7 +343,7 @@ class Install extends BaseModule
|
||||||
*/
|
*/
|
||||||
private function whatNext(): string
|
private function whatNext(): string
|
||||||
{
|
{
|
||||||
$baseurl = $this->baseUrl->get();
|
$baseurl = $this->baseUrl;
|
||||||
return
|
return
|
||||||
$this->t('<h1>What next</h1>')
|
$this->t('<h1>What next</h1>')
|
||||||
. "<p>" . $this->t('IMPORTANT: You will need to [manually] setup a scheduled task for the worker.')
|
. "<p>" . $this->t('IMPORTANT: You will need to [manually] setup a scheduled task for the worker.')
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
|
|
||||||
<h1><img width="32" height="32" src="{{$baseurl}}/images/friendica.svg"> {{$title}}</h1>
|
<h1><img width="32" height="32" src="{{$baseurl}}/images/friendica.svg"> {{$title}}</h1>
|
||||||
<h2>{{$pass}}</h2>
|
<h2>{{$pass}}</h2>
|
||||||
<form action="{{$baseurl}}/index.php?pagename=install" method="post">
|
<form action="{{$baseurl}}/install" method="post">
|
||||||
<table>
|
<table>
|
||||||
{{foreach $checks as $check}}
|
{{foreach $checks as $check}}
|
||||||
<tr><td>{{$check.title nofilter}} </td><td>
|
<tr><td>{{$check.title nofilter}} </td><td>
|
|
@ -12,13 +12,9 @@
|
||||||
<input type="hidden" name="config-php_path" value="{{$php_path}}" />
|
<input type="hidden" name="config-php_path" value="{{$php_path}}" />
|
||||||
<input type="hidden" name="pass" value="3" />
|
<input type="hidden" name="pass" value="3" />
|
||||||
|
|
||||||
{{include file="field_select.tpl" field=$ssl_policy}}
|
|
||||||
<br />
|
|
||||||
{{include file="field_input.tpl" field=$hostname}}
|
|
||||||
<br />
|
|
||||||
{{include file="field_input.tpl" field=$basepath}}
|
{{include file="field_input.tpl" field=$basepath}}
|
||||||
<br />
|
<br />
|
||||||
{{include file="field_input.tpl" field=$urlpath}}
|
{{include file="field_input.tpl" field=$system_url}}
|
||||||
|
|
||||||
<input id="install-submit" type="submit" name="submit" value="{{$submit}}" />
|
<input id="install-submit" type="submit" name="submit" value="{{$submit}}" />
|
||||||
|
|
|
@ -22,10 +22,8 @@
|
||||||
<form id="install-form" action="{{$baseurl}}/install" method="post">
|
<form id="install-form" action="{{$baseurl}}/install" method="post">
|
||||||
|
|
||||||
<input type="hidden" name="config-php_path" value="{{$php_path}}" />
|
<input type="hidden" name="config-php_path" value="{{$php_path}}" />
|
||||||
<input type="hidden" name="config-hostname" value="{{$hostname}}" />
|
|
||||||
<input type="hidden" name="system-ssl_policy" value="{{$ssl_policy}}" />
|
|
||||||
<input type="hidden" name="system-basepath" value="{{$basepath}}" />
|
<input type="hidden" name="system-basepath" value="{{$basepath}}" />
|
||||||
<input type="hidden" name="system-urlpath" value="{{$urlpath}}" />
|
<input type="hidden" name="system-url" value="{{$system_url}}" />
|
||||||
<input type="hidden" name="pass" value="4" />
|
<input type="hidden" name="pass" value="4" />
|
||||||
|
|
||||||
{{include file="field_input.tpl" field=$dbhost}}
|
{{include file="field_input.tpl" field=$dbhost}}
|
|
@ -7,10 +7,8 @@
|
||||||
<form id="install-form" action="{{$baseurl}}/install" method="post">
|
<form id="install-form" action="{{$baseurl}}/install" method="post">
|
||||||
|
|
||||||
<input type="hidden" name="config-php_path" value="{{$php_path}}" />
|
<input type="hidden" name="config-php_path" value="{{$php_path}}" />
|
||||||
<input type="hidden" name="config-hostname" value="{{$hostname}}" />
|
|
||||||
<input type="hidden" name="system-ssl_policy" value="{{$ssl_policy}}" />
|
|
||||||
<input type="hidden" name="system-basepath" value="{{$basepath}}" />
|
<input type="hidden" name="system-basepath" value="{{$basepath}}" />
|
||||||
<input type="hidden" name="system-urlpath" value="{{$urlpath}}" />
|
<input type="hidden" name="system-url" value="{{$system_url}}" />
|
||||||
<input type="hidden" name="database-hostname" value="{{$dbhost}}" />
|
<input type="hidden" name="database-hostname" value="{{$dbhost}}" />
|
||||||
<input type="hidden" name="database-username" value="{{$dbuser}}" />
|
<input type="hidden" name="database-username" value="{{$dbuser}}" />
|
||||||
<input type="hidden" name="database-password" value="{{$dbpass}}" />
|
<input type="hidden" name="database-password" value="{{$dbpass}}" />
|
|
@ -24,14 +24,11 @@ return [
|
||||||
'php_path' => '{{$phpath|escape:'quotes' nofilter}}',
|
'php_path' => '{{$phpath|escape:'quotes' nofilter}}',
|
||||||
'admin_email' => '{{$adminmail|escape:'quotes' nofilter}}',
|
'admin_email' => '{{$adminmail|escape:'quotes' nofilter}}',
|
||||||
'sitename' => 'Friendica Social Network',
|
'sitename' => 'Friendica Social Network',
|
||||||
'hostname' => '{{$hostname|escape:'quotes' nofilter}}',
|
|
||||||
'register_policy' => \Friendica\Module\Register::OPEN,
|
'register_policy' => \Friendica\Module\Register::OPEN,
|
||||||
'max_import_size' => 200000,
|
'max_import_size' => 200000,
|
||||||
],
|
],
|
||||||
'system' => [
|
'system' => [
|
||||||
'urlpath' => '{{$urlpath|escape:'quotes' nofilter}}',
|
'url' => '{{$system_url|escape:'quotes' nofilter}}',
|
||||||
'url' => '{{$baseurl|escape:'quotes' nofilter}}',
|
|
||||||
'ssl_policy' => {{$sslpolicy|escape:'quotes' nofilter}},
|
|
||||||
'basepath' => '{{$basepath|escape:'quotes' nofilter}}',
|
'basepath' => '{{$basepath|escape:'quotes' nofilter}}',
|
||||||
'default_timezone' => '{{$timezone|escape:'quotes' nofilter}}',
|
'default_timezone' => '{{$timezone|escape:'quotes' nofilter}}',
|
||||||
'language' => '{{$language|escape:'quotes' nofilter}}',
|
'language' => '{{$language|escape:'quotes' nofilter}}',
|
Loading…
Reference in a new issue