package com.oying.rest; import com.baomidou.mybatisplus.extension.plugins.pagination.Page; import com.oying.annotation.Log; import com.oying.domain.SysLog; import com.oying.domain.dto.SysLogQueryCriteria; import com.oying.service.SysLogService; import io.swagger.annotations.Api; import io.swagger.annotations.ApiOperation; import lombok.RequiredArgsConstructor; import com.oying.utils.PageResult; import com.oying.utils.SecurityUtils; import org.springframework.http.HttpStatus; import org.springframework.http.ResponseEntity; import org.springframework.security.access.prepost.PreAuthorize; import org.springframework.web.bind.annotation.*; import javax.servlet.http.HttpServletResponse; import java.io.IOException; /** * @author Z * @date 2018-11-24 */ @RestController @RequiredArgsConstructor @RequestMapping("/api/logs") @Api(tags = "系统:日志管理") public class SysLogController { private final SysLogService sysLogService; @Log("导出数据") @ApiOperation("导出数据") @GetMapping(value = "/download") @PreAuthorize("@el.check()") public void exportLog(HttpServletResponse response, SysLogQueryCriteria criteria) throws IOException { criteria.setLogType("INFO"); sysLogService.download(sysLogService.queryAll(criteria), response); } @Log("导出错误数据") @ApiOperation("导出错误数据") @GetMapping(value = "/error/download") @PreAuthorize("@el.check()") public void exportErrorLog(HttpServletResponse response, SysLogQueryCriteria criteria) throws IOException { criteria.setLogType("ERROR"); sysLogService.download(sysLogService.queryAll(criteria), response); } @GetMapping @ApiOperation("日志查询") @PreAuthorize("@el.check()") public ResponseEntity> queryLog(SysLogQueryCriteria criteria){ criteria.setLogType("INFO"); Page page = new Page<>(criteria.getPage(), criteria.getSize()); return new ResponseEntity<>(sysLogService.queryAll(criteria,page), HttpStatus.OK); } @GetMapping(value = "/user") @ApiOperation("用户日志查询") public ResponseEntity> queryUserLog(SysLogQueryCriteria criteria){ criteria.setLogType("INFO"); criteria.setUsername(SecurityUtils.getCurrentUsername()); Page page = new Page<>(criteria.getPage(), criteria.getSize()); return new ResponseEntity<>(sysLogService.queryAllByUser(criteria,page), HttpStatus.OK); } @GetMapping(value = "/error") @ApiOperation("错误日志查询") @PreAuthorize("@el.check()") public ResponseEntity> queryErrorLog(SysLogQueryCriteria criteria){ criteria.setLogType("ERROR"); Page page = new Page<>(criteria.getPage(), criteria.getSize()); return new ResponseEntity<>(sysLogService.queryAll(criteria,page), HttpStatus.OK); } @GetMapping(value = "/error/{id}") @ApiOperation("日志异常详情查询") @PreAuthorize("@el.check()") public ResponseEntity queryErrorLogDetail(@PathVariable Long id){ return new ResponseEntity<>(sysLogService.findByErrDetail(id), HttpStatus.OK); } @DeleteMapping(value = "/del/error") @Log("删除所有ERROR日志") @ApiOperation("删除所有ERROR日志") @PreAuthorize("@el.check()") public ResponseEntity delAllErrorLog(){ sysLogService.delAllByError(); return new ResponseEntity<>(HttpStatus.OK); } @DeleteMapping(value = "/del/info") @Log("删除所有INFO日志") @ApiOperation("删除所有INFO日志") @PreAuthorize("@el.check()") public ResponseEntity delAllInfoLog(){ sysLogService.delAllByInfo(); return new ResponseEntity<>(HttpStatus.OK); } }