Nevar pievienot vairāk kā 25 tēmas Tēmai ir jāsākas ar burtu vai ciparu, tā var saturēt domu zīmes ('-') un var būt līdz 35 simboliem gara.

125 rindas
3.5 KiB

  1. package auth
  2. import (
  3. "bytes"
  4. "errors"
  5. "fmt"
  6. "golib.gaore.com/GaoreGo/gaore-common-sdk-go/sdk/requests"
  7. "golib.gaore.com/GaoreGo/gaore-common-sdk-go/sdk/utils"
  8. "net/http"
  9. "net/url"
  10. "strconv"
  11. "strings"
  12. "time"
  13. )
  14. func signRpcRequest(request requests.AcsRequest, signer Signer) (err error) {
  15. err = completeRpcSignParams(request, signer)
  16. if err != nil {
  17. return
  18. }
  19. if _, isContainsSign := request.GetQueryParams()["sign"]; isContainsSign {
  20. delete(request.GetQueryParams(), "sign")
  21. }
  22. stringToSign := buildRpcStringToSign(request)
  23. request.SetStringToSign(stringToSign)
  24. signature := signer.Sign(stringToSign, "&")
  25. request.GetQueryParams()["sign"] = signature
  26. debug("grsdk sign %s", signature)
  27. return
  28. }
  29. func completeRpcSignParams(request requests.AcsRequest, signer Signer) (err error) {
  30. var accessKeyFrom string
  31. if accessKeyFrom, err = signer.GetAccessKeyFrom(); err != nil {
  32. return
  33. }
  34. queryParams := request.GetQueryParams()
  35. queryParams["access_time"] = fmt.Sprintf("%d", time.Now().Unix())
  36. queryParams["access_key"], err = signer.GetAccessKeyId()
  37. queryParams["access_from"] = accessKeyFrom
  38. if err != nil {
  39. return
  40. }
  41. request.GetHeaders()["Content-type"] = requests.Form
  42. request.GetHeaders()["Gr-Sdk-From"] = accessKeyFrom
  43. formString := utils.GetUrlFormedMap(request.GetFormParams())
  44. request.SetContent(bytes.NewBufferString(formString).Bytes())
  45. return
  46. }
  47. func buildRpcStringToSign(request requests.AcsRequest) (stringToSign string) {
  48. signParams := make(map[string]string)
  49. for key, value := range request.GetQueryParams() {
  50. signParams[key] = value
  51. }
  52. if strings.ToUpper(request.GetMethod()) == requests.POST {
  53. for key, value := range request.GetFormParams() {
  54. signParams[key] = value
  55. }
  56. }
  57. stringToSign = utils.GetUrlFormedMap(signParams)
  58. stringToSign = strings.Replace(stringToSign, "+", "%20", -1)
  59. stringToSign = strings.Replace(stringToSign, "*", "%2A", -1)
  60. stringToSign = strings.Replace(stringToSign, "%7E", "~", -1)
  61. stringToSign = url.QueryEscape(stringToSign)
  62. stringToSign = request.GetMethod() + "&%2F&" + stringToSign
  63. return
  64. }
  65. func unsignRpcRequest(request *http.Request, signer Signer) (err error) {
  66. signParams := make(map[string]string)
  67. for key, value := range request.URL.Query() {
  68. signParams[key] = value[0]
  69. }
  70. if strings.ToUpper(request.Method) == requests.POST {
  71. for key, value := range request.Form {
  72. signParams[key] = value[0]
  73. }
  74. }
  75. if accessKey, err := signer.GetAccessKeyId(); err != nil {
  76. return err
  77. } else if accessKey == "" {
  78. return errors.New("access key is not allow empty")
  79. } else if accessKey != signParams["access_key"] {
  80. return errors.New("illegal access key")
  81. }
  82. signValue, ok := signParams["sign"]
  83. if !ok {
  84. return errors.New("sign value is not exists")
  85. } else {
  86. delete(signParams, "sign")
  87. }
  88. stringToSign := utils.GetUrlFormedMap(signParams)
  89. stringToSign = strings.Replace(stringToSign, "+", "%20", -1)
  90. stringToSign = strings.Replace(stringToSign, "*", "%2A", -1)
  91. stringToSign = strings.Replace(stringToSign, "%7E", "~", -1)
  92. stringToSign = url.QueryEscape(stringToSign)
  93. stringToSign = request.Method + "&%2F&" + stringToSign
  94. debug("grsdk signstring %s", stringToSign)
  95. if timestamp, err := strconv.ParseInt(signParams["access_time"], 10, 64); err != nil {
  96. return err
  97. } else {
  98. if time.Unix(timestamp, 0).Before(time.Now().Add(-5 * time.Minute)) {
  99. err = errors.New("sign timeout 5 minute")
  100. }
  101. }
  102. if signer.Sign(stringToSign, "&") != signValue {
  103. return errors.New("sign string is not correct")
  104. }
  105. return
  106. }