summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorSamantaz Fox <coding@samantaz.fr>2021-11-28 02:35:39 +0100
committerGitHub <noreply@github.com>2021-11-28 02:35:39 +0100
commit05f9613e14c6faaca4fb51c9c21d5ec5ae603d64 (patch)
treec1cbde7d58cb0fa5bab417f383d92e82f50a2db3
parent50bb5918264ed5565fe40d9183823d92aa593f5f (diff)
parentba48f68fc30990437331791848efe896559f49cd (diff)
downloadinvidious-05f9613e14c6faaca4fb51c9c21d5ec5ae603d64.tar.gz
invidious-05f9613e14c6faaca4fb51c9c21d5ec5ae603d64.tar.bz2
invidious-05f9613e14c6faaca4fb51c9c21d5ec5ae603d64.zip
Merge pull request #2623 from SamantazFox/temp-decompression-fix
Temporarily fix for #2612
-rw-r--r--src/invidious/yt_backend/youtube_api.cr45
1 files changed, 33 insertions, 12 deletions
diff --git a/src/invidious/yt_backend/youtube_api.cr b/src/invidious/yt_backend/youtube_api.cr
index 27f25036..977aea04 100644
--- a/src/invidious/yt_backend/youtube_api.cr
+++ b/src/invidious/yt_backend/youtube_api.cr
@@ -404,19 +404,10 @@ module YoutubeAPI
url = "#{endpoint}?key=#{client_config.api_key}"
headers = HTTP::Headers{
- "Content-Type" => "application/json; charset=UTF-8",
+ "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,38 @@ module YoutubeAPI
)
end
+ if {{ !flag?(:disable_quic) }} && CONFIG.use_quic
+ body = response.body
+ else
+ # Decompress the body ourselves, when using HTTP::Client 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
+ #
+ if encodings = response.headers["Content-Encoding"]?
+ io = response.body_io
+
+ # Multiple encodings can be combined, and are listed in the order
+ # in which they were applied. E.g: "deflate, gzip" means that the
+ # content must be first "gunzipped", then "defated".
+ encodings.split(',').reverse.each do |enc|
+ case enc.strip(' ')
+ when "gzip"
+ io = Compress::Gzip::Reader.new(io, sync_close: true)
+ when "deflate"
+ io = Compress::Deflate::Reader.new(io, sync_close: true)
+ end
+ end
+
+ body = io.gets_to_end
+ else
+ body = response.body
+ end
+ 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")