auth.go 6.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246
  1. package controller
  2. import (
  3. "encoding/base64"
  4. "eta/eta_bridge/controller/resp"
  5. "eta/eta_bridge/global"
  6. "eta/eta_bridge/models/crm"
  7. "eta/eta_bridge/models/eta"
  8. "eta/eta_bridge/models/rddp"
  9. "eta/eta_bridge/models/request"
  10. "eta/eta_bridge/models/response"
  11. "eta/eta_bridge/services"
  12. "eta/eta_bridge/utils"
  13. "fmt"
  14. "github.com/gin-gonic/gin"
  15. "github.com/go-playground/validator/v10"
  16. "time"
  17. )
  18. type AuthController struct{}
  19. // CreateAuthCode
  20. // @Description 生成编码
  21. // @Success 200 {string} string "获取成功"
  22. // @Router /auth/auth_code [post]
  23. func (a *AuthController) CreateAuthCode(c *gin.Context) {
  24. var req request.CreateAuthCodeReq
  25. err := c.Bind(&req)
  26. if err != nil {
  27. errs, ok := err.(validator.ValidationErrors)
  28. if !ok {
  29. resp.FailData("参数解析失败", "Err:"+err.Error(), c)
  30. return
  31. }
  32. resp.FailData("参数解析失败", errs.Translate(global.Trans), c)
  33. return
  34. }
  35. prefix := map[int]string{
  36. utils.SOURCE_CRM_FLAG: utils.CACHE_ETA_AUTH_CODE_PREFIX,
  37. utils.SOURCE_ETA_FLAG: utils.CACHE_CRM_AUTH_CODE_PREFIX,
  38. }
  39. str := base64.URLEncoding.EncodeToString([]byte(req.AdminName))
  40. key := fmt.Sprint(prefix[req.Source], str)
  41. // 是否已生成但未消费
  42. exist, _ := global.Rc.RedisString(key)
  43. if exist != "" {
  44. resp.OkData("获取成功", str, c)
  45. return
  46. }
  47. if global.Rc.SetNX(key, req.AdminName, utils.GetTodayLastSecond()) {
  48. resp.OkData("获取成功", str, c)
  49. return
  50. }
  51. return
  52. }
  53. // GetEtaToken
  54. // @Description 换取ETA系统Token
  55. // @Success 200 {string} string "操作成功"
  56. // @Router /auth/eta_token [post]
  57. func (a *AuthController) GetEtaToken(c *gin.Context) {
  58. var req request.TokenLoginReq
  59. err := c.Bind(&req)
  60. if err != nil {
  61. errs, ok := err.(validator.ValidationErrors)
  62. if !ok {
  63. resp.FailData("参数解析失败", "Err:"+err.Error(), c)
  64. return
  65. }
  66. resp.FailData("参数解析失败", errs.Translate(global.Trans), c)
  67. return
  68. }
  69. authCode := req.AuthCode
  70. if authCode == `` {
  71. authCode = req.Code
  72. }
  73. if authCode == `` {
  74. resp.FailData("参数解析失败", "code or auth_code为空", c)
  75. return
  76. }
  77. key := fmt.Sprint(utils.CACHE_ETA_AUTH_CODE_PREFIX, authCode)
  78. adminName, e := global.Rc.RedisString(key)
  79. if e != nil {
  80. resp.FailMsg("获取失败", "获取失败, Redis Err: "+e.Error(), c)
  81. return
  82. }
  83. if adminName == "" {
  84. resp.Fail("获取失败, 无效编码", c)
  85. return
  86. }
  87. // 清除AuthCode
  88. defer func() {
  89. _ = global.Rc.Delete(key)
  90. }()
  91. // 获取用户信息
  92. sysUser, e := eta.GetSysUserByAdminName(adminName)
  93. if e != nil {
  94. if e == utils.ErrNoRow {
  95. resp.Fail("用户不存在", c)
  96. return
  97. }
  98. resp.FailMsg("获取失败", "获取用户信息失败, err: "+e.Error(), c)
  99. return
  100. }
  101. // 生成登录session
  102. respResult, _, err, errMsg := services.CreateEtaSession(sysUser)
  103. if err != nil {
  104. if errMsg == `` {
  105. errMsg = "获取失败"
  106. }
  107. resp.FailMsg("获取失败", "生成登录session失败, err: "+e.Error(), c)
  108. return
  109. }
  110. resp.OkData("获取成功", respResult, c)
  111. }
  112. // GetCrmToken
  113. // @Description 换取CRM系统Token
  114. // @Success 200 {string} string "操作成功"
  115. // @Router /auth/crm_token [post]
  116. func (a *AuthController) GetCrmToken(c *gin.Context) {
  117. var req request.TokenLoginReq
  118. err := c.Bind(&req)
  119. if err != nil {
  120. errs, ok := err.(validator.ValidationErrors)
  121. if !ok {
  122. resp.FailData("参数解析失败", "Err:"+err.Error(), c)
  123. return
  124. }
  125. resp.FailData("参数解析失败", errs.Translate(global.Trans), c)
  126. return
  127. }
  128. if req.AuthCode == `` {
  129. resp.FailData("参数解析失败", "auth_code为空", c)
  130. return
  131. }
  132. key := fmt.Sprint(utils.CACHE_CRM_AUTH_CODE_PREFIX, req.AuthCode)
  133. adminName, e := global.Rc.RedisString(key)
  134. if e != nil {
  135. resp.FailMsg("获取失败", "获取失败, Redis Err: "+e.Error(), c)
  136. return
  137. }
  138. if adminName == "" {
  139. resp.Fail("获取失败, 无效编码", c)
  140. return
  141. }
  142. // 清除AuthCode
  143. defer func() {
  144. _ = global.Rc.Delete(key)
  145. }()
  146. // 获取用户信息
  147. sysUser, e := crm.GetSysUserByAdminName(adminName)
  148. if e != nil {
  149. if e == utils.ErrNoRow {
  150. resp.Fail("用户不存在", c)
  151. return
  152. }
  153. resp.FailMsg("获取失败", "获取用户信息失败, err: "+e.Error(), c)
  154. return
  155. }
  156. var token string
  157. account := utils.MD5(adminName)
  158. // 获取用户未过期的session, 避免过于频繁生成token
  159. expired := time.Now().AddDate(0, 0, 1).Format(utils.FormatDateTime)
  160. session, _ := rddp.GetUserUnexpiredSysSession(adminName, expired)
  161. if session != nil && session.AccessToken != "" {
  162. token = session.AccessToken
  163. } else {
  164. token = utils.GenToken(account)
  165. sysSession := new(rddp.SysSession)
  166. sysSession.UserName = adminName
  167. sysSession.SysUserId = sysUser.AdminId
  168. sysSession.ExpiredTime = time.Now().AddDate(0, 0, 90)
  169. sysSession.IsRemember = 1
  170. sysSession.CreatedTime = time.Now()
  171. sysSession.LastUpdatedTime = time.Now()
  172. sysSession.AccessToken = token
  173. if e := rddp.AddSysSession(sysSession); e != nil {
  174. resp.FailMsg("获取失败", "新增session失败, err: "+e.Error(), c)
  175. return
  176. }
  177. }
  178. login := new(response.LoginResp)
  179. login.Authorization = token
  180. login.Authorization = "authorization=" + token + "$account=" + account
  181. login.RealName = sysUser.RealName
  182. login.AdminId = sysUser.AdminId
  183. login.AdminName = sysUser.AdminName
  184. login.RoleName = sysUser.RoleName
  185. login.SysRoleTypeCode = sysUser.RoleTypeCode //系统角色编码
  186. login.RoleTypeCode = sysUser.RoleTypeCode
  187. login.Authority = sysUser.Authority
  188. // 判断实际的角色类型
  189. if sysUser.RoleTypeCode == utils.ROLE_TYPE_CODE_FICC_GROUP {
  190. login.RoleTypeCode = utils.ROLE_TYPE_CODE_FICC_SELLER
  191. }
  192. if sysUser.RoleTypeCode == utils.ROLE_TYPE_CODE_FICC_TEAM {
  193. login.RoleTypeCode = utils.ROLE_TYPE_CODE_FICC_SELLER
  194. }
  195. if sysUser.RoleTypeCode == utils.ROLE_TYPE_CODE_FICC_DEPARTMENT {
  196. login.RoleTypeCode = utils.ROLE_TYPE_CODE_FICC_SELLER
  197. }
  198. if sysUser.RoleTypeCode == utils.ROLE_TYPE_CODE_RAI_GROUP {
  199. login.RoleTypeCode = utils.ROLE_TYPE_CODE_RAI_SELLER
  200. }
  201. if sysUser.RoleTypeCode == utils.ROLE_TYPE_CODE_RAI_DEPARTMENT {
  202. login.RoleTypeCode = utils.ROLE_TYPE_CODE_RAI_SELLER
  203. }
  204. if sysUser.RoleName == utils.ROLE_NAME_FICC_DIRECTOR {
  205. login.RoleTypeCode = utils.ROLE_TYPE_CODE_FICC_SELLER
  206. }
  207. // 角色产品ID
  208. productId := services.GetProductId(sysUser.RoleTypeCode)
  209. productIdName := map[int]string{
  210. 0: "admin",
  211. utils.COMPANY_PRODUCT_FICC_ID: utils.COMPANY_PRODUCT_FICC_NAME,
  212. utils.COMPANY_PRODUCT_RAI_ID: utils.COMPANY_PRODUCT_RAI_NAME,
  213. }
  214. login.ProductName = productIdName[productId]
  215. // 新增登录记录
  216. {
  217. record := new(rddp.SysUserLoginRecord)
  218. record.Uid = sysUser.AdminId
  219. record.UserName = adminName
  220. record.Ip = c.RemoteIP()
  221. record.Stage = "login"
  222. record.CreateTime = time.Now()
  223. go rddp.AddSysUserLoginRecord(record)
  224. }
  225. resp.OkData("获取成功", login, c)
  226. }