summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorChunkyProgrammer <78101139+ChunkyProgrammer@users.noreply.github.com>2024-08-24 18:00:59 -0400
committerChunkyProgrammer <78101139+ChunkyProgrammer@users.noreply.github.com>2024-09-30 22:02:57 -0400
commit1961fc3b113ff763b46afd4a44fb5796c083c820 (patch)
tree6191282e1d62c6a560aac785047f1164098c9017
parent2e649363d2c985737ce8379c383adbe632607c39 (diff)
downloadinvidious-1961fc3b113ff763b46afd4a44fb5796c083c820.tar.gz
invidious-1961fc3b113ff763b46afd4a44fb5796c083c820.tar.bz2
invidious-1961fc3b113ff763b46afd4a44fb5796c083c820.zip
switch to enum flag instead of adding lots of properties to SearchVideo
-rw-r--r--src/invidious/channels/channels.cr4
-rw-r--r--src/invidious/helpers/serialized_yt_data.cr41
-rw-r--r--src/invidious/routes/feeds.cr11
-rw-r--r--src/invidious/yt_backend/extractors.cr53
4 files changed, 39 insertions, 70 deletions
diff --git a/src/invidious/channels/channels.cr b/src/invidious/channels/channels.cr
index 29546e38..1478c8fc 100644
--- a/src/invidious/channels/channels.cr
+++ b/src/invidious/channels/channels.cr
@@ -223,7 +223,7 @@ def fetch_channel(ucid, pull_all_videos : Bool)
length_seconds = channel_video.try &.length_seconds
length_seconds ||= 0
- live_now = channel_video.try &.live_now
+ live_now = channel_video.try &.badges.live_now?
live_now ||= false
premiere_timestamp = channel_video.try &.premiere_timestamp
@@ -275,7 +275,7 @@ def fetch_channel(ucid, pull_all_videos : Bool)
ucid: video.ucid,
author: video.author,
length_seconds: video.length_seconds,
- live_now: video.live_now,
+ live_now: video.badges.live_now?,
premiere_timestamp: video.premiere_timestamp,
views: video.views,
})
diff --git a/src/invidious/helpers/serialized_yt_data.cr b/src/invidious/helpers/serialized_yt_data.cr
index c0ca789e..8f57954a 100644
--- a/src/invidious/helpers/serialized_yt_data.cr
+++ b/src/invidious/helpers/serialized_yt_data.cr
@@ -1,3 +1,16 @@
+@[Flags]
+enum VideoBadges
+ LiveNow
+ Premium
+ ThreeD
+ FourK
+ New
+ EightK
+ VR180
+ VR360
+ CCommons
+end
+
struct SearchVideo
include DB::Serializable
@@ -9,17 +22,9 @@ struct SearchVideo
property views : Int64
property description_html : String
property length_seconds : Int32
- property live_now : Bool
- property premium : Bool
property premiere_timestamp : Time?
property author_verified : Bool
- property is_new : Bool
- property is_4k : Bool
- property is_8k : Bool
- property is_vr180 : Bool
- property is_vr360 : Bool
- property is_3d : Bool
- property has_captions : Bool
+ property badges : VideoBadges
def to_xml(auto_generated, query_params, xml : XML::Builder)
query_params["v"] = self.id
@@ -95,20 +100,20 @@ struct SearchVideo
json.field "published", self.published.to_unix
json.field "publishedText", translate(locale, "`x` ago", recode_date(self.published, locale))
json.field "lengthSeconds", self.length_seconds
- json.field "liveNow", self.live_now
- json.field "premium", self.premium
+ json.field "liveNow", self.badges.live_now?
+ json.field "premium", self.badges.premium?
json.field "isUpcoming", self.upcoming?
if self.premiere_timestamp
json.field "premiereTimestamp", self.premiere_timestamp.try &.to_unix
end
- json.field "isNew", self.is_new
- json.field "is4k", self.is_4k
- json.field "is8k", self.is_8k
- json.field "isVR180", is_vr180
- json.field "isVR360", is_vr360
- json.field "is3d", is_3d
- json.field "hasCaptions", self.has_captions
+ json.field "isNew", self.badges.new?
+ json.field "is4k", self.badges.four_k?
+ json.field "is8k", self.badges.eight_k?
+ json.field "isVr180", self.badges.vr180?
+ json.field "isVr360", self.badges.vr360?
+ json.field "is3d", self.badges.three_d?
+ json.field "hasCaptions", self.badges.c_commons?
end
end
diff --git a/src/invidious/routes/feeds.cr b/src/invidious/routes/feeds.cr
index b76aeb46..ea7fb396 100644
--- a/src/invidious/routes/feeds.cr
+++ b/src/invidious/routes/feeds.cr
@@ -192,18 +192,9 @@ module Invidious::Routes::Feeds
views: views,
description_html: description_html,
length_seconds: 0,
- live_now: false,
- paid: false,
- premium: false,
premiere_timestamp: nil,
author_verified: false,
- is_new: false,
- is_4k: false,
- is_8k: false,
- is_vr180: false,
- is_vr360: false,
- is_3d: false,
- has_captions: false,
+ badges: VideoBadges::None,
})
end
diff --git a/src/invidious/yt_backend/extractors.cr b/src/invidious/yt_backend/extractors.cr
index 48c2155b..36f2dc4a 100644
--- a/src/invidious/yt_backend/extractors.cr
+++ b/src/invidious/yt_backend/extractors.cr
@@ -108,42 +108,31 @@ private module Parsers
length_seconds = 0
end
- live_now = false
- premium = false
- is_new = false
- is_4k = false
- is_8k = false
- is_vr180 = false
- is_vr360 = false
- is_3d = false
- has_captions = false
-
premiere_timestamp = item_contents.dig?("upcomingEventData", "startTime").try { |t| Time.unix(t.as_s.to_i64) }
-
+ badges = VideoBadges::None
item_contents["badges"]?.try &.as_a.each do |badge|
b = badge["metadataBadgeRenderer"]
case b["label"].as_s
when "LIVE NOW"
- live_now = true
+ badges |= VideoBadges::LiveNow
when "New"
- is_new = true
+ badges |= VideoBadges::New
when "4K"
- is_4k = true
+ badges |= VideoBadges::FourK
when "8K"
- is_8k = true
+ badges |= VideoBadges::EightK
when "VR180"
- is_vr180 = true
+ badges |= VideoBadges::VR180
when "360°"
- is_vr360 = true
+ badges |= VideoBadges::VR360
when "3D"
- is_3d = true
+ badges |= VideoBadges::ThreeD
when "CC"
- has_captions = true
+ badges |= VideoBadges::CCommons
when "Premium"
# TODO: Potentially available as item_contents["topStandaloneBadge"]["metadataBadgeRenderer"]
- premium = true
- else # Ignore
- puts b["label"].as_s
+ badges |= VideoBadges::Premium
+ else nil # Ignore
end
end
@@ -156,17 +145,9 @@ private module Parsers
views: view_count,
description_html: description_html,
length_seconds: length_seconds,
- live_now: live_now,
- premium: premium,
premiere_timestamp: premiere_timestamp,
author_verified: author_verified,
- is_new: is_new,
- is_4k: is_4k,
- is_8k: is_8k,
- is_vr180: is_vr180,
- is_vr360: is_vr360,
- is_3d: is_3d,
- has_captions: has_captions,
+ badges: badges,
})
end
@@ -590,17 +571,9 @@ private module Parsers
views: view_count,
description_html: "",
length_seconds: duration,
- live_now: false,
- premium: false,
premiere_timestamp: Time.unix(0),
author_verified: false,
- is_new: false,
- is_4k: false,
- is_8k: false,
- is_vr180: false,
- is_vr360: false,
- is_3d: false,
- has_captions: false,
+ badges: VideoBadges::None,
})
end