auth.go 4.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190
  1. package gn
  2. import (
  3. "bytes"
  4. "encoding/json"
  5. "errors"
  6. "eta_gn/eta_bridge/global"
  7. "fmt"
  8. "io"
  9. "net/http"
  10. "net/url"
  11. "strings"
  12. )
  13. type AccessTokenResp struct {
  14. ErrResp `description:"报错响应"`
  15. AccessToken string `json:"access_token"`
  16. ExpiresIn int `json:"expires_in"`
  17. RefreshExpiresIn int `json:"refresh_expires_in"`
  18. RefreshToken string `json:"refresh_token"`
  19. TokenType string `json:"token_type"`
  20. NotBeforePolicy int `json:"not-before-policy"`
  21. SessionState string `json:"session_state"`
  22. }
  23. type UserBaseInfoResp struct {
  24. ErrResp `description:"报错响应"`
  25. Sub string `json:"sub"`
  26. Name string `json:"name"`
  27. PreferredUsername string `json:"preferred_username"`
  28. GivenName string `json:"given_name"`
  29. FamilyName string `json:"family_name"`
  30. }
  31. type ErrResp struct {
  32. Error string `json:"error" description:"错误代码"`
  33. ErrorDescription string `json:"error_description" description:"错误描述"`
  34. }
  35. func GetToken(code string) (resp *AccessTokenResp, err error) {
  36. code = strings.TrimSpace(code)
  37. if code == "" {
  38. err = fmt.Errorf("code不可为空")
  39. return
  40. }
  41. baseUrl := global.CONFIG.Gn.AuthTokenApiUrl
  42. params := url.Values{}
  43. params.Add("client_id", global.CONFIG.Gn.AuthClientId)
  44. params.Add("client_secret", global.CONFIG.Gn.AuthClientSecret)
  45. params.Add("redirect_uri", global.CONFIG.Gn.AuthSSOCallbackUrl)
  46. params.Add("code", code)
  47. params.Add("grant_type", "authorization_code")
  48. result, e := HttpPostAuth(baseUrl, params, "")
  49. if e != nil {
  50. err = fmt.Errorf("统一认证请求失败, %v", e)
  51. return
  52. }
  53. fmt.Printf("Token RequestResult: %s\n", string(result))
  54. if e := json.Unmarshal(result, &resp); e != nil {
  55. err = fmt.Errorf("解析响应失败, %v", e)
  56. return
  57. }
  58. if resp.Error != "" {
  59. err = fmt.Errorf("Token请求失败, Err: %s, ErrMsg: %s ", resp.Error, resp.ErrorDescription)
  60. return
  61. }
  62. return
  63. }
  64. func GetUserInfo(code, token string) (resp *UserBaseInfoResp, err error) {
  65. code = strings.TrimSpace(code)
  66. token = strings.TrimSpace(token)
  67. if code == "" || token == "" {
  68. err = fmt.Errorf("Code和Token不可为空, Code: %s, Token: %s", code, token)
  69. return
  70. }
  71. baseUrl := global.CONFIG.Gn.AuthUserApiUrl
  72. params := url.Values{}
  73. params.Add("code", code)
  74. params.Add("access_token", token)
  75. result, err := HttpPostAuth(baseUrl, params, "")
  76. if err != nil {
  77. return
  78. }
  79. fmt.Printf("UserInfoResult: %s\n", string(result))
  80. err = json.Unmarshal(result, &resp)
  81. if err != nil {
  82. return
  83. }
  84. if resp.Error != "" {
  85. err = fmt.Errorf("UserInfo请求失败, Err: %s, ErrMsg: %s ", resp.Error, resp.ErrorDescription)
  86. return
  87. }
  88. return
  89. }
  90. func HttpPostAuth(postUrl string, params url.Values, contentTypes ...string) ([]byte, error) {
  91. client := &http.Client{}
  92. req, err := http.NewRequest("POST", postUrl, bytes.NewBufferString(params.Encode()))
  93. if err != nil {
  94. return nil, err
  95. }
  96. contentType := "application/x-www-form-urlencoded;charset=utf-8"
  97. if len(contentTypes) > 0 && contentTypes[0] != "" {
  98. contentType = contentTypes[0]
  99. }
  100. req.Header.Set("content-Type", contentType)
  101. resp, err := client.Do(req)
  102. if err != nil {
  103. return nil, err
  104. }
  105. defer func() {
  106. _ = resp.Body.Close()
  107. }()
  108. result, err := io.ReadAll(resp.Body)
  109. if err != nil {
  110. return nil, err
  111. }
  112. postData := fmt.Sprintf("%v", params)
  113. global.FILE_LOG.Debug("统一认证:地址:" + postUrl + ";\n请求参数:" + postData + ";\n返回参数:" + string(result))
  114. if !json.Valid(result) {
  115. err = errors.New("返回参数不是json格式")
  116. }
  117. return result, err
  118. }
  119. func GetUserInfoBySci(token string) (resp *UserBaseInfoResp, err error) {
  120. token = strings.TrimSpace(token)
  121. if token == "" {
  122. err = fmt.Errorf("Token不可为空,Token: %s", token)
  123. return
  124. }
  125. urlPath := fmt.Sprintf(`%s?token=%s`, `getuserinfo`, token)
  126. result, err := HttpGetAuth(urlPath)
  127. if err != nil {
  128. return
  129. }
  130. err = json.Unmarshal(result, &resp)
  131. if err != nil {
  132. return
  133. }
  134. if resp.Error != "" {
  135. err = fmt.Errorf("UserInfo请求失败, Err: %s, ErrMsg: %s ", resp.Error, resp.ErrorDescription)
  136. return
  137. }
  138. return
  139. }
  140. func HttpGetAuth(urlPath string) ([]byte, error) {
  141. if global.CONFIG.Gn.AuthUserApiUrl == `` {
  142. return nil, errors.New("授权平台同步接口地址为空")
  143. }
  144. getUrl := global.CONFIG.Gn.AuthUserApiUrl + urlPath
  145. client := &http.Client{}
  146. req, err := http.NewRequest("GET", getUrl, nil)
  147. if err != nil {
  148. return nil, err
  149. }
  150. resp, err := client.Do(req)
  151. if err != nil {
  152. return nil, err
  153. }
  154. defer resp.Body.Close()
  155. result, err := io.ReadAll(resp.Body)
  156. if err != nil {
  157. return nil, err
  158. }
  159. global.FILE_LOG.Debug("授权平台:地址:" + getUrl + ";\n返回参数:" + string(result))
  160. if !json.Valid(result) {
  161. err = errors.New("返回参数不是json格式")
  162. }
  163. return result, err
  164. }