Browse Source

compatible with aws-sdk-go's cxpect header

Signed-off-by: changlin.shi <changlin.shi@ly.com>
pull/5936/head
changlin.shi 2 years ago
parent
commit
d393937c90
  1. 8
      weed/s3api/auth_signature_v4.go

8
weed/s3api/auth_signature_v4.go

@ -56,6 +56,7 @@ const (
// http Header "x-amz-content-sha256" == "UNSIGNED-PAYLOAD" indicates that the // http Header "x-amz-content-sha256" == "UNSIGNED-PAYLOAD" indicates that the
// client did not calculate sha256 of the payload. // client did not calculate sha256 of the payload.
unsignedPayload = "UNSIGNED-PAYLOAD" unsignedPayload = "UNSIGNED-PAYLOAD"
expect100Continue = "100-contine"
) )
// Returns SHA256 for calculating canonical-request. // Returns SHA256 for calculating canonical-request.
@ -592,7 +593,12 @@ func extractSignedHeaders(signedHeaders []string, r *http.Request) (http.Header,
// be sent, for the time being keep this work around. // be sent, for the time being keep this work around.
// Adding a *TODO* to remove this later when Golang server // Adding a *TODO* to remove this later when Golang server
// doesn't filter out the 'Expect' header. // doesn't filter out the 'Expect' header.
extractedSignedHeaders.Set(header, "100-continue")
expectHeaderValue := extractedSignedHeaders.Get(header)
// here in order to be compatible with the aws go sdk v1 version, it sets the expect header to '100-Continue'
if !strings.EqualFold(expectHeaderValue, expect100Continue) {
extractedSignedHeaders.Set(header, expect100Continue)
}
case "host": case "host":
// Go http server removes "host" from Request.Header // Go http server removes "host" from Request.Header
extractedSignedHeaders.Set(header, r.Host) extractedSignedHeaders.Set(header, r.Host)

Loading…
Cancel
Save