diff options
| author | 2024-01-17 07:42:43 +0000 | |
|---|---|---|
| committer | 2024-01-17 08:42:43 +0100 | |
| commit | 6d14813840d163c76f6dc25395b0007a88b42e9d (patch) | |
| tree | d01fccbd7e31f4fdccfc6649621ba1d8d75a9eef /cli/export-zip-for-user.php | |
| parent | 314077a457f04cc2f0472e036af029e2676fbf02 (diff) | |
Standardise command line option parsing (#6036)
* Separates long & short options for parsing
* Adds parsing for short options + doc rewrites
* Fixes undefined constant in check.translation
* Standardises CL option parsing
* Refactors option parsing
* Renames getLongOptions -> getOptions
* Removes unused code
* Converges on string typing for options
* Updates docs & help files
* Updates array syntax array( ) -> [ ]
Diffstat (limited to 'cli/export-zip-for-user.php')
| -rwxr-xr-x | cli/export-zip-for-user.php | 24 |
1 files changed, 14 insertions, 10 deletions
diff --git a/cli/export-zip-for-user.php b/cli/export-zip-for-user.php index 5458784bf..d818096e4 100755 --- a/cli/export-zip-for-user.php +++ b/cli/export-zip-for-user.php @@ -5,14 +5,18 @@ require(__DIR__ . '/_cli.php'); performRequirementCheck(FreshRSS_Context::systemConf()->db['type'] ?? ''); -$params = array( - 'user:', - 'max-feed-entries:', -); - -$options = getopt('', $params); - -if (!validateOptions($argv, $params) || empty($options['user']) || !is_string($options['user'])) { +$parameters = [ + 'long' => [ + 'user' => ':', + 'max-feed-entries' => ':', + ], + 'short' => [], + 'deprecated' => [], +]; + +$options = parseCliParams($parameters); + +if (!empty($options['invalid']) || empty($options['valid']['user']) || !is_string($options['valid']['user'])) { fail('Usage: ' . basename(__FILE__) . " --user username ( --max-feed-entries 100 ) > /path/to/file.zip"); } @@ -20,12 +24,12 @@ if (!extension_loaded('zip')) { fail('FreshRSS error: Lacking php-zip extension!'); } -$username = cliInitUser($options['user']); +$username = cliInitUser($options['valid']['user']); fwrite(STDERR, 'FreshRSS exporting ZIP for user “' . $username . "”…\n"); $export_service = new FreshRSS_Export_Service($username); -$number_entries = empty($options['max-feed-entries']) ? 100 : intval($options['max-feed-entries']); +$number_entries = empty($options['valid']['max-feed-entries']) ? 100 : intval($options['valid']['max-feed-entries']); $exported_files = []; // First, we generate the OPML file |
