forked from midou/invidious
Add local alternatives for video links
This commit is contained in:
parent
e9f214cdc0
commit
ebe51c91d7
@ -290,6 +290,9 @@ def template_comments(root)
|
|||||||
score = child["data"]["score"]
|
score = child["data"]["score"]
|
||||||
body_html = HTML.unescape(child["data"]["body_html"].as_s)
|
body_html = HTML.unescape(child["data"]["body_html"].as_s)
|
||||||
|
|
||||||
|
# Replace local links wtih links back to Reddit
|
||||||
|
body_html = fill_links(body_html, "https", "www.reddit.com")
|
||||||
|
|
||||||
replies_html = ""
|
replies_html = ""
|
||||||
if child["data"]["replies"] != ""
|
if child["data"]["replies"] != ""
|
||||||
replies_html = template_comments(child["data"]["replies"]["data"]["children"])
|
replies_html = template_comments(child["data"]["replies"]["data"]["children"])
|
||||||
@ -341,3 +344,48 @@ def arg_array(array)
|
|||||||
|
|
||||||
return args
|
return args
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def add_alt_links(html)
|
||||||
|
alt_links = [] of {Int32, String}
|
||||||
|
|
||||||
|
# This is painful but is likely the only way to accomplish this in Crystal,
|
||||||
|
# as Crystigiri and others are not able to insert XML Nodes into a document.
|
||||||
|
# The goal here is to use as little regex as possible
|
||||||
|
html.scan(/<a[^>]*>([^<]+)<\/a>/) do |match|
|
||||||
|
anchor = XML.parse_html(match[0])
|
||||||
|
anchor = anchor.xpath_node("//a").not_nil!
|
||||||
|
url = URI.parse(HTML.unescape(anchor["href"]))
|
||||||
|
|
||||||
|
if ["www.youtube.com", "youtu.be", "m.youtube.com"].includes?(url.host) && url.path == "/watch"
|
||||||
|
alt_link = <<-END_HTML
|
||||||
|
<a class="link" href="#{url.full_path}">
|
||||||
|
<i class="fa fa-link" aria-hidden="true"></i>
|
||||||
|
</a>
|
||||||
|
END_HTML
|
||||||
|
|
||||||
|
alt_links << {match.end.not_nil!, alt_link}
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
alt_links.reverse!
|
||||||
|
alt_links.each do |position, alt_link|
|
||||||
|
html = html.insert(position, alt_link)
|
||||||
|
end
|
||||||
|
|
||||||
|
return html
|
||||||
|
end
|
||||||
|
|
||||||
|
def fill_links(html, scheme, host)
|
||||||
|
html = XML.parse_html(html)
|
||||||
|
|
||||||
|
html.xpath_nodes("//a").each do |match|
|
||||||
|
url = URI.parse(match["href"])
|
||||||
|
if !url.host # If reddit link
|
||||||
|
url.scheme = scheme
|
||||||
|
url.host = host
|
||||||
|
match["href"] = url
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
html = html.to_xml
|
||||||
|
end
|
||||||
|
@ -218,11 +218,17 @@ get "/watch" do |env|
|
|||||||
headers = HTTP::Headers{"User-Agent" => "web:invidio.us:v0.1.0 (by /u/omarroth)"}
|
headers = HTTP::Headers{"User-Agent" => "web:invidio.us:v0.1.0 (by /u/omarroth)"}
|
||||||
begin
|
begin
|
||||||
reddit_comments, reddit_thread = get_reddit_comments(id, reddit_client, headers)
|
reddit_comments, reddit_thread = get_reddit_comments(id, reddit_client, headers)
|
||||||
|
reddit_html = template_comments(reddit_comments)
|
||||||
|
|
||||||
|
reddit_html = add_alt_links(reddit_html)
|
||||||
rescue ex
|
rescue ex
|
||||||
reddit_comments = JSON.parse("[]")
|
|
||||||
reddit_thread = nil
|
reddit_thread = nil
|
||||||
|
reddit_html = ""
|
||||||
end
|
end
|
||||||
|
|
||||||
|
video.description = fill_links(video.description, "https", "www.youtube.com")
|
||||||
|
video.description = add_alt_links(video.description)
|
||||||
|
|
||||||
templated "watch"
|
templated "watch"
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -105,13 +105,13 @@ function toggle(target) {
|
|||||||
<%= video.description %>
|
<%= video.description %>
|
||||||
</div>
|
</div>
|
||||||
<hr style="margin-right:1em;">
|
<hr style="margin-right:1em;">
|
||||||
<% if reddit_thread && !reddit_comments.as_a.empty? %>
|
<% if reddit_thread && !reddit_html.empty? %>
|
||||||
<div style="margin-right:1em; overflow-wrap:break-word; word-wrap:break-word;">
|
<div style="margin-right:1em; overflow-wrap:break-word; word-wrap:break-word;">
|
||||||
<h3><%= reddit_thread.data.title %></h3>
|
<h3><%= reddit_thread.data.title %></h3>
|
||||||
<b>
|
<b>
|
||||||
<a target="_blank" class="link" href="https://reddit.com<%= reddit_thread.data.permalink %>">View comments on Reddit</a>
|
<a target="_blank" class="link" href="https://reddit.com<%= reddit_thread.data.permalink %>">View comments on Reddit</a>
|
||||||
</b>
|
</b>
|
||||||
<%= template_comments(reddit_comments) %>
|
<%= reddit_html %>
|
||||||
</div>
|
</div>
|
||||||
<% end %>
|
<% end %>
|
||||||
</div>
|
</div>
|
||||||
|
Loading…
Reference in New Issue
Block a user