From 0e9bd809c4a4c096b9ffab43124ba827354256df Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?J=C3=B6rn=20Friedrich=20Dreyer?= Date: Tue, 13 Jul 2021 05:37:41 +0200 Subject: [PATCH] Do not send body on failed range request (#1884) MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Signed-off-by: Jörn Friedrich Dreyer --- changelog/unreleased/no-body-on-failed-range.md | 5 +++++ pkg/rhttp/datatx/utils/download/download.go | 3 ++- 2 files changed, 7 insertions(+), 1 deletion(-) create mode 100644 changelog/unreleased/no-body-on-failed-range.md diff --git a/changelog/unreleased/no-body-on-failed-range.md b/changelog/unreleased/no-body-on-failed-range.md new file mode 100644 index 0000000000..7beee7b047 --- /dev/null +++ b/changelog/unreleased/no-body-on-failed-range.md @@ -0,0 +1,5 @@ +Bugfix: Do not send body on failed range request + +Instead of send the error in the body of a 416 response we log it. This prevents the go reverse proxy from choking on it and turning it into a 502 Bad Gateway response. + +https://github.com/cs3org/reva/pull/1884 \ No newline at end of file diff --git a/pkg/rhttp/datatx/utils/download/download.go b/pkg/rhttp/datatx/utils/download/download.go index 8cab207bff..84879b83eb 100644 --- a/pkg/rhttp/datatx/utils/download/download.go +++ b/pkg/rhttp/datatx/utils/download/download.go @@ -68,8 +68,9 @@ func GetOrHeadFile(w http.ResponseWriter, r *http.Request, fs storage.FS) { if err == ErrNoOverlap { w.Header().Set("Content-Range", fmt.Sprintf("bytes */%d", md.Size)) } + sublog.Error().Err(err).Interface("md", md).Interface("ranges", ranges).Msg("range request not satisfiable") w.WriteHeader(http.StatusRequestedRangeNotSatisfiable) - fmt.Fprintln(w, err) + return } if SumRangesSize(ranges) > int64(md.Size) {