summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorFéry Mathieu (Mathius) <ferymathieuy@gmail.com>2022-02-26 17:53:39 +0100
committerFéry Mathieu (Mathius) <ferymathieuy@gmail.com>2022-02-26 17:53:39 +0100
commit19805b91d90cc6e8648a213d0b46636392484f38 (patch)
treea01b0510c33468a9e88a35cbe6e2aae4f26efc17
parent420c458b6adab8a6e35a7612c9eb6a0ba2382440 (diff)
downloadinvidious-19805b91d90cc6e8648a213d0b46636392484f38.tar.gz
invidious-19805b91d90cc6e8648a213d0b46636392484f38.tar.bz2
invidious-19805b91d90cc6e8648a213d0b46636392484f38.zip
Patch links related to youtube.com
Related to followings comments : - https://github.com/iv-org/invidious/pull/2936#discussion_r815253405
-rw-r--r--src/invidious/comments.cr12
1 files changed, 5 insertions, 7 deletions
diff --git a/src/invidious/comments.cr b/src/invidious/comments.cr
index ae8f052a..1fd3dcfd 100644
--- a/src/invidious/comments.cr
+++ b/src/invidious/comments.cr
@@ -573,26 +573,24 @@ def content_to_comment_html(content)
if run["navigationEndpoint"]?
if url = run["navigationEndpoint"]["urlEndpoint"]?.try &.["url"].as_s
- base_url = URI.parse(url)
url = URI.parse(url)
+ displayed_url = url
if url.host == "youtu.be"
- url = "youtube.com/watch?v=#{url.request_target.lstrip('/')}"
+ url = "/watch?v=#{url.request_target.lstrip('/')}"
+ displayed_url = "youtube.com#{url}"
elsif url.host.nil? || url.host.not_nil!.ends_with?("youtube.com")
if url.path == "/redirect"
# Sometimes, links can be corrupted (why?) so make sure to fallback
# nicely. See https://github.com/iv-org/invidious/issues/2682
url = HTTP::Params.parse(url.query.not_nil!)["q"]? || ""
+ displayed_url = url
else
url = url.request_target
+ displayed_url = "youtube.com#{url}"
end
end
- if base_url.host.not_nil!.ends_with?("youtube.com") && base_url.path != "/redirect"
- displayed_url = "youtube.com#{base_url.request_target}"
- else
- displayed_url = url
- end
text = %(<a href="#{url}">#{reduce_uri(displayed_url)}</a>)
elsif watch_endpoint = run["navigationEndpoint"]["watchEndpoint"]?
length_seconds = watch_endpoint["startTimeSeconds"]?