mirror of
				https://gitea.invidious.io/iv-org/invidious-copy-2023-06-08.git
				synced 2024-08-15 00:53:38 +00:00 
			
		
		
		
	Temporary fix for #2612
Don't rely on the auto compression/decompression provided by the crystal stdlib.
This commit is contained in:
		
							parent
							
								
									4940759627
								
							
						
					
					
						commit
						2eac23a0b3
					
				
					 1 changed files with 18 additions and 12 deletions
				
			
		|  | @ -405,18 +405,9 @@ module YoutubeAPI | |||
| 
 | ||||
|     headers = HTTP::Headers{ | ||||
|       "Content-Type"    => "application/json; charset=UTF-8", | ||||
|       "Accept-Encoding" => "gzip, deflate", | ||||
|     } | ||||
| 
 | ||||
|     # The normal HTTP client automatically applies accept-encoding: gzip, | ||||
|     # and decompresses. However, explicitly applying it will remove this functionality. | ||||
|     # | ||||
|     # https://github.com/crystal-lang/crystal/issues/11252#issuecomment-929594741 | ||||
|     {% unless flag?(:disable_quic) %} | ||||
|       if CONFIG.use_quic | ||||
|         headers["Accept-Encoding"] = "gzip" | ||||
|       end | ||||
|     {% end %} | ||||
| 
 | ||||
|     # Logging | ||||
|     LOGGER.debug("YoutubeAPI: Using endpoint: \"#{endpoint}\"") | ||||
|     LOGGER.trace("YoutubeAPI: ClientConfig: #{client_config}") | ||||
|  | @ -434,8 +425,23 @@ module YoutubeAPI | |||
|       ) | ||||
|     end | ||||
| 
 | ||||
|     # Decompress the body ourselves, given that auto-decompress is | ||||
|     # broken in the Crystal stdlib. | ||||
|     # Read more: | ||||
|     #  - https://github.com/iv-org/invidious/issues/2612 | ||||
|     #  - https://github.com/crystal-lang/crystal/issues/11354 | ||||
|     # | ||||
|     case headers["Content-Encoding"]? | ||||
|     when "gzip" | ||||
|       body = Compress::Gzip::Reader.new(response.body_io, sync_close: true) | ||||
|     when "deflate" | ||||
|       body = Compress::Deflate::Reader.new(response.body_io, sync_close: true) | ||||
|     else | ||||
|       body = response.body | ||||
|     end | ||||
| 
 | ||||
|     # Convert result to Hash | ||||
|     initial_data = JSON.parse(response.body).as_h | ||||
|     initial_data = JSON.parse(body).as_h | ||||
| 
 | ||||
|     # Error handling | ||||
|     if initial_data.has_key?("error") | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue