diff --git a/src/invidious/comments.cr b/src/invidious/comments.cr
index e2c7b3a0..ae8f052a 100644
--- a/src/invidious/comments.cr
+++ b/src/invidious/comments.cr
@@ -573,10 +573,11 @@ 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)
if url.host == "youtu.be"
- url = "/watch?v=#{url.request_target.lstrip('/')}"
+ url = "youtube.com/watch?v=#{url.request_target.lstrip('/')}"
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
@@ -587,7 +588,12 @@ def content_to_comment_html(content)
end
end
- text = %(#{reduce_uri(url)})
+ 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 = %(#{reduce_uri(displayed_url)})
elsif watch_endpoint = run["navigationEndpoint"]["watchEndpoint"]?
length_seconds = watch_endpoint["startTimeSeconds"]?
video_id = watch_endpoint["videoId"].as_s
@@ -595,7 +601,7 @@ def content_to_comment_html(content)
if length_seconds && length_seconds.as_i > 0
text = %(#{text})
else
- text = %(#{reduce_uri("/watch?v=#{video_id}")})
+ text = %(#{reduce_uri("youtube.com/watch?v=#{video_id}")})
end
elsif url = run.dig?("navigationEndpoint", "commandMetadata", "webCommandMetadata", "url").try &.as_s
text = %(#{reduce_uri(url)})