fix pagination

This commit is contained in:
Konstantin Lebedev 2022-07-01 14:17:49 +05:00
parent 06a8b174b5
commit 3d5f1cbc5e

View file

@ -254,20 +254,23 @@ func (s3a *S3ApiServer) doListFilerEntries(client filer_pb.SeaweedFilerClient, d
sepIndex := strings.Index(marker, "/") sepIndex := strings.Index(marker, "/")
if sepIndex != -1 { if sepIndex != -1 {
subPrefix, subMarker := marker[0:sepIndex], marker[sepIndex+1:] subPrefix, subMarker := marker[0:sepIndex], marker[sepIndex+1:]
subDir := fmt.Sprintf("%s/%s", dir[0:bucketPrefixLen-1], subPrefix) var subDir string
if strings.HasPrefix(subDir, dir) { if len(dir) > bucketPrefixLen && dir[bucketPrefixLen:] == subPrefix {
subCounter, subIsTruncated, subNextMarker, subErr := s3a.doListFilerEntries(client, subDir, "", maxKeys, subMarker, delimiter, false, false, bucketPrefixLen, eachEntryFn) subDir = dir
if subErr != nil { } else {
err = subErr subDir = fmt.Sprintf("%s/%s", dir, subPrefix)
return
}
counter += subCounter
isTruncated = isTruncated || subIsTruncated
maxKeys -= subCounter
nextMarker = subNextMarker
// finished processing this sub directory
marker = subPrefix
} }
subCounter, subIsTruncated, subNextMarker, subErr := s3a.doListFilerEntries(client, subDir, "", maxKeys, subMarker, delimiter, false, false, bucketPrefixLen, eachEntryFn)
if subErr != nil {
err = subErr
return
}
counter += subCounter
isTruncated = isTruncated || subIsTruncated
maxKeys -= subCounter
nextMarker = subNextMarker
// finished processing this sub directory
marker = subPrefix
} }
} }
if maxKeys <= 0 { if maxKeys <= 0 {