Compare commits
25 Commits
b52faac854
...
main
| Author | SHA1 | Date | |
|---|---|---|---|
| d28e2ea89a | |||
| f79501e4c8 | |||
| a79f5c7ee6 | |||
| 618d186ea2 | |||
| 6245e4a16a | |||
| 988bc7a0f5 | |||
| e41eb07485 | |||
| 1efa0c24e8 | |||
| 5e4cd968ec | |||
| 872a787989 | |||
| 52ac5aec24 | |||
| 1eccbe5405 | |||
| 580b243bbf | |||
| de3996172a | |||
| 8a08b6c760 | |||
| 7ac2ba401c | |||
| adacdda404 | |||
| 5318fb2304 | |||
| 0dd3dd299c | |||
| 987a3e81cc | |||
| d2e6f186cf | |||
| 762246f879 | |||
| 835a46ae27 | |||
| 02d3e02919 | |||
| 4686d0d5f5 |
51
README.md
51
README.md
@@ -2,31 +2,52 @@
|
||||
|
||||
This role deploys [FreshRSS](https://www.freshrss.org/) to your server(s).
|
||||
|
||||
It **does not** deploy php, nor a webserver or a database. However, it does install the dependencies for FreshRSS, including php-sqlite3 in case you want to use a simple SQLite database.
|
||||
It **does not** deploy php, nor a webserver or a database.
|
||||
|
||||
## Example playbook
|
||||
However, it does install the PHP dependencies for FreshRSS, including php-sqlite3 in case you want to use a simple SQLite database.
|
||||
|
||||
## Requirements
|
||||
|
||||
- Ansible 2.10
|
||||
- Deb-based distribution (Debian, Ubuntu, etc.)
|
||||
|
||||
## Dependencies
|
||||
|
||||
This role doesn't have any dependencies to other roles.
|
||||
|
||||
## Playbook example
|
||||
|
||||
```yaml
|
||||
---
|
||||
- name: Deploy FreshRSS
|
||||
hosts: freshrss
|
||||
hosts: freshrss_servers
|
||||
become: true
|
||||
|
||||
roles:
|
||||
- freshrss
|
||||
```
|
||||
|
||||
## Example var file
|
||||
|
||||
```yaml
|
||||
vars:
|
||||
freshrss_root_dir: "/var/www"
|
||||
freshrss_path: "/var/www/rss"
|
||||
freshrss_version: "1.27.1"
|
||||
freshrss_refresh_interval: 15 # every 15 minutes
|
||||
freshrss_checksum: "99fd1d0e6f506832e6600c98e4c9369edad6bfec715df9b1b7c8c3eb6a455c22"
|
||||
freshrss_refresh_interval: 10
|
||||
roles:
|
||||
- ansible-role-freshrss
|
||||
```
|
||||
|
||||
## FreshRSS configuration
|
||||
## Variables
|
||||
|
||||
It's done once deployed, navigate to the address you’ve installed your server to complete the installation from the GUI.
|
||||
| Variable | Required | Default | Description |
|
||||
| --------------------------- | -------- | ---------------------------------- | ---------------------------------------------------------------- |
|
||||
| `freshrss_checksum` | No | `""` | SHA256 checksum to verify the archive if user sets it |
|
||||
| `freshrss_group` | No | `www-data` | Group that will own FreshRSS files |
|
||||
| `freshrss_path` | No | `{{ freshrss_root_dir }}/freshrss` | Web-accessible path where FreshRSS will be symlinked |
|
||||
| `freshrss_refresh_interval` | No | `15` | Feed refresh interval in minutes (every X minutes) |
|
||||
| `freshrss_root_dir` | **Yes** | - | Directory where FreshRSS archive is downloaded and extracted |
|
||||
| `freshrss_user` | No | `www-data` | User that will own FreshRSS files and run the cron job |
|
||||
| `freshrss_version` | **Yes** | - | FreshRSS version to deploy (e.g., `"1.27.1"`) |
|
||||
|
||||
## Additional information
|
||||
|
||||
FreshRSS configuration is to be done once deployed.
|
||||
|
||||
Navigate to the address you’ve installed your server to complete the installation from the GUI.
|
||||
|
||||
## License
|
||||
|
||||
|
||||
6
defaults/main.yml
Normal file
6
defaults/main.yml
Normal file
@@ -0,0 +1,6 @@
|
||||
---
|
||||
freshrss_path: "{{ freshrss_root_dir }}/freshrss"
|
||||
freshrss_checksum: ""
|
||||
freshrss_user: www-data
|
||||
freshrss_group: www-data
|
||||
freshrss_refresh_interval: 15
|
||||
@@ -8,8 +8,11 @@
|
||||
ansible.builtin.get_url:
|
||||
url: https://github.com/FreshRSS/FreshRSS/archive/refs/tags/{{ freshrss_version }}.tar.gz
|
||||
dest: "{{ freshrss_root_dir }}/freshrss-{{ freshrss_version }}.tar.gz"
|
||||
mode: '0644'
|
||||
mode: "0644"
|
||||
checksum: "{{ 'sha256:' ~ freshrss_checksum if (freshrss_checksum | length > 0) else omit }}"
|
||||
when: not freshrss_dir.stat.exists
|
||||
retries: 3
|
||||
delay: 5
|
||||
|
||||
- name: Uncompress FreshRSS
|
||||
ansible.builtin.unarchive:
|
||||
@@ -22,12 +25,13 @@
|
||||
ansible.builtin.file:
|
||||
name: "{{ freshrss_root_dir }}/freshrss-{{ freshrss_version }}.tar.gz"
|
||||
state: absent
|
||||
when: not freshrss_dir.stat.exists
|
||||
|
||||
- name: Give ownership to www-data
|
||||
- name: Give ownership to user {{ freshrss_user }} and group {{ freshrss_group }}
|
||||
ansible.builtin.file:
|
||||
path: "{{ freshrss_root_dir }}/FreshRSS-{{ freshrss_version }}"
|
||||
owner: www-data
|
||||
group: www-data
|
||||
owner: "{{ freshrss_user }}"
|
||||
group: "{{ freshrss_group }}"
|
||||
recurse: true
|
||||
|
||||
- name: Link the folder to web root on folder
|
||||
@@ -38,16 +42,16 @@
|
||||
follow: false
|
||||
force: true
|
||||
|
||||
- name: Give ownership to www-data on link
|
||||
- name: Give ownership to {{ freshrss_user }} on link
|
||||
ansible.builtin.file:
|
||||
path: "{{ freshrss_path }}"
|
||||
owner: www-data
|
||||
group: www-data
|
||||
owner: "{{ freshrss_user }}"
|
||||
group: "{{ freshrss_group }}"
|
||||
follow: false
|
||||
|
||||
- name: Setup a cron to refresh feeds
|
||||
ansible.builtin.cron:
|
||||
name: update feeds
|
||||
user: www-data
|
||||
user: "{{ freshrss_user }}"
|
||||
minute: "*/{{ freshrss_refresh_interval }}"
|
||||
job: php -f {{ freshrss_path }}/app/actualize_script.php 1>/dev/null 2>&1
|
||||
|
||||
@@ -1,4 +1,10 @@
|
||||
---
|
||||
- name: Create freshrss_root_dir if it doesn't exist
|
||||
ansible.builtin.file:
|
||||
path: "{{ freshrss_root_dir }}"
|
||||
state: directory
|
||||
mode: "0755"
|
||||
|
||||
- name: Install cron for automatic feed refresh
|
||||
ansible.builtin.apt:
|
||||
name: cron
|
||||
|
||||
Reference in New Issue
Block a user