AWS: Ensure that the order returned by ListObjects is consistent

When a backup is deleted, the delete method uses ListObjects to get a list of
files it needs to delete in s3. Different s3 implementations may return
the object lists in different, even non-deterministic orders, which can
result in the deletion not working because ark tries to delete a non empty folder
before it tries to delete the files in the folder.

Signed-off-by: Bastian Hofmann <bashofmann@gmail.com>
pull/999/head
Bastian Hofmann 2018-10-25 16:39:41 +02:00
parent 9165d514a3
commit 8bbfc538f1
1 changed files with 6 additions and 0 deletions

View File

@ -18,6 +18,7 @@ package aws
import (
"io"
"sort"
"strconv"
"time"
@ -187,6 +188,11 @@ func (o *objectStore) ListObjects(bucket, prefix string) ([]string, error) {
return nil, errors.WithStack(err)
}
// ensure that returned objects are in a consistent order so that the deletion logic deletes the objects before
// the pseudo-folder prefix object for s3 providers (such as Quobyte) that return the pseudo-folder as an object.
// See https://github.com/heptio/ark/pull/999
sort.Sort(sort.Reverse(sort.StringSlice(ret)))
return ret, nil
}