From df94f1c0b82d95846574487231ea251530838ef0 Mon Sep 17 00:00:00 2001 From: Fijxu Date: Wed, 18 Dec 2024 21:57:42 -0300 Subject: [PATCH] support pubsub notifications without making a request to innertube Closes https://git.nadeko.net/Fijxu/invidious/issues/56 --- src/invidious/config.cr | 1 + src/invidious/routes/feeds.cr | 28 ++++++++++++++++------------ 2 files changed, 17 insertions(+), 12 deletions(-) diff --git a/src/invidious/config.cr b/src/invidious/config.cr index 5cee4012..76b1d46f 100644 --- a/src/invidious/config.cr +++ b/src/invidious/config.cr @@ -111,6 +111,7 @@ class Config # Subscribe to channels using PubSubHubbub (requires domain, hmac_key) property use_pubsub_feeds : Bool | Int32 = false + property use_innertube_for_feeds : Bool = true property popular_enabled : Bool = true property captcha_enabled : Bool = true property login_enabled : Bool = true diff --git a/src/invidious/routes/feeds.cr b/src/invidious/routes/feeds.cr index 19f8aac2..a43301c5 100644 --- a/src/invidious/routes/feeds.cr +++ b/src/invidious/routes/feeds.cr @@ -416,18 +416,22 @@ module Invidious::Routes::Feeds author = entry.xpath_node("default:author/default:name", namespaces).not_nil!.content published = Time.parse_rfc3339(entry.xpath_node("default:published", namespaces).not_nil!.content) updated = Time.parse_rfc3339(entry.xpath_node("default:updated", namespaces).not_nil!.content) + ucid = entry.xpath_node("yt:channelId", namespaces).not_nil!.content + title = entry.xpath_node("default:title", namespaces).not_nil!.content - begin - video = get_video(id, force_refresh: true) - rescue - next # skip this video since it raised an exception (e.g. it is a scheduled live event) + if CONFIG.use_innertube_for_feeds + begin + video_ = get_video(id, force_refresh: true) + rescue + next # skip this video since it raised an exception (e.g. it is a scheduled live event) + end end if CONFIG.enable_user_notifications # Deliver notifications to `/api/v1/auth/notifications` payload = { - "topic" => video.ucid, - "videoId" => video.id, + "topic" => ucid, + "videoId" => id, "published" => published.to_unix, }.to_json PG_DB.exec("NOTIFY notifications, E'#{payload}'") @@ -435,15 +439,15 @@ module Invidious::Routes::Feeds video = ChannelVideo.new({ id: id, - title: video.title, + title: title, published: published, updated: updated, - ucid: video.ucid, + ucid: ucid, author: author, - length_seconds: video.length_seconds, - live_now: video.live_now, - premiere_timestamp: video.premiere_timestamp, - views: video.views, + length_seconds: video_.try &.length_seconds || 0, + live_now: video_.try &.live_now || false, + premiere_timestamp: video_.try &.premiere_timestamp || nil, + views: video_.try &.views || nil, }) was_insert = Invidious::Database::ChannelVideos.insert(video, with_premiere_timestamp: true)