SysOperLogServiceImpl.java 5.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137
  1. package com.ruoyi.system.service.impl;
  2. import cn.hutool.core.bean.BeanUtil;
  3. import cn.hutool.core.util.ArrayUtil;
  4. import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
  5. import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
  6. import com.ruoyi.common.core.domain.PageQuery;
  7. import com.ruoyi.common.core.domain.dto.OperLogDTO;
  8. import com.ruoyi.common.core.mybatisplus.core.ServicePlusImpl;
  9. import com.ruoyi.common.core.page.TableDataInfo;
  10. import com.ruoyi.common.core.service.OperLogService;
  11. import com.ruoyi.common.utils.StringUtils;
  12. import com.ruoyi.common.utils.ip.AddressUtils;
  13. import com.ruoyi.system.domain.SysOperLog;
  14. import com.ruoyi.system.mapper.SysOperLogMapper;
  15. import com.ruoyi.system.service.ISysOperLogService;
  16. import org.springframework.scheduling.annotation.Async;
  17. import org.springframework.stereotype.Service;
  18. import java.util.Arrays;
  19. import java.util.Date;
  20. import java.util.List;
  21. import java.util.Map;
  22. /**
  23. * 操作日志 服务层处理
  24. *
  25. * @author Lion Li
  26. */
  27. @Service
  28. public class SysOperLogServiceImpl extends ServicePlusImpl<SysOperLogMapper, SysOperLog, SysOperLog> implements ISysOperLogService, OperLogService {
  29. /**
  30. * 操作日志记录
  31. *
  32. * @param operLogDTO 操作日志信息
  33. */
  34. @Async
  35. @Override
  36. public void recordOper(final OperLogDTO operLogDTO) {
  37. SysOperLog operLog = BeanUtil.toBean(operLogDTO, SysOperLog.class);
  38. // 远程查询操作地点
  39. operLog.setOperLocation(AddressUtils.getRealAddressByIP(operLog.getOperIp()));
  40. insertOperlog(operLog);
  41. }
  42. @Override
  43. public TableDataInfo<SysOperLog> selectPageOperLogList(SysOperLog operLog, PageQuery pageQuery) {
  44. Map<String, Object> params = operLog.getParams();
  45. LambdaQueryWrapper<SysOperLog> lqw = new LambdaQueryWrapper<SysOperLog>()
  46. .like(StringUtils.isNotBlank(operLog.getTitle()), SysOperLog::getTitle, operLog.getTitle())
  47. .eq(operLog.getBusinessType() != null && operLog.getBusinessType() > 0,
  48. SysOperLog::getBusinessType, operLog.getBusinessType())
  49. .func(f -> {
  50. if (ArrayUtil.isNotEmpty(operLog.getBusinessTypes())) {
  51. f.in(SysOperLog::getBusinessType, Arrays.asList(operLog.getBusinessTypes()));
  52. }
  53. })
  54. .eq(operLog.getStatus() != null,
  55. SysOperLog::getStatus, operLog.getStatus())
  56. .like(StringUtils.isNotBlank(operLog.getOperName()), SysOperLog::getOperName, operLog.getOperName())
  57. .between(params.get("beginTime") != null && params.get("endTime") != null,
  58. SysOperLog::getOperTime, params.get("beginTime"), params.get("endTime"));
  59. if(StringUtils.isBlank(pageQuery.getOrderByColumn())) {
  60. pageQuery.setOrderByColumn("oper_id").setIsAsc("desc");
  61. }
  62. Page<SysOperLog> page = page(pageQuery.build(), lqw);
  63. return TableDataInfo.build(page);
  64. }
  65. /**
  66. * 新增操作日志
  67. *
  68. * @param operLog 操作日志对象
  69. */
  70. @Override
  71. public void insertOperlog(SysOperLog operLog) {
  72. operLog.setOperTime(new Date());
  73. save(operLog);
  74. }
  75. /**
  76. * 查询系统操作日志集合
  77. *
  78. * @param operLog 操作日志对象
  79. * @return 操作日志集合
  80. */
  81. @Override
  82. public List<SysOperLog> selectOperLogList(SysOperLog operLog) {
  83. Map<String, Object> params = operLog.getParams();
  84. return list(new LambdaQueryWrapper<SysOperLog>()
  85. .like(StringUtils.isNotBlank(operLog.getTitle()), SysOperLog::getTitle, operLog.getTitle())
  86. .eq(operLog.getBusinessType() != null && operLog.getBusinessType() > 0,
  87. SysOperLog::getBusinessType, operLog.getBusinessType())
  88. .func(f -> {
  89. if (ArrayUtil.isNotEmpty(operLog.getBusinessTypes())) {
  90. f.in(SysOperLog::getBusinessType, Arrays.asList(operLog.getBusinessTypes()));
  91. }
  92. })
  93. .eq(operLog.getStatus() != null && operLog.getStatus() > 0,
  94. SysOperLog::getStatus, operLog.getStatus())
  95. .like(StringUtils.isNotBlank(operLog.getOperName()), SysOperLog::getOperName, operLog.getOperName())
  96. .between(params.get("beginTime") != null && params.get("endTime") != null,
  97. SysOperLog::getOperTime, params.get("beginTime"), params.get("endTime"))
  98. .orderByDesc(SysOperLog::getOperId));
  99. }
  100. /**
  101. * 批量删除系统操作日志
  102. *
  103. * @param operIds 需要删除的操作日志ID
  104. * @return 结果
  105. */
  106. @Override
  107. public int deleteOperLogByIds(Long[] operIds) {
  108. return baseMapper.deleteBatchIds(Arrays.asList(operIds));
  109. }
  110. /**
  111. * 查询操作日志详细
  112. *
  113. * @param operId 操作ID
  114. * @return 操作日志对象
  115. */
  116. @Override
  117. public SysOperLog selectOperLogById(Long operId) {
  118. return getById(operId);
  119. }
  120. /**
  121. * 清空操作日志
  122. */
  123. @Override
  124. public void cleanOperLog() {
  125. remove(new LambdaQueryWrapper<>());
  126. }
  127. }