mirror of
				https://gitea.invidious.io/iv-org/invidious-copy-2023-06-08.git
				synced 2024-08-15 00:53:38 +00:00 
			
		
		
		
	Allow ggpht queries with QUIC disabled
This commit is contained in:
		
							parent
							
								
									245122104a
								
							
						
					
					
						commit
						c3747c2d49
					
				
					 1 changed files with 45 additions and 15 deletions
				
			
		|  | @ -3,31 +3,61 @@ module Invidious::Routes::Images | ||||||
|   def self.ggpht(env) |   def self.ggpht(env) | ||||||
|     url = env.request.path.lchop("/ggpht") |     url = env.request.path.lchop("/ggpht") | ||||||
| 
 | 
 | ||||||
|     headers = HTTP::Headers{":authority" => "yt3.ggpht.com"} |     headers = ( | ||||||
|  |       {% unless flag?(:disable_quic) %} | ||||||
|  |         if CONFIG.use_quic | ||||||
|  |           HTTP::Headers{":authority" => "yt3.ggpht.com"} | ||||||
|  |         else | ||||||
|  |           HTTP::Headers.new | ||||||
|  |         end | ||||||
|  |       {% else %} | ||||||
|  |         HTTP::Headers.new | ||||||
|  |       {% end %} | ||||||
|  |     ) | ||||||
|  | 
 | ||||||
|     REQUEST_HEADERS_WHITELIST.each do |header| |     REQUEST_HEADERS_WHITELIST.each do |header| | ||||||
|       if env.request.headers[header]? |       if env.request.headers[header]? | ||||||
|         headers[header] = env.request.headers[header] |         headers[header] = env.request.headers[header] | ||||||
|       end |       end | ||||||
|     end |     end | ||||||
| 
 | 
 | ||||||
|  |     # We're encapsulating this into a proc in order to easily reuse this | ||||||
|  |     # portion of the code for each request block below. | ||||||
|  |     request_proc = ->(response : HTTP::Client::Response) { | ||||||
|  |       env.response.status_code = response.status_code | ||||||
|  |       response.headers.each do |key, value| | ||||||
|  |         if !RESPONSE_HEADERS_BLACKLIST.includes?(key.downcase) | ||||||
|  |           env.response.headers[key] = value | ||||||
|  |         end | ||||||
|  |       end | ||||||
|  | 
 | ||||||
|  |       env.response.headers["Access-Control-Allow-Origin"] = "*" | ||||||
|  | 
 | ||||||
|  |       if response.status_code >= 300 | ||||||
|  |         env.response.headers.delete("Transfer-Encoding") | ||||||
|  |         return | ||||||
|  |       end | ||||||
|  | 
 | ||||||
|  |       proxy_file(response, env) | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|     begin |     begin | ||||||
|       YT_POOL.client &.get(url, headers) do |response| |       {% unless flag?(:disable_quic) %} | ||||||
|         env.response.status_code = response.status_code |         if CONFIG.use_quic | ||||||
|         response.headers.each do |key, value| |           YT_POOL.client &.get(url, headers) do |resp| | ||||||
|           if !RESPONSE_HEADERS_BLACKLIST.includes?(key.downcase) |             return request_proc.call(resp) | ||||||
|             env.response.headers[key] = value |           end | ||||||
|  |         else | ||||||
|  |           HTTP::Client.get("yt3.ggpht.com#{url}") do |resp| | ||||||
|  |             return request_proc.call(resp) | ||||||
|           end |           end | ||||||
|         end |         end | ||||||
| 
 |       {% else %} | ||||||
|         env.response.headers["Access-Control-Allow-Origin"] = "*" |         # This can likely be optimized into a (small) pool sometime in the future. | ||||||
| 
 |         HTTP::Client.get("yt3.ggpht.com#{url}") do |resp| | ||||||
|         if response.status_code >= 300 |           return request_proc.call(resp) | ||||||
|           env.response.headers.delete("Transfer-Encoding") |  | ||||||
|           break |  | ||||||
|         end |         end | ||||||
| 
 |       {% end %} | ||||||
|         proxy_file(response, env) |  | ||||||
|       end |  | ||||||
|     rescue ex |     rescue ex | ||||||
|     end |     end | ||||||
|   end |   end | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue