aboutsummaryrefslogtreecommitdiff
path: root/cli/import-for-user.php
diff options
context:
space:
mode:
Diffstat (limited to 'cli/import-for-user.php')
-rwxr-xr-xcli/import-for-user.php33
1 files changed, 15 insertions, 18 deletions
diff --git a/cli/import-for-user.php b/cli/import-for-user.php
index 6969a8946..4c4db8405 100755
--- a/cli/import-for-user.php
+++ b/cli/import-for-user.php
@@ -5,27 +5,24 @@ require(__DIR__ . '/_cli.php');
performRequirementCheck(FreshRSS_Context::systemConf()->db['type'] ?? '');
-$parameters = [
- 'long' => [
- 'user' => ':',
- 'filename' => ':',
- ],
- 'short' => [],
- 'deprecated' => [],
-];
-
-$options = parseCliParams($parameters);
-
-if (!empty($options['invalid'])
- || empty($options['valid']['user']) || empty($options['valid']['filename'])
- || !is_string($options['valid']['user']) || !is_string($options['valid']['filename'])
-) {
- fail('Usage: ' . basename(__FILE__) . " --user username --filename /path/to/file.ext");
+$cliOptions = new class extends CliOptionsParser {
+ public string $user;
+ public string $filename;
+
+ public function __construct() {
+ $this->addRequiredOption('user', (new CliOption('user')));
+ $this->addRequiredOption('filename', (new CliOption('filename')));
+ parent::__construct();
+ }
+};
+
+if (!empty($cliOptions->errors)) {
+ fail('FreshRSS error: ' . array_shift($cliOptions->errors) . "\n" . $cliOptions->usage);
}
-$username = cliInitUser($options['valid']['user']);
+$username = cliInitUser($cliOptions->user);
+$filename = $cliOptions->filename;
-$filename = $options['valid']['filename'];
if (!is_readable($filename)) {
fail('FreshRSS error: file is not readable “' . $filename . '”');
}