aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--CHANGELOG.md1
-rw-r--r--app/Models/Entry.php13
2 files changed, 14 insertions, 0 deletions
diff --git a/CHANGELOG.md b/CHANGELOG.md
index fef33948c..1526cef75 100644
--- a/CHANGELOG.md
+++ b/CHANGELOG.md
@@ -6,6 +6,7 @@
* Require PHP 7.4+, and implement *typed properties* [#5720](https://github.com/FreshRSS/FreshRSS/pull/5720)
* Require Apache 2.4+ (but repair minimal compatibility with Apache 2.2) [#5791](https://github.com/FreshRSS/FreshRSS/pull/5791), [#5804](https://github.com/FreshRSS/FreshRSS/pull/5804)
* Features
+ * Add support for more thumbnail types [#5806](https://github.com/FreshRSS/FreshRSS/pull/5806)
* Increase SQL (`VARCHAR`) text fields length to maximum possible [#5788](https://github.com/FreshRSS/FreshRSS/pull/5788)
* Increase SQL date fields to 64-bit to be ready for year 2038+ [#5570](https://github.com/FreshRSS/FreshRSS/pull/5570)
* Bug fixing
diff --git a/app/Models/Entry.php b/app/Models/Entry.php
index e3e61fb00..3e9cee4e2 100644
--- a/app/Models/Entry.php
+++ b/app/Models/Entry.php
@@ -298,11 +298,24 @@ HTML;
*/
public function thumbnail(bool $searchEnclosures = true): ?array {
$thumbnail = $this->attributes('thumbnail');
+ // First, use the provided thumbnail, if any
if (!empty($thumbnail['url'])) {
return $thumbnail;
}
if ($searchEnclosures) {
foreach ($this->enclosures(true) as $enclosure) {
+ // Second, search each enclosure’s thumbnails
+ if (!empty($enclosure['thumbnails'][0])) {
+ foreach ($enclosure['thumbnails'] as $src) {
+ if (is_string($src)) {
+ return [
+ 'url' => $src,
+ 'medium' => 'image',
+ ];
+ }
+ }
+ }
+ // Third, check whether each enclosure itself is an appropriate image
if (self::enclosureIsImage($enclosure)) {
return $enclosure;
}