1
0
mirror of https://git.cloudron.io/cloudron/freshrss-app synced 2026-06-20 23:25:51 +00:00

Compare commits

...

99 Commits

Author SHA1 Message Date
Package Updates 0826aa325c Update package version to 1.28.1 2026-05-21 08:10:43 +00:00
Renovate Bot 38d1d40f73 chore(deps): update dependency freshrss/freshrss to v1.29.1
| datasource      | package           | from   | to     |
| --------------- | ----------------- | ------ | ------ |
| github-releases | FreshRSS/FreshRSS | 1.29.0 | 1.29.1 |
2026-05-21 05:19:20 +00:00
Girish Ramakrishnan 7656977d62 test: make test/test.js non-executable and remove shebang 2026-05-19 15:32:44 +02:00
Package Updates 6b96e18e4d Update package version to 1.28.0 2026-05-11 07:42:14 +00:00
Girish Ramakrishnan 5c643c8393 Fix test 2026-05-11 09:27:55 +02:00
Renovate Bot 9a0a6a6011 chore(deps): update dependency freshrss/freshrss to v1.29.0
| datasource      | package           | from   | to     |
| --------------- | ----------------- | ------ | ------ |
| github-releases | FreshRSS/FreshRSS | 1.28.1 | 1.29.0 |
2026-05-11 05:20:30 +00:00
Girish Ramakrishnan 752dc395e1 test: simplify clearCache, drop logout helpers, simplify button selectors
- Drop `await clearCache()` from login/auth helpers; clearing cache before
  every login is no longer necessary now that charlie isolates sessions.
- Replace `logout` helpers with `clearCache` directly in `it()` calls; the
  helpers were either thin wrappers around `clearCache()` or did real
  navigation that is no longer worth the maintenance.
- Simplify `xpath=//button[text()=...]` / `[contains(., ...)]` button text
  selectors to charlie's bare-string (or RegExp for OR-clauses) form.
2026-05-01 10:39:27 +02:00
Girish Ramakrishnan d9bf01f557 test: pass full Mocha test to takeScreenshot for unique screenshot names 2026-04-29 17:09:55 +02:00
Girish Ramakrishnan b08f62e4e2 test: port to charlie
Made-with: Cursor
2026-04-24 20:37:49 +02:00
Girish Ramakrishnan 654bc431c7 test: remove package.json and package-lock.json, charlie provides all deps
Made-with: Cursor
2026-04-16 10:42:58 +02:00
Girish Ramakrishnan 88bdd18e8f test: remove chromedriver dependency
Selenium Manager auto-detects the system ChromeDriver, making the
chromedriver npm package unnecessary.

Made-with: Cursor
2026-04-15 17:18:09 +02:00
Girish Ramakrishnan ca55bcf330 test: fix @cloudron/superagent API compatibility
Replace .statusCode with .status, remove .agent() and .end()
usage to match @cloudron/superagent API.

Made-with: Cursor
2026-04-15 16:54:55 +02:00
Girish Ramakrishnan dc29214e71 test: use @cloudron scoped safetydance and superagent
Made-with: Cursor
2026-04-15 16:39:11 +02:00
Girish Ramakrishnan 5fad46b733 test: convert test to ESM
Replace CommonJS require() with ESM imports, add "type": "module"
to test/package.json, remove 'use strict' and jshint directives,
replace __dirname with import.meta.dirname.

Made-with: Cursor
2026-04-15 16:16:54 +02:00
Girish Ramakrishnan 6581c225c0 Replace expect.js with node:assert/strict
expect.js is unmaintained and unnecessary — Node's built-in assert
module covers all our assertion patterns. This also removes expect.js
from package.json dependencies.

Made-with: Cursor
2026-04-15 15:37:12 +02:00
Package Updates e425f4459a Update package version to 1.27.1 2026-01-26 07:37:44 +00:00
Renovate Bot 2aea63d85a chore(deps): update dependency freshrss/freshrss to v1.28.1
| datasource      | package           | from   | to     |
| --------------- | ----------------- | ------ | ------ |
| github-releases | FreshRSS/FreshRSS | 1.28.0 | 1.28.1 |
2026-01-26 06:20:55 +00:00
Girish Ramakrishnan 9938298edd Add ServerName to virtual host config 2026-01-19 14:33:48 +01:00
Girish Ramakrishnan c3f2702de1 Set ServerHost to remove start up warnings. It does not support env subst 2026-01-19 14:25:23 +01:00
Package Updates ce5b6ba960 Update package version to 1.27.0 2025-12-25 10:24:49 +00:00
Renovate Bot 5f42ec1d49 chore(deps): update dependency freshrss/freshrss to v1.28.0
| datasource      | package           | from   | to     |
| --------------- | ----------------- | ------ | ------ |
| github-releases | FreshRSS/FreshRSS | 1.27.1 | 1.28.0 |
2025-12-25 06:20:40 +00:00
Package Updates 46079cab5b Update package version to 1.26.1 2025-09-29 08:30:49 +00:00
Girish Ramakrishnan da4875d17f Fix test 2025-09-29 09:59:20 +02:00
Renovate Bot 2e0f7ffb00 chore(deps): update dependency freshrss/freshrss to v1.27.1
| datasource      | package           | from   | to     |
| --------------- | ----------------- | ------ | ------ |
| github-releases | FreshRSS/FreshRSS | 1.27.0 | 1.27.1 |
2025-09-28 05:19:31 +00:00
Package Updates de811a5b95 Update package version to 1.26.0 2025-08-19 08:11:05 +00:00
Johannes Zellner 067a448120 Fixup tests 2025-08-19 09:46:38 +02:00
Renovate Bot 99eb91f995 chore(deps): update dependency freshrss/freshrss to v1.27.0
| datasource      | package           | from   | to     |
| --------------- | ----------------- | ------ | ------ |
| github-releases | FreshRSS/FreshRSS | 1.26.3 | 1.27.0 |
2025-08-19 01:02:18 +00:00
Girish Ramakrishnan 68c5a8f6c6 Update documentation url 2025-06-05 10:44:32 +02:00
Package Updates 90af4fc830 Update package version to 1.25.2 2025-06-03 10:16:04 +00:00
Renovate Bot 15f30af4bb chore(deps): update dependency freshrss/freshrss to v1.26.3
| datasource      | package           | from   | to     |
| --------------- | ----------------- | ------ | ------ |
| github-releases | FreshRSS/FreshRSS | 1.26.2 | 1.26.3 |
2025-06-03 05:20:24 +00:00
Package Updates 5ac482c1c4 Update package version to 1.25.1 2025-05-04 13:10:06 +00:00
Renovate Bot 38fa58f1c1 chore(deps): update dependency freshrss/freshrss to v1.26.2
| datasource      | package           | from   | to     |
| --------------- | ----------------- | ------ | ------ |
| github-releases | FreshRSS/FreshRSS | 1.26.1 | 1.26.2 |
2025-05-04 14:59:06 +02:00
Girish Ramakrishnan 4a1c4f7eab Fix test 2025-05-04 14:58:34 +02:00
Girish Ramakrishnan cf05842d11 Fix chown usage 2025-04-08 10:04:12 +02:00
Package Updates 04647d32c3 Update package version to 1.25.0 2025-03-14 11:09:04 +00:00
Girish Ramakrishnan b983a26b44 Update base image to 5.0.0 2025-03-14 11:54:50 +01:00
Package Updates 91f91bd18e Update package version to 1.24.1 2025-03-14 10:54:04 +00:00
Renovate Bot 4a64ac2219 chore(deps): update dependency freshrss/freshrss to v1.26.1
| datasource      | package           | from   | to     |
| --------------- | ----------------- | ------ | ------ |
| github-releases | FreshRSS/FreshRSS | 1.26.0 | 1.26.1 |
2025-03-14 06:19:28 +00:00
Package Updates 2911418f1e Update package version to 1.24.0 2025-02-25 11:52:06 +00:00
Vladimir D 9194eb2a61 enableApi fix 2025-02-25 15:28:20 +04:00
Vladimir D 0d31e89741 tests fixed 2025-02-25 14:25:59 +04:00
Renovate Bot ca2eecb0fb chore(deps): update dependency freshrss/freshrss to v1.26.0
| datasource      | package           | from   | to     |
| --------------- | ----------------- | ------ | ------ |
| github-releases | FreshRSS/FreshRSS | 1.25.0 | 1.26.0 |
2025-02-23 16:07:07 +00:00
Package Updates 5bdce48281 Update package version to 1.23.0 2024-12-24 07:59:16 +00:00
Renovate Bot ecd914b78f chore(deps): update dependency freshrss/freshrss to v1.25.0
| datasource      | package           | from   | to     |
| --------------- | ----------------- | ------ | ------ |
| github-releases | FreshRSS/FreshRSS | 1.24.3 | 1.25.0 |
2024-12-24 06:20:11 +00:00
Vladimir D 924a98f8da "CLOUDRON_OIDC_PROVIDER_NAME is not supported" comment added 2024-12-10 14:32:21 +04:00
Package Updates b977f0cfe1 Update package version to 1.22.0 2024-12-09 10:02:20 +00:00
Vladimir D 94f42678bd checklist added to CloudronManifest 2024-12-09 10:46:47 +01:00
Johannes Zellner 4a9ce49f7e Revert "Downgrade for ci test"
This reverts commit 9eb5c48ec8.
2024-11-09 17:11:55 +01:00
Johannes Zellner 9eb5c48ec8 Downgrade for ci test 2024-11-09 10:46:33 +01:00
Johannes Zellner 81ac195aa3 Prepare for ci 2024-11-09 10:46:04 +01:00
Girish Ramakrishnan 6b58760334 Update renovate.json5 2024-11-04 17:10:00 +00:00
Girish Ramakrishnan 441807c5ec Add renovate.json5 2024-11-04 17:02:56 +00:00
Johannes Zellner ea99b7c4ba Bump version 2024-09-06 11:48:55 +02:00
Johannes Zellner f236000d0d Update test deps 2024-09-06 11:35:44 +02:00
Johannes Zellner 00b67c9e3f Update to 1.24.3 2024-09-06 11:35:38 +02:00
Girish Ramakrishnan eea79146f9 Version 1.21.2 2024-08-23 18:42:26 +02:00
Girish Ramakrishnan 30c116edad Update test packages 2024-08-23 18:25:28 +02:00
Girish Ramakrishnan 7f9c1f91eb Update FreshRSS to 1.24.2 2024-08-23 18:12:04 +02:00
Johannes Zellner 48ca54d300 Bump version 2024-06-05 20:30:14 +02:00
Johannes Zellner c70b70d6b0 Fixup tests 2024-06-05 20:29:29 +02:00
Johannes Zellner 7c098a3236 Update test deps 2024-06-05 19:49:28 +02:00
Johannes Zellner 3338db16f0 Update to 1.24.1 2024-06-05 19:49:17 +02:00
Girish Ramakrishnan 2c8ed386ca Version 1.21.0 2024-05-23 18:12:46 +02:00
Girish Ramakrishnan 81bd749001 Fix test name 2024-05-23 18:10:22 +02:00
Girish Ramakrishnan 4f96317a75 Update test packages 2024-05-23 17:57:47 +02:00
Girish Ramakrishnan f5dc0cef24 Update FreshRSS to 1.24.0 2024-05-23 17:56:16 +02:00
Girish Ramakrishnan 143d4a80b9 Version 1.20.1 2024-01-02 10:48:47 +01:00
Girish Ramakrishnan 50172402be Update FreshRSS to 1.23.1 2024-01-02 10:34:16 +01:00
Girish Ramakrishnan 7935b892bd Update extensions 2023-12-29 14:30:57 +01:00
Girish Ramakrishnan d70ee21b89 Version 1.20.0-1 2023-12-26 13:51:18 +01:00
Girish Ramakrishnan 9cc7f803c7 Update FreshRSS to 1.23.0 2023-12-26 13:45:26 +01:00
Johannes Zellner a2a59d1a1b Fixup tests 2023-12-24 13:42:07 +01:00
Johannes Zellner 64a620770c Update test deps 2023-12-24 12:48:07 +01:00
Johannes Zellner 7605d62f17 Bump version 2023-12-24 12:47:51 +01:00
Girish Ramakrishnan 84ccab7e9f Fix test 2023-10-31 00:00:04 +01:00
Girish Ramakrishnan 7d42bed79b Version 1.19.1 2023-10-30 23:58:47 +01:00
Girish Ramakrishnan fb641b4c61 Update FreshRSS to 1.22.1 2023-10-30 23:48:42 +01:00
Girish Ramakrishnan 0a0d2d9f41 Version 1.19.0 2023-10-27 16:09:09 +02:00
Girish Ramakrishnan 2a5c04fdd7 Fixup tests 2023-10-27 15:48:46 +02:00
Girish Ramakrishnan 278637ef3a only generate oidc secret for oidc 2023-10-27 15:15:41 +02:00
Girish Ramakrishnan 2cfffbced7 Kill tabs 2023-10-27 15:12:30 +02:00
Girish Ramakrishnan 87f9c4f33f style 2023-10-27 12:13:03 +02:00
Girish Ramakrishnan 3947d62faf Update extensions 2023-10-27 12:11:03 +02:00
Girish Ramakrishnan da1e195e1d Cleanup apt 2023-10-27 12:10:24 +02:00
Vladimir D f8e08f1c51 OIDC auth implemented, tests amended 2023-10-27 12:36:22 +04:00
Girish Ramakrishnan 8b6fbb5aab Version 1.18.0 2023-10-24 10:25:10 +02:00
Girish Ramakrishnan 3b2d8446c0 Update test packages 2023-10-24 10:19:21 +02:00
Girish Ramakrishnan 0d1f6584b7 Update FreshRSS to 1.22.0 2023-10-24 10:18:24 +02:00
Girish Ramakrishnan 20097b8daf Version 1.17.0 2023-10-09 07:51:48 +05:30
Girish Ramakrishnan 108d4fae58 Update base image 2023-10-09 07:02:55 +05:30
Girish Ramakrishnan edb67b841e Version 1.16.0-1 2023-08-17 18:02:39 +05:30
Johannes Zellner 5516004525 Update test deps 2023-03-04 21:42:01 +01:00
Johannes Zellner bc70f2f33c Bump version 2023-03-04 21:33:28 +01:00
Girish Ramakrishnan 3dc389a3e0 Version 1.15.3 2022-12-08 16:17:26 +01:00
Girish Ramakrishnan 50c187a247 Update extensions 2022-12-08 16:07:45 +01:00
Johannes Zellner a5859749cc The initial startup already requires an the extensions symlink to be valid 2022-12-08 14:33:20 +01:00
Johannes Zellner 3a5458cdf6 also update base image 2022-12-08 14:13:03 +01:00
Johannes Zellner c845c79cc4 Update test deps 2022-12-08 14:07:32 +01:00
Johannes Zellner c86ce2c5c1 Bump version 2022-12-08 14:06:11 +01:00
11 changed files with 437 additions and 2920 deletions
+252
View File
@@ -243,3 +243,255 @@
* Add default redirect when authenticating #4778 * Add default redirect when authenticating #4778
* Force default user before rendering login page #4620 * Force default user before rendering login page #4620
[1.15.2]
* Update FreshRSS to 1.20.2
* Update Cloudron base image to 4.0.0
* [Full Changelog](https://github.com/FreshRSS/FreshRSS/releases/tag/1.20.2)
* Fix security vulnerability in ext.php #4928 reported by @c3l3si4n
[1.15.3]
* Update FreshRSS extensions repo to f66efcf5f
[1.16.0]
* Update FreshRSS to 1.21.1
* [Full Changelog](https://github.com/FreshRSS/FreshRSS/releases/tag/1.21.0)
* New XML+XPath mode for fetching XML documents when there is no RSS/ATOM feed #5076
* Better support of feed enclosures (image / audio / video attachments) #4944
* User-defined time-zone #4906
* New CLI script cli/sensitive-log.sh to help e.g. Apache clear logs for sensitive information such as credentials #5001
* Mark some themes as tentatively deprecated: BlueLagoon, Flat, Screwdriver #4807
* Many UI improvements
[1.17.0]
* Update base image to 4.2.0
[1.18.0]
* Update FreshRSS to 1.22.0
* [Full Changelog](https://github.com/FreshRSS/FreshRSS/releases/tag/1.22.0)
* Rework trusted proxies
* Improve scaling with many feeds and long processes, reduce database locks
* Fix many bugs and regressions
* Improve themes Origine (also with automatic dark mode), Nord, etc.
* Several UI / UX improvements
* New languages Hungarian, Latvian, Persian
[1.19.0]
* Implement OIDC login
[1.19.1]
* Update FreshRSS to 1.22.1
* [Full Changelog](https://github.com/FreshRSS/FreshRSS/releases/tag/1.22.1)
* Fix regression in extensions translations (i18n)
* Better identification of proxied client IP
[1.20.0]
* Update FreshRSS to 1.23.0
* [Full Changelog](https://github.com/FreshRSS/FreshRSS/releases/tag/1.23.0)
* New Important feeds group in the main view, with corresponding new priority level for feeds #5782
* Entries from important feeds are not marked as read during scroll, during focus, nor during Mark all as read
* Add filter actions (auto mark as read) at category level and at global levels #5942
* Increase SQL fields length to maximum possible #5788, #5570
* Many bug fixes
* Soft require Apache 2.4+ (but repair minimal compatibility with Apache 2.2)
* Upgraded extensions require FreshRSS 1.23.0+ Extensions#181
[1.20.1]
* Update FreshRSS to 1.23.1
* [Full Changelog](https://github.com/FreshRSS/FreshRSS/releases/tag/1.23.0)
* Fix crash regression with the option Max number of tags shown #5978
* Fix crash regression when enabling extensions defined by old FreshRSS installations #5979
* Fix crash regression during export when using MySQL #5988
* More robust assignment of categories to feeds #5986
[1.21.0]
* Update FreshRSS to 1.24.0
* [Full Changelog](https://github.com/FreshRSS/FreshRSS/releases/tag/1.24.0)
* New shareable user query mechanism to share lists of articles by HTML, RSS, OPML
* New CLI for database backup & restore
* New JSON scraping mode to consume JSON data and JSON Feeds
* New support for HTTP POST
* New option to automatically add labels to incoming articles
* New button to download a feed configuration as OPML
[1.21.1]
* Update FreshRSS to 1.24.1
* [Full Changelog](https://github.com/FreshRSS/FreshRSS/releases/tag/1.24.1)
* New button to export OMPL of a category
* Many bug fixes
[1.21.2]
* Update FreshRSS to 1.24.2
* [Full Changelog](https://github.com/FreshRSS/FreshRSS/releases/tag/1.24.2)
* New global option to automatically add articles to favourites
* New option to share articles from the article title line
* Add core extensions, shipped by default: UserCSS and UserJS
* Security: Force log out of users when they are disabled
* Last version supporting PHP 7.4 and initial support for PHP 8.4+
* Many bug and regression fixes
[1.21.3]
* Update FreshRSS to 1.24.3
* [Full Changelog](https://github.com/FreshRSS/FreshRSS/releases/tag/1.24.3)
* Fix mark-as-read from user query #6738
* Fix regression for shortcut to move between categories #6741
* Fix feed title option #6771
* Fix XPath for HTML documents with broken root (used by CSS selectors to fetch full content) #6774
* Fix UI regression in Mapco/Ansum themes #6740
* Fix minor style bug with some themes #6746
* Fix export of OPML information for date format of JSON and HTML+XPath feeds #6779
* OpenID Connect better definition of session parameters #6730
[1.22.0]
* checklist added to CloudronManifest
[1.23.0]
* Update FreshRSS to 1.25.0
* [Full Changelog](https://github.com/FreshRSS/FreshRSS/releases/tag/1.25.0)
* Features
* Bug fixing
* API
* Compatibility
* Deployment
* SimplePie
* Security
* UI
* Extensions
* I18n
* Misc.
[1.24.0]
* Update FreshRSS to 1.26.0
* [Full Changelog](https://github.com/FreshRSS/FreshRSS/releases/tag/1.26.0)
* Add order-by options to sort articles by received date (existing, default), publication date, title, link, random
* Allow searching in all feeds, also feeds only visible at category level with &get=A, and also those archived with &get=Z
* UI accessible from user-query view
* New shortcuts for adding user labels to articles
* Several improvements and bug fixes
[1.24.1]
* Update FreshRSS to 1.26.1
* [Full Changelog](https://github.com/FreshRSS/FreshRSS/releases/tag/1.26.1)
* Fix back-compatibility with cURL 7.51 (we require cURL 7.52+ for `CURLPROXY_HTTPS`)
* Add cURL version to page about system information
* Fix regression with cURL HTTP headers breaking conditional HTTP requests
* Fix regression with saving states of user queries
* Fix regression with dynamic OPML
* Fix update of the users last activity on login action
* Fix setting category option *Maximum number of articles to keep per feed*
* Fix priority field when processing a new feed from an extension
* Use case-insensitive sort for categories
* Improve dark mode of *Origine* theme
[1.25.0]
* Update base image to 5.0.0
[1.25.1]
* Update FreshRSS to 1.26.2
* [Full Changelog](https://github.com/FreshRSS/FreshRSS/releases/tag/1.26.2)
* Implement JSON string concatenation with & operator [#7414](https://github.com/FreshRSS/FreshRSS/pull/7414)
* Support multiple JSON fragments in HTML+XPath+JSON mode [#7369](https://github.com/FreshRSS/FreshRSS/pull/7369)
* Fix escaping of tag search [#7468](https://github.com/FreshRSS/FreshRSS/pull/7468)
* Fix CLI parsing of Boolean flags [#7430](https://github.com/FreshRSS/FreshRSS/pull/7430)
* Fix API for labels with slash [#7437](https://github.com/FreshRSS/FreshRSS/pull/7437)
* Fix support for feeds with XML preamble + DTD [#7515](https://github.com/FreshRSS/FreshRSS/pull/7515), [simplepie#914](https://github.com/simplepie/simplepie/pull/914)
* Disallow `<iframe srcdoc="">` [#7494](https://github.com/FreshRSS/FreshRSS/pull/7494), [CVE-2025-32015](https://github.com/FreshRSS/FreshRSS/security/advisories/GHSA-wgrq-mcwc-8f8v)
* Disallow `<button formaction="">` [#7506](https://github.com/FreshRSS/FreshRSS/pull/7506)
* Improve favicons hash to avoid favicon pollution [#7505](https://github.com/FreshRSS/FreshRSS/pull/7505), [CVE-2025-46339](https://github.com/FreshRSS/FreshRSS/security/advisories/GHSA-8f79-3q3w-43c4)
* Add `Content-Security-Policy` HTTP headers to favicons [#7471](https://github.com/FreshRSS/FreshRSS/pull/7471), [CVE-2025-31136](https://github.com/FreshRSS/FreshRSS/security/advisories/GHSA-f6r4-jrvc-cfmr)
[1.25.2]
* Update FreshRSS to 1.26.3
* [Full Changelog](https://github.com/FreshRSS/FreshRSS/releases/tag/1.26.3)
* Keep sort and order criteria during navigation [#&#8203;7585](https://github.com/FreshRSS/FreshRSS/pull/7585)
* Add info about `PDO::ATTR_CLIENT_VERSION` (relevant for MySQL / MariaDB with obsolete driver) [#&#8203;7591](https://github.com/FreshRSS/FreshRSS/pull/7591)
* Fix SQL request for user labels with custom sort (affecting PostgreSQL) [#&#8203;7588](https://github.com/FreshRSS/FreshRSS/pull/7588)
* Fix regression for favicon in GReader and Fever APIs [#&#8203;7573](https://github.com/FreshRSS/FreshRSS/pull/7573)
* Fix newest articles (within last second) not shown [#&#8203;7577](https://github.com/FreshRSS/FreshRSS/pull/7577)
* Fix duplicate HTTP header for POST [#&#8203;7556](https://github.com/FreshRSS/FreshRSS/pull/7556)
* Fix important articles on reader view [#&#8203;7602](https://github.com/FreshRSS/FreshRSS/pull/7602)
* Fix remove last share method [#&#8203;7613](https://github.com/FreshRSS/FreshRSS/pull/7613)
* Fix API handling of default category [#&#8203;7610](https://github.com/FreshRSS/FreshRSS/pull/7610)
* Fix user self-deletion [#&#8203;7626](https://github.com/FreshRSS/FreshRSS/pull/7626)
[1.26.0]
* Update FreshRSS to 1.27.0
* [Full Changelog](https://github.com/FreshRSS/FreshRSS/releases/tag/1.27.0)
* Implement support for HTTP `429 Too Many Requests` and `503 Service Unavailable`, obey `Retry-After` [#&#8203;7760](https://github.com/FreshRSS/FreshRSS/pull/7760)
* Add sort by category title, or by feed title [#&#8203;7702](https://github.com/FreshRSS/FreshRSS/pull/7702)
* Add search operator `c:` for categories like `c:23,34` or `!c:45,56` [#&#8203;7696](https://github.com/FreshRSS/FreshRSS/pull/7696)
* Custom feed favicons [#&#8203;7646](https://github.com/FreshRSS/FreshRSS/pull/7646), [#&#8203;7704](https://github.com/FreshRSS/FreshRSS/pull/7704), [#&#8203;7717](https://github.com/FreshRSS/FreshRSS/pull/7717), [#&#8203;7792](https://github.com/FreshRSS/FreshRSS/pull/7792)
* Rework fetch favicons for fewer HTTP requests [#&#8203;7767](https://github.com/FreshRSS/FreshRSS/pull/7767)
* Add more unicity criteria based on title and/or content [#&#8203;7789](https://github.com/FreshRSS/FreshRSS/pull/7789)
* Automatically restore user configuration from backup [#&#8203;7682](https://github.com/FreshRSS/FreshRSS/pull/7682)
* API add support for states in `s` parameter of `streamId` [#&#8203;7695](https://github.com/FreshRSS/FreshRSS/pull/7695)
* Improve sharing via Print [#&#8203;7728](https://github.com/FreshRSS/FreshRSS/pull/7728)
* Redirect to the login page from bookmarklet instead of 403 [#&#8203;7782](https://github.com/FreshRSS/FreshRSS/pull/7782)
[1.26.1]
* Update FreshRSS to 1.27.1
* [Full Changelog](https://github.com/FreshRSS/FreshRSS/releases/tag/1.27.1)
* Automatic database recovery: skip broken entries during CLI export/import [#&#8203;7949](https://github.com/FreshRSS/FreshRSS/pull/7949)
* Add security option for CSP `frame-ancestors` [#&#8203;7857](https://github.com/FreshRSS/FreshRSS/pull/7857), [#&#8203;8021](https://github.com/FreshRSS/FreshRSS/pull/8021)
* Lazy-load `<track src>` [#&#8203;7997](https://github.com/FreshRSS/FreshRSS/pull/7997)
* Regenerate session ID on login [#&#8203;7829](https://github.com/FreshRSS/FreshRSS/pull/7829)
* Disallow setting non-existent language [#&#8203;7878](https://github.com/FreshRSS/FreshRSS/pull/7878), [#&#8203;7934](https://github.com/FreshRSS/FreshRSS/pull/7934)
* Safer calling of `install.php` [#&#8203;7971](https://github.com/FreshRSS/FreshRSS/pull/7971)
* Prevent log CR/LF injection [#&#8203;7883](https://github.com/FreshRSS/FreshRSS/pull/7883)
* Restrict allowed cURL parameters [#&#8203;7979](https://github.com/FreshRSS/FreshRSS/pull/7979), [#&#8203;8009](https://github.com/FreshRSS/FreshRSS/pull/8009)
* Fix reauthentication while updating [#&#8203;7989](https://github.com/FreshRSS/FreshRSS/pull/7989)
* Fix some CSRFs [#&#8203;8000](https://github.com/FreshRSS/FreshRSS/pull/8000)
[1.27.0]
* Update FreshRSS to 1.28.0
* [Full Changelog](https://github.com/FreshRSS/FreshRSS/releases/tag/1.28.0)
* Move unsafe autologin to an extension [#7958](https://github.com/FreshRSS/FreshRSS/pull/7958)
* Housekeeping of `lib_rss.php` with potential breaking changes for some extensions [#8193](https://github.com/FreshRSS/FreshRSS/pull/8193)
* New sorting and filtering by date of *User modified* [#7886](https://github.com/FreshRSS/FreshRSS/pull/7886), [#8090](https://github.com/FreshRSS/FreshRSS/pull/8090), [#8105](https://github.com/FreshRSS/FreshRSS/pull/8105), [#8118](https://github.com/FreshRSS/FreshRSS/pull/8118), [#8130](https://github.com/FreshRSS/FreshRSS/pull/8130)
* New sorting by article length [#8119](https://github.com/FreshRSS/FreshRSS/pull/8119)
* New advanced search form [#8103](https://github.com/FreshRSS/FreshRSS/pull/8103), [#8122](https://github.com/FreshRSS/FreshRSS/pull/8122), [#8226](https://github.com/FreshRSS/FreshRSS/pull/8226)
* Add compatibility with PCRE word boundary `\b` and `\B` for regex search using PostgreSQL [#8141](https://github.com/FreshRSS/FreshRSS/pull/8141)
* More uniform SQL search and PHP search for accents and case-sensitivity (e.g. for automatically marking as read) [#8329](https://github.com/FreshRSS/FreshRSS/pull/8329)
* New overview of dates with most unread articles [#8089](https://github.com/FreshRSS/FreshRSS/pull/8089)
* Exclude local networks for domain-wide HTTP `Retry-After` [#8195](https://github.com/FreshRSS/FreshRSS/pull/8195)
* Fix OpenID Connect with Debian 13 [#8032](https://github.com/FreshRSS/FreshRSS/pull/8032)
[1.27.1]
* Update FreshRSS to 1.28.1
* [Full Changelog](https://github.com/FreshRSS/FreshRSS/releases/tag/1.28.1)
* Handle Web scraping of `text/plain` as `<pre class="text-plain">` [#&#8203;8340](https://github.com/FreshRSS/FreshRSS/pull/8340)
* New customisable message for closed registrations [#&#8203;8462](https://github.com/FreshRSS/FreshRSS/pull/8462)
* Fix unwanted expansion of user queries (saved searches) applied to filters [#&#8203;8395](https://github.com/FreshRSS/FreshRSS/pull/8395)
* Fix encoding of filter actions for labels [#&#8203;8368](https://github.com/FreshRSS/FreshRSS/pull/8368)
* Fix searching of tags [#&#8203;8425](https://github.com/FreshRSS/FreshRSS/pull/8425)
* Fix refreshing feeds with token while anonymous refresh is disabled [#&#8203;8371](https://github.com/FreshRSS/FreshRSS/pull/8371)
* Fix RSS and OPML access by token [#&#8203;8434](https://github.com/FreshRSS/FreshRSS/pull/8434)
* Fix MySQL/MariaDB `transliterator_transliterate` fallback (when the `php-intl` extension is unavailable) [#&#8203;8427](https://github.com/FreshRSS/FreshRSS/pull/8427)
* Fix regression with MySQL/MariaDB index hint [#&#8203;8460](https://github.com/FreshRSS/FreshRSS/pull/8460)
* Auto-add `lastUserModified` database column also during mark-as-read action [#&#8203;8346](https://github.com/FreshRSS/FreshRSS/pull/8346)
[1.28.0]
* Update FreshRSS to 1.29.0
* [Full Changelog](https://github.com/FreshRSS/FreshRSS/releases/tag/1.29.0)
* New sort order preferences at global, category, and feed levels [#8234](https://github.com/FreshRSS/FreshRSS/pull/8234)
* New filtering by date of *Server modification date* [#8131](https://github.com/FreshRSS/FreshRSS/pull/8131), [#8576](https://github.com/FreshRSS/FreshRSS/pull/8576)
* New option to automatically mark new articles as read if an identical GUID already exists in the same category [#8673](https://github.com/FreshRSS/FreshRSS/pull/8673)
* Add option to enable/disable notifications, also for PWA [#8458](https://github.com/FreshRSS/FreshRSS/pull/8458)
* Fix wrong search `toString` in case of regex-looking string [#8479](https://github.com/FreshRSS/FreshRSS/pull/8479)
* Fix redirect to wrong view after mark as read in *reader* and *global* views [#8552](https://github.com/FreshRSS/FreshRSS/pull/8552)
* Fix do not include hidden feeds when counting total number of unread articles [#8715](https://github.com/FreshRSS/FreshRSS/pull/8715)
* Limit cURL to protocols HTTP, HTTPS [#8713](https://github.com/FreshRSS/FreshRSS/pull/8713)
* New Webhook extension for automated RSS notifications [Extensions#456](https://github.com/FreshRSS/Extensions/pull/456)
* New `cli/purge.php` to apply purge policy [#8740](https://github.com/FreshRSS/FreshRSS/pull/8740)
[1.28.1]
* Update FreshRSS to 1.29.1
* [Full Changelog](https://github.com/FreshRSS/FreshRSS/releases/tag/1.29.1)
* Accept `.txt` import of feed URLs in additional to e.g. OPML [#8818](https://github.com/FreshRSS/FreshRSS/pull/8818), [#8837](https://github.com/FreshRSS/FreshRSS/pull/8837)
* New CLI for automatic periodic SQLite export with retention [#8819](https://github.com/FreshRSS/FreshRSS/pull/8819)
* More feed info: last received date, publication date [#8799](https://github.com/FreshRSS/FreshRSS/pull/8799)
* Fix cookies with some browsers [#8867](https://github.com/FreshRSS/FreshRSS/pull/8867)
* Fix search in shared user queries with empty results [#8863](https://github.com/FreshRSS/FreshRSS/pull/8863)
* Fix XML errors with loading invalid OPML in `lib_opml` library [#8652](https://github.com/FreshRSS/FreshRSS/pull/8652), [#8853](https://github.com/FreshRSS/FreshRSS/pull/8853), [lib_opml#48](https://framagit.org/marienfressinaud/lib_opml/-/merge_requests/48), [lib_opml#51](https://framagit.org/marienfressinaud/lib_opml/-/merge_requests/51)
* Fix ensure maximum number of feeds also with Dynamic OPML [#8832](https://github.com/FreshRSS/FreshRSS/pull/8832)
* Fix click mark as read [#8817](https://github.com/FreshRSS/FreshRSS/pull/8817)
+27 -5
View File
@@ -5,13 +5,16 @@
"description": "file://DESCRIPTION.md", "description": "file://DESCRIPTION.md",
"changelog": "file://CHANGELOG.md", "changelog": "file://CHANGELOG.md",
"tagline": "RSS feed reader", "tagline": "RSS feed reader",
"version": "1.15.1", "version": "1.28.1",
"upstreamVersion": "1.20.1", "upstreamVersion": "1.29.1",
"healthCheckPath": "/", "healthCheckPath": "/",
"httpPort": 8000, "httpPort": 8000,
"addons": { "addons": {
"localstorage": {}, "localstorage": {},
"mysql": {}, "mysql": {},
"oidc": {
"loginRedirectUri": "/i/oidc/"
},
"scheduler": { "scheduler": {
"update_feeds": { "update_feeds": {
"schedule": "*/1 * * * *", "schedule": "*/1 * * * *",
@@ -19,16 +22,35 @@
} }
} }
}, },
"checklist": {
"change-default-password": {
"sso": false,
"message": "Change the default admin password"
},
"create-admin": {
"sso": true,
"message": "On first visit, sign in using the built-in Cloudron authentication and then make the user administrator by running: `php cli/reconfigure.php --default_user YOUR_USERNAME`"
}
},
"manifestVersion": 2, "manifestVersion": 2,
"website": "http://www.freshrss.org", "website": "http://www.freshrss.org",
"contactEmail": "support@cloudron.io", "contactEmail": "support@cloudron.io",
"icon": "logo.png", "icon": "logo.png",
"tags": [ "rss", "atom", "greader", "reader", "news", "feeds", "feedly" ], "tags": [
"rss",
"atom",
"greader",
"reader",
"news",
"feeds",
"feedly"
],
"mediaLinks": [ "mediaLinks": [
"https://screenshots.cloudron.io/org.freshrss.cloudronapp/1.png" "https://screenshots.cloudron.io/org.freshrss.cloudronapp/1.png"
], ],
"postInstallMessage": "file://POSTINSTALL.md", "postInstallMessage": "file://POSTINSTALL.md",
"minBoxVersion": "7.1.0", "minBoxVersion": "8.1.0",
"forumUrl": "https://forum.cloudron.io/category/27/freshrss", "forumUrl": "https://forum.cloudron.io/category/27/freshrss",
"documentationUrl": "https://cloudron.io/documentation/apps/freshrss/" "documentationUrl": "https://cloudron.io/documentation/packages/freshrss/",
"optionalSso": true
} }
-2
View File
@@ -1,5 +1,3 @@
This app packages FreshRSS <upstream>1.19.2</upstream>.
## About ## About
FreshRSS is a self-hosted RSS feed aggregator such as Leed or Kriss Feed. FreshRSS is a self-hosted RSS feed aggregator such as Leed or Kriss Feed.
+18 -15
View File
@@ -1,15 +1,18 @@
FROM cloudron/base:3.2.0@sha256:ba1d566164a67c266782545ea9809dc611c4152e27686fd14060332dd88263ea FROM cloudron/base:5.0.0@sha256:04fd70dbd8ad6149c19de39e35718e024417c3e01dc9c6637eaf4a41ec4e596c
RUN apt-get update && apt-get install --no-install-recommends -y libapache2-mod-auth-openidc && rm -rf /var/cache/apt /var/lib/apt/lists
RUN mkdir -p /app/code RUN mkdir -p /app/code
WORKDIR /app/code WORKDIR /app/code
ARG VERSION=1.20.1 # renovate: datasource=github-releases depName=FreshRSS/FreshRSS versioning=semver
RUN curl -L https://github.com/FreshRSS/FreshRSS/archive/${VERSION}.tar.gz | tar -zxvf - --strip-components=1 ARG FRESHRSS_VERSION=1.29.1
RUN mv data data-orig && ln -s /app/data data RUN curl -L https://github.com/FreshRSS/FreshRSS/archive/${FRESHRSS_VERSION}.tar.gz | tar -zxvf - --strip-components=1 && \
mv data data-orig && ln -s /app/data data
# official extensions # official extensions (https://github.com/FreshRSS/Extensions/commits/master)
RUN wget https://github.com/FreshRSS/Extensions/archive/1784092164139dc6961ba5cc5b920331b586acbc.tar.gz -O - | tar -xz --strip-components=1 -C /app/code/extensions && \ RUN wget https://github.com/FreshRSS/Extensions/archive/a82e080a1e68eb34539959a852fc5e800b7346dd.tar.gz -O - | tar -xz --strip-components=1 -C /app/code/extensions && \
mv /app/code/extensions /app/code/extensions-orig && \ mv /app/code/extensions /app/code/extensions-orig && \
ln -s /app/data/extensions /app/code/extensions ln -s /app/data/extensions /app/code/extensions
@@ -22,19 +25,19 @@ RUN a2disconf other-vhosts-access-log
ADD apache/freshrss.conf /etc/apache2/sites-enabled/freshrss.conf ADD apache/freshrss.conf /etc/apache2/sites-enabled/freshrss.conf
RUN echo "Listen 8000" > /etc/apache2/ports.conf RUN echo "Listen 8000" > /etc/apache2/ports.conf
RUN a2enmod headers expires deflate mime dir rewrite setenvif RUN a2enmod headers expires deflate mime dir rewrite setenvif auth_openidc
RUN rm -rf /var/lib/php && ln -s /run/php /var/lib/php RUN rm -rf /var/lib/php && ln -s /run/php /var/lib/php
RUN crudini --set /etc/php/7.4/apache2/php.ini PHP upload_max_filesize 64M && \ RUN crudini --set /etc/php/8.3/apache2/php.ini PHP upload_max_filesize 64M && \
crudini --set /etc/php/7.4/apache2/php.ini PHP post_max_size 64M && \ crudini --set /etc/php/8.3/apache2/php.ini PHP post_max_size 64M && \
crudini --set /etc/php/7.4/apache2/php.ini PHP memory_limit 64M && \ crudini --set /etc/php/8.3/apache2/php.ini PHP memory_limit 64M && \
crudini --set /etc/php/7.4/apache2/php.ini Session session.save_path /run/php/session && \ crudini --set /etc/php/8.3/apache2/php.ini Session session.save_path /run/php/session && \
crudini --set /etc/php/7.4/apache2/php.ini Session session.gc_probability 1 && \ crudini --set /etc/php/8.3/apache2/php.ini Session session.gc_probability 1 && \
crudini --set /etc/php/7.4/apache2/php.ini Session session.gc_divisor 100 crudini --set /etc/php/8.3/apache2/php.ini Session session.gc_divisor 100
RUN ln -s /app/data/php.ini /etc/php/7.4/apache2/conf.d/99-cloudron.ini && \ RUN ln -s /app/data/php.ini /etc/php/8.3/apache2/conf.d/99-cloudron.ini && \
ln -s /app/data/php.ini /etc/php/7.4/cli/conf.d/99-cloudron.ini ln -s /app/data/php.ini /etc/php/8.3/cli/conf.d/99-cloudron.ini
ADD start.sh /app/code/start.sh ADD start.sh /app/code/start.sh
+2 -2
View File
@@ -1,7 +1,7 @@
<nosso>
This app is pre-setup with an admin account. The initial credentials are: This app is pre-setup with an admin account. The initial credentials are:
**Username**: admin<br/> **Username**: admin<br/>
**Password**: changeme<br/> **Password**: changeme<br/>
Please change the admin password immediately. </nosso>
+45 -1
View File
@@ -1,6 +1,10 @@
ServerName %{HTTP_HOST} # https://github.com/FreshRSS/FreshRSS/blob/edge/Docker/FreshRSS.Apache.conf
ServerName localhost
<VirtualHost *:8000> <VirtualHost *:8000>
ServerName localhost
UseCanonicalName Off
DocumentRoot /app/code/p DocumentRoot /app/code/p
AllowEncodedSlashes On AllowEncodedSlashes On
@@ -13,4 +17,44 @@ ServerName %{HTTP_HOST}
AllowOverride All AllowOverride All
Require all granted Require all granted
</Directory> </Directory>
<Directory /app/code/p/api>
Include /app/code/p/api/.htaccess
</Directory>
<Directory /app/code/p/i>
ExpiresActive Off
<IfDefine OIDC_ENABLED>
AuthType openid-connect
Require valid-user
</IfDefine>
IncludeOptional /app/code/p/i/.htaccess
</Directory>
<Directory /app/code/p/themes>
Include /app/code/p/themes/.htaccess
</Directory>
<IfDefine OIDC_ENABLED>
# CLOUDRON_OIDC_PROVIDER_NAME is not supported
OIDCProviderMetadataURL ${CLOUDRON_OIDC_DISCOVERY_URL}
OIDCClientID ${CLOUDRON_OIDC_CLIENT_ID}
OIDCClientSecret ${CLOUDRON_OIDC_CLIENT_SECRET}
OIDCRedirectURI /i/oidc/
OIDCCryptoPassphrase ${OIDC_CRYPTO_PASSPHRASE}
OIDCRemoteUserClaim sub
OIDCScope "openid profile email"
OIDCRefreshAccessTokenBeforeExpiry 30
OIDCPassClaimsAs headers
OIDCXForwardedHeaders X-Forwarded-Proto
</IfDefine>
</VirtualHost> </VirtualHost>
+4
View File
@@ -0,0 +1,4 @@
{
"$schema": "https://docs.renovatebot.com/renovate-schema.json",
"extends": ["local>devops/renovator//default.renovate.json5"]
}
+16 -5
View File
@@ -2,7 +2,7 @@
set -eu set -eu
mkdir -p /run/php/session mkdir -p /run/php/session /app/data/extensions
if ! [ -f /app/data/.installed ]; then if ! [ -f /app/data/.installed ]; then
echo "==> Fresh installation, setting up..." echo "==> Fresh installation, setting up..."
@@ -13,7 +13,11 @@ if ! [ -f /app/data/.installed ]; then
--db-user "${CLOUDRON_MYSQL_USERNAME}" --db-password "${CLOUDRON_MYSQL_PASSWORD}" \ --db-user "${CLOUDRON_MYSQL_USERNAME}" --db-password "${CLOUDRON_MYSQL_PASSWORD}" \
--db-base "${CLOUDRON_MYSQL_DATABASE}" --db-prefix "" \ --db-base "${CLOUDRON_MYSQL_DATABASE}" --db-prefix "" \
--disable_update --disable_update
if [[ -z "${CLOUDRON_OIDC_ISSUER:-}" ]]; then
php cli/create-user.php --user admin --password changeme --language en php cli/create-user.php --user admin --password changeme --language en
fi
touch /app/data/.installed touch /app/data/.installed
echo "==> Done." echo "==> Done."
fi fi
@@ -29,23 +33,30 @@ ln -s /tmp/log_api.txt /app/data/users/_/log_api.txt
# We have to copy instead of symlinking extensions (see #2) # We have to copy instead of symlinking extensions (see #2)
echo "==> Copying packaged extensions" echo "==> Copying packaged extensions"
mkdir -p /app/data/extensions
for f in $(ls /app/code/extensions-orig); do for f in $(ls /app/code/extensions-orig); do
rm -rf "/app/data/extensions/$f" rm -rf "/app/data/extensions/$f"
cp -r "/app/code/extensions-orig/$f" "/app/data/extensions" cp -r "/app/code/extensions-orig/$f" "/app/data/extensions"
done done
echo "==> Updating config file" echo "==> Updating config file"
php cli/reconfigure.php --default_user admin --base_url "https://${CLOUDRON_APP_DOMAIN}" \ if [[ -z "${CLOUDRON_OIDC_ISSUER:-}" ]]; then
extra_args="--default_user admin"
[[ ! -f /app/data/.oauth_crypto_passphrase ]] && openssl rand -base64 42 > /app/data/.oauth_crypto_passphrase
export OIDC_CRYPTO_PASSPHRASE=$(</app/data/.oauth_crypto_passphrase) # used in apache config
else
extra_args="--auth_type http_auth"
fi
php cli/reconfigure.php ${extra_args} --base_url "https://${CLOUDRON_APP_DOMAIN}" \
--db-type mysql --db-host "${CLOUDRON_MYSQL_HOST}" \ --db-type mysql --db-host "${CLOUDRON_MYSQL_HOST}" \
--db-user "${CLOUDRON_MYSQL_USERNAME}" --db-password "${CLOUDRON_MYSQL_PASSWORD}" \ --db-user "${CLOUDRON_MYSQL_USERNAME}" --db-password "${CLOUDRON_MYSQL_PASSWORD}" \
--db-base "${CLOUDRON_MYSQL_DATABASE}" --db-prefix "" \ --db-base "${CLOUDRON_MYSQL_DATABASE}" --db-prefix "" \
--disable_update --disable_update
echo "==> Setting permissions" echo "==> Setting permissions"
chown -R www-data.www-data /run/php /app/data /tmp/log_api.txt chown -R www-data:www-data /run/php /app/data /tmp/log_api.txt
echo "==> Starting apache" echo "==> Starting apache"
APACHE_CONFDIR="" source /etc/apache2/envvars APACHE_CONFDIR="" source /etc/apache2/envvars
rm -f "${APACHE_PID_FILE}" rm -f "${APACHE_PID_FILE}"
exec /usr/sbin/apache2 -DFOREGROUND exec /usr/sbin/apache2 -D FOREGROUND $([[ -n "$CLOUDRON_OIDC_ISSUER" ]] && echo '-D OIDC_ENABLED')
-2732
View File
File diff suppressed because it is too large Load Diff
-20
View File
@@ -1,20 +0,0 @@
{
"name": "test",
"version": "1.0.0",
"description": "",
"main": "index.js",
"scripts": {
"test": "echo \"Error: no test specified\" && exit 1"
},
"author": "",
"license": "ISC",
"dependencies": {
"chromedriver": "^107.0.3",
"expect.js": "^0.3.1",
"mkdirp": "^1.0.4",
"mocha": "^10.1.0",
"rimraf": "^3.0.2",
"selenium-webdriver": "^4.6.0",
"superagent": "^8.0.3"
}
}
+71 -136
View File
@@ -1,196 +1,131 @@
#!/usr/bin/env node
/* jshint esversion: 8 */ import assert from 'node:assert/strict';
/* global describe */ import superagent from '@cloudron/superagent';
/* global before */
/* global after */
/* global it */
'use strict'; import { app, clearCache, click, cloudronCli, press, goto, loginOIDC, password, sendKeys, setupBrowser, takeScreenshot, teardownBrowser, username, waitFor } from '@cloudron/charlie';
require('chromedriver'); /* global it, describe, before, after, afterEach */
var execSync = require('child_process').execSync,
expect = require('expect.js'),
path = require('path'),
superagent = require('superagent'),
{ Builder, By, Key, until } = require('selenium-webdriver'),
{ Options } = require('selenium-webdriver/chrome');
var username = 'admin',
password = 'changeme';
describe('Application life cycle test', function () { describe('Application life cycle test', function () {
this.timeout(0); const admin_username = 'admin';
const admin_password = 'changeme';
const LOCATION = 'test'; before(setupBrowser);
const TEST_TIMEOUT = 10000; after(teardownBrowser);
const EXEC_ARGS = { cwd: path.resolve(__dirname, '..'), stdio: 'inherit' };
var browser, app; afterEach(async function () {
await takeScreenshot(this.currentTest);
before(function () {
const options = new Options().windowSize({ width: 1280, height: 1024 });
if (process.env.HEADLESS) options.addArguments('headless');
browser = new Builder().forBrowser('chrome').setChromeOptions(options).build();
}); });
after(function () {
browser.quit();
});
function getAppInfo() {
var inspect = JSON.parse(execSync('cloudron inspect'));
app = inspect.apps.filter(function (a) { return a.location.indexOf(LOCATION) === 0; })[0];
expect(app).to.be.an('object');
}
function baseUrl() { function baseUrl() {
if (app.manifest.version === '1.4.0') return `https://${app.fqdn}/p`; if (app.manifest.version === '1.4.0') return `https://${app.fqdn}/p`;
return `https://${app.fqdn}`; return `https://${app.fqdn}`;
} }
async function waitForElement(elem) { async function login(uname, pass) {
await browser.wait(until.elementLocated(elem), TEST_TIMEOUT); await goto(`https://${app.fqdn}`, 'label=Username');
await browser.wait(until.elementIsVisible(browser.findElement(elem)), TEST_TIMEOUT); await sendKeys('label=Username', uname);
await sendKeys('label=Password', pass);
await click('Login', { role: 'button' }); // there is a link at the top
await waitFor('Subscription management');
} }
async function login(password) { async function loginViaOIDC() {
await browser.get('https://' + app.fqdn); await goto(`https://${app.fqdn}/i/`);
await waitForElement(By.id('loginButton')); await loginOIDC('css=#btn-subscription');
await browser.findElement(By.id('username')).sendKeys(username);
await browser.findElement(By.id('passwordPlain')).sendKeys(password);
await browser.findElement(By.id('loginButton')).click();
await waitForElement(By.id('btn-subscription'));
}
async function logout() {
var logout_btn = By.xpath('//li/a[@class="signout"]');
await browser.get('https://' + app.fqdn);
await waitForElement(By.id('stream'));
await browser.findElement(By.className('dropdown-toggle')).click();
await waitForElement(logout_btn);
await browser.findElement(logout_btn).click();
await waitForElement(By.id('loginButton'));
} }
async function addSubscription() { async function addSubscription() {
var url = 'https://blog.cloudron.io/rss/'; await goto(`${baseUrl()}/i/?c=subscription&a=add`, 'label=Feed URL');
const addUrl = app.manifest.version === '1.10.0' ? `${baseUrl()}/i/?c=subscription` : `${baseUrl()}/i/?c=subscription&a=add`; await sendKeys('label=Feed URL', 'https://blog.cloudron.io/rss/');
await press('label=Feed URL', 'Enter'); // there are multiple "Add" buttons on that page
await browser.get(addUrl); await waitFor('RSS feed Cloudron has been added');
await waitForElement(By.xpath('//input[@name="url_rss"]'));
await browser.findElement(By.xpath('//input[@name="url_rss"]')).sendKeys(url);
await browser.findElement(By.xpath('//form[@id="add_rss"]//button[text()="Add"]')).click();
await waitForElement(By.xpath('//div[@id="notification" and @class="notification good"]'));
} }
async function addUser(password) { async function enableApi({ relogin = true } = {}) {
var test_username = 'test'; await goto(`${baseUrl()}/i/?c=auth`);
await browser.get(`${baseUrl()}/i/?c=user&a=manage`); if (relogin) {
await waitForElement(By.id('new_user_name')); await sendKeys('label=Password', admin_password);
await browser.findElement(By.id('new_user_name')).sendKeys(test_username); await click('Login');
await browser.findElement(By.id('new_user_passwordPlain')).sendKeys(password);
await browser.findElement(By.xpath('//button[text()="Create"]')).click();
await waitForElement(By.xpath('//div[@id="notification" and @class="notification good"]'));
} }
async function enableApi() { await click(/Allow API access/);
await browser.get(`${baseUrl()}/i/?c=auth`); await click('Submit');
await waitForElement(By.id('api_enabled')); await waitFor(/Configuration has been updated/);
await browser.findElement(By.id('api_enabled')).click();
await browser.findElement(By.xpath('//button[text()="Submit"]')).click();
} }
async function checkApiConfiguration() { async function checkApiConfiguration() {
await browser.get(`${baseUrl()}/api/`); await goto(`${baseUrl()}/api/`, /PASS/);
await waitForElement(By.xpath('//dd[@id="greaderOutput" and contains(text(), "PASS")]')); await waitFor(/PASS/);
await waitForElement(By.xpath('//dd[@id="feverOutput" and contains(text(), "PASS")]'));
} }
async function subscriptionExists() { async function subscriptionExists() {
await browser.get(`${baseUrl()}/i/?get=c_1`); await goto(`${baseUrl()}/i/?get=c_1`, 'Cloudron');
return waitForElement(By.xpath('//span[text()="Cloudron"]'));
} }
function getStaticExtensionFile(callback) { async function getStaticExtensionFile() {
superagent.get(`${baseUrl()}/ext.php?f=xExtension-StickyFeeds/static/script.js&t=js`) const url = `${baseUrl()}/ext.php?f=xExtension-StickyFeeds/static/script.js&t=js`;
.buffer(true) const response = await superagent.get(url)
.end(function (err, res) { .set('Cache-Control', 'no-store')
expect(err).to.be(null); .set('Pragma', 'no-cache')
expect(res.status).to.be(200); .ok(() => true);
expect(res.text).to.contain('sticky_feeds'); // relies on the buffer flag above assert.strictEqual(response.status, 200);
callback(); assert.ok(response.body.toString('utf8').includes('sticky_feeds')); // content-type is application/javascript, so body is a buffer
});
} }
xit('build app', function () { execSync('cloudron build', EXEC_ARGS); }); // No SSO
it('install app', function () { execSync('cloudron install --location ' + LOCATION, EXEC_ARGS); }); it('install app (no sso)', () => cloudronCli.install({ noSso: true }));
it('can get app information', getAppInfo); it('can login', login.bind(null, admin_username, admin_password));
it('can login', login.bind(null, password));
it('can subscribe', addSubscription); it('can subscribe', addSubscription);
it('can add users', addUser.bind(null, password)); it('can enable API', () => enableApi({ relogin: true }));
it('can enable API', enableApi);
it('can check configuration', checkApiConfiguration); it('can check configuration', checkApiConfiguration);
it('subscription exists', subscriptionExists); it('subscription exists', subscriptionExists);
it('can get static extension file', getStaticExtensionFile); it('can get static extension file', getStaticExtensionFile);
it('can logout', logout); it('can logout', clearCache);
it('uninstall app', cloudronCli.uninstall);
it('backup app', function () { execSync('cloudron backup create --app ' + app.id, EXEC_ARGS); }); // SSO
it('install app (sso)', cloudronCli.install);
it('restore app', function () { it('can make user Administrator', () => cloudronCli.exec(`bash -c "php cli/reconfigure.php --default-user ${username}"`));
const backups = JSON.parse(execSync(`cloudron backup list --raw --app ${app.id}`)); it('can login OIDC', () => loginViaOIDC(username, password));
execSync('cloudron uninstall --app ' + app.id, EXEC_ARGS); it('can subscribe', addSubscription);
execSync('cloudron install --location ' + LOCATION, EXEC_ARGS); it('can enable API', () => enableApi({ relogin: false }));
getAppInfo();
execSync(`cloudron restore --backup ${backups[0].id} --app ${app.id}`, EXEC_ARGS);
});
it('can login', login.bind(null, password));
it('can check configuration', checkApiConfiguration); it('can check configuration', checkApiConfiguration);
it('subscription exists', subscriptionExists); it('subscription exists', subscriptionExists);
it('can get static extension file', getStaticExtensionFile); it('can get static extension file', getStaticExtensionFile);
it('can logout', logout);
it('move to different location', function () { it('backup app', cloudronCli.createBackup);
browser.manage().deleteAllCookies(); it('restore app', cloudronCli.restoreFromLatestBackup);
execSync('cloudron configure --location ' + LOCATION + '2 --app ' + app.id, EXEC_ARGS);
var inspect = JSON.parse(execSync('cloudron inspect'));
app = inspect.apps.filter(function (a) { return a.location === LOCATION + '2'; })[0];
expect(app).to.be.an('object');
});
it('can login', login.bind(null, password)); it('can login OIDC', loginViaOIDC);
it('can check configuration', checkApiConfiguration); it('can check configuration', checkApiConfiguration);
it('subscription exists', subscriptionExists); it('subscription exists', subscriptionExists);
it('can get static extension file', getStaticExtensionFile); it('can get static extension file', getStaticExtensionFile);
it('can logout', logout);
it('uninstall app', function () { execSync('cloudron uninstall --app ' + app.id, EXEC_ARGS); }); it('move to different location', cloudronCli.changeLocation);
it('can login OIDC', loginViaOIDC);
it('can check configuration', checkApiConfiguration);
it('subscription exists', subscriptionExists);
it('can get static extension file', getStaticExtensionFile);
it('uninstall app', cloudronCli.uninstall);
// test update // test update
it('can install app', function () { execSync('cloudron install --appstore-id org.freshrss.cloudronapp --location ' + LOCATION, EXEC_ARGS); }); it('can install app for update', cloudronCli.appstoreInstall);
it('can get app information', getAppInfo); it('can login OIDC', loginViaOIDC);
it('can login', login.bind(null, password)); it('can make user Administrator', () => cloudronCli.exec(`bash -c "php cli/reconfigure.php --default-user ${username}"`));
it('can subscribe', addSubscription); it('can subscribe', addSubscription);
it('can add users', addUser.bind(null, password));
it('can update', function () { it('can update', cloudronCli.update);
execSync('cloudron update --app ' + app.id, EXEC_ARGS);
var inspect = JSON.parse(execSync('cloudron inspect'));
app = inspect.apps.filter(function (a) { return a.location === LOCATION; })[0];
expect(app).to.be.an('object');
});
it('can login', login.bind(null, password)); it('can login OIDC', loginViaOIDC);
it('subscription exists', subscriptionExists); it('subscription exists', subscriptionExists);
it('can get static extension file', getStaticExtensionFile); it('can get static extension file', getStaticExtensionFile);
it('uninstall app', function () { execSync('cloudron uninstall --app ' + app.id, EXEC_ARGS); }); it('uninstall app', cloudronCli.uninstall);
}); });