diff options
author | Samantaz Fox <coding@samantaz.fr> | 2024-04-26 23:30:30 +0200 |
---|---|---|
committer | Samantaz Fox <coding@samantaz.fr> | 2024-04-26 23:30:30 +0200 |
commit | 48ad86457298cfc9f79d3924ad238d89ecbf1140 (patch) | |
tree | 6005e14b8595feb0e013b215f4acd05723049026 | |
parent | bcb679e653aa0183a5c9c69e363e0fb6ccfe0e49 (diff) | |
parent | 5ceeefa2362de32b97ca2d5c8b44e8d87f3e0ba9 (diff) | |
download | invidious-48ad86457298cfc9f79d3924ad238d89ecbf1140.tar.gz invidious-48ad86457298cfc9f79d3924ad238d89ecbf1140.zip |
Videos: Add support for new likes format (#4462)
YouTube added a new format for like data in December 2023.
This PR adds support for parsing saod new format.
Related: LuanRT/YouTube.js issue 557
Closes 4419
-rw-r--r-- | src/invidious/videos/parser.cr | 16 |
1 files changed, 14 insertions, 2 deletions
diff --git a/src/invidious/videos/parser.cr b/src/invidious/videos/parser.cr index 75fe4a36..6fd57462 100644 --- a/src/invidious/videos/parser.cr +++ b/src/invidious/videos/parser.cr @@ -267,7 +267,18 @@ def parse_video_info(video_id : String, player_response : Hash(String, JSON::Any .try &.dig?("videoActions", "menuRenderer", "topLevelButtons") if toplevel_buttons - likes_button = toplevel_buttons.try &.as_a + # New Format as of december 2023 + likes_button = toplevel_buttons.dig?(0, + "segmentedLikeDislikeButtonViewModel", + "likeButtonViewModel", + "likeButtonViewModel", + "toggleButtonViewModel", + "toggleButtonViewModel", + "defaultButtonViewModel", + "buttonViewModel" + ) + + likes_button ||= toplevel_buttons.try &.as_a .find(&.dig?("toggleButtonRenderer", "defaultIcon", "iconType").=== "LIKE") .try &.["toggleButtonRenderer"] @@ -280,9 +291,10 @@ def parse_video_info(video_id : String, player_response : Hash(String, JSON::Any ) if likes_button + likes_txt = likes_button.dig?("accessibilityText") # Note: The like count from `toggledText` is off by one, as it would # represent the new like count in the event where the user clicks on "like". - likes_txt = (likes_button["defaultText"]? || likes_button["toggledText"]?) + likes_txt ||= (likes_button["defaultText"]? || likes_button["toggledText"]?) .try &.dig?("accessibility", "accessibilityData", "label") likes = likes_txt.as_s.gsub(/\D/, "").to_i64? if likes_txt |