package com.jiayue.biz.controller; import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; import com.baomidou.mybatisplus.core.toolkit.Wrappers; import com.baomidou.mybatisplus.extension.plugins.pagination.Page; import com.jiayue.common.annotation.Log; import com.jiayue.common.core.controller.BaseController; import com.jiayue.common.core.domain.AjaxResult; import com.jiayue.common.enums.BusinessType; import com.jiayue.common.utils.poi.ExcelUtil; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.security.access.prepost.PreAuthorize; 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.PutMapping; import org.springframework.web.bind.annotation.RequestBody; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RestController; import java.util.Arrays; import java.util.List; import javax.servlet.http.HttpServletResponse; import cn.hutool.core.util.ObjectUtil; import cn.hutool.core.util.StrUtil; import lombok.RequiredArgsConstructor; import com.jiayue.biz.domain.AnalysisLog; import com.jiayue.biz.service.IAnalysisLogService; import com.jiayue.common.core.page.TableDataInfo; /** * 【邮件解析日志】Controller * * @author L.ym * @date 2022-05-23 */ @RequiredArgsConstructor(onConstructor_ = @Autowired) @RestController @RequestMapping("/dataQuery/log") public class AnalysisLogController extends BaseController { private final IAnalysisLogService iAnalysisLogService; /** * 查询邮件解析日志列表 */ @PreAuthorize("@ss.hasPermi('client:log:list')") @GetMapping("/list") public TableDataInfo list(AnalysisLog analysisLog) { startPage(); LambdaQueryWrapper queryWrapper = this.buildQueryParams(analysisLog); List list = iAnalysisLogService.list(queryWrapper); return getDataTable(list); } /** * 查询邮件解析日志列表 */ @GetMapping("/dayLog") public TableDataInfo getDaylist() { return getDataTable(iAnalysisLogService.getAllList()); } /** * 导出邮件解析日志列表 */ @PreAuthorize("@ss.hasPermi('client:log:export')") @Log(title = "【请填写功能名称】", businessType = BusinessType.EXPORT) @PostMapping("/export") public void export(HttpServletResponse response, AnalysisLog analysisLog) { LambdaQueryWrapper queryWrapper = this.buildQueryParams(analysisLog); List list = iAnalysisLogService.list(queryWrapper); ExcelUtil util = new ExcelUtil<>(AnalysisLog. class); util.exportExcel(response, list, "【请填写功能名称】数据"); } /** * 获取邮件解析日志详细信息 */ @PreAuthorize("@ss.hasPermi('client:log:query')") @GetMapping(value = "/{id}") public AjaxResult getInfo(@PathVariable("id") String id) { return AjaxResult.success(iAnalysisLogService.getById(id)); } /** * 新增邮件解析日志 */ @PreAuthorize("@ss.hasPermi('client:log:add')") @Log(title = "【请填写功能名称】", businessType = BusinessType.INSERT) @PostMapping public AjaxResult add(@RequestBody AnalysisLog analysisLog) { return toAjax(iAnalysisLogService.save(analysisLog) ? 1 : 0); } /** * 修改邮件解析日志 */ @PreAuthorize("@ss.hasPermi('client:log:edit')") @Log(title = "【请填写功能名称】", businessType = BusinessType.UPDATE) @PutMapping public AjaxResult edit(@RequestBody AnalysisLog analysisLog) { return toAjax(iAnalysisLogService.updateById(analysisLog) ? 1 : 0); } /** * 删除邮件解析日志 */ @PreAuthorize("@ss.hasPermi('client:log:remove')") @Log(title = "【请填写功能名称】", businessType = BusinessType.DELETE) @DeleteMapping("/{ids}") public AjaxResult remove(@PathVariable String[]ids) { return toAjax(iAnalysisLogService.removeByIds(Arrays.asList(ids)) ? 1 : 0); } /** * 根据时间邮件解析日志 */ @GetMapping("/findByTime") public Page findByTime(Integer current, Integer size , Long startTime, Long endTime, String equipmentId) { return iAnalysisLogService.findByTime(current, size, startTime, endTime, equipmentId); } /** * 构建查询条件 **/ private LambdaQueryWrapper buildQueryParams(AnalysisLog analysisLog) { LambdaQueryWrapper queryWrapper = Wrappers.lambdaQuery(); if (StrUtil.isNotBlank(analysisLog.getEquipmentId())) { queryWrapper.eq(AnalysisLog::getEquipmentId ,analysisLog.getEquipmentId()); } if (ObjectUtil.isNotNull(analysisLog.getStatus())) { queryWrapper.eq(AnalysisLog::getStatus ,analysisLog.getStatus()); } if (ObjectUtil.isNotNull(analysisLog.getTime())) { queryWrapper.eq(AnalysisLog::getTime ,analysisLog.getTime()); } return queryWrapper; } }