mirror of
				https://github.com/iv-org/invidious.git
				synced 2025-10-26 02:38:30 -05:00 
			
		
		
		
	Add option to disable force_resolve in make_client
Some websites such as archive.org and textcaptcha.com does not support IPv6 and as such requests fail when Invidious requests with IPv6 to those services.
This commit is contained in:
		
							parent
							
								
									9e8baa3539
								
							
						
					
					
						commit
						2fea6a8499
					
				| @ -2,7 +2,7 @@ module Invidious::Comments | |||||||
|   extend self |   extend self | ||||||
| 
 | 
 | ||||||
|   def fetch_reddit(id, sort_by = "confidence") |   def fetch_reddit(id, sort_by = "confidence") | ||||||
|     client = make_client(REDDIT_URL) |     client = make_client(REDDIT_URL, force_resolve: false) | ||||||
|     headers = HTTP::Headers{"User-Agent" => "web:invidious:v#{CURRENT_VERSION} (by github.com/iv-org/invidious)"} |     headers = HTTP::Headers{"User-Agent" => "web:invidious:v#{CURRENT_VERSION} (by github.com/iv-org/invidious)"} | ||||||
| 
 | 
 | ||||||
|     # TODO: Use something like #479 for a static list of instances to use here |     # TODO: Use something like #479 for a static list of instances to use here | ||||||
|  | |||||||
| @ -302,7 +302,7 @@ def subscribe_pubsub(topic, key) | |||||||
|     "hub.secret"        => key.to_s, |     "hub.secret"        => key.to_s, | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
|   return make_client(PUBSUB_URL, &.post("/subscribe", form: body)) |   return make_client(PUBSUB_URL, force_resolve: false, &.post("/subscribe", form: body)) | ||||||
| end | end | ||||||
| 
 | 
 | ||||||
| def parse_range(range) | def parse_range(range) | ||||||
|  | |||||||
| @ -256,13 +256,13 @@ module Invidious::Routes::API::V1::Videos | |||||||
| 
 | 
 | ||||||
|         file = URI.encode_www_form("#{id[0, 3]}/#{id}.xml") |         file = URI.encode_www_form("#{id[0, 3]}/#{id}.xml") | ||||||
| 
 | 
 | ||||||
|         location = make_client(ARCHIVE_URL, &.get("/download/youtubeannotations_#{index}/#{id[0, 2]}.tar/#{file}")) |         location = make_client(ARCHIVE_URL, force_resolve: false, &.get("/download/youtubeannotations_#{index}/#{id[0, 2]}.tar/#{file}")) | ||||||
| 
 | 
 | ||||||
|         if !location.headers["Location"]? |         if !location.headers["Location"]? | ||||||
|           env.response.status_code = location.status_code |           env.response.status_code = location.status_code | ||||||
|         end |         end | ||||||
| 
 | 
 | ||||||
|         response = make_client(URI.parse(location.headers["Location"]), &.get(location.headers["Location"])) |         response = make_client(URI.parse(location.headers["Location"]), force_resolve: false, &.get(location.headers["Location"])) | ||||||
| 
 | 
 | ||||||
|         if response.body.empty? |         if response.body.empty? | ||||||
|           haltf env, 404 |           haltf env, 404 | ||||||
|  | |||||||
| @ -62,7 +62,7 @@ struct Invidious::User | |||||||
|     end |     end | ||||||
| 
 | 
 | ||||||
|     def generate_text(key) |     def generate_text(key) | ||||||
|       response = make_client(TEXTCAPTCHA_URL, &.get("/github.com/iv.org/invidious.json").body) |       response = make_client(TEXTCAPTCHA_URL, force_resolve: false, &.get("/github.com/iv.org/invidious.json").body) | ||||||
|       response = JSON.parse(response) |       response = JSON.parse(response) | ||||||
| 
 | 
 | ||||||
|       tokens = response["a"].as_a.map do |answer| |       tokens = response["a"].as_a.map do |answer| | ||||||
|  | |||||||
| @ -59,9 +59,14 @@ struct YoutubeConnectionPool | |||||||
|   end |   end | ||||||
| end | end | ||||||
| 
 | 
 | ||||||
| def make_client(url : URI, region = nil) | def make_client(url : URI, region = nil, force_resolve : Bool = true) | ||||||
|   client = HTTPClient.new(url, OpenSSL::SSL::Context::Client.insecure) |   client = HTTPClient.new(url, OpenSSL::SSL::Context::Client.insecure) | ||||||
|   client.family = CONFIG.force_resolve | 
 | ||||||
|  |   # Some services do not support IPv6. | ||||||
|  |   if force_resolve | ||||||
|  |     client.family = CONFIG.force_resolve | ||||||
|  |   end | ||||||
|  | 
 | ||||||
|   client.before_request { |r| add_yt_headers(r) } if url.host == "www.youtube.com" |   client.before_request { |r| add_yt_headers(r) } if url.host == "www.youtube.com" | ||||||
|   client.read_timeout = 10.seconds |   client.read_timeout = 10.seconds | ||||||
|   client.connect_timeout = 10.seconds |   client.connect_timeout = 10.seconds | ||||||
| @ -80,8 +85,8 @@ def make_client(url : URI, region = nil) | |||||||
|   return client |   return client | ||||||
| end | end | ||||||
| 
 | 
 | ||||||
| def make_client(url : URI, region = nil, &block) | def make_client(url : URI, region = nil, force_resolve : Bool = true, &block) | ||||||
|   client = make_client(url, region) |   client = make_client(url, region, force_resolve) | ||||||
|   begin |   begin | ||||||
|     yield client |     yield client | ||||||
|   ensure |   ensure | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user