api: Multi object delete should be protected. (#3814)

Add missing protection from deleting multiple objects
in parallel. Currently we are deleting objects without
proper locking through this API.

This can cause significant amount of races.
This commit is contained in:
Harshavardhana 2017-02-28 18:00:24 -08:00 committed by GitHub
parent 097cec676a
commit 472fa4a6ca

View File

@ -277,7 +277,11 @@ func (api objectAPIHandlers) DeleteMultipleObjectsHandler(w http.ResponseWriter,
for index, object := range deleteObjects.Objects { for index, object := range deleteObjects.Objects {
wg.Add(1) wg.Add(1)
go func(i int, obj ObjectIdentifier) { go func(i int, obj ObjectIdentifier) {
objectLock := globalNSMutex.NewNSLock(bucket, obj.ObjectName)
objectLock.Lock()
defer objectLock.Unlock()
defer wg.Done() defer wg.Done()
dErr := objectAPI.DeleteObject(bucket, obj.ObjectName) dErr := objectAPI.DeleteObject(bucket, obj.ObjectName)
if dErr != nil { if dErr != nil {
dErrs[i] = dErr dErrs[i] = dErr