mirror of
https://github.com/minio/minio.git
synced 2025-01-26 06:03:17 -05:00
Strict checks for delimiter and prefix if absent or present
This commit is contained in:
parent
44f02058ea
commit
7a01db8005
@ -270,8 +270,9 @@ func (storage *Storage) GetObjectMetadata(bucket, object, prefix string) (mstora
|
|||||||
return mstorage.ObjectMetadata{}, mstorage.ObjectNameInvalid{Bucket: bucket, Object: bucket}
|
return mstorage.ObjectMetadata{}, mstorage.ObjectNameInvalid{Bucket: bucket, Object: bucket}
|
||||||
}
|
}
|
||||||
|
|
||||||
objectPath := path.Join(storage.root, bucket, object)
|
// Do not use path.Join() since path.Join strips off any object names with '/', use them as is
|
||||||
|
// in a static manner so that we can send a proper 'ObjectNotFound' reply back upon os.Stat()
|
||||||
|
objectPath := storage.root + "/" + bucket + "/" + object
|
||||||
stat, err := os.Stat(objectPath)
|
stat, err := os.Stat(objectPath)
|
||||||
if os.IsNotExist(err) {
|
if os.IsNotExist(err) {
|
||||||
return mstorage.ObjectMetadata{}, mstorage.ObjectNotFound{Bucket: bucket, Object: object}
|
return mstorage.ObjectMetadata{}, mstorage.ObjectNotFound{Bucket: bucket, Object: object}
|
||||||
@ -391,6 +392,7 @@ func (storage *Storage) ListObjects(bucket string, resources mstorage.BucketReso
|
|||||||
}
|
}
|
||||||
// TODO handle resources.Marker
|
// TODO handle resources.Marker
|
||||||
switch true {
|
switch true {
|
||||||
|
// Delimiter present and Prefix is absent
|
||||||
case resources.Delimiter != "" && resources.Prefix == "":
|
case resources.Delimiter != "" && resources.Prefix == "":
|
||||||
delimitedName := delimiter(name, resources.Delimiter)
|
delimitedName := delimiter(name, resources.Delimiter)
|
||||||
switch true {
|
switch true {
|
||||||
@ -411,7 +413,8 @@ func (storage *Storage) ListObjects(bucket string, resources mstorage.BucketReso
|
|||||||
case delimitedName != "":
|
case delimitedName != "":
|
||||||
resources.CommonPrefixes = appendUniq(resources.CommonPrefixes, delimitedName)
|
resources.CommonPrefixes = appendUniq(resources.CommonPrefixes, delimitedName)
|
||||||
}
|
}
|
||||||
case resources.Delimiter != "" && strings.HasPrefix(name, resources.Prefix):
|
// Both delimiter and Prefix is present
|
||||||
|
case resources.Delimiter != "" && resources.Prefix != "" && strings.HasPrefix(name, resources.Prefix):
|
||||||
trimmedName := strings.TrimPrefix(name, resources.Prefix)
|
trimmedName := strings.TrimPrefix(name, resources.Prefix)
|
||||||
delimitedName := delimiter(trimmedName, resources.Delimiter)
|
delimitedName := delimiter(trimmedName, resources.Delimiter)
|
||||||
switch true {
|
switch true {
|
||||||
@ -436,16 +439,22 @@ func (storage *Storage) ListObjects(bucket string, resources mstorage.BucketReso
|
|||||||
resources.CommonPrefixes = appendUniq(resources.CommonPrefixes, delimitedName)
|
resources.CommonPrefixes = appendUniq(resources.CommonPrefixes, delimitedName)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
case strings.HasPrefix(name, resources.Prefix):
|
// Delimiter is absent and only Prefix is present
|
||||||
|
case resources.Delimiter == "" && resources.Prefix != "" && strings.HasPrefix(name, resources.Prefix):
|
||||||
// Do not strip prefix object output
|
// Do not strip prefix object output
|
||||||
metadata, err := storage.GetObjectMetadata(bucket, name, "")
|
metadata, err := storage.GetObjectMetadata(bucket, name, "")
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return []mstorage.ObjectMetadata{}, resources, mstorage.EmbedError(bucket, "", err)
|
return []mstorage.ObjectMetadata{}, resources, mstorage.EmbedError(bucket, "", err)
|
||||||
}
|
}
|
||||||
metadataList = append(metadataList, metadata)
|
metadataList = append(metadataList, metadata)
|
||||||
|
case resources.Prefix == "" && resources.Delimiter == "":
|
||||||
|
metadata, err := storage.GetObjectMetadata(bucket, name, "")
|
||||||
|
if err != nil {
|
||||||
|
return []mstorage.ObjectMetadata{}, resources, mstorage.EmbedError(bucket, "", err)
|
||||||
|
}
|
||||||
|
metadataList = append(metadataList, metadata)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
ret:
|
ret:
|
||||||
sort.Sort(byObjectKey(metadataList))
|
sort.Sort(byObjectKey(metadataList))
|
||||||
return metadataList, resources, nil
|
return metadataList, resources, nil
|
||||||
|
Loading…
x
Reference in New Issue
Block a user