mirror of
https://github.com/FreshRSS/FreshRSS.git
synced 2026-01-31 08:31:03 -05:00
* remove outdated mailing list information * add information about normal view * add information about global and reader view * fix import section header * reorder documentation to reflect menu's order * clarify setting as default in normal view * add info about reading section for config * fix heading levels, add info about archive + profile sections * unfix heading levels * move section on feed-specific settings to the subscription management page * update information about adding feeds, add information about feed management * fix link to security page in installation * fix broken links * fix broken link to install page * add lighttpd from project readme * add php modules to step 4, add horizontal line to better separate steps from footnotes visually * fix broken link * add index page for easier access of other pages * move first steps document * make dedicated bug reporting page * make index page for linking to other pages * moved fever API to relevant location, linked to index * remove outdated mailing list information * add information about normal view * add information about global and reader view * fix import section header * reorder documentation to reflect menu's order * clarify setting as default in normal view * add info about reading section for config * fix heading levels, add info about archive + profile sections * unfix heading levels * move section on feed-specific settings to the subscription management page * update information about adding feeds, add information about feed management * fix link to security page in installation * fix broken links * fix broken link to install page * add lighttpd from project readme * add php modules to step 4, add horizontal line to better separate steps from footnotes visually * fix broken link * add index page for easier access of other pages * move first steps document * make dedicated bug reporting page * make index page for linking to other pages * moved fever API to relevant location, linked to index * re-fix link * remove mention of defunct mailing list * grammar fix * replace stream with feed * add optional items, replace stream with feed * replace stream with feed * fix word choice Co-authored-by: Frans de Jonge <fransdejonge@gmail.com> * fix word choice better reflect age of project Co-authored-by: Frans de Jonge <fransdejonge@gmail.com> * grammar fixes Co-authored-by: Frans de Jonge <fransdejonge@gmail.com> * remove double headings Co-authored-by: Frans de Jonge <fransdejonge@gmail.com> * change single quote to double quote for consistency * add subreddit link * change php module list to Dockerfile link * fix link to developer index, change html links to md for consistency * update css selector terms Co-authored-by: Frans de Jonge <fransdejonge@gmail.com> Co-authored-by: Frans de Jonge <fransdejonge@gmail.com>
111 lines
5.2 KiB
Markdown
111 lines
5.2 KiB
Markdown
# FreshRSS - Fever API implementation
|
||
|
||
See the [page about our Google Reader compatible API](06_Mobile_access.md) for another possibility
|
||
and general aspects of API access.
|
||
|
||
## RSS clients
|
||
|
||
There are many RSS clients that support the Fever API, but they seem to understand the Fever API a bit differently.
|
||
If your favourite client doesn't work properly with this API, please create an issue and we'll have a look.
|
||
But we can **only** do that for free clients.
|
||
|
||
### Usage & Authentication
|
||
|
||
Before you can start using this API, you have to enable and setup API access, which is [documented here](https://freshrss.github.io/FreshRSS/en/users/06_Mobile_access.html),
|
||
and then reset the user’s API password.
|
||
|
||
Then point your mobile application to the `fever.php` address (e.g. `https://freshrss.example.net/api/fever.php`).
|
||
|
||
## Compatible clients
|
||
|
||
| App | Platform | License |
|
||
|:----------------------------------------------------------------------------------:|:-------------------:|:--------------------------------------------------------:|
|
||
|[Fluent Reader](https://hyliu.me/fluent-reader/) |Windows, Linux, macOS|[BSD-3-Clause](https://github.com/yang991178/fluent-reader/blob/master/LICENSE)|
|
||
|[Readably](https://play.google.com/store/apps/details?id=com.isaiasmatewos.readably)|Android |Closed Source |
|
||
|[Fiery Feeds](https://apps.apple.com/app/fiery-feeds-rss-reader/id1158763303) |iOS |Closed Source |
|
||
|[Unread](https://apps.apple.com/app/unread-rss-reader/id1252376153) |iOS |Closed Source |
|
||
|[Reeder](https://www.reederapp.com/) |iOS |Closed Source |
|
||
|[ReadKit](https://apps.apple.com/app/readkit/id588726889) |macOS |Closed Source |
|
||
|
||
## Features
|
||
|
||
The following features are implemented:
|
||
|
||
* fetching categories
|
||
* fetching feeds
|
||
* fetching RSS items (new, favorites, unread, by_id, by_feed, by_category, since)
|
||
* fetching favicons
|
||
* setting read marker for item(s)
|
||
* setting starred marker for item(s)
|
||
* setting read marker for feed
|
||
* setting read marker for category
|
||
* supports FreshRSS extensions, which use the `entry_before_display` hook
|
||
|
||
The following features are not supported:
|
||
|
||
* **Hot Links** aka **hot** as there is nothing in FreshRSS yet that is similar or could be used to simulate it.
|
||
|
||
## Testing and debugging
|
||
|
||
If this API does not work as expected in your RSS reader, you can test it manually with a tool like [Postman](https://www.getpostman.com/).
|
||
|
||
Configure a POST request to the URL https://freshrss.example.net/api/fever.php?api which should give you the result:
|
||
```json
|
||
{
|
||
"api_version": 3,
|
||
"auth": 0
|
||
}
|
||
```
|
||
Great, the base setup seems to work!
|
||
|
||
Now lets try an authenticated call. Fever uses an `api_key`, which is the MD5 hash of `"$username:$apiPassword"`.
|
||
Assuming the user is `kevin` and the password `freshrss`, here is a command-line example to compute the resulting `api_key`
|
||
|
||
```sh
|
||
api_key=`echo -n "kevin:freshrss" | md5sum | cut -d' ' -f1`
|
||
```
|
||
|
||
Add a body to your POST request encoded as `form-data` and one key named `api_key` with the value `your-password-hash`:
|
||
|
||
```sh
|
||
curl -s -F "api_key=$api_key" 'https://freshrss.example.net/api/fever.php?api'
|
||
```
|
||
|
||
This should give:
|
||
```json
|
||
{
|
||
"api_version": 3,
|
||
"auth": 1,
|
||
"last_refreshed_on_time": "1520013061"
|
||
}
|
||
```
|
||
Perfect, you're now authenticated and you can start testing the more advanced features. To do so, change the URL and append the possible API actions to your request parameters. Please refer to the [original Fever documentation](https://feedafever.com/api) for more information.
|
||
|
||
Some basic calls are:
|
||
|
||
* https://freshrss.example.net/api/fever.php?api&items
|
||
* https://freshrss.example.net/api/fever.php?api&feeds
|
||
* https://freshrss.example.net/api/fever.php?api&groups
|
||
* https://freshrss.example.net/api/fever.php?api&unread_item_ids
|
||
* https://freshrss.example.net/api/fever.php?api&saved_item_ids
|
||
* https://freshrss.example.net/api/fever.php?api&items&since_id=some_id
|
||
* https://freshrss.example.net/api/fever.php?api&items&max_id=some_id
|
||
* https://freshrss.example.net/api/fever.php?api&mark=item&as=read&id=some_id
|
||
* https://freshrss.example.net/api/fever.php?api&mark=item&as=unread&id=some_id
|
||
|
||
Replace `some_id` with a real ID from your `freshrss_username_entry` database.
|
||
|
||
### Debugging
|
||
|
||
If nothing helps and your client is still misbehaving, you can add the following lines to the beginning of the `fever.api` file to determine the cause of the problems:
|
||
|
||
```php
|
||
file_put_contents(__DIR__ . '/fever.log', $_SERVER['HTTP_USER_AGENT'] . ': ' . json_encode($_REQUEST) . PHP_EOL, FILE_APPEND);
|
||
```
|
||
|
||
Then use your RSS client to query the API and afterwards check the file `fever.log`.
|
||
|
||
## Credits
|
||
|
||
This plugin was inspired by the [tinytinyrss-fever-plugin](https://github.com/dasmurphy/tinytinyrss-fever-plugin).
|