admin.go 2.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102
  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. "hongze/hongze_mobile_admin/models/tables/h5_admin_session"
  7. "hongze/hongze_mobile_admin/services"
  8. "hongze/hongze_mobile_admin/utils"
  9. "time"
  10. )
  11. type AdminCommon struct {
  12. BaseAuth
  13. }
  14. // Login
  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 (c *AdminCommon) Login() {
  21. var req admin.LoginReq
  22. err := json.Unmarshal(c.Ctx.Input.RequestBody, &req)
  23. if err != nil {
  24. c.FailWithMessage("参数解析异常!", "参数解析失败,Err:"+err.Error())
  25. return
  26. }
  27. if req.Username == "" {
  28. c.FailWithMessage("请输入账号", "请输入账号")
  29. return
  30. }
  31. if req.Password == "" {
  32. c.FailWithMessage("请输入密码", "请输入密码")
  33. return
  34. }
  35. adminWx, err := services.BindWxUser(c.Session.OpenId, req.Username, req.Password, utils.WxPlatform)
  36. if err != nil {
  37. if err.Error() == utils.ErrNoRow() {
  38. c.FailWithMessage("登录失败,账号或密码错误", "登录失败,账号或密码错误")
  39. return
  40. }
  41. c.FailWithMessage("登录失败", "登录失败,Err:"+err.Error())
  42. return
  43. }
  44. if adminWx.Enabled != 1 {
  45. c.FailWithMessage("账户信息异常!", "账户状态异常,不允许登录")
  46. return
  47. }
  48. err = h5_admin_session.UpdateSession(c.Session.SessionId, adminWx.AdminId, time.Now().AddDate(0, 0, 90))
  49. if err != nil {
  50. c.FailWithMessage("登录失败", "变更session信息失败,Err:"+err.Error())
  51. return
  52. }
  53. resp := admin3.LoginResp{
  54. RealName: adminWx.RealName,
  55. AdminName: adminWx.AdminName,
  56. RoleName: adminWx.RoleName,
  57. RoleTypeCode: adminWx.RoleTypeCode,
  58. AdminId: adminWx.AdminId,
  59. DepartmentName: adminWx.DepartmentName,
  60. GroupName: adminWx.GroupName,
  61. }
  62. resp.AdminId = adminWx.AdminId
  63. var productName string
  64. productId := services.GetProductId(adminWx.RoleTypeCode)
  65. if productId == 1 {
  66. productName = utils.COMPANY_PRODUCT_FICC_NAME
  67. } else if productId == 2 {
  68. productName = utils.COMPANY_PRODUCT_RAI_NAME
  69. } else {
  70. productName = "admin"
  71. }
  72. resp.ProductName = productName
  73. resp.Authority = adminWx.Authority
  74. resp.Headimgurl = adminWx.Headimgurl
  75. c.OkDetailed(resp, "登录成功")
  76. }
  77. // Logout
  78. // @Title 用户退出登录接口
  79. // @Description 用户退出登录接口
  80. // @Success Ret=200 退出成功
  81. // @router /logout [post]
  82. func (c *AdminCommon) Logout() {
  83. adminWx := c.AdminWx
  84. err := services.UnbindWxUser(adminWx.OpenId)
  85. if err != nil {
  86. c.FailWithMessage("退出失败", "退出失败,Err:"+err.Error())
  87. return
  88. }
  89. err = h5_admin_session.UpdateSession(c.Session.SessionId, 0, time.Now().AddDate(0, 0, 10))
  90. if err != nil {
  91. c.FailWithMessage("退出失败", "变更session信息失败,Err:"+err.Error())
  92. return
  93. }
  94. c.OkWithMessage("退出成功")
  95. }