mirror of
https://github.com/minio/minio.git
synced 2025-01-24 21:23:15 -05:00
Fix issue with UNSIGNED payloads.
Additionally also fixes escaping slashes in temporary multipart names
This commit is contained in:
parent
52b500cce9
commit
bfff251e2a
@ -37,6 +37,12 @@ import (
|
|||||||
|
|
||||||
"bytes"
|
"bytes"
|
||||||
|
|
||||||
|
// this package contains the url code of go 1.8
|
||||||
|
// due to compatibility with older versions
|
||||||
|
// copied it to our rep
|
||||||
|
|
||||||
|
"path/filepath"
|
||||||
|
|
||||||
minio "github.com/minio/minio-go"
|
minio "github.com/minio/minio-go"
|
||||||
"github.com/minio/minio-go/pkg/policy"
|
"github.com/minio/minio-go/pkg/policy"
|
||||||
)
|
)
|
||||||
@ -589,9 +595,7 @@ func (l *gcsGateway) ListMultipartUploads(bucket string, prefix string, keyMarke
|
|||||||
attrs, err := it.Next()
|
attrs, err := it.Next()
|
||||||
if err == iterator.Done {
|
if err == iterator.Done {
|
||||||
break
|
break
|
||||||
}
|
} else if err != nil {
|
||||||
|
|
||||||
if err != nil {
|
|
||||||
return ListMultipartsInfo{}, gcsToObjectError(traceError(err), bucket)
|
return ListMultipartsInfo{}, gcsToObjectError(traceError(err), bucket)
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -629,6 +633,9 @@ func (l *gcsGateway) ListMultipartUploads(bucket string, prefix string, keyMarke
|
|||||||
}
|
}
|
||||||
|
|
||||||
func fromGCSMultipartKey(s string) (key, uploadID string, partID int, err error) {
|
func fromGCSMultipartKey(s string) (key, uploadID string, partID int, err error) {
|
||||||
|
// remove prefixes
|
||||||
|
s = filepath.Base(s)
|
||||||
|
|
||||||
parts := strings.Split(s, "-")
|
parts := strings.Split(s, "-")
|
||||||
if parts[0] != "multipart" {
|
if parts[0] != "multipart" {
|
||||||
return "", "", 0, ErrNotValidMultipartIdentifier
|
return "", "", 0, ErrNotValidMultipartIdentifier
|
||||||
@ -638,7 +645,8 @@ func fromGCSMultipartKey(s string) (key, uploadID string, partID int, err error)
|
|||||||
return "", "", 0, ErrNotValidMultipartIdentifier
|
return "", "", 0, ErrNotValidMultipartIdentifier
|
||||||
}
|
}
|
||||||
|
|
||||||
key = parts[1]
|
key = unescape(parts[1])
|
||||||
|
|
||||||
uploadID = parts[3]
|
uploadID = parts[3]
|
||||||
|
|
||||||
partID, err = strconv.Atoi(parts[3])
|
partID, err = strconv.Atoi(parts[3])
|
||||||
@ -649,18 +657,32 @@ func fromGCSMultipartKey(s string) (key, uploadID string, partID int, err error)
|
|||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
func toGCSMultipartKey(key string, uploadID string, partID int) string {
|
func unescape(s string) string {
|
||||||
// we don't use the etag within the key, because the amazon spec
|
s = strings.Replace(s, "%2D", "-", -1)
|
||||||
// explicitly notes that uploaded parts with same number are being overwritten
|
s = strings.Replace(s, "%2F", "/", -1)
|
||||||
|
s = strings.Replace(s, "%25", "%", -1)
|
||||||
|
return s
|
||||||
|
}
|
||||||
|
|
||||||
|
func escape(s string) string {
|
||||||
|
s = strings.Replace(s, "%", "%25", -1)
|
||||||
|
s = strings.Replace(s, "/", "%2F", -1)
|
||||||
|
s = strings.Replace(s, "-", "%2D", -1)
|
||||||
|
return s
|
||||||
|
}
|
||||||
|
|
||||||
|
func toGCSMultipartKey(key string, uploadID string, partID int) string {
|
||||||
// parts are allowed to be numbered from 1 to 10,000 (inclusive)
|
// parts are allowed to be numbered from 1 to 10,000 (inclusive)
|
||||||
return fmt.Sprintf("%s/multipart-%s-%s-%05d", ZZZZMinioPrefix, key, uploadID, partID)
|
|
||||||
|
// we need to encode the key because of possible slashes
|
||||||
|
return fmt.Sprintf("%s/multipart-%s-%s-%05d", ZZZZMinioPrefix, escape(key), uploadID, partID)
|
||||||
}
|
}
|
||||||
|
|
||||||
// NewMultipartUpload - upload object in multiple parts
|
// NewMultipartUpload - upload object in multiple parts
|
||||||
func (l *gcsGateway) NewMultipartUpload(bucket string, key string, metadata map[string]string) (uploadID string, err error) {
|
func (l *gcsGateway) NewMultipartUpload(bucket string, key string, metadata map[string]string) (uploadID string, err error) {
|
||||||
// generate new uploadid
|
// generate new uploadid
|
||||||
uploadID = mustGetUUID()
|
uploadID = mustGetUUID()
|
||||||
|
uploadID = strings.Replace(uploadID, "-", "", -1)
|
||||||
|
|
||||||
// generate name for part zero
|
// generate name for part zero
|
||||||
partZeroKey := toGCSMultipartKey(key, uploadID, 0)
|
partZeroKey := toGCSMultipartKey(key, uploadID, 0)
|
||||||
@ -769,9 +791,7 @@ func (l *gcsGateway) AbortMultipartUpload(bucket string, key string, uploadID st
|
|||||||
attrs, err := it.Next()
|
attrs, err := it.Next()
|
||||||
if err == iterator.Done {
|
if err == iterator.Done {
|
||||||
break
|
break
|
||||||
}
|
} else if err != nil {
|
||||||
|
|
||||||
if err != nil {
|
|
||||||
return gcsToObjectError(traceError(err), bucket, prefix)
|
return gcsToObjectError(traceError(err), bucket, prefix)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -272,10 +272,9 @@ func (api gatewayAPIHandlers) PutObjectHandler(w http.ResponseWriter, r *http.Re
|
|||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
sha256sum := getContentSha256Cksum(r)
|
sha256sum := ""
|
||||||
|
|
||||||
if !skipContentSha256Cksum(r) {
|
if !skipContentSha256Cksum(r) {
|
||||||
sha256sum = r.Header.Get("X-Amz-Content-Sha256")
|
sha256sum = getContentSha256Cksum(r)
|
||||||
}
|
}
|
||||||
|
|
||||||
// Create object.
|
// Create object.
|
||||||
|
1053
cmd/gcs/gateway-gcs-url.go
Normal file
1053
cmd/gcs/gateway-gcs-url.go
Normal file
File diff suppressed because it is too large
Load Diff
Loading…
x
Reference in New Issue
Block a user