From be19d6a4037c0e796b9499836fc3c77ab0fe663a Mon Sep 17 00:00:00 2001 From: Nathan Collins Date: Mon, 14 Dec 2020 14:10:11 -0500 Subject: [PATCH] fshttp: prevent overlap of HTTP headers in logs --- fs/fshttp/http.go | 5 +++++ 1 file changed, 5 insertions(+) diff --git a/fs/fshttp/http.go b/fs/fshttp/http.go index 1debb2a74..11ed0da4b 100644 --- a/fs/fshttp/http.go +++ b/fs/fshttp/http.go @@ -31,6 +31,7 @@ var ( noTransport = new(sync.Once) tpsBucket *rate.Limiter // for limiting number of http transactions per second cookieJar, _ = cookiejar.New(&cookiejar.Options{PublicSuffixList: publicsuffix.List}) + logMutex sync.Mutex ) // StartHTTPTokenBucket starts the token bucket if necessary @@ -331,15 +332,18 @@ func (t *Transport) RoundTrip(req *http.Request) (resp *http.Response, err error if t.dump&fs.DumpAuth == 0 { buf = cleanAuths(buf) } + logMutex.Lock() fs.Debugf(nil, "%s", separatorReq) fs.Debugf(nil, "%s (req %p)", "HTTP REQUEST", req) fs.Debugf(nil, "%s", string(buf)) fs.Debugf(nil, "%s", separatorReq) + logMutex.Unlock() } // Do round trip resp, err = t.Transport.RoundTrip(req) // Logf response if t.dump&(fs.DumpHeaders|fs.DumpBodies|fs.DumpAuth|fs.DumpRequests|fs.DumpResponses) != 0 { + logMutex.Lock() fs.Debugf(nil, "%s", separatorResp) fs.Debugf(nil, "%s (req %p)", "HTTP RESPONSE", req) if err != nil { @@ -349,6 +353,7 @@ func (t *Transport) RoundTrip(req *http.Request) (resp *http.Response, err error fs.Debugf(nil, "%s", string(buf)) } fs.Debugf(nil, "%s", separatorResp) + logMutex.Unlock() } if err == nil { checkServerTime(req, resp)