forked from TrueCloudLab/frostfs-s3-gw
[#129] Fix root objects listing
Signed-off-by: Denis Kirillov <denis@nspcc.ru>
This commit is contained in:
parent
daed0978a6
commit
e145effd17
2 changed files with 58 additions and 9 deletions
|
@ -285,15 +285,7 @@ func (n *layer) ListObjects(ctx context.Context, p *ListObjectsParams) (*ListObj
|
|||
result.NextMarker = result.Objects[len(result.Objects)-1].Name
|
||||
}
|
||||
|
||||
index := 0
|
||||
for _, oi := range result.Objects {
|
||||
if isDir := uniqNames[oi.Name]; isDir {
|
||||
result.Objects = append(result.Objects[:index], result.Objects[index+1:]...)
|
||||
result.Prefixes = append(result.Prefixes, oi.Name)
|
||||
} else {
|
||||
index++
|
||||
}
|
||||
}
|
||||
fillPrefixes(&result, uniqNames)
|
||||
if needDirectoryAsKey {
|
||||
res := []*ObjectInfo{{
|
||||
Name: p.Prefix,
|
||||
|
@ -306,6 +298,19 @@ func (n *layer) ListObjects(ctx context.Context, p *ListObjectsParams) (*ListObj
|
|||
return &result, nil
|
||||
}
|
||||
|
||||
func fillPrefixes(result *ListObjectsInfo, directories map[string]bool) {
|
||||
index := 0
|
||||
for range result.Objects {
|
||||
name := result.Objects[index].Name
|
||||
if isDir := directories[name]; isDir {
|
||||
result.Objects = append(result.Objects[:index], result.Objects[index+1:]...)
|
||||
result.Prefixes = append(result.Prefixes, name)
|
||||
} else {
|
||||
index++
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
// GetObject from storage.
|
||||
func (n *layer) GetObject(ctx context.Context, p *GetObjectParams) error {
|
||||
var (
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue