package com.ruoyi.system.controller;
|
|
import java.util.Iterator;
|
import java.util.List;
|
import java.util.Objects;
|
import javax.servlet.http.HttpServletResponse;
|
|
import com.alibaba.fastjson2.JSONObject;
|
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
|
import com.ruoyi.common.core.utils.StringUtils;
|
import com.ruoyi.system.query.SysOperLogQuery;
|
import io.swagger.annotations.ApiOperation;
|
import org.springframework.beans.factory.annotation.Autowired;
|
import org.springframework.web.bind.annotation.DeleteMapping;
|
import org.springframework.web.bind.annotation.GetMapping;
|
import org.springframework.web.bind.annotation.PathVariable;
|
import org.springframework.web.bind.annotation.PostMapping;
|
import org.springframework.web.bind.annotation.RequestBody;
|
import org.springframework.web.bind.annotation.RequestMapping;
|
import org.springframework.web.bind.annotation.RestController;
|
import com.ruoyi.common.core.utils.poi.ExcelUtil;
|
import com.ruoyi.common.core.web.controller.BaseController;
|
import com.ruoyi.common.core.web.domain.AjaxResult;
|
import com.ruoyi.common.core.web.page.TableDataInfo;
|
import com.ruoyi.common.log.annotation.Log;
|
import com.ruoyi.common.log.enums.BusinessType;
|
import com.ruoyi.common.security.annotation.InnerAuth;
|
import com.ruoyi.common.security.annotation.RequiresPermissions;
|
import com.ruoyi.system.api.domain.SysOperLog;
|
import com.ruoyi.system.service.ISysOperLogService;
|
|
/**
|
* 操作日志记录
|
*
|
* @author ruoyi
|
*/
|
@RestController
|
@RequestMapping("/operlog")
|
public class SysOperlogController extends BaseController
|
{
|
@Autowired
|
private ISysOperLogService operLogService;
|
|
// @RequiresPermissions("system:operlog:list")
|
// @GetMapping("/list")
|
// public TableDataInfo list(SysOperLog operLog)
|
// {
|
// startPage();
|
// List<SysOperLog> list = operLogService.selectOperLogList(operLog);
|
// return getDataTable(list);
|
// }
|
|
@ApiOperation(value = "当前车辆操作日志查询")
|
@PostMapping("/list")
|
public AjaxResult list(@RequestBody SysOperLogQuery query)
|
{
|
LambdaQueryWrapper<SysOperLog> wrapper = new LambdaQueryWrapper<>();
|
wrapper.like(SysOperLog::getTitle,"车辆管理");
|
wrapper.ne(SysOperLog::getBusinessType,1);
|
List<SysOperLog> list = operLogService.list(wrapper);
|
Iterator<SysOperLog> iterator = list.iterator();
|
while (iterator.hasNext()){
|
SysOperLog sysOperLog = iterator.next();
|
String operParam = sysOperLog.getOperParam();
|
JSONObject jsonObject = JSONObject.parseObject(operParam);
|
String carId = jsonObject.getString("carId");
|
if(StringUtils.isNotEmpty(carId) && Objects.nonNull(query.getCarId()) && !carId.equals(String.valueOf(query.getCarId()))){
|
iterator.remove();
|
}
|
}
|
return AjaxResult.success(list);
|
}
|
|
|
@Log(title = "操作日志", businessType = BusinessType.EXPORT)
|
@RequiresPermissions("system:operlog:export")
|
@PostMapping("/export")
|
public void export(HttpServletResponse response, SysOperLog operLog)
|
{
|
List<SysOperLog> list = operLogService.selectOperLogList(operLog);
|
ExcelUtil<SysOperLog> util = new ExcelUtil<SysOperLog>(SysOperLog.class);
|
util.exportExcel(response, list, "操作日志");
|
}
|
|
@Log(title = "操作日志", businessType = BusinessType.DELETE)
|
@RequiresPermissions("system:operlog:remove")
|
@DeleteMapping("/{operIds}")
|
public AjaxResult remove(@PathVariable Long[] operIds)
|
{
|
return toAjax(operLogService.deleteOperLogByIds(operIds));
|
}
|
|
@RequiresPermissions("system:operlog:remove")
|
@Log(title = "操作日志", businessType = BusinessType.CLEAN)
|
@DeleteMapping("/clean")
|
public AjaxResult clean()
|
{
|
operLogService.cleanOperLog();
|
return success();
|
}
|
|
@InnerAuth
|
@PostMapping
|
public AjaxResult add(@RequestBody SysOperLog operLog)
|
{
|
return toAjax(operLogService.insertOperlog(operLog));
|
}
|
}
|