sys_oper_log.go 4.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172
  1. package service
  2. import (
  3. comModel "dashoo.cn/micro/app/common/model"
  4. "dashoo.cn/micro/app/dao"
  5. "dashoo.cn/micro/app/model"
  6. "dashoo.cn/opms_libary/utils"
  7. "github.com/gogf/gf/encoding/gjson"
  8. "github.com/gogf/gf/errors/gerror"
  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. )
  14. type sysOperLog struct {
  15. Pool *grpool.Pool
  16. }
  17. var SysOperLog = &sysOperLog{
  18. Pool: grpool.New(100),
  19. }
  20. func (s *sysOperLog) Invoke(data *model.SysOperLogAdd) {
  21. s.Pool.Add(func() {
  22. //写入日志数据
  23. s.OperationLogAdd(data)
  24. })
  25. }
  26. // OperationLogAdd 添加操作日志
  27. func (s sysOperLog) OperationLogAdd(data *model.SysOperLogAdd) {
  28. menuTitle := ""
  29. if data.Menu != nil {
  30. menuTitle = data.Menu.MenuName
  31. }
  32. err, dept := data.User.GetDept()
  33. if err != nil {
  34. g.Log().Error(err)
  35. return
  36. }
  37. insertData := g.Map{
  38. dao.SysOperLog.Columns.Title: menuTitle,
  39. dao.SysOperLog.Columns.Method: data.Url.Path,
  40. dao.SysOperLog.Columns.RequestMethod: data.Method,
  41. dao.SysOperLog.Columns.OperatorType: data.OperatorType,
  42. dao.SysOperLog.Columns.OperName: data.User.UserName,
  43. dao.SysOperLog.Columns.DeptName: dept.DeptName,
  44. dao.SysOperLog.Columns.OperIp: data.ClientIp,
  45. dao.SysOperLog.Columns.OperLocation: utils.GetCityByIp(data.ClientIp),
  46. dao.SysOperLog.Columns.OperTime: gtime.Now(),
  47. }
  48. rawQuery := data.Url.RawQuery
  49. if rawQuery != "" {
  50. rawQuery = "?" + rawQuery
  51. }
  52. insertData[dao.SysOperLog.Columns.OperUrl] = data.Url.Path + rawQuery
  53. if data.Params != nil {
  54. if v, ok := data.Params["apiReturnRes"]; ok {
  55. res := gconv.Map(v)
  56. if gconv.Int(res["code"]) == 0 {
  57. insertData[dao.SysOperLog.Columns.Status] = 1
  58. } else {
  59. insertData[dao.SysOperLog.Columns.Status] = 0
  60. }
  61. if _, ok = res["data"]; ok {
  62. delete(res, "data")
  63. }
  64. b, _ := gjson.Encode(res)
  65. if len(b) > 0 {
  66. insertData[dao.SysOperLog.Columns.JsonResult] = string(b)
  67. }
  68. delete(data.Params, "apiReturnRes")
  69. }
  70. b, _ := gjson.Encode(data.Params)
  71. if len(b) > 0 {
  72. insertData[dao.SysOperLog.Columns.OperParam] = string(b)
  73. }
  74. }
  75. _, err = dao.SysOperLog.Insert(insertData)
  76. if err != nil {
  77. g.Log().Error(err)
  78. }
  79. }
  80. func (s *sysOperLog) OperationLogListByPage(req *model.SysOperLogSearchReq) (total, page int, list []*model.SysOperLog, err error) {
  81. model := dao.SysOperLog.M
  82. order := "oper_id DESC"
  83. if req != nil {
  84. if req.OperName != "" {
  85. model = model.Where("oper_name like ?", "%"+req.OperName+"%")
  86. }
  87. if req.Title != "" {
  88. model = model.Where("title like ?", "%"+req.Title+"%")
  89. }
  90. if req.RequestMethod != "" {
  91. model = model.Where("request_method = ?", req.RequestMethod)
  92. }
  93. if req.Status != "" {
  94. model = model.Where("status", gconv.Int(req.Status))
  95. }
  96. if req.BeginTime != "" {
  97. model = model.Where("oper_time >=", req.BeginTime)
  98. }
  99. if req.EndTime != "" {
  100. model = model.Where("oper_time <=", req.EndTime)
  101. }
  102. if req.SortName != "" {
  103. if req.SortOrder != "" {
  104. order = req.SortName + " " + req.SortOrder
  105. } else {
  106. order = req.SortName + " DESC"
  107. }
  108. }
  109. }
  110. total, err = model.Count()
  111. if err != nil {
  112. g.Log().Error(err)
  113. err = gerror.New("获取总行数失败")
  114. return
  115. }
  116. if req.PageNum == 0 {
  117. req.PageNum = 1
  118. }
  119. page = req.PageNum
  120. if req.PageSize == 0 {
  121. req.PageSize = comModel.PageSize
  122. }
  123. err = model.Page(page, req.PageSize).Order(order).Scan(&list)
  124. if err != nil {
  125. g.Log().Error(err)
  126. err = gerror.New("获取数据失败")
  127. }
  128. return
  129. }
  130. func (s *sysOperLog) DeleteOperationLogByIds(ids []int) (err error) {
  131. if len(ids) == 0 {
  132. err = gerror.New("参数错误")
  133. return
  134. }
  135. _, err = dao.SysOperLog.Delete("oper_id in (?)", ids)
  136. if err != nil {
  137. g.Log().Error(err)
  138. err = gerror.New("删除失败")
  139. }
  140. return
  141. }
  142. func (s *sysOperLog) GetOperationLogById(id int64) (log *model.SysOperLog, err error) {
  143. if id == 0 {
  144. err = gerror.New("参数错误")
  145. return
  146. }
  147. err = dao.SysOperLog.Where("oper_id", id).Scan(&log)
  148. if err != nil {
  149. g.Log().Error(err)
  150. }
  151. if err != nil || log == nil {
  152. err = gerror.New("获取操作日志失败")
  153. }
  154. return
  155. }
  156. func (s *sysOperLog) ClearOperationLog() (err error) {
  157. _, err = g.DB().Exec("truncate " + dao.SysOperLog.Table)
  158. if err != nil {
  159. g.Log().Error(err)
  160. err = gerror.New("清除失败")
  161. }
  162. return
  163. }