1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64
|
package cs
import (
"net/http"
"sort"
"strings"
"log"
"github.com/denverdino/aliyungo/util"
)
func (client *Client) signRequest(request *http.Request) {
headers := request.Header
contentMd5 := headers.Get("Content-Md5")
contentType := headers.Get("Content-Type")
accept := headers.Get("Accept")
date := headers.Get("Date")
canonicalizedResource := request.URL.RequestURI()
_, canonicalizedHeader := canonicalizeHeader(headers)
stringToSign := request.Method + "\n" + accept + "\n" + contentMd5 + "\n" + contentType + "\n" + date + "\n" + canonicalizedHeader + canonicalizedResource
if client.debug {
log.Printf("stringToSign = %s: ", stringToSign)
}
signature := util.CreateSignature(stringToSign, client.AccessKeySecret)
headers.Set("Authorization", "acs "+client.AccessKeyId+":"+signature)
}
const headerOSSPrefix = "x-acs-"
//Have to break the abstraction to append keys with lower case.
func canonicalizeHeader(headers http.Header) (newHeaders http.Header, result string) {
var canonicalizedHeaders []string
newHeaders = http.Header{}
for k, v := range headers {
if lower := strings.ToLower(k); strings.HasPrefix(lower, headerOSSPrefix) {
newHeaders[lower] = v
canonicalizedHeaders = append(canonicalizedHeaders, lower)
} else {
newHeaders[k] = v
}
}
sort.Strings(canonicalizedHeaders)
var canonicalizedHeader string
for _, k := range canonicalizedHeaders {
v := ""
if len(headers[k]) > 0 {
v = headers[k][0]
}
canonicalizedHeader += k + ":" + v + "\n"
}
return newHeaders, canonicalizedHeader
}
|