auth.go 8.1 KB

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