From b91946261044d5c941da253aa983a6ad42cdd376 Mon Sep 17 00:00:00 2001 From: "A. Elleuch" Date: Wed, 18 Oct 2017 22:42:10 +0100 Subject: [PATCH] fix: Avoid teeing data into a null cache buffer (#5070) In some cases, Cache manager returns ErrCacheFull error when creating a new cache buffer but the code still sends object data to nil cache buffer data. --- cmd/xl-v1-object.go | 13 ++++++++----- 1 file changed, 8 insertions(+), 5 deletions(-) diff --git a/cmd/xl-v1-object.go b/cmd/xl-v1-object.go index 1408a4fa1..266c9b604 100644 --- a/cmd/xl-v1-object.go +++ b/cmd/xl-v1-object.go @@ -476,12 +476,15 @@ func (xl xlObjects) PutObject(bucket string, object string, data *HashReader, me // Create a new entry in memory of size. newBuffer, err = xl.objCache.Create(path.Join(bucket, object), data.Size()) - // Ignore error if cache is full, proceed to write the object. - if err != nil && err != objcache.ErrCacheFull { - // For any other error return here. - return ObjectInfo{}, toObjectErr(traceError(err), bucket, object) + if err == nil { + // Cache incoming data into a buffer + reader = io.TeeReader(data, newBuffer) + } else { + // Return errors other than ErrCacheFull + if err != objcache.ErrCacheFull { + return ObjectInfo{}, toObjectErr(traceError(err), bucket, object) + } } - reader = io.TeeReader(data, newBuffer) } // Initialize parts metadata