aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorGravatar Dag <me@dvikan.no> 2025-01-02 16:33:56 +0100
committerGravatar GitHub <noreply@github.com> 2025-01-02 16:33:56 +0100
commit7d544f1fab0e7c2d7518f0a6e3495dbc4f8e7cb3 (patch)
treecc9702d5e732a636b69b1f0f9d354c6794ebc977
parent152e96d3d06b626574ecc79781479d46c7d9867d (diff)
downloadrss-bridge-7d544f1fab0e7c2d7518f0a6e3495dbc4f8e7cb3.tar.gz
rss-bridge-7d544f1fab0e7c2d7518f0a6e3495dbc4f8e7cb3.tar.zst
rss-bridge-7d544f1fab0e7c2d7518f0a6e3495dbc4f8e7cb3.zip
feat(reddit): support video (#4380)
-rw-r--r--bridges/RedditBridge.php23
1 files changed, 18 insertions, 5 deletions
diff --git a/bridges/RedditBridge.php b/bridges/RedditBridge.php
index 03f279d8..2a3824f4 100644
--- a/bridges/RedditBridge.php
+++ b/bridges/RedditBridge.php
@@ -234,11 +234,14 @@ class RedditBridge extends BridgeAbstract
} elseif ($data->is_video) {
// Video
- // Higher index -> Higher resolution
- end($data->preview->images[0]->resolutions);
- $index = key($data->preview->images[0]->resolutions);
-
- $item['content'] = $this->createFigureLink($data->url, $data->preview->images[0]->resolutions[$index]->url, 'Video');
+ if ($data->media->reddit_video) {
+ $item['content'] = $this->createVideoContent($data->media->reddit_video);
+ } else {
+ // Higher index -> Higher resolution
+ end($data->preview->images[0]->resolutions);
+ $index = key($data->preview->images[0]->resolutions);
+ $item['content'] = $this->createFigureLink($data->url, $data->preview->images[0]->resolutions[$index]->url, 'Video');
+ }
} elseif (isset($data->media) && $data->media->type == 'youtube.com') {
// Youtube link
$item['content'] = $this->createFigureLink($data->url, $data->media->oembed->thumbnail_url, 'YouTube');
@@ -318,6 +321,16 @@ class RedditBridge extends BridgeAbstract
return sprintf('<a href="%s">%s</a>', $href, $text);
}
+ private function createVideoContent(\stdClass $video): string
+ {
+ return <<<HTML
+ <video width="$video->width" height="$video->height" controls>
+ <source src="$video->fallback_url" type="video/mp4">
+ Your browser does not support the video tag.
+ </video>
+ HTML;
+ }
+
public function detectParameters($url)
{
try {