mirror of
https://github.com/minio/minio.git
synced 2025-01-11 23:13:23 -05:00
Send XML header before the first of whitespace chars (#2046)
* Sent XML header before the first of whitespace chars XML parsing fails in aws cli due to unexpected whitespace character. To fix this, we send the xml header before we send the first whitespace character, if any. * Fix race between sendWhiteSpaceChars and completeMultiUploadpart
This commit is contained in:
parent
285a94d2c0
commit
bcb822c390
@ -502,10 +502,11 @@ func writeErrorResponse(w http.ResponseWriter, req *http.Request, errorCode APIE
|
|||||||
setCommonHeaders(w)
|
setCommonHeaders(w)
|
||||||
// write Header
|
// write Header
|
||||||
w.WriteHeader(error.HTTPStatusCode)
|
w.WriteHeader(error.HTTPStatusCode)
|
||||||
writeErrorResponseNoHeader(w, req, error, resource)
|
writeErrorResponseNoHeader(w, req, errorCode, resource)
|
||||||
}
|
}
|
||||||
|
|
||||||
func writeErrorResponseNoHeader(w http.ResponseWriter, req *http.Request, error APIError, resource string) {
|
func writeErrorResponseNoHeader(w http.ResponseWriter, req *http.Request, errorCode APIErrorCode, resource string) {
|
||||||
|
error := getAPIError(errorCode)
|
||||||
// Generate error response.
|
// Generate error response.
|
||||||
errorResponse := getAPIErrorResponse(error, resource)
|
errorResponse := getAPIErrorResponse(error, resource)
|
||||||
encodedErrorResponse := encodeResponse(errorResponse)
|
encodedErrorResponse := encodeResponse(errorResponse)
|
||||||
|
@ -974,6 +974,14 @@ func (api objectAPIHandlers) CompleteMultipartUploadHandler(w http.ResponseWrite
|
|||||||
// Send 200 OK
|
// Send 200 OK
|
||||||
setCommonHeaders(w)
|
setCommonHeaders(w)
|
||||||
w.WriteHeader(http.StatusOK)
|
w.WriteHeader(http.StatusOK)
|
||||||
|
// Xml headers need to be sent before we possibly send whitespace characters
|
||||||
|
// to the client.
|
||||||
|
_, err = w.Write([]byte(xml.Header))
|
||||||
|
if err != nil {
|
||||||
|
errorIf(err, "Unable to write XML header for complete multipart upload")
|
||||||
|
writeErrorResponseNoHeader(w, r, ErrInternalError, r.URL.Path)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
doneCh := make(chan struct{})
|
doneCh := make(chan struct{})
|
||||||
// Signal that completeMultipartUpload is over via doneCh
|
// Signal that completeMultipartUpload is over via doneCh
|
||||||
@ -992,7 +1000,7 @@ func (api objectAPIHandlers) CompleteMultipartUploadHandler(w http.ResponseWrite
|
|||||||
writePartSmallErrorResponse(w, r, oErr)
|
writePartSmallErrorResponse(w, r, oErr)
|
||||||
default:
|
default:
|
||||||
// Handle all other generic issues.
|
// Handle all other generic issues.
|
||||||
writeErrorResponseNoHeader(w, r, getAPIError(toAPIErrorCode(err)), r.URL.Path)
|
writeErrorResponseNoHeader(w, r, toAPIErrorCode(err), r.URL.Path)
|
||||||
}
|
}
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
@ -1001,7 +1009,12 @@ func (api objectAPIHandlers) CompleteMultipartUploadHandler(w http.ResponseWrite
|
|||||||
location := getLocation(r)
|
location := getLocation(r)
|
||||||
// Generate complete multipart response.
|
// Generate complete multipart response.
|
||||||
response := generateCompleteMultpartUploadResponse(bucket, object, location, md5Sum)
|
response := generateCompleteMultpartUploadResponse(bucket, object, location, md5Sum)
|
||||||
encodedSuccessResponse := encodeResponse(response)
|
encodedSuccessResponse, err := xml.Marshal(response)
|
||||||
|
if err != nil {
|
||||||
|
errorIf(err, "Unable to parse CompleteMultipartUpload response")
|
||||||
|
writeErrorResponseNoHeader(w, r, ErrInternalError, r.URL.Path)
|
||||||
|
return
|
||||||
|
}
|
||||||
// write success response.
|
// write success response.
|
||||||
w.Write(encodedSuccessResponse)
|
w.Write(encodedSuccessResponse)
|
||||||
w.(http.Flusher).Flush()
|
w.(http.Flusher).Flush()
|
||||||
|
Loading…
Reference in New Issue
Block a user