aboutsummaryrefslogtreecommitdiff
path: root/cli
diff options
context:
space:
mode:
authorGravatar Alexandre Alapetite <alexandre@alapetite.fr> 2017-08-05 18:27:47 +0200
committerGravatar Alexandre Alapetite <alexandre@alapetite.fr> 2017-08-05 18:27:47 +0200
commit673b6e48b0af5f2f6f92c501f82fe10281dbf20f (patch)
treef8d0a3f0ae270cb496d25bb7237b5ad57b2cd321 /cli
parent03a99c2408ce5439c3a1402cf308eec557bfdaaf (diff)
Mutualise create-user and update-user
Diffstat (limited to 'cli')
-rw-r--r--cli/README.md5
-rw-r--r--cli/_update-or-create-user.php51
-rwxr-xr-xcli/create-user.php27
-rwxr-xr-xcli/update-user.php42
4 files changed, 63 insertions, 62 deletions
diff --git a/cli/README.md b/cli/README.md
index 6e120babe..ce1be10a7 100644
--- a/cli/README.md
+++ b/cli/README.md
@@ -43,10 +43,11 @@ cd /usr/share/FreshRSS
./cli/reconfigure.php
# Same parameters as for do-install.php. Used to update an existing installation.
-./cli/create-user.php --user username ( --password 'password' --api-password 'api_password' --language en --email user@example.net --token 'longRandomString' --no-default-feeds )
+./cli/create-user.php --user username ( --password 'password' --api_password 'api_password' --language en --email user@example.net --token 'longRandomString' --no_default_feeds --purge_after_months 3 --feed_min_articles_default 50 --feed_ttl_default 3600 --since_hours_posts_per_rss 168 --min_posts_per_rss 2 --max_posts_per_rss 400 )
# --language can be: 'en' (default), 'fr', or one of the [supported languages](../app/i18n/)
-./cli/update-user.php --user username ( --password 'password' --api-password 'api_password' --language en --email user@example.net --token 'longRandomString' --purge_after_months 3 --feed_min_articles_default 50 --feed_ttl_default 3600 --since_hours_posts_per_rss 168 --min_posts_per_rss 2 --max_posts_per_rss 400 )
+./cli/update-user.php --user username ( ... )
+# Same options as create-user.php, except --no_default_feeds which is only available for create-user.php
./cli/delete-user.php --user username
diff --git a/cli/_update-or-create-user.php b/cli/_update-or-create-user.php
new file mode 100644
index 000000000..951e28fa2
--- /dev/null
+++ b/cli/_update-or-create-user.php
@@ -0,0 +1,51 @@
+<?php
+require('_cli.php');
+
+$params = array(
+ 'user:',
+ 'password:',
+ 'api_password:',
+ 'language:',
+ 'email:',
+ 'token:',
+ 'purge_after_months:',
+ 'feed_min_articles_default:',
+ 'feed_ttl_default:',
+ 'since_hours_posts_per_rss:',
+ 'min_posts_per_rss:',
+ 'max_posts_per_rss:',
+ );
+
+if (!$isUpdate) {
+ $params[] = 'no_default_feeds'; //Only for creating new users
+}
+
+$options = getopt('', $params);
+
+if (empty($options['user'])) {
+ fail('Usage: ' . basename(__FILE__) . " --user username ( --password 'password' --api_password 'api_password'" .
+ " --language en --email user@example.net --token 'longRandomString'" .
+ ($isUpdate ? '' : '--no_default_feeds') .
+ " --purge_after_months 3 --feed_min_articles_default 50 --feed_ttl_default 3600" .
+ " --since_hours_posts_per_rss 168 --min_posts_per_rss 2 --max_posts_per_rss 400 )");
+}
+
+function strParam($name) {
+ return isset($options[$name]) ? strval($options[$name]) : null;
+}
+
+function intParam($name) {
+ return isset($options[$name]) && ctype_digit($options[$name]) ? intval($options[$name]) : null;
+}
+
+$values = array(
+ 'language' => strParam('language'),
+ 'mail_login' => strParam('email'),
+ 'token' => strParam('token'),
+ 'old_entries' => intParam('purge_after_months'),
+ 'keep_history_default' => intParam('feed_min_articles_default'),
+ 'ttl_default' => intParam('feed_ttl_default'),
+ 'since_hours_posts_per_rss' => intParam('since_hours_posts_per_rss'),
+ 'min_posts_per_rss' => intParam('min_posts_per_rss'),
+ 'max_posts_per_rss' => intParam('max_posts_per_rss'),
+ );
diff --git a/cli/create-user.php b/cli/create-user.php
index f710e8d66..add9c1b13 100755
--- a/cli/create-user.php
+++ b/cli/create-user.php
@@ -1,21 +1,8 @@
#!/usr/bin/php
<?php
-require('_cli.php');
-
-$options = getopt('', array(
- 'user:',
- 'password:',
- 'api-password:',
- 'language:',
- 'email:',
- 'token:',
- 'no-default-feeds',
- ));
-
-if (empty($options['user'])) {
- fail('Usage: ' . basename(__FILE__) . " --user username ( --password 'password' --api-password 'api_password'" .
- " --language en --email user@example.net --token 'longRandomString' --no-default-feeds )");
-}
+$isUpdate = false;
+require('_update-or-create-user.php');
+
$username = $options['user'];
if (!FreshRSS_user_Controller::checkUsername($username)) {
fail('FreshRSS error: invalid username “' . $username . '”! Must be matching ' . FreshRSS_user_Controller::USERNAME_PATTERN);
@@ -30,12 +17,8 @@ echo 'FreshRSS creating user “', $username, "”…\n";
$ok = FreshRSS_user_Controller::createUser($username,
empty($options['password']) ? '' : $options['password'],
- empty($options['api-password']) ? '' : $options['api-password'],
- array(
- 'language' => empty($options['language']) ? '' : $options['language'],
- 'mail_login' => empty($options['email']) ? '' : $options['email'],
- 'token' => empty($options['token']) ? '' : $options['token'],
- ),
+ empty($options['api_password']) ? '' : $options['api_password'],
+ $values,
!isset($options['no-default-feeds']));
if (!$ok) {
diff --git a/cli/update-user.php b/cli/update-user.php
index f8ed26c8f..ac674484c 100755
--- a/cli/update-user.php
+++ b/cli/update-user.php
@@ -1,50 +1,16 @@
#!/usr/bin/php
<?php
-require('_cli.php');
-
-$options = getopt('', array(
- 'user:',
- 'password:',
- 'api-password:',
- 'language:',
- 'email:',
- 'token:',
- 'purge_after_months:',
- 'feed_min_articles_default:',
- 'feed_ttl_default:',
- 'since_hours_posts_per_rss:',
- 'min_posts_per_rss:',
- 'max_posts_per_rss:',
- ));
-
-if (empty($options['user'])) {
- fail('Usage: ' . basename(__FILE__) . " --user username ( --password 'password' --api-password 'api_password'" .
- " --language en --email user@example.net --token 'longRandomString' --purge_after_months 3 " .
- " --feed_min_articles_default 50 --feed_ttl_default 3600 --since_hours_posts_per_rss 168 --min_posts_per_rss 2 --max_posts_per_rss 400 )");
-}
+$isUpdate = true;
+require('_update-or-create-user.php');
$username = cliInitUser($options['user']);
echo 'FreshRSS updating user “', $username, "”…\n";
-function intParam($name) {
- return isset($options[$name]) && ctype_digit($options[$name]) ? intval($options[$name]) : null;
-}
-
$ok = FreshRSS_user_Controller::updateContextUser(
empty($options['password']) ? '' : $options['password'],
- empty($options['api-password']) ? '' : $options['api-password'],
- array(
- 'language' => isset($options['language']) ? $options['language'] : null,
- 'mail_login' => isset($options['email']) ? $options['email'] : null,
- 'token' => isset($options['token']) ? $options['token'] : null,
- 'old_entries' => intParam('purge_after_months'),
- 'keep_history_default' => intParam('feed_min_articles_default'),
- 'ttl_default' => intParam('feed_ttl_default'),
- 'since_hours_posts_per_rss' => intParam('since_hours_posts_per_rss'),
- 'min_posts_per_rss' => intParam('min_posts_per_rss'),
- 'max_posts_per_rss' => intParam('max_posts_per_rss'),
- ));
+ empty($options['api_password']) ? '' : $options['api_password'],
+ $values);
if (!$ok) {
fail('FreshRSS could not update user!');