|
|
@ -27,7 +27,10 @@ import ( |
|
|
|
"github.com/minio-io/minio/pkg/iodine" |
|
|
|
"github.com/minio-io/minio/pkg/iodine" |
|
|
|
"github.com/minio-io/minio/pkg/storage/drivers" |
|
|
|
"github.com/minio-io/minio/pkg/storage/drivers" |
|
|
|
"github.com/minio-io/minio/pkg/utils/log" |
|
|
|
"github.com/minio-io/minio/pkg/utils/log" |
|
|
|
"strings" |
|
|
|
) |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
const ( |
|
|
|
|
|
|
|
maxPartsList = 1000 |
|
|
|
) |
|
|
|
) |
|
|
|
|
|
|
|
|
|
|
|
// GET Object
|
|
|
|
// GET Object
|
|
|
@ -235,22 +238,24 @@ func (server *minioAPI) newMultipartUploadHandler(w http.ResponseWriter, req *ht |
|
|
|
vars := mux.Vars(req) |
|
|
|
vars := mux.Vars(req) |
|
|
|
bucket = vars["bucket"] |
|
|
|
bucket = vars["bucket"] |
|
|
|
object = vars["object"] |
|
|
|
object = vars["object"] |
|
|
|
var uploadID string |
|
|
|
uploadID, err := server.driver.NewMultipartUpload(bucket, object, "") |
|
|
|
var err error |
|
|
|
switch err := iodine.ToError(err).(type) { |
|
|
|
if uploadID, err = server.driver.NewMultipartUpload(bucket, object, ""); err != nil { |
|
|
|
case nil: |
|
|
|
|
|
|
|
response := generateInitiateMultipartUploadResult(bucket, object, uploadID) |
|
|
|
|
|
|
|
encodedSuccessResponse := encodeSuccessResponse(response, acceptsContentType) |
|
|
|
|
|
|
|
// write headers
|
|
|
|
|
|
|
|
setCommonHeaders(w, getContentTypeString(acceptsContentType)) |
|
|
|
|
|
|
|
// set content-length to the size of the body
|
|
|
|
|
|
|
|
w.Header().Set("Content-Length", strconv.Itoa(len(encodedSuccessResponse))) |
|
|
|
|
|
|
|
w.WriteHeader(http.StatusOK) |
|
|
|
|
|
|
|
// write body
|
|
|
|
|
|
|
|
w.Write(encodedSuccessResponse) |
|
|
|
|
|
|
|
case drivers.ObjectExists: |
|
|
|
|
|
|
|
writeErrorResponse(w, req, MethodNotAllowed, acceptsContentType, req.URL.Path) |
|
|
|
|
|
|
|
default: |
|
|
|
log.Println(iodine.New(err, nil)) |
|
|
|
log.Println(iodine.New(err, nil)) |
|
|
|
writeErrorResponse(w, req, NotAcceptable, acceptsContentType, req.URL.Path) |
|
|
|
writeErrorResponse(w, req, InternalError, acceptsContentType, req.URL.Path) |
|
|
|
return |
|
|
|
|
|
|
|
} |
|
|
|
} |
|
|
|
response := generateInitiateMultipartUploadResult(bucket, object, uploadID) |
|
|
|
|
|
|
|
encodedSuccessResponse := encodeSuccessResponse(response, acceptsContentType) |
|
|
|
|
|
|
|
// write headers
|
|
|
|
|
|
|
|
setCommonHeaders(w, getContentTypeString(acceptsContentType)) |
|
|
|
|
|
|
|
// set content-length to the size of the body
|
|
|
|
|
|
|
|
w.Header().Set("Content-Length", strconv.Itoa(len(encodedSuccessResponse))) |
|
|
|
|
|
|
|
w.WriteHeader(http.StatusOK) |
|
|
|
|
|
|
|
// write body
|
|
|
|
|
|
|
|
w.Write(encodedSuccessResponse) |
|
|
|
|
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
func (server *minioAPI) putObjectPartHandler(w http.ResponseWriter, req *http.Request) { |
|
|
|
func (server *minioAPI) putObjectPartHandler(w http.ResponseWriter, req *http.Request) { |
|
|
@ -295,16 +300,21 @@ func (server *minioAPI) putObjectPartHandler(w http.ResponseWriter, req *http.Re |
|
|
|
writeErrorResponse(w, req, InvalidRequest, acceptsContentType, req.URL.Path) |
|
|
|
writeErrorResponse(w, req, InvalidRequest, acceptsContentType, req.URL.Path) |
|
|
|
return |
|
|
|
return |
|
|
|
} |
|
|
|
} |
|
|
|
var object, bucket string |
|
|
|
|
|
|
|
vars := mux.Vars(req) |
|
|
|
vars := mux.Vars(req) |
|
|
|
bucket = vars["bucket"] |
|
|
|
bucket := vars["bucket"] |
|
|
|
object = vars["object"] |
|
|
|
object := vars["object"] |
|
|
|
uploadID := vars["uploadId"] |
|
|
|
|
|
|
|
// workaround for mux not splitting on & properly
|
|
|
|
var uploadID, partIDString string |
|
|
|
if len(uploadID) > 1 { |
|
|
|
for key, value := range req.URL.Query() { |
|
|
|
uploadID = strings.Split(uploadID, "&")[0] |
|
|
|
switch true { |
|
|
|
|
|
|
|
case key == "uploadId": |
|
|
|
|
|
|
|
uploadID = value[0] |
|
|
|
|
|
|
|
case key == "partNumber": |
|
|
|
|
|
|
|
partIDString = value[0] |
|
|
|
|
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
partIDString := vars["partNumber"] |
|
|
|
|
|
|
|
partID, err := strconv.Atoi(partIDString) |
|
|
|
partID, err := strconv.Atoi(partIDString) |
|
|
|
if err != nil { |
|
|
|
if err != nil { |
|
|
|
writeErrorResponse(w, req, InvalidPart, acceptsContentType, req.URL.Path) |
|
|
|
writeErrorResponse(w, req, InvalidPart, acceptsContentType, req.URL.Path) |
|
|
@ -337,11 +347,6 @@ func (server *minioAPI) putObjectPartHandler(w http.ResponseWriter, req *http.Re |
|
|
|
{ |
|
|
|
{ |
|
|
|
writeErrorResponse(w, req, InvalidDigest, acceptsContentType, req.URL.Path) |
|
|
|
writeErrorResponse(w, req, InvalidDigest, acceptsContentType, req.URL.Path) |
|
|
|
} |
|
|
|
} |
|
|
|
case drivers.ImplementationError: |
|
|
|
|
|
|
|
{ |
|
|
|
|
|
|
|
log.Error.Println(err) |
|
|
|
|
|
|
|
writeErrorResponse(w, req, InternalError, acceptsContentType, req.URL.Path) |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
default: |
|
|
|
default: |
|
|
|
{ |
|
|
|
{ |
|
|
|
log.Error.Println(err) |
|
|
|
log.Error.Println(err) |
|
|
@ -359,9 +364,10 @@ func (server *minioAPI) abortMultipartUploadHandler(w http.ResponseWriter, req * |
|
|
|
vars := mux.Vars(req) |
|
|
|
vars := mux.Vars(req) |
|
|
|
bucket := vars["bucket"] |
|
|
|
bucket := vars["bucket"] |
|
|
|
object := vars["object"] |
|
|
|
object := vars["object"] |
|
|
|
uploadID := vars["uploadId"] |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
err := server.driver.AbortMultipartUpload(bucket, object, uploadID) |
|
|
|
objectResourcesMetadata := getObjectResources(req.URL.Query()) |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
err := server.driver.AbortMultipartUpload(bucket, object, objectResourcesMetadata.UploadID) |
|
|
|
switch err := iodine.ToError(err).(type) { |
|
|
|
switch err := iodine.ToError(err).(type) { |
|
|
|
case nil: |
|
|
|
case nil: |
|
|
|
setCommonHeaders(w, getContentTypeString(acceptsContentType)) |
|
|
|
setCommonHeaders(w, getContentTypeString(acceptsContentType)) |
|
|
@ -383,9 +389,12 @@ func (server *minioAPI) listObjectPartsHandler(w http.ResponseWriter, req *http. |
|
|
|
vars := mux.Vars(req) |
|
|
|
vars := mux.Vars(req) |
|
|
|
bucket := vars["bucket"] |
|
|
|
bucket := vars["bucket"] |
|
|
|
object := vars["object"] |
|
|
|
object := vars["object"] |
|
|
|
uploadID := vars["uploadId"] |
|
|
|
objectResourcesMetadata := getObjectResources(req.URL.Query()) |
|
|
|
|
|
|
|
if objectResourcesMetadata.MaxParts == 0 { |
|
|
|
|
|
|
|
objectResourcesMetadata.MaxParts = maxPartsList |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
objectResourcesMetadata, err := server.driver.ListObjectParts(bucket, object, uploadID) |
|
|
|
objectResourcesMetadata, err := server.driver.ListObjectParts(bucket, object, objectResourcesMetadata) |
|
|
|
switch err := iodine.ToError(err).(type) { |
|
|
|
switch err := iodine.ToError(err).(type) { |
|
|
|
case nil: |
|
|
|
case nil: |
|
|
|
response := generateListPartsResult(objectResourcesMetadata) |
|
|
|
response := generateListPartsResult(objectResourcesMetadata) |
|
|
@ -428,13 +437,14 @@ func (server *minioAPI) completeMultipartUploadHandler(w http.ResponseWriter, re |
|
|
|
vars := mux.Vars(req) |
|
|
|
vars := mux.Vars(req) |
|
|
|
bucket := vars["bucket"] |
|
|
|
bucket := vars["bucket"] |
|
|
|
object := vars["object"] |
|
|
|
object := vars["object"] |
|
|
|
uploadID := vars["uploadId"] |
|
|
|
objectResourcesMetadata := getObjectResources(req.URL.Query()) |
|
|
|
|
|
|
|
|
|
|
|
partMap := make(map[int]string) |
|
|
|
partMap := make(map[int]string) |
|
|
|
for _, part := range parts.Part { |
|
|
|
for _, part := range parts.Part { |
|
|
|
partMap[part.PartNumber] = part.ETag |
|
|
|
partMap[part.PartNumber] = part.ETag |
|
|
|
} |
|
|
|
} |
|
|
|
etag, err := server.driver.CompleteMultipartUpload(bucket, object, uploadID, partMap) |
|
|
|
|
|
|
|
|
|
|
|
etag, err := server.driver.CompleteMultipartUpload(bucket, object, objectResourcesMetadata.UploadID, partMap) |
|
|
|
switch err := iodine.ToError(err).(type) { |
|
|
|
switch err := iodine.ToError(err).(type) { |
|
|
|
case nil: |
|
|
|
case nil: |
|
|
|
response := generateCompleteMultpartUploadResult(bucket, object, "", etag) |
|
|
|
response := generateCompleteMultpartUploadResult(bucket, object, "", etag) |
|
|
@ -453,8 +463,3 @@ func (server *minioAPI) completeMultipartUploadHandler(w http.ResponseWriter, re |
|
|
|
writeErrorResponse(w, req, InternalError, acceptsContentType, req.URL.Path) |
|
|
|
writeErrorResponse(w, req, InternalError, acceptsContentType, req.URL.Path) |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
func (server *minioAPI) notImplementedHandler(w http.ResponseWriter, req *http.Request) { |
|
|
|
|
|
|
|
acceptsContentType := getContentType(req) |
|
|
|
|
|
|
|
writeErrorResponse(w, req, NotImplemented, acceptsContentType, req.URL.Path) |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|