crm_eta.go 5.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180
  1. package services
  2. import (
  3. "encoding/json"
  4. "fmt"
  5. "hongze/hz_crm_api/utils"
  6. "io/ioutil"
  7. "net/http"
  8. "strings"
  9. )
  10. const (
  11. LoginAuthCodeSource = 1
  12. )
  13. // MiddleServerResultData 中间服务响应体
  14. type MiddleServerResultData struct {
  15. Code int `json:"code" description:"状态码"`
  16. Msg string `json:"msg" description:"提示信息"`
  17. Data interface{} `json:"data" description:"返回数据"`
  18. ErrMsg string `json:"-" description:"错误信息,不用返回给前端,只是做日志记录"`
  19. }
  20. // GetLoginAuthCodeReq 获取登录编码请求体
  21. type GetLoginAuthCodeReq struct {
  22. AdminName string `json:"admin_name" description:"用户名"`
  23. Source int `json:"source" description:"来源: 1-CRM; 2-ETA"`
  24. }
  25. // GetAuthCodeFromMiddleServer CRM_ETA服务-获取登录编码
  26. func GetAuthCodeFromMiddleServer(adminName string) (authCode string, err error) {
  27. url := fmt.Sprint(utils.CrmEtaServerUrl, "/api/auth/auth_code")
  28. param := GetLoginAuthCodeReq{
  29. Source: LoginAuthCodeSource,
  30. AdminName: adminName,
  31. }
  32. data, e := json.Marshal(param)
  33. if e != nil {
  34. err = fmt.Errorf("data json marshal err: %s", e.Error())
  35. return
  36. }
  37. body := ioutil.NopCloser(strings.NewReader(string(data)))
  38. client := &http.Client{}
  39. req, e := http.NewRequest("POST", url, body)
  40. if e != nil {
  41. err = fmt.Errorf("http create request err: %s", e.Error())
  42. return
  43. }
  44. contentType := "application/json;charset=utf-8"
  45. req.Header.Set("Content-Type", contentType)
  46. req.Header.Set("Authorization", utils.CrmEtaAuthorization)
  47. resp, e := client.Do(req)
  48. if e != nil {
  49. err = fmt.Errorf("http client do err: %s", e.Error())
  50. return
  51. }
  52. defer func() {
  53. _ = resp.Body.Close()
  54. }()
  55. b, e := ioutil.ReadAll(resp.Body)
  56. if e != nil {
  57. err = fmt.Errorf("resp body read err: %s", e.Error())
  58. return
  59. }
  60. if len(b) == 0 {
  61. err = fmt.Errorf("resp body is empty")
  62. return
  63. }
  64. // 生产环境解密, 注意有个坑前后的双引号
  65. if utils.RunMode == "release" {
  66. str := string(b)
  67. str = strings.Trim(str, `"`)
  68. b = utils.DesBase64Decrypt([]byte(str))
  69. }
  70. result := new(MiddleServerResultData)
  71. if e = json.Unmarshal(b, &result); e != nil {
  72. err = fmt.Errorf("result unmarshal err: %s\nresult: %s", e.Error(), string(b))
  73. return
  74. }
  75. if result.Code != 200 {
  76. err = fmt.Errorf("result: %s", string(b))
  77. return
  78. }
  79. code, ok := result.Data.(string)
  80. if !ok {
  81. err = fmt.Errorf("auth code empty")
  82. return
  83. }
  84. authCode = code
  85. return
  86. }
  87. // GetEtaTokenReq 获取Token请求体
  88. type GetEtaTokenReq struct {
  89. AuthCode string `json:"auth_code"`
  90. }
  91. // GetEtaTokenDataResp 获取Token信息响应体
  92. type GetEtaTokenDataResp struct {
  93. Code int `json:"code" description:"状态码"`
  94. Msg string `json:"msg" description:"提示信息"`
  95. Data GetEtaTokenData `json:"data" description:"返回数据"`
  96. }
  97. // GetEtaTokenData Token数据
  98. type GetEtaTokenData struct {
  99. Authorization string `description:"Auth Token"`
  100. AdminName string `description:"系统用户名称"`
  101. RealName string `description:"系统用户姓名"`
  102. RoleName string `description:"角色名称"`
  103. RoleTypeCode string `description:"角色类型编码"`
  104. SysRoleTypeCode string `description:"角色类型编码"`
  105. AdminId int `description:"系统用户id"`
  106. ProductName string `description:"产品名称:admin,ficc,权益"`
  107. Authority int `description:"管理权限,0:无,1:部门负责人,2:小组负责人,或者ficc销售主管,4:ficc销售组长"`
  108. }
  109. // CodeLoginFromMiddleServer 中间服务-编码登录
  110. func CodeLoginFromMiddleServer(authCode string) (tokenResp GetEtaTokenData, err error) {
  111. url := fmt.Sprint(utils.CrmEtaServerUrl, "/api/auth/crm_token")
  112. param := GetEtaTokenReq{
  113. AuthCode: authCode,
  114. }
  115. data, e := json.Marshal(param)
  116. if e != nil {
  117. err = fmt.Errorf("data json marshal err: %s", e.Error())
  118. return
  119. }
  120. body := ioutil.NopCloser(strings.NewReader(string(data)))
  121. client := &http.Client{}
  122. req, e := http.NewRequest("POST", url, body)
  123. if e != nil {
  124. err = fmt.Errorf("http create request err: %s", e.Error())
  125. return
  126. }
  127. contentType := "application/json;charset=utf-8"
  128. req.Header.Set("Content-Type", contentType)
  129. req.Header.Set("Authorization", utils.CrmEtaAuthorization)
  130. resp, e := client.Do(req)
  131. if e != nil {
  132. err = fmt.Errorf("http client do err: %s", e.Error())
  133. return
  134. }
  135. defer func() {
  136. _ = resp.Body.Close()
  137. }()
  138. b, e := ioutil.ReadAll(resp.Body)
  139. if e != nil {
  140. err = fmt.Errorf("resp body read err: %s", e.Error())
  141. return
  142. }
  143. if len(b) == 0 {
  144. err = fmt.Errorf("resp body is empty")
  145. return
  146. }
  147. // 生产环境解密, 注意有个坑前后的双引号
  148. if utils.RunMode == "release" {
  149. str := string(b)
  150. str = strings.Trim(str, `"`)
  151. b = utils.DesBase64Decrypt([]byte(str))
  152. }
  153. result := new(GetEtaTokenDataResp)
  154. if e = json.Unmarshal(b, &result); e != nil {
  155. err = fmt.Errorf("result unmarshal err: %s\nresult: %s", e.Error(), string(b))
  156. return
  157. }
  158. if result.Code != 200 {
  159. err = fmt.Errorf("result: %s", string(b))
  160. return
  161. }
  162. tokenResp = result.Data
  163. return
  164. }