mirror of
https://github.com/minio/minio.git
synced 2025-01-26 22:23:15 -05:00
Update getObjectInfo to stat for objects with trailing / (#5179)
Apache Spark sends getObject requests with trailing "/". This PR updates the getObjectInfo to stat for files even if they are sent with trailing "/". Fixes #2965
This commit is contained in:
parent
2a0a62b78d
commit
f7b6f7b22f
12
cmd/fs-v1.go
12
cmd/fs-v1.go
@ -452,14 +452,18 @@ func (fs fsObjects) GetObject(bucket, object string, offset int64, length int64,
|
|||||||
// getObjectInfo - wrapper for reading object metadata and constructs ObjectInfo.
|
// getObjectInfo - wrapper for reading object metadata and constructs ObjectInfo.
|
||||||
func (fs fsObjects) getObjectInfo(bucket, object string) (oi ObjectInfo, e error) {
|
func (fs fsObjects) getObjectInfo(bucket, object string) (oi ObjectInfo, e error) {
|
||||||
fsMeta := fsMetaV1{}
|
fsMeta := fsMetaV1{}
|
||||||
if hasSuffix(object, slashSeparator) {
|
|
||||||
// Directory call needs to arrive with object ending with "/".
|
|
||||||
fi, err := fsStatDir(pathJoin(fs.fsPath, bucket, object))
|
fi, err := fsStatDir(pathJoin(fs.fsPath, bucket, object))
|
||||||
if err != nil {
|
if err != nil && errorCause(err) != errFileAccessDenied {
|
||||||
return oi, toObjectErr(err, bucket, object)
|
return oi, toObjectErr(err, bucket, object)
|
||||||
}
|
}
|
||||||
|
if fi != nil {
|
||||||
|
// If file found and request was with object ending with "/", consider it
|
||||||
|
// as directory and return object info
|
||||||
|
if hasSuffix(object, slashSeparator) {
|
||||||
return fsMeta.ToObjectInfo(bucket, object, fi), nil
|
return fsMeta.ToObjectInfo(bucket, object, fi), nil
|
||||||
}
|
}
|
||||||
|
return oi, toObjectErr(errFileNotFound, bucket, object)
|
||||||
|
}
|
||||||
|
|
||||||
fsMetaPath := pathJoin(fs.fsPath, minioMetaBucket, bucketMetaPrefix, bucket, object, fsMetaJSONFile)
|
fsMetaPath := pathJoin(fs.fsPath, minioMetaBucket, bucketMetaPrefix, bucket, object, fsMetaJSONFile)
|
||||||
|
|
||||||
@ -485,7 +489,7 @@ func (fs fsObjects) getObjectInfo(bucket, object string) (oi ObjectInfo, e error
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Stat the file to get file size.
|
// Stat the file to get file size.
|
||||||
fi, err := fsStatFile(pathJoin(fs.fsPath, bucket, object))
|
fi, err = fsStatFile(pathJoin(fs.fsPath, bucket, object))
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return oi, toObjectErr(err, bucket, object)
|
return oi, toObjectErr(err, bucket, object)
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user