From 54cfbf84c67bb2358b8b0162565ecb35f5b46c50 Mon Sep 17 00:00:00 2001 From: evazion Date: Thu, 31 Mar 2022 02:17:51 -0500 Subject: [PATCH] pawoo: fix www.pawoo.net urls not being normalized to pawoo.net. Fix artist URLs like https://www.pawoo.net/@01051708 not being normalized to https://pawoo.net/@01051708. --- app/logical/source/url/mastodon.rb | 26 +++++++++++++------------- test/unit/artist_url_test.rb | 4 ++-- 2 files changed, 15 insertions(+), 15 deletions(-) diff --git a/app/logical/source/url/mastodon.rb b/app/logical/source/url/mastodon.rb index 78b39ff5d..1a4a7be12 100644 --- a/app/logical/source/url/mastodon.rb +++ b/app/logical/source/url/mastodon.rb @@ -13,40 +13,40 @@ class Source::URL::Mastodon < Source::URL end def parse - case [host, *path_segments] + case [subdomain, domain, *path_segments] # https://pawoo.net/@evazion/19451018 # https://baraag.net/@curator/102270656480174153 - in _, /^@/ => username, /^\d+$/ => work_id, *rest + in _, _, /^@/ => username, /^\d+$/ => work_id, *rest @username = username.delete_prefix("@") @work_id = work_id # https://pawoo.net/@evazion # https://baraag.net/@danbooru # https://baraag.net/@quietvice/media - in _, /^@/ => username, *rest + in _, _, /^@/ => username, *rest @username = username.delete_prefix("@") # https://pawoo.net/users/esoraneko # https://pawoo.net/users/khurata/media - in _, "users", username, *rest + in _, _, "users", username, *rest @username = username # https://pawoo.net/web/statuses/19451018 # https://pawoo.net/web/statuses/19451018/favorites # https://baraag.net/web/statuses/102270656480174153 - in _, "web", "statuses", work_id, *rest + in _, _, "web", "statuses", work_id, *rest @work_id = work_id # https://pawoo.net/web/accounts/47806 # https://baraag.net/web/accounts/107862785324786980 - in _, "web", "accounts", user_id + in _, _, "web", "accounts", user_id @user_id = user_id # Page: https://pawoo.net/@evazion/19451018 # https://img.pawoo.net/media_attachments/files/001/297/997/small/c4272a09570757c2.png # https://img.pawoo.net/media_attachments/files/001/297/997/original/c4272a09570757c2.png - in "img.pawoo.net", "media_attachments", "files", *subdirs, file_size, file + in "img", "pawoo.net", "media_attachments", "files", *subdirs, file_size, file @file_size = file_size @full_image_url = "#{site}/media_attachments/files/#{subdirs.join("/")}/original/#{file}" @@ -54,12 +54,12 @@ class Source::URL::Mastodon < Source::URL # https://baraag.net/system/media_attachments/files/107/866/084/749/942/932/original/a9e0f553e332f303.mp4 # https://baraag.net/system/media_attachments/files/107/866/084/754/127/256/original/3895a14ce3736f13.mp4 # https://baraag.net/system/media_attachments/files/107/866/084/754/651/925/original/8f3df857681a1639.png - in "baraag.net", "system", "media_attachments", "files", *subdirs, file_size, file + in _, "baraag.net", "system", "media_attachments", "files", *subdirs, file_size, file @file_size = file_size @full_image_url = "#{site}/system/media_attachments/files/#{subdirs.join("/")}/original/#{file}" # https://pawoo.net/media/lU2uV7C1MMQSb1czwvg - in "pawoo.net", "media", media_hash + in _, "pawoo.net", "media", media_hash @media_hash = media_hash else @@ -79,17 +79,17 @@ class Source::URL::Mastodon < Source::URL def page_url if username.present? && work_id.present? - "https://#{host}/@#{username}/#{work_id}" + "https://#{domain}/@#{username}/#{work_id}" elsif work_id.present? - "https://#{host}/web/statuses/#{work_id}" + "https://#{domain}/web/statuses/#{work_id}" end end def profile_url if username.present? - "https://#{host}/@#{username}" + "https://#{domain}/@#{username}" elsif user_id.present? - "https://#{host}/web/accounts/#{user_id}" + "https://#{domain}/web/accounts/#{user_id}" end end end diff --git a/test/unit/artist_url_test.rb b/test/unit/artist_url_test.rb index 085c2b10a..1eeb10ed3 100644 --- a/test/unit/artist_url_test.rb +++ b/test/unit/artist_url_test.rb @@ -179,11 +179,11 @@ class ArtistURLTest < ActiveSupport::TestCase end should "normalize pawoo.net urls" do - url = create(:artist_url, url: "http://pawoo.net/@evazion/19451018") + url = create(:artist_url, url: "http://www.pawoo.net/@evazion/19451018") assert_equal("https://pawoo.net/@evazion", url.url) assert_equal("http://pawoo.net/@evazion/", url.normalized_url) - url = create(:artist_url, url: "http://pawoo.net/users/evazion/media") + url = create(:artist_url, url: "http://www.pawoo.net/users/evazion/media") assert_equal("https://pawoo.net/@evazion", url.url) assert_equal("http://pawoo.net/@evazion/", url.normalized_url) end