FreshRSS is a self-hosted RSS feed aggregator like Leed or Kriss Feed.
It is lightweight, easy to work with, powerful, and customizable.
It is a multi-user application with an anonymous reading mode. It supports custom tags. There is an API for (mobile) clients, and a Command-Line Interface.
Thanks to the WebSub standard (formerly PubSubHubbub), FreshRSS is able to receive instant push notifications from compatible sources, such as Mastodon, Friendica, WordPress, Blogger, FeedBurner, etc.
Finally, it supports extensions for further tuning.
Feature requests, bug reports, and other contributions are welcome. The best way to contribute is to open an issue on GitHub. We are a friendly community.
FreshRSS comes with absolutely no warranty.
See the list of releases.
./p/ folder to the Web)./data/ folder for the webserver userdata/config.php.AllowEncodedSlashes for better compatibility with mobile clients.More detailed information about installation and server configuration can be found in our documentation.
# If you use an Apache Web server (otherwise you need another Web server)
sudo apt-get install apache2
sudo a2enmod headers expires rewrite ssl #Apache modules
# Example for Ubuntu >= 16.04, Debian >= 9 Stretch
sudo apt install php php-curl php-gmp php-intl php-mbstring php-sqlite3 php-xml php-zip
sudo apt install libapache2-mod-php #For Apache
sudo apt install mysql-server mysql-client php-mysql #Optional MySQL database
sudo apt install postgresql php-pgsql #Optional PostgreSQL database
# Restart Web server
sudo service apache2 restart
# For FreshRSS itself (git is optional if you manually download the installation files)
cd /usr/share/
sudo apt-get install git
sudo git clone https://github.com/FreshRSS/FreshRSS.git
cd FreshRSS
# If you want to use the development version of FreshRSS
sudo git checkout -b dev origin/dev
# Set the rights so that your Web server can access the files
sudo chown -R :www-data . && sudo chmod -R g+r . && sudo chmod -R g+w ./data/
# If you would like to allow updates from the Web interface
sudo chmod -R g+w .
# Publish FreshRSS in your public HTML directory
sudo ln -s /usr/share/FreshRSS/p /var/www/html/FreshRSS
# Navigate to http://example.net/FreshRSS to complete the installation
# (If you do it from localhost, you may have to adjust the setting of your public address later)
# or use the Command-Line Interface
# Update to a newer version of FreshRSS with git
cd /usr/share/FreshRSS
sudo git pull
sudo chown -R :www-data . && sudo chmod -R g+r . && sudo chmod -R g+w ./data/
See more commands and git commands in the Command-Line Interface documentation.
This is needed if you will be using the multi-user mode, to limit access to FreshRSS. Options Available:
./p/i/.htaccess file with a matching .htpasswd file.You can add a Cron job to launch the update script. Check the Cron documentation related to your distribution (Debian/Ubuntu, Red Hat/Fedora, Slackware, Gentoo, Arch Linux…). It is a good idea to run the cron job as the webserver user (often “www-data”). For instance, if you want to run the script every hour:
9 * * * * php /usr/share/FreshRSS/app/actualize_script.php > /tmp/FreshRSS.log 2>&1
Create /etc/cron.d/FreshRSS with:
6,36 * * * * www-data php -f /usr/share/FreshRSS/app/actualize_script.php > /tmp/FreshRSS.log 2>&1
./p/ folder to the Web.
./data/ folder contains all personal data, so it is a bad idea to expose it../constants.php file defines access to the application folder. If you want to customize your installation, look here first../data/users/*/log*.txt files.
./data/users/_/ contains the part of the logs that are shared by all users../data/config.php, and ./data/users/*/config.php filesTo save articles, you can use phpMyAdmin or MySQL tools:
mysqldump --skip-comments --disable-keys --user=<db_user> --password --host <db_host> --result-file=freshrss.dump.sql --databases <freshrss_db>
FreshRSS supports further customizations by adding extensions on top of its core functionality. See the repository dedicated to those extensions.
FreshRSS supports access from native apps for Linux, Android, iOS, and OS X, via two distinct APIs.
There is more information available about our Google Reader compatible API on the page mobile access.
Supported clients are:
See our Fever API documentation page.
Supported clients are: