sys_login_log.go 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135
  1. package service
  2. import (
  3. "context"
  4. "dashoo.cn/micro/app/dao"
  5. "dashoo.cn/micro/app/model"
  6. "dashoo.cn/opms_libary/micro_srv"
  7. "dashoo.cn/opms_libary/myerrors"
  8. "dashoo.cn/opms_libary/utils"
  9. "github.com/gogf/gf/frame/g"
  10. "github.com/gogf/gf/os/grpool"
  11. "github.com/gogf/gf/os/gtime"
  12. "github.com/gogf/gf/util/gconv"
  13. "github.com/mssola/user_agent"
  14. )
  15. type LoginLogService struct {
  16. *contextService
  17. Dao *dao.SysLoginDao
  18. Pool *grpool.Pool
  19. }
  20. func NewLoginLogService(ctx context.Context) (svc *LoginLogService, err error) {
  21. svc = new(LoginLogService)
  22. if svc.contextService, err = svc.Init(ctx); err != nil {
  23. return nil, err
  24. }
  25. svc.Dao = dao.NewSysLoginDao(svc.Tenant)
  26. svc.Pool = grpool.New(100)
  27. return svc, nil
  28. }
  29. func (s *LoginLogService) Invoke(ctx context.Context, userName string, err error) {
  30. s.Pool.Add(func() {
  31. //写入日志数据
  32. s.Create(ctx, userName, err)
  33. })
  34. }
  35. func (s *LoginLogService) GetList(req *model.SysLoginLogSearchReq) (total int, list []*model.SysLogin, err error) {
  36. db := s.Dao.M
  37. order := "info_id DESC"
  38. if req.LoginName != "" {
  39. db = db.WhereLike("login_name", "%"+req.LoginName+"%")
  40. }
  41. if req.Status != "" {
  42. db = db.Where("status", gconv.Int(req.Status))
  43. }
  44. if req.Ipaddr != "" {
  45. db = db.WhereLike("ipaddr", "%"+req.Ipaddr+"%")
  46. }
  47. if req.LoginLocation != "" {
  48. db = db.WhereLike("login_location", "%"+req.LoginLocation+"%")
  49. }
  50. if req.BeginTime != "" {
  51. db = db.WhereGTE("login_time", req.BeginTime)
  52. }
  53. if req.EndTime != "" {
  54. db = db.WhereLTE("login_time", req.EndTime)
  55. }
  56. if req.SortName != "" {
  57. if req.SortOrder != "" {
  58. order = req.SortName + " " + req.SortOrder
  59. } else {
  60. order = req.SortName + " DESC"
  61. }
  62. }
  63. total, err = db.Count()
  64. if err != nil {
  65. g.Log().Error(err)
  66. err = myerrors.TipsError("获取总行数失败")
  67. return
  68. }
  69. err = db.Page(req.GetPage()).Order(order).Scan(&list)
  70. if err != nil {
  71. g.Log().Error(err)
  72. err = myerrors.TipsError("获取数据失败")
  73. }
  74. return
  75. }
  76. // Create 记录登录日志
  77. func (s *LoginLogService) Create(ctx context.Context, userName string, loginErr error) {
  78. clientIP, userAgent, err := micro_srv.GetBrowserInfo(ctx)
  79. if err != nil {
  80. // 非必要信息,只输出错误日志
  81. g.Log().Error(err)
  82. }
  83. ua := user_agent.New(userAgent)
  84. browser, _ := ua.Browser()
  85. status := "10"
  86. msg := "登录成功"
  87. if loginErr != nil {
  88. status = "20"
  89. msg = err.Error()
  90. }
  91. loginData := &model.SysLogin{
  92. UserName: userName,
  93. Ipaddr: clientIP,
  94. LoginLocation: utils.GetCityByIp(clientIP),
  95. Browser: browser,
  96. Os: ua.OS(),
  97. Status: status,
  98. Msg: msg,
  99. LoginTime: gtime.Now(),
  100. }
  101. _, err = s.Dao.Insert(loginData)
  102. if err != nil {
  103. // 非必要信息,只输出错误日志
  104. g.Log().Error(err)
  105. }
  106. }
  107. func (s *LoginLogService) DeleteByIds(ids []int64) (err error) {
  108. if len(ids) == 0 {
  109. err = myerrors.TipsError("参数错误")
  110. return
  111. }
  112. _, err = s.Dao.Delete("info_id in (?)", ids)
  113. if err != nil {
  114. g.Log().Error(err)
  115. err = myerrors.TipsError("删除失败")
  116. }
  117. return
  118. }
  119. func (s *LoginLogService) ClearLoginLog() (err error) {
  120. _, err = s.Dao.DB.Exec("truncate " + s.Dao.Table)
  121. if err != nil {
  122. g.Log().Error(err)
  123. err = myerrors.TipsError("清除失败")
  124. }
  125. return
  126. }