Alexandre Alapetite ae1bf1f56f CLI do no list un-created user admin 9 سال پیش
..
.htaccess e1f214e9e2 CLI list-users and create-user 9 سال پیش
README.md 745f0ae014 Changelog 1436, 1439 9 سال پیش
_cli.php 4eeae5171b use function with preg_match to check username 9 سال پیش
actualize-user.php 879af85d3c +x execution rights actualie-user 9 سال پیش
create-user.php 4eeae5171b use function with preg_match to check username 9 سال پیش
delete-user.php 4eeae5171b use function with preg_match to check username 9 سال پیش
do-install.php 992a811df6 CLI add language to install 9 سال پیش
export-opml-for-user.php 1f03e8a3ae CLI typo in usage example 9 سال پیش
export-zip-for-user.php c8e5292ab7 CLI minor formatting 9 سال پیش
import-for-user.php fcb9280fc8 CLI export 9 سال پیش
index.html e1f214e9e2 CLI list-users and create-user 9 سال پیش
list-users.php ae1bf1f56f CLI do no list un-created user admin 9 سال پیش
reconfigure.php 271a1fdc89 Missing checkUsername and const patten 9 سال پیش
user-info.php 1f37424c09 +x execution rights user-info 9 سال پیش

README.md

FreshRSS Command-Line Interface (CLI)

Note on access rights

When using the command-line interface, remember that your user might not be the same as the one used by your Web server. This might create some access right problems.

It is recommended to invoke commands using the same user as your Web server:

cd /usr/share/FreshRSS
sudo -u www-data sh -c './cli/list-users.php'

In any case, when you are done with a series of commands, you should re-apply the access rights:

cd /usr/share/FreshRSS
sudo chown -R :www-data .
sudo chmod -R g+r .
sudo chmod -R g+w ./data/

Commands

Options in parenthesis are optional.

cd /usr/share/FreshRSS

./cli/do-install.php --default_user admin ( --auth_type form --environment production --base_url https://rss.example.net/ --title FreshRSS --allow_anonymous --api_enabled --db-type mysql --db-host localhost:3306 --db-user freshrss --db-password dbPassword123 --db-base freshrss --db-prefix freshrss )
# --auth_type can be: 'form' (default), 'http_auth' (using the Web server access control), 'none' (dangerous)
# --db-type can be: 'sqlite' (default), 'mysql' (MySQL or MariaDB), 'pgsql' (PostgreSQL)
# --environment can be: 'production' (default), 'development' (for additional log messages)
# --db-prefix is an optional prefix in front of the names of the tables. We suggest using 'freshrss_'
# This command does not create the default user. Do that with ./cli/create-user.php

./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 )
# --language can be: 'en' (default), 'fr', or one of the [supported languages](../app/i18n/)

./cli/delete-user.php --user username

./cli/list-users.php
# Return a list of users, with the default/admin user first

./cli/actualize-user.php --user username

./cli/import-for-user.php --user username --filename /path/to/file.ext
# The extension of the file { .json, .opml, .xml, .zip } is used to detect the type of import

./cli/export-opml-for-user.php --user username > /path/to/file.opml.xml

./cli/export-zip-for-user.php --user username ( --max-feed-entries 100 ) > /path/to/file.zip

./cli/user-info.php -h --user username
# -h is to use a human-readable format
# --user can be a username, or '*' to loop on all users
# Returns a * if the user is admin, the name of the user, the date/time of last action, and the size occupied

Unix piping

It is possible to invoke a command multiple times, e.g. with different usernames, thanks to the xargs -n1 command.

Example showing user information for all users which username starts with 'a':

./cli/list-users.php | grep '^a' | xargs -n1 ./cli/user-info.php -h --user

Example showing all users ranked by date of last activity:

./cli/user-info.php -h --user '*' | sort -k2 -r