Skip to content

Commit

Permalink
Compress all responses if compression is enabled
Browse files Browse the repository at this point in the history
  • Loading branch information
zhkvia committed May 2, 2024
1 parent 18c54b0 commit 7a1f322
Show file tree
Hide file tree
Showing 2 changed files with 4 additions and 2 deletions.
5 changes: 3 additions & 2 deletions conn_http.go
Original file line number Diff line number Diff line change
Expand Up @@ -78,6 +78,7 @@ type HTTPReaderWriter struct {
// NewReader will return a reader that will decompress data if needed.
func (rw *HTTPReaderWriter) NewReader(res *http.Response) (io.Reader, error) {
enc := res.Header.Get("Content-Encoding")

if !res.Uncompressed && rw.method.String() == enc {
switch rw.method {
case CompressionGZIP:
Expand Down Expand Up @@ -424,14 +425,14 @@ func (h *httpConnect) readRawResponse(response *http.Response) (body []byte, err
if err != nil {
return nil, err
}
if response.StatusCode == http.StatusOK && (h.compression == CompressionLZ4 || h.compression == CompressionZSTD) {
if h.compression == CompressionLZ4 || h.compression == CompressionZSTD {
chReader := chproto.NewReader(reader)
chReader.EnableCompression()
reader = chReader
}

body, err = io.ReadAll(reader)
if err != nil {
if err != nil && !errors.Is(err, io.EOF) {
return nil, err
}
return body, nil
Expand Down
1 change: 1 addition & 0 deletions conn_http_batch.go
Original file line number Diff line number Diff line change
Expand Up @@ -199,6 +199,7 @@ func (b *httpBatch) Send() (err error) {
headers["Content-Encoding"] = b.conn.compression.String()
case CompressionZSTD, CompressionLZ4:
options.settings["decompress"] = "1"
options.settings["compress"] = "1"
}

go func() {
Expand Down

0 comments on commit 7a1f322

Please sign in to comment.