diff options
| author | 2024-01-09 22:01:17 +0000 | |
|---|---|---|
| committer | 2024-01-09 23:01:17 +0100 | |
| commit | 9a80dde238caf1338b803f67003cd459393efdc3 (patch) | |
| tree | e382cf8f980aa0813e55f2b478a21d5c30cb19ad /cli/do-install.php | |
| parent | c89073d60e491f775a13a9ec57915313eb073964 (diff) | |
2297 cli parameters consistency (#6028)
* Updates do-install params
* Adds parseCliParams to _cli.php
* Updates do-install to use parseCliParams
* Updates reconfigure to use parseCliParams
* Fixes bug mail_login => email
* Update create-user to use parseCliParams
* Minor refactor
* Updates update-user to use parseCliParams
* Fix no_default_feeds => no-default-feeds
* Refactors arrays
* Updates CLI Readme
* Adds docblocks to _cli functions
* Sets vars in _cli functions
* Fixes indentation
* Meeting coding standards around colons
* Meeting PHPStan standards
* Removes stray whitespace
* Meeting PHPStan Next Level standards
* More specific typing
* Maintaining types
* Typing around getopt()
* Fixes typo
* Fixes typo perameters -> parameters
* Removes unused variable
* Rewrites deprecation warning message
Diffstat (limited to 'cli/do-install.php')
| -rwxr-xr-x | cli/do-install.php | 115 |
1 files changed, 72 insertions, 43 deletions
diff --git a/cli/do-install.php b/cli/do-install.php index c69d5f081..3e9c59162 100755 --- a/cli/do-install.php +++ b/cli/do-install.php @@ -7,37 +7,69 @@ if (file_exists(DATA_PATH . '/applied_migrations.txt')) { fail('FreshRSS seems to be already installed!' . "\n" . 'Please use `./cli/reconfigure.php` instead.', EXIT_CODE_ALREADY_EXISTS); } -$params = array( - 'environment:', - 'base_url:', - 'language:', - 'title:', - 'default_user:', - 'allow_anonymous', - 'allow_anonymous_refresh', - 'auth_type:', - 'api_enabled', - 'allow_robots', - 'disable_update', - ); - -$dBparams = array( - 'db-type:', - 'db-host:', - 'db-user:', - 'db-password:', - 'db-base:', - 'db-prefix::', - ); - -$options = getopt('', array_merge($params, $dBparams)); - -if (!validateOptions($argv, array_merge($params, $dBparams)) || empty($options['default_user']) || !is_string($options['default_user'])) { - fail('Usage: ' . basename(__FILE__) . " --default_user admin ( --auth_type form" . - " --environment production --base_url https://rss.example.net --allow_robots" . - " --language en --title FreshRSS --allow_anonymous --allow_anonymous_refresh --api_enabled" . +$parameters = array( + 'valid' => array( + 'environment' => ':', + 'base-url' => ':', + 'language' => ':', + 'title' => ':', + 'default-user' => ':', + 'allow-anonymous' => '', + 'allow-anonymous-refresh' => '', + 'auth-type' => ':', + 'api-enabled' => '', + 'allow-robots' => '', + 'disable-update' => '', + 'db-type' => ':', + 'db-host' => ':', + 'db-user' => ':', + 'db-password' => ':', + 'db-base' => ':', + 'db-prefix' => '::', + ), + 'deprecated' => array( + 'base-url' => 'base_url', + 'default-user' => 'default_user', + 'allow-anonymous' => 'allow_anonymous', + 'allow-anonymous-refresh' => 'allow_anonymous_refresh', + 'auth-type' => 'auth_type', + 'api-enabled' => 'api_enabled', + 'allow-robots' => 'allow_robots', + 'disable-update' => 'disable_update', + ), +); + +$configParams = array( + 'environment' => 'environment', + 'base-url' => 'base_url', + 'language' => 'language', + 'title' => 'title', + 'default-user' => 'default_user', + 'allow-anonymous' => 'allow_anonymous', + 'allow-anonymous-refresh' => 'allow_anonymous_refresh', + 'auth-type' => 'auth_type', + 'api-enabled' => 'api_enabled', + 'allow-robots' => 'allow_robots', + 'disable-update' => 'disable_update', +); + +$dBconfigParams = array( + 'db-type' => 'type', + 'db-host' => 'host', + 'db-user' => 'user', + 'db-password' => 'password', + 'db-base' => 'base', + 'db-prefix' => 'prefix', +); + +$options = parseCliParams($parameters); + +if (!empty($options['invalid']) || empty($options['valid']['default-user']) || !is_string($options['valid']['default-user'])) { + fail('Usage: ' . basename(__FILE__) . " --default-user admin ( --auth-type form" . + " --environment production --base-url https://rss.example.net --allow-robots" . + " --language en --title FreshRSS --allow-anonymous --allow-anonymous-refresh --api-enabled" . " --db-type mysql --db-host localhost:3306 --db-user freshrss --db-password dbPassword123" . - " --db-base freshrss --db-prefix freshrss_ --disable_update )"); + " --db-base freshrss --db-prefix freshrss_ --disable-update )"); } fwrite(STDERR, 'FreshRSS install…' . "\n"); @@ -55,10 +87,9 @@ if (file_exists($customConfigPath)) { } } -foreach ($params as $param) { - $param = rtrim($param, ':'); - if (isset($options[$param])) { - $config[$param] = $options[$param] === false ? true : $options[$param]; +foreach ($configParams as $param => $configParam) { + if (isset($options['valid'][$param])) { + $config[$configParam] = $options['valid'][$param]; } } @@ -66,23 +97,21 @@ if ((!empty($config['base_url'])) && is_string($config['base_url']) && Minz_Requ $config['pubsubhubbub_enabled'] = true; } -foreach ($dBparams as $dBparam) { - $dBparam = rtrim($dBparam, ':'); - if (isset($options[$dBparam])) { - $param = substr($dBparam, strlen('db-')); - $config['db'][$param] = $options[$dBparam]; +foreach ($dBconfigParams as $dBparam => $configDbParam) { + if (isset($options['valid'][$dBparam])) { + $config['db'][$configDbParam] = $options['valid'][$dBparam]; } } performRequirementCheck($config['db']['type']); -if (!FreshRSS_user_Controller::checkUsername($options['default_user'])) { - fail('FreshRSS error: invalid default username “' . $options['default_user'] +if (!FreshRSS_user_Controller::checkUsername($options['valid']['default-user'])) { + fail('FreshRSS error: invalid default username “' . $options['valid']['default-user'] . '”! Must be matching ' . FreshRSS_user_Controller::USERNAME_PATTERN); } -if (isset($options['auth_type']) && !in_array($options['auth_type'], ['form', 'http_auth', 'none'], true)) { - fail('FreshRSS invalid authentication method (auth_type must be one of { form, http_auth, none })'); +if (isset($options['valid']['auth-type']) && !in_array($options['valid']['auth-type'], ['form', 'http_auth', 'none'], true)) { + fail('FreshRSS invalid authentication method (auth-type must be one of { form, http_auth, none })'); } if (file_put_contents(join_path(DATA_PATH, 'config.php'), |
