diff options
| author | Lukas <lukas.schwarz@posteo.de> | 2020-12-06 21:47:50 +0100 |
|---|---|---|
| committer | Lukas <lukas.schwarz@posteo.de> | 2020-12-06 21:47:50 +0100 |
| commit | 62e8c091831ce2d2db7e928dd25cb55330d72323 (patch) | |
| tree | b4f606e7dd7c5009b578737d3f016ef878454eff /src | |
| parent | cb40a74aafb5e2df3899475a4046a1ccd002e5a4 (diff) | |
| download | invidious-62e8c091831ce2d2db7e928dd25cb55330d72323.tar.gz invidious-62e8c091831ce2d2db7e928dd25cb55330d72323.tar.bz2 invidious-62e8c091831ce2d2db7e928dd25cb55330d72323.zip | |
Fix YouTube subscription import parser
Diffstat (limited to 'src')
| -rw-r--r-- | src/invidious.cr | 7 |
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! |
