summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorLukas <lukas.schwarz@posteo.de>2020-12-06 21:47:50 +0100
committerLukas <lukas.schwarz@posteo.de>2020-12-06 21:47:50 +0100
commit62e8c091831ce2d2db7e928dd25cb55330d72323 (patch)
treeb4f606e7dd7c5009b578737d3f016ef878454eff
parentcb40a74aafb5e2df3899475a4046a1ccd002e5a4 (diff)
downloadinvidious-62e8c091831ce2d2db7e928dd25cb55330d72323.tar.gz
invidious-62e8c091831ce2d2db7e928dd25cb55330d72323.tar.bz2
invidious-62e8c091831ce2d2db7e928dd25cb55330d72323.zip
Fix YouTube subscription import parser
-rw-r--r--src/invidious.cr7
1 files changed, 4 insertions, 3 deletions
diff --git a/src/invidious.cr b/src/invidious.cr
index 1b59025c..c4ca9c08 100644
--- a/src/invidious.cr
+++ b/src/invidious.cr
@@ -1492,9 +1492,10 @@ post "/data_control" do |env|
end
end
when "import_youtube"
- subscriptions = XML.parse(body)
- user.subscriptions += subscriptions.xpath_nodes(%q(//outline[@type="rss"])).map do |channel|
- channel["xmlUrl"].match(/UC[a-zA-Z0-9_-]{22}/).not_nil![0]
+ subscriptions = JSON.parse(body)
+
+ user.subscriptions += subscriptions.as_a.compact_map do |entry|
+ entry["snippet"]["resourceId"]["channelId"].as_s
end
user.subscriptions.uniq!