SysOperLogServiceImpl.java 4.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121
  1. package com.ruoyi.system.service.impl;
  2. import cn.hutool.core.util.ArrayUtil;
  3. import com.ruoyi.common.utils.StringUtils;
  4. import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
  5. import com.ruoyi.common.core.mybatisplus.core.ServicePlusImpl;
  6. import com.ruoyi.common.core.page.TableDataInfo;
  7. import com.ruoyi.common.utils.PageUtils;
  8. import com.ruoyi.system.domain.SysOperLog;
  9. import com.ruoyi.system.mapper.SysOperLogMapper;
  10. import com.ruoyi.system.service.ISysOperLogService;
  11. import org.springframework.stereotype.Service;
  12. import java.util.Arrays;
  13. import java.util.Date;
  14. import java.util.List;
  15. import java.util.Map;
  16. /**
  17. * 操作日志 服务层处理
  18. *
  19. * @author ruoyi
  20. */
  21. @Service
  22. public class SysOperLogServiceImpl extends ServicePlusImpl<SysOperLogMapper, SysOperLog, SysOperLog> implements ISysOperLogService {
  23. @Override
  24. public TableDataInfo<SysOperLog> selectPageOperLogList(SysOperLog operLog) {
  25. Map<String, Object> params = operLog.getParams();
  26. LambdaQueryWrapper<SysOperLog> lqw = new LambdaQueryWrapper<SysOperLog>()
  27. .like(StringUtils.isNotBlank(operLog.getTitle()), SysOperLog::getTitle, operLog.getTitle())
  28. .eq(operLog.getBusinessType() != null && operLog.getBusinessType() > 0,
  29. SysOperLog::getBusinessType, operLog.getBusinessType())
  30. .func(f -> {
  31. if (ArrayUtil.isNotEmpty(operLog.getBusinessTypes())) {
  32. f.in(SysOperLog::getBusinessType, Arrays.asList(operLog.getBusinessTypes()));
  33. }
  34. })
  35. .eq(operLog.getStatus() != null && operLog.getStatus() > 0,
  36. SysOperLog::getStatus, operLog.getStatus())
  37. .like(StringUtils.isNotBlank(operLog.getOperName()), SysOperLog::getOperName, operLog.getOperName())
  38. .apply(StringUtils.isNotEmpty(params.get("beginTime")),
  39. "date_format(oper_time,'%y%m%d') >= date_format({0},'%y%m%d')",
  40. params.get("beginTime"))
  41. .apply(StringUtils.isNotEmpty(params.get("endTime")),
  42. "date_format(oper_time,'%y%m%d') <= date_format({0},'%y%m%d')",
  43. params.get("endTime"));
  44. return PageUtils.buildDataInfo(page(PageUtils.buildPage("oper_id","desc"), lqw));
  45. }
  46. /**
  47. * 新增操作日志
  48. *
  49. * @param operLog 操作日志对象
  50. */
  51. @Override
  52. public void insertOperlog(SysOperLog operLog) {
  53. operLog.setOperTime(new Date());
  54. save(operLog);
  55. }
  56. /**
  57. * 查询系统操作日志集合
  58. *
  59. * @param operLog 操作日志对象
  60. * @return 操作日志集合
  61. */
  62. @Override
  63. public List<SysOperLog> selectOperLogList(SysOperLog operLog) {
  64. Map<String, Object> params = operLog.getParams();
  65. return list(new LambdaQueryWrapper<SysOperLog>()
  66. .like(StringUtils.isNotBlank(operLog.getTitle()),SysOperLog::getTitle,operLog.getTitle())
  67. .eq(operLog.getBusinessType() != null && operLog.getBusinessType() > 0,
  68. SysOperLog::getBusinessType,operLog.getBusinessType())
  69. .func(f -> {
  70. if (ArrayUtil.isNotEmpty(operLog.getBusinessTypes())){
  71. f.in(SysOperLog::getBusinessType, Arrays.asList(operLog.getBusinessTypes()));
  72. }
  73. })
  74. .eq(operLog.getStatus() != null && operLog.getStatus() > 0,
  75. SysOperLog::getStatus,operLog.getStatus())
  76. .like(StringUtils.isNotBlank(operLog.getOperName()),SysOperLog::getOperName,operLog.getOperName())
  77. .apply(StringUtils.isNotEmpty(params.get("beginTime")),
  78. "date_format(oper_time,'%y%m%d') >= date_format({0},'%y%m%d')",
  79. params.get("beginTime"))
  80. .apply(StringUtils.isNotEmpty(params.get("endTime")),
  81. "date_format(oper_time,'%y%m%d') <= date_format({0},'%y%m%d')",
  82. params.get("endTime"))
  83. .orderByDesc(SysOperLog::getOperId));
  84. }
  85. /**
  86. * 批量删除系统操作日志
  87. *
  88. * @param operIds 需要删除的操作日志ID
  89. * @return 结果
  90. */
  91. @Override
  92. public int deleteOperLogByIds(Long[] operIds) {
  93. return baseMapper.deleteBatchIds(Arrays.asList(operIds));
  94. }
  95. /**
  96. * 查询操作日志详细
  97. *
  98. * @param operId 操作ID
  99. * @return 操作日志对象
  100. */
  101. @Override
  102. public SysOperLog selectOperLogById(Long operId) {
  103. return getById(operId);
  104. }
  105. /**
  106. * 清空操作日志
  107. */
  108. @Override
  109. public void cleanOperLog() {
  110. remove(new LambdaQueryWrapper<>());
  111. }
  112. }