summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorBenjamin Brahmer <info@b-brahmer.de>2021-05-08 14:34:58 +0200
committerBenjamin Brahmer <info@b-brahmer.de>2021-05-19 14:58:29 +0200
commit79e469fd335133671185cf8539f77ef38ac3b4e6 (patch)
tree4e2b7075e85225c9ac93cf78c7ef1e95b78e5ac4
parent271b6ee3c993264bd44a966b82f1a5daa85f53ab (diff)
Refactor News documentation with mkdocs and mkdocs-material
- move all pages to new structure - use gh-pages to host html version - use github actions for automatic build Co-authored-by: anoy <anoymouserver+github@mailbox.org> Signed-off-by: Benjamin Brahmer <info@b-brahmer.de>
-rw-r--r--.github/workflows/documentation.yml23
-rw-r--r--.gitignore1
-rw-r--r--README.md39
-rw-r--r--appinfo/info.xml20
-rw-r--r--docs/README.md16
-rw-r--r--docs/admin.md33
-rw-r--r--docs/api/api-v1.md (renamed from docs/externalapi/Legacy.md)3
-rw-r--r--docs/api/api-v2.md (renamed from docs/externalapi/External-Api.md)79
-rw-r--r--docs/assets/favicon.pngbin0 -> 678 bytes
-rw-r--r--docs/assets/logo.svg31
-rw-r--r--docs/clients.md31
-rw-r--r--docs/explore/README.md46
-rw-r--r--docs/faq.md (renamed from docs/faq/README.md)57
-rw-r--r--docs/features/customCSS.md (renamed from docs/feedcss/README.md)0
-rw-r--r--docs/features/plugins.md (renamed from docs/plugins/README.md)40
-rw-r--r--docs/features/themes.md4
-rw-r--r--docs/index.md5
-rw-r--r--docs/install.md13
-rw-r--r--docs/maintenance.md17
-rw-r--r--docs/updateInterval/README.md10
-rw-r--r--mkdocs.yml35
-rw-r--r--templates/admin.php9
22 files changed, 319 insertions, 193 deletions
diff --git a/.github/workflows/documentation.yml b/.github/workflows/documentation.yml
new file mode 100644
index 000000000..409fb4da8
--- /dev/null
+++ b/.github/workflows/documentation.yml
@@ -0,0 +1,23 @@
+name: Publish docs via GitHub Pages
+on:
+ push:
+ branches:
+ - master
+
+jobs:
+ build:
+ name: Deploy docs
+ runs-on: ubuntu-latest
+ steps:
+ - name: Checkout master
+ uses: actions/checkout@v2
+
+ - name: Deploy docs
+ uses: mhausenblas/mkdocs-deploy-gh-pages@master
+ # Or use mhausenblas/mkdocs-deploy-gh-pages@nomaterial to build without the mkdocs-material theme
+ env:
+ GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
+ #CUSTOM_DOMAIN: optionaldomain.com
+ #CONFIG_FILE: folder/mkdocs.yml
+ #EXTRA_PACKAGES: build-base
+ # GITHUB_DOMAIN: github.myenterprise.com \ No newline at end of file
diff --git a/.gitignore b/.gitignore
index 89b9ac989..44cf6f335 100644
--- a/.gitignore
+++ b/.gitignore
@@ -10,6 +10,7 @@ js/*.xml
.rvm
*.clover
.phpunit.result.cache
+site/
# python
PKG-INFO
diff --git a/README.md b/README.md
index bb38b8ec1..3b4a63269 100644
--- a/README.md
+++ b/README.md
@@ -6,45 +6,12 @@
The News app is an RSS/Atom feed aggregator. It offers a [RESTful API](https://github.com/nextcloud/news/tree/master/docs/externalapi/Legacy.md) for app developers. The source code is [available on GitHub](https://github.com/nextcloud/news)
-## Install
-See the [install document](https://github.com/nextcloud/news/blob/master/docs/install.md)
-
-## FAQ
-* [My browser shows a mixed content warning](https://github.com/nextcloud/news/blob/master/docs/faq/README.md#my-browser-shows-a-mixed-content-warning-connection-is-not-secure)
-* [I am getting: Exception: Some\\Class does not exist erros in my nextcloud.log](https://github.com/nextcloud/news/blob/master/docs/faq/README.md#i-am-getting-exception-someclass-does-not-exist-erros-in-my-nextcloudlog)
-* [Feeds are not updated](https://github.com/nextcloud/news/blob/master/docs/faq/README.md#feeds-not-updated)
-* [Adding feeds that use self-signed certificates](https://github.com/nextcloud/news/blob/master/docs/faq/README.md#adding-feeds-that-use-self-signed-certificates)
-* [Is There An Subscription URL To Easily Subscribe To Feeds](https://github.com/nextcloud/news/blob/master/docs/faq/README.md#is-there-an-subscription-url-to-easily-subscribe-to-feeds)
-* [Database table grows too big](https://github.com/nextcloud/news/blob/master/docs/faq/README.md#database-table-grows-too-big)
-
-## Supported Browsers
-* Newest Firefox (Desktop, Android, Firefox OS)
-* Newest Chrome/Chromium (Desktop, Android)
+## Documentation
+The documentation can be found [here](https://nextcloud.github.io/news/), the source of the documentation is on [GitHub](https://github.com/nextcloud/news/blob/master/docs)
## Bugs
Please read the [appropriate section in the contributing notices](https://github.com/nextcloud/news/blob/master/CONTRIBUTING.md#issues)
-## Sync Clients
-Nextcloud News can be synced with the following apps:
- * [RSS Guard (Windows, Linux, OS/2, Mac OS)](https://github.com/martinrotter/rssguard), [open source](https://github.com/martinrotter/rssguard)
- * [Nextcloud News Reader (Android)](https://play.google.com/store/apps/details?id=de.luhmer.owncloudnewsreader), [open source](https://github.com/nextcloud/news-android-app)
- * [OCReader (Android)](https://f-droid.org/repository/browse/?fdid=email.schaal.ocreader), [open source](https://github.com/schaal/ocreader)
- * [Newsout (Android)](https://play.google.com/store/apps/details?id=com.inspiredandroid.newsout), [open source](https://github.com/SimonSchubert/NewsOut)
- * [Readrops (Android)](https://f-droid.org/en/packages/com.readrops.app/), [open source](https://github.com/readrops/Readrops)
- * [CloudNews (iOS)](https://apps.apple.com/app/cloudnews-owncloud-news-reader/id683859706), [open source](https://github.com/owncloud/news-ios-app)
- * [Fiery Feeds (iOS)](https://apps.apple.com/us/app/fiery-feeds-rss-reader/id1158763303), closed source
- * [News Checker (Chrome extension)](https://chrome.google.com/webstore/detail/owncloud-news-checker/hnmagnmdnfdhabdlicankfbfhcdgbfhe)
- * [own News (BlackBerry)](http://appworld.blackberry.com/webstore/content/32767887/)
- * [FeedSpider (Firefox OS, WebOS, LuneOS)](http://www.feedspider.net/), [open source](https://github.com/OthelloVentures/feedspider)
- * [fastReader (Windows Phone)](http://www.windowsphone.com/en-us/store/app/fastreader/e55e696d-aa45-4a49-bb1c-a1fc7fdabec1), closed source
- * [py3status](https://github.com/ultrabug/py3status/) for [i3 (UNIX-like)](http://i3wm.org/), [open source](https://github.com/i3/i3)
- * [newsboat](http://newsboat.org/) for Unix terminal, [open source](https://github.com/newsboat/newsboat)
- * [Newsie (Ubuntu Touch)](https://open-store.io/app/newsie.martinferretti), [open source](https://gitlab.com/ferrettim/newsie)
-
-## Custom Themes
-Nextcloud News can look different with the following themes:
- * [Nextcloud News Themes](https://github.com/cwmke/nextcloud-news-themes)
-
## Updating Notices
To receive notifications when a new News app version was released, simply add the following Atom feed in your currently installed News app:
@@ -59,4 +26,4 @@ To receive notifications when a new News app version was released, simply add th
* [Sean Molenaar](https://github.com/SMillerDev)
### Special thanks to the Feed-IO library
-Please consider donating to the developer of the RSS parser that powers nextcloud/news: [https://github.com/sponsors/alexdebril](https://github.com/sponsors/alexdebril)
+Please consider donating to the developer of the RSS parser that powers the Nextcloud News App: [https://github.com/sponsors/alexdebril](https://github.com/sponsors/alexdebril)
diff --git a/appinfo/info.xml b/appinfo/info.xml
index 997ea42fd..61da2eb58 100644
--- a/appinfo/info.xml
+++ b/appinfo/info.xml
@@ -3,11 +3,20 @@
<id>news</id>
<name>News</name>
<summary>An RSS/Atom feed reader</summary>
- <description><![CDATA[The News app is an RSS/Atom feed reader for Nextcloud which can be synced with many mobile devices. A list of all clients and requirements can be found [in the README](https://github.com/nextcloud/news)
+ <description><![CDATA[📰 A RSS/Atom Feed reader App for Nextcloud
-Before you update to a new version, [check the changelog](https://github.com/nextcloud/news/blob/master/CHANGELOG.md) to avoid surprises.
+- 📲 Synchronize your feeds with multiple mobile or desktop [clients](https://nextcloud.github.io/news/clients/)
+- 🔄 Automatic updates of your news feeds
+- 🆓 Free and open source under AGPLv3, no ads or premium functions
-**Important**: To enable feed updates you will need to enable either [Nextcloud system cron](https://docs.nextcloud.org/server/latest/admin_manual/configuration_server/background_jobs_configuration.html#cron) or use [an updater](https://github.com/nextcloud/news-updater) which uses the built in update API and disable cron updates. More information can be found [in the README](https://github.com/nextcloud/news).]]></description>
+**System Cron is currently required for this app to work**
+Requirements can be found [here](https://nextcloud.github.io/news/install/#dependencies)
+The Changelog is available [here](https://github.com/nextcloud/news/blob/master/CHANGELOG.md)
+
+Create a [bug report](https://github.com/nextcloud/news/issues/new/choose)
+Create a [feature request](https://github.com/nextcloud/news/discussions/new)
+Report a [feed issue](https://github.com/nextcloud/news/discussions/new)
+ ]]></description>
<version>16.0.0</version>
<licence>agpl</licence>
<author>Benjamin Brahmer</author>
@@ -17,8 +26,9 @@ Before you update to a new version, [check the changelog](https://github.com/nex
<author>Jan-Christoph Borchardt (former)</author>
<namespace>News</namespace>
<documentation>
- <admin>https://github.com/nextcloud/news#readme</admin>
- <developer>https://github.com/nextcloud/news/tree/master/docs</developer>
+ <user>https://nextcloud.github.io/news/</user>
+ <admin>https://nextcloud.github.io/news/admin/</admin>
+ <developer>https://nextcloud.github.io/news/</developer>
</documentation>
<category>multimedia</category>
<website>https://github.com/nextcloud/news</website>
diff --git a/docs/README.md b/docs/README.md
index 62c2dac07..d9b331250 100644
--- a/docs/README.md
+++ b/docs/README.md
@@ -1,13 +1,9 @@
-# Documentation
+# News Documentation
+The News documentation of News uses mkdocs and is hosted [here](https://nextcloud.github.io/news/).
+As extension of mkdocs, mkdocs-material is used.
-As a developer you can interact with the News app in the following ways:
-
-* [Use the API for syncing and updating feeds](externalapi/)
-* [Write plugins](plugins/)
-* [Add custom CSS for feeds](feedcss/)
-* [Customize the explore section](explore/)
-
-
-The News app uses [FeedIO](https://github.com/alexdebril/feed-io) for parsing feeds and full text feeds. FeedIO is a fantastic library so if you contribute or fix bugs, please consider **contributing your changes** back to the library to help others :)
+Check the resources below for how to install both of them locally.
+* [mkdocs](https://www.mkdocs.org/)
+* [mkdocs-material](https://squidfunk.github.io/mkdocs-material/)
diff --git a/docs/admin.md b/docs/admin.md
new file mode 100644
index 000000000..00efe0d20
--- /dev/null
+++ b/docs/admin.md
@@ -0,0 +1,33 @@
+# Admin
+Welcome to the Admin documentation this page explains some of the configuration options for news.
+## System Cron
+Nextcloud uses Cron to run regular jobs, News relies on the Job system to execute the feed updates.
+Alternatively you may use an [external updater](https://nextcloud.github.io/news/clients/#update-clients), in this case you need to disable the system cron in the settings.
+
+## Auto purge count
+This value represents the maximum amount of read items per feed, which won't be deleted by the cleanup job.
+For example if the value is 200 there can be maximum 200 read items per feed, unread items are unaffected.
+If old articles reappear after being read, try to increase this value.
+To disable this feature use -1.
+
+## Explore Service
+If you are using the News app in your company/community it might be interesting to offer your users a bunch of easily to discover default feeds. You could also create a website where people can add and up-vote news feeds like bigger cloud feed readers like Feedly do it or even convert their APIs into a service for the News app (if someone wants to provide one for the News app, feel free to contact us by creating an issue in the bug tracker).
+
+The URL should be a path to a directory which contains a JSON file in the format of **feeds.LANG_CODE.json** where LANG_CODE is a two character language code (e.g. **en** or **de**).
+
+For example, entering the URL **https://domain.com/directory** as explore URL will produce the following request for German users:
+
+ GET https://domain.com/directory/feeds.de.json
+
+**Do not forget to implement [CORS](https://developer.mozilla.org/en-US/docs/Web/HTTP/Access_control_CORS) in your API, otherwise the request will fail!**
+
+## Update Interval
+The update interval is used to determine when the next update of all feeds should be done.
+You can configure this interval as an administrator.
+
+### What is a good update interval?
+That depends on your individual needs.
+Please keep in mind that the lower you set your update interval, the more traffic is generated.
+
+### Can I set individual update intervals per feed/user?
+No, the job framework of Nextcloud is pretty simple. \ No newline at end of file
diff --git a/docs/externalapi/Legacy.md b/docs/api/api-v1.md
index 8afb6f9c7..fd39a8acd 100644
--- a/docs/externalapi/Legacy.md
+++ b/docs/api/api-v1.md
@@ -1,4 +1,4 @@
-# External API v1-2 (Legacy)
+# External API v1-2
The **News app 1.2** offers a RESTful API
@@ -629,6 +629,7 @@ This is used to stay up to date.
To enable people to write their own update scripts instead of relying on the sequential built in web and system cron, API routes and console commands have been created.
Updating should be done in the following fashion:
+
* Run the cleanup before the update
* Get all feeds and user ids
* For each feed and user id, run the update command
diff --git a/docs/externalapi/External-Api.md b/docs/api/api-v2.md
index 1848fe5b3..c5fee3806 100644
--- a/docs/externalapi/External-Api.md
+++ b/docs/api/api-v2.md
@@ -1,8 +1,10 @@
# External API v2 (Draft)
+**Disclaimer:** this API has not been fully implemented yet.
+
The **News app** offers a RESTful API which can be used to sync folders, feeds and items. The API also supports [CORS](https://developer.mozilla.org/en-US/docs/Web/HTTP/Access_control_CORS) which means that you can access the API from your browser using JavaScript.
-In addition, an updater API is exposed which enables API users to run feed updates in parallel using a REST API or ownCloud console API.
+In addition, an updater API is exposed which enables API users to run feed updates in parallel using a REST API or Nextcloud console API.
## Conventions
This document uses the following conventions:
@@ -15,6 +17,7 @@ This document uses the following conventions:
In order to only specify the JSON objects once, comments are used to alias them.
There are two types of aliases:
+
* Objects
* Object arrays
@@ -77,19 +80,22 @@ You have to design your app with these things in mind!:
## Request Format
The base URL for all calls is:
- https://yourowncloud.com/index.php/apps/news/api/v2
+ https://yournextcloud.com/index.php/apps/news/api/v2
Unless an absolute Url is specified, the relative Urls in the Specification are appended to this url. To access the route **/sync** for instance you'd use the following url:
- https://yourowncloud.com/index.php/apps/news/api/v2/sync
+ https://yournextcloud.com/index.php/apps/news/api/v2/sync
The required request headers are:
+
* **Accept**: application/json
Any request method except GET:
+
* **Content-Type**: application/json; charset=utf-8
Any route that allows caching:
+
* **If-None-Match**: an Etag, e.g. 6d82cbb050ddc7fa9cbb659014546e59. If no previous Etag is known, this header should be omitted
The request body is either passed in the URL in case of a **GET** request (e.g.: **?foo=bar&index=0**) or as JSON, e.g.:
@@ -107,7 +113,7 @@ The request body is either passed in the URL in case of a **GET** request (e.g.:
Check the [API level route](#api-level)
### Authentication
-Because REST is stateless you have to re-send user and password each time you access the API. Therefore running ownCloud **with SSL is highly recommended** otherwise **everyone in your network can log your credentials**.
+Because REST is stateless you have to re-send user and password each time you access the API. Therefore running Nextcloud **with SSL is highly recommended** otherwise **everyone in your network can log your credentials**.
Credentials are passed as an HTTP header using [HTTP basic auth](https://en.wikipedia.org/wiki/Basic_access_authentication#Client_side):
@@ -122,21 +128,24 @@ This authentication/authorization method will be the recommended default until c
**Note**: Even if login cookies are sent back to your client, they will not be considered for authentication.
## Response Format
-The status codes are not always provided by the News app itself, but might also be returned because of ownCloud internal errors.
+The status codes are not always provided by the News app itself, but might also be returned because of Nextcloud internal errors.
-The following status codes can always be returned by ownCloud:
-* **401**: The provided credentials to log into ownCloud are invalid.
+The following status codes can always be returned by Nextcloud:
+
+* **401**: The provided credentials to log into Nextcloud are invalid.
* **403**: The user is not allowed to access the route. This can happen if for instance of only users in the admin group can access the route and the user is not in it.
* **404**: The route can not be found or the resource does not exist. Can also happen if for instance you are trying to delete a folder which does not exist.
* **5xx**: An internal server error occurred. This can happen if the server is in maintenance mode or because of other reasons.
The following status codes are returned by News:
+
* **200**: Everything went fine
* **304**: In case the resource was not modified, contains no response body. This means that you can ignore the request since everything is up to date.
* **400**: There was an app related error, check the **error** object if specified
* **409**: Conflict error which means that the resource exists already. Can be returned when updating (**PATCH**) or creating (**POST**) a resource, e.g. a folder
The response headers are:
+
* **Content-Type**: application/json; charset=utf-8
* **Etag**: A string containing a cache header of maximum length 64, e.g. 6d82cbb050ddc7fa9cbb659014546e59. The etag value will be assembled using the number of feeds, folders and the highest last modified timestamp in milliseconds, e.g. 2-3-123131923912392391239. However consider that a detail and dont rely on it.
@@ -159,6 +168,7 @@ In case of an **4xx** or **5xx** error the request was not successful and has to
## Security Guidelines
Read the following notes carefully to prevent being subject to security exploits:
+
* You should always enforce SSL certificate verification and never offer a way to turn it off. Certificate verification is important to prevent MITM attacks which is especially important in the mobile world where users are almost always connected to untrusted networks. In case a user runs a self-signed certificate on his server ask him to either install his certificate on his device or direct him to one of the many ways to sign his certificate for free (most notably letsencrypt.com)
* All string fields in a JSON response **expect an item's body** are **not sanitized**. This means that if you do not escape it properly before rendering you will be vulnerable to [XSS](https://www.owasp.org/index.php/Cross-site_Scripting_%28XSS%29) attacks
* Basic Auth headers can easily be decrypted by anyone since base64 is an encoding, not an encryption. Therefore only send them if you are accessing an HTTPS website or display an easy to understand warning if the user chooses HTTP
@@ -166,14 +176,15 @@ Read the following notes carefully to prevent being subject to security exploits
* If you are building a client in JavaScript or are using a link with **target="blank"**, remember to set the **window.opener** property to **null** and/or add a **rel="noreferrer"** to your link to prevent your app from being [target by an XSS attack](https://medium.com/@jitbit/target-blank-the-most-underestimated-vulnerability-ever-96e328301f4c#.wf2ddytbh)
## Syncing
-All routes are given relative to the base API url, e.g.: **/sync** becomes **https://yourowncloud.com/index.php/apps/news/api/v2/sync**
+All routes are given relative to the base API url, e.g.: **/sync** becomes **https://yourNextcloud.com/index.php/apps/news/api/v2/sync**
There are two usecases for syncing:
+
* **Initial sync**: the user does not have any data at all
* **Syncing local and remote changes**: the user has synced at least once and wants to submit and receive changes
### Initial Sync
-The intial sync happens when a user adds an ownCloud account in your app. In that case you want to download all folders, feeds and unread/starred items. To do this, make the following request:
+The intial sync happens when a user adds an Nextcloud account in your app. In that case you want to download all folders, feeds and unread/starred items. To do this, make the following request:
* **Method**: GET
* **Route**: /sync
@@ -182,9 +193,11 @@ The intial sync happens when a user adds an ownCloud account in your app. In tha
* **Accept: "application/json"**
This will return the following status codes:
+
* **200**: Success
and the following HTTP headers:
+
* **Content-Type**: application/json; charset=utf-8
* **Etag**: A string containing a cache header, maximum size 64 ASCII characters, e.g. 6d82cbb050ddc7fa9cbb659014546e59
@@ -198,6 +211,7 @@ and the following request body:
```
**Note**: Each object is explained in more detail in a separate section:
+
* [Folders](#folders)
* [Feeds](#feeds)
* [Items](#items)
@@ -247,6 +261,7 @@ If no items have been read or starred, simply leave the **items** array empty, e
```
The response matches the **GET** call, except there can be two different types of item objects:
+
* **[Full](#full)**: Contains all attributes
* **[Reduced](#reduced)**: Contains only **id**, **isUnread** and **isStarred**
@@ -308,11 +323,13 @@ Folders are represented using the following data structure:
```
The attributes mean the following:
+
* **id**: 64bit Integer, id
* **name**: Abitrary long text, folder's name
### Deleting A Folder
To delete a folder, use the following request:
+
* **Method**: DELETE
* **Route**: /folders/{id}
* **Route Parameters**:
@@ -322,6 +339,7 @@ To delete a folder, use the following request:
The following response is being returned:
Status codes:
+
* **200**: Folder was deleted successfully
* **404**: Folder does not exist
@@ -339,6 +357,7 @@ In case of an HTTP 200, the deleted folder is returned in full in the response,
### Creating A Folder
To create a folder, use the following request:
+
* **Method**: POST
* **Route**: /folders
* **Authentication**: [required](#authentication)
@@ -353,6 +372,7 @@ with the following request body:
The following response is being returned:
Status codes:
+
* **200**: Folder was created successfully
* **400**: Folder creation error, check the error object:
* **code**: 1: folder name is empty
@@ -367,9 +387,11 @@ In case of an HTTP 200, the created or already existing folder is returned in fu
### Changing A Folder
The following attributes can be changed on the folder:
+
* **name**
To change any number of attributes on a folder, use the following request and provide as much attributes that can be changed as you want:
+
* **Method**: PATCH
* **Route**: /folders/{id}
* **Route Parameters**:
@@ -388,10 +410,11 @@ with the following request body:
The following response is being returned:
Status codes:
+
* **200**: Folder was updated successfully
* **400**: Folder update error, check the error object:
* **code**: 1: folder name is empty
-* Other ownCloud errors, see [Response Format](#response-format)
+* Other Nextcloud errors, see [Response Format](#response-format)
In case of an HTTP 200, the changed or already existing folder is returned in full in the response, e.g.:
@@ -423,6 +446,7 @@ Feeds are represented using the following data structure:
```
The attributes mean the following:
+
* **id**: 64bit Integer, id
* **name**: Abitrary long text, feed's name
* **faviconLink**: Abitrary long text, feed's favicon location, **null** if not found
@@ -443,6 +467,7 @@ The attributes mean the following:
### Deleting A Feed
To delete a feed, use the following request:
+
* **Method**: DELETE
* **Route**: /feeds/{id}
* **Route Parameters**:
@@ -453,9 +478,10 @@ To delete a feed, use the following request:
The following response is being returned:
Status codes:
+
* **200**: Feed was deleted successfully
* **404**: Feed with given id was not found, no error object
-* Other ownCloud errors, see [Response Format](#response-format)
+* Other Nextcloud errors, see [Response Format](#response-format)
In case of an HTTP 200, the deleted feed is returned in full in the response, e.g.:
@@ -472,6 +498,7 @@ In case of an HTTP 200, the deleted feed is returned in full in the response, e.
### Creating A feed
To create a feed, use the following request:
+
* **Method**: POST
* **Route**: /feeds
* **Authentication**: [required](#authentication)
@@ -490,6 +517,7 @@ with the following request body:
"basicAuthPassword": "password"
}
```
+
* **url**: Abitrary long text, the url needs to have the full schema e.g. https://the-url.com. In case the user omits the schema, prepending **https** is recommended
* **folderId**: 64bit Integer, the feed's folder or **0** in case no folder is specified
* **name (optional)**: Abitrary long text, the feeds name or if not given taken from the RSS/Atom feed
@@ -503,6 +531,7 @@ with the following request body:
The following response is being returned:
Status codes:
+
* **200**: Feed was created successfully
* **400**: Feed creation error, check the **error** object:
* **code**: 1: url is empty
@@ -529,6 +558,7 @@ In case of an HTTP 200, the created feed is returned in full in the response, e.
### Changing A Feed
To change a feed, use the following request:
+
* **Method**: PATCH
* **Route**: /feeds/{id}
* **Route Parameters**:
@@ -564,6 +594,7 @@ All parameters are optional
The following response is being returned:
Status codes:
+
* **200**: Feed was changed successfully
* **400**: Feed creation error, check the error object:
* **code**: 1: url is empty
@@ -577,7 +608,7 @@ Status codes:
* **code**: 9: request timed out
* **code**: 10: invalid or missing http basic auth headers
* **code**: 11: not allowed to access the feed (difference here is that the user can be authenticated but not allowed to access the feed)
-* Other ownCloud errors, see [Response Format](#response-format)
+* Other Nextcloud errors, see [Response Format](#response-format)
In case of an HTTP 200, the changed feed is returned in full in the response, e.g.:
@@ -597,6 +628,7 @@ Items can occur in two different formats:
* Reduced
The attributes mean the following:
+
* **id**: 64bit Integer, id
* **url**: Abitrary long text, location of the online resource
* **title**: Abitrary long text, item's title
@@ -649,7 +681,7 @@ A reduced item only contains the item status:
```
## Updater
-Instead of using the built in, slow cron updater you can use the parallel update API to update feeds. The API can be accessed through REST or ownCloud console API.
+Instead of using the built in, slow cron updater you can use the parallel update API to update feeds. The API can be accessed through REST or Nextcloud console API.
The API should be used in the following way:
@@ -658,17 +690,17 @@ The API should be used in the following way:
* For each feed and user id, run the update
* Clean up after the update
-The reference [implementation in Python](https://github.com/owncloud/news-updater) should give you a good idea how to design your own updater.
+The reference [implementation in Python](https://github.com/nextcloud/news-updater) should give you a good idea how to design your own updater.
If the REST API is used, Authorization is required via Basic Auth and the user needs to be in the admin group.
-If the ownCloud console API is used, no authorization is required.
+If the Nextcloud console API is used, no authorization is required.
### Clean Up Before Update
This is used to clean up the database. It deletes folders and feeds that are marked for deletion.
**Console API**:
- php -f /path/to/owncloud/occ news:updater:before-update
+ php -f /path/to/nextcloud/occ news:updater:before-update
**REST API**:
@@ -681,7 +713,7 @@ This call returns pairs of feed ids and user ids.
**Console API**:
- php -f /path/to/owncloud/occ news:updater:all-feeds
+ php -f /path/to/nextcloud/occ news:updater:all-feeds
**REST API**:
@@ -705,12 +737,13 @@ Both APIs will return the following response body or terminal output:
After all feed ids and user ids are known, feeds can be updated in parallel.
**Console API**:
+
* **Positional Parameters**:
* **{feedId}**: the feed's id
* **{userId}**: the user's id
- php -f /path/to/owncloud/occ news:updater:update-feed {feedId} {userId}
+ php -f /path/to/nextcloud/occ news:updater:update-feed {feedId} {userId}
**REST API**:
@@ -727,7 +760,7 @@ This is used to clean up the database. It removes old read articles which are no
**Console API**:
- php -f /path/to/owncloud/occ news:updater:after-update
+ php -f /path/to/nextcloud/occ news:updater:after-update
**REST API**:
@@ -746,6 +779,7 @@ The retrieve meta data about the app, use the following request:
The following response is being returned:
Status codes:
+
* **200**: Meta data accessed successfully
In case of an HTTP 200, the the following response is returned:
@@ -768,6 +802,7 @@ In case of an HTTP 200, the the following response is returned:
```
The attributes mean the following:
+
* **version**: Abitrary long text, News app version
* **issues**: An object containing a dictionary of issues which need to be displayed to the user:
* **improperlyConfiguredCron**: Boolean, if true this means that no feed updates are run on the server because the updater is misconfigured
@@ -783,12 +818,13 @@ The attributes mean the following:
To find out which API levels are supported, make a request to the following route:
* **Method**: GET
-* **Route**: https://yourowncloud.com/index.php/apps/news/api
+* **Route**: https://yournextcloud.com/index.php/apps/news/api
* **Authentication**: none
The following response is being returned:
Status codes:
+
* **200**: The supported API levels can be parsed from the response
* **404**: The user is either running a version prior to **8.8.0** or the News app is disabled or not installed.
@@ -804,10 +840,11 @@ In case of an HTTP 200, the supported API levels are returned as JSON, e.g.:
To find out if a user is running an older News version than **8.8.0**, make a request to the following route:
* **Method**: GET
-* **Route**: https://yourowncloud.com/index.php/apps/news/api/v1-2/version
+* **Route**: https://yournextcloud.com/index.php/apps/news/api/v1-2/version
* **Authentication**: [required](#authentication)
Status codes:
+
* **200**: Only the v1-2 API level is supported
* **404**: The News app is disabled or not installed.
diff --git a/docs/assets/favicon.png b/docs/assets/favicon.png
new file mode 100644
index 000000000..a0ee9549d
--- /dev/null
+++ b/docs/assets/favicon.png
Binary files differ
diff --git a/docs/assets/logo.svg b/docs/assets/logo.svg
new file mode 100644
index 000000000..84cd0b839
--- /dev/null
+++ b/docs/assets/logo.svg
@@ -0,0 +1,31 @@
+<?xml version="1.0" encoding="UTF-8" standalone="no"?>
+<svg
+ xmlns:dc="http://purl.org/dc/elements/1.1/"
+ xmlns:cc="http://creativecommons.org/ns#"
+ xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
+ xmlns:svg="http://www.w3.org/2000/svg"
+ xmlns="http://www.w3.org/2000/svg"
+ id="svg4551"
+ viewBox="0 0 32 32"
+ x="0px"
+ y="0px"
+ enable-background="new 0 0 595.275 311.111"
+ width="32"
+ height="32"
+ xml:space="preserve"
+ version="1.1"><metadata
+ id="metadata4557"><rdf:RDF><cc:Work
+ rdf:about=""><dc:format>image/svg+xml</dc:format><dc:type
+ rdf:resource="http://purl.org/dc/dcmitype/StillImage" /></cc:Work></rdf:RDF></metadata><defs
+ id="defs4555" /><rect
+ id="rect4547"
+ fill="#0082c9"
+ x="0"
+ y="-.0000052588"
+ width="32"
+ height="32"
+ ry="5"
+ rx="5" /><path
+ style="fill:#ffffff;stroke-width:0.92142856"