mirror of
https://github.com/opentofu/opentofu.git
synced 2025-01-15 19:22:46 -06:00
6fe2703665
* Remove `make updatedeps` from Travis build. We'll follow up with more specific plans around dependency updating in subsequent PRs. * Update all `make` targets to set `GO15VENDOREXPERIMENT=1` and to filter out `/vendor/` from `./...` where appropriate. * Temporarily remove `vet` from the `make test` target until we can figure out how to get it to not vet `vendor/`. (Initial experimentation failed to yield the proper incantation.) Everything is pinned to current master, with the exception of: * Azure/azure-sdk-for-go which is pinned before the breaking change today * aws/aws-sdk-go which is pinned to the most recent tag The documentation still needs to be updated, which we can do in a follow up PR. The goal here is to unblock release.
37 lines
945 B
Go
37 lines
945 B
Go
package s3
|
|
|
|
import (
|
|
"crypto/md5"
|
|
"encoding/base64"
|
|
"io"
|
|
|
|
"github.com/aws/aws-sdk-go/aws/awserr"
|
|
"github.com/aws/aws-sdk-go/aws/request"
|
|
)
|
|
|
|
// contentMD5 computes and sets the HTTP Content-MD5 header for requests that
|
|
// require it.
|
|
func contentMD5(r *request.Request) {
|
|
h := md5.New()
|
|
|
|
// hash the body. seek back to the first position after reading to reset
|
|
// the body for transmission. copy errors may be assumed to be from the
|
|
// body.
|
|
_, err := io.Copy(h, r.Body)
|
|
if err != nil {
|
|
r.Error = awserr.New("ContentMD5", "failed to read body", err)
|
|
return
|
|
}
|
|
_, err = r.Body.Seek(0, 0)
|
|
if err != nil {
|
|
r.Error = awserr.New("ContentMD5", "failed to seek body", err)
|
|
return
|
|
}
|
|
|
|
// encode the md5 checksum in base64 and set the request header.
|
|
sum := h.Sum(nil)
|
|
sum64 := make([]byte, base64.StdEncoding.EncodedLen(len(sum)))
|
|
base64.StdEncoding.Encode(sum64, sum)
|
|
r.HTTPRequest.Header.Set("Content-MD5", string(sum64))
|
|
}
|