aboutsummaryrefslogtreecommitdiff
path: root/cli
diff options
context:
space:
mode:
authorGravatar Alexandre Alapetite <alexandre@alapetite.fr> 2017-07-22 20:05:36 +0200
committerGravatar Alexandre Alapetite <alexandre@alapetite.fr> 2017-07-22 20:05:36 +0200
commite046791c9330ee80580494b8fce3f5fc0bf08f98 (patch)
tree138fd1790fef6532594bc542091c1949be741f2f /cli
parentbf6dc46c644002dd195dfad18af9a1116a00fad4 (diff)
CLI update user
https://github.com/FreshRSS/FreshRSS/issues/1600 Not tested
Diffstat (limited to 'cli')
-rw-r--r--cli/README.md2
-rwxr-xr-xcli/create-user.php1
-rw-r--r--cli/update-user.php54
3 files changed, 57 insertions, 0 deletions
diff --git a/cli/README.md b/cli/README.md
index 1ac8c95ce..6e120babe 100644
--- a/cli/README.md
+++ b/cli/README.md
@@ -46,6 +46,8 @@ cd /usr/share/FreshRSS
./cli/create-user.php --user username ( --password 'password' --api-password 'api_password' --language en --email user@example.net --token 'longRandomString' --no-default-feeds )
# --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/delete-user.php --user username
./cli/list-users.php
diff --git a/cli/create-user.php b/cli/create-user.php
index c9e350c14..0b131ac35 100755
--- a/cli/create-user.php
+++ b/cli/create-user.php
@@ -33,6 +33,7 @@ $ok = FreshRSS_user_Controller::createUser($username,
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'],
),
!isset($options['no-default-feeds']));
diff --git a/cli/update-user.php b/cli/update-user.php
new file mode 100644
index 000000000..5f3335f2e
--- /dev/null
+++ b/cli/update-user.php
@@ -0,0 +1,54 @@
+#!/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' )");
+}
+
+$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($username,
+ 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'),
+ ));
+
+if (!$ok) {
+ fail('FreshRSS could not update user!');
+}
+
+invalidateHttpCache($username);
+
+done($ok);