Refactor geo-bypass

pull/697/head
Omar Roth 5 years ago
parent cad284519f
commit 900d8790b3
No known key found for this signature in database
GPG Key ID: B8254FB7EC3D37F2

@ -1132,35 +1132,20 @@ def fetch_video(id, region)
info = extract_player_config(response.body, html) info = extract_player_config(response.body, html)
info["cookie"] = response.cookies.to_h.map { |name, cookie| "#{name}=#{cookie.value}" }.join("; ") info["cookie"] = response.cookies.to_h.map { |name, cookie| "#{name}=#{cookie.value}" }.join("; ")
# Try to use proxies for region-blocked videos allowed_regions = html.xpath_node(%q(//meta[@itemprop="regionsAllowed"])).try &.["content"].split(",")
if info["reason"]? && info["reason"].includes? "your country" allowed_regions ||= [] of String
bypass_channel = Channel({XML::Node, HTTP::Params} | Nil).new
PROXY_LIST.each do |proxy_region, list|
spawn do
client = make_client(YT_URL, proxy_region)
proxy_response = client.get("/watch?v=#{id}&gl=US&hl=en&disable_polymer=1&has_verified=1&bpctr=9999999999")
proxy_html = XML.parse_html(proxy_response.body) # Check for region-blocks
proxy_info = extract_player_config(proxy_response.body, proxy_html) if info["reason"]? && info["reason"].includes? "your country"
region = allowed_regions.sample(1)[0]?
client = make_client(YT_URL, region)
response = client.get("/watch?v=#{id}&gl=US&hl=en&disable_polymer=1&has_verified=1&bpctr=9999999999")
if !proxy_info["reason"]? html = XML.parse_html(response.body)
proxy_info["region"] = proxy_region info = extract_player_config(response.body, html)
proxy_info["cookie"] = proxy_response.cookies.to_h.map { |name, cookie| "#{name}=#{cookie.value}" }.join("; ")
bypass_channel.send({proxy_html, proxy_info})
else
bypass_channel.send(nil)
end
end
end
PROXY_LIST.size.times do info["region"] = region if region
response = bypass_channel.receive info["cookie"] = response.cookies.to_h.map { |name, cookie| "#{name}=#{cookie.value}" }.join("; ")
if response
html, info = response
break
end
end
end end
# Try to pull streams from embed URL # Try to pull streams from embed URL
@ -1215,9 +1200,6 @@ def fetch_video(id, region)
published ||= Time.utc.to_s("%Y-%m-%d") published ||= Time.utc.to_s("%Y-%m-%d")
published = Time.parse(published, "%Y-%m-%d", Time::Location.local) published = Time.parse(published, "%Y-%m-%d", Time::Location.local)
allowed_regions = html.xpath_node(%q(//meta[@itemprop="regionsAllowed"])).try &.["content"].split(",")
allowed_regions ||= [] of String
is_family_friendly = html.xpath_node(%q(//meta[@itemprop="isFamilyFriendly"])).try &.["content"] == "True" is_family_friendly = html.xpath_node(%q(//meta[@itemprop="isFamilyFriendly"])).try &.["content"] == "True"
is_family_friendly ||= true is_family_friendly ||= true

Loading…
Cancel
Save