| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107 |
- /*
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
- package auth
- import (
- "bytes"
- "github.com/aliyun/alibaba-cloud-sdk-go/sdk/requests"
- "github.com/aliyun/alibaba-cloud-sdk-go/sdk/utils"
- "sort"
- "strings"
- )
- func signRoaRequest(request requests.AcsRequest, signer Signer, regionId string) {
- completeROASignParams(request, signer, regionId)
- stringToSign := buildRoaStringToSign(request)
- signature := signer.Sign(stringToSign, "")
- request.GetHeaders()["Authorization"] = "acs " + signer.GetAccessKeyId() + ":" + signature
- }
- func completeROASignParams(request requests.AcsRequest, signer Signer, regionId string) {
- // complete query params
- queryParams := request.GetQueryParams()
- if _, ok := queryParams["RegionId"]; !ok {
- queryParams["RegionId"] = regionId
- }
- if extraParam := signer.GetExtraParam(); extraParam != nil {
- for key, value := range extraParam {
- queryParams[key] = value
- }
- }
- // complete header params
- headerParams := request.GetHeaders()
- headerParams["Date"] = utils.GetTimeInFormatRFC2616()
- headerParams["x-acs-signature-method"] = signer.GetName()
- headerParams["x-acs-signature-version"] = signer.GetVersion()
- if request.GetFormParams() != nil && len(request.GetFormParams()) > 0 {
- formString := utils.GetUrlFormedMap(request.GetFormParams())
- request.SetContent([]byte(formString))
- headerParams["Content-Type"] = requests.Form
- }
- contentMD5 := utils.GetMD5Base64(request.GetContent())
- headerParams["Content-MD5"] = contentMD5
- if _, contains := headerParams["Content-Type"]; !contains {
- headerParams["Content-Type"] = requests.Raw
- }
- switch format := request.GetAcceptFormat(); format {
- case "JSON":
- headerParams["Accept"] = requests.Json
- case "XML":
- headerParams["Accept"] = requests.Xml
- default:
- headerParams["Accept"] = requests.Raw
- }
- }
- func buildRoaStringToSign(request requests.AcsRequest) (stringToSign string) {
- headers := request.GetHeaders()
- stringToSignBuilder := bytes.Buffer{}
- stringToSignBuilder.WriteString(request.GetMethod())
- stringToSignBuilder.WriteString(requests.HeaderSeparator)
- // append header keys for sign
- appendIfContain(headers, &stringToSignBuilder, "Accept", requests.HeaderSeparator)
- appendIfContain(headers, &stringToSignBuilder, "Content-MD5", requests.HeaderSeparator)
- appendIfContain(headers, &stringToSignBuilder, "Content-Type", requests.HeaderSeparator)
- appendIfContain(headers, &stringToSignBuilder, "Date", requests.HeaderSeparator)
- // sort and append headers witch starts with 'x-acs-'
- var acsHeaders []string
- for key := range headers {
- if strings.HasPrefix(key, "x-acs-") {
- acsHeaders = append(acsHeaders, key)
- }
- }
- sort.Strings(acsHeaders)
- for _, key := range acsHeaders {
- stringToSignBuilder.WriteString(key + ":" + headers[key])
- stringToSignBuilder.WriteString(requests.HeaderSeparator)
- }
- // append query params
- stringToSignBuilder.WriteString(request.BuildQueries())
- stringToSign = stringToSignBuilder.String()
- return
- }
- func appendIfContain(sourceMap map[string]string, target *bytes.Buffer, key, separator string) {
- if value, contain := sourceMap[key]; contain && len(value) > 0 {
- target.WriteString(sourceMap[key])
- target.WriteString(separator)
- }
- }
|