admin.go 2.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182
  1. package controllers
  2. import (
  3. "encoding/json"
  4. "hongze/hongze_mobile_admin/models/request/admin"
  5. admin3 "hongze/hongze_mobile_admin/models/response/admin"
  6. admin2 "hongze/hongze_mobile_admin/models/tables/admin"
  7. "hongze/hongze_mobile_admin/models/tables/h5_admin_session"
  8. "hongze/hongze_mobile_admin/services"
  9. "hongze/hongze_mobile_admin/utils"
  10. "time"
  11. )
  12. type AdminCommon struct {
  13. BaseAuth
  14. }
  15. // @Title 用户账号、密码登录接口
  16. // @Description 用户账号、密码登录接口
  17. // @Param request body admin.LoginReq true "type json string"
  18. // @Success 200 {object} admin.LoginResp
  19. // @router /login [post]
  20. func (this *AdminCommon) Login() {
  21. var req admin.LoginReq
  22. err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  23. if err != nil {
  24. this.FailWithMessage("参数解析异常!", "参数解析失败,Err:"+err.Error())
  25. return
  26. }
  27. if req.Username == "" {
  28. this.FailWithMessage("请输入账号", "请输入账号")
  29. return
  30. }
  31. if req.Password == "" {
  32. this.FailWithMessage("请输入密码", "请输入密码")
  33. return
  34. }
  35. sysUser, err := admin2.CheckAdmin(req.Username, req.Password)
  36. if err != nil {
  37. if err.Error() == utils.ErrNoRow() {
  38. this.FailWithMessage("登录失败,账号或密码错误", "登录失败,账号或密码错误,Err:"+err.Error())
  39. return
  40. }
  41. this.FailWithMessage("登录失败,账号或密码错误", "登录失败,Err:"+err.Error())
  42. return
  43. }
  44. if sysUser == nil {
  45. this.FailWithMessage("登录失败,账号或密码错误", "登录失败,admin_wx is nil")
  46. return
  47. }
  48. if sysUser.Enabled == 0 {
  49. this.FailWithMessage("您的账号已被禁用,如需登录,请联系管理员", "您的账号已被禁用,如需登录,请联系管理员")
  50. return
  51. }
  52. err = h5_admin_session.UpdateSession(this.Session.SessionId, sysUser.AdminId, time.Now().AddDate(0, 0, 90))
  53. if err != nil {
  54. this.FailWithMessage("登录失败", "变更session信息失败,Err:"+err.Error())
  55. return
  56. }
  57. resp := admin3.LoginResp{
  58. RealName: sysUser.RealName,
  59. AdminName: sysUser.AdminName,
  60. RoleName: sysUser.RoleName,
  61. RoleTypeCode: sysUser.RoleTypeCode,
  62. }
  63. resp.AdminId = sysUser.AdminId
  64. var productName string
  65. productId := services.GetProductId(sysUser.RoleTypeCode)
  66. if productId == 1 {
  67. productName = utils.COMPANY_PRODUCT_FICC_NAME
  68. } else if productId == 2 {
  69. productName = utils.COMPANY_PRODUCT_RAI_NAME
  70. } else {
  71. productName = "admin"
  72. }
  73. resp.ProductName = productName
  74. resp.Authority = sysUser.Authority
  75. this.OkDetailed(resp, "登录成功")
  76. }