package cc.mrbird.febs.server.system.controller; import cc.mrbird.febs.common.core.entity.FebsResponse; import cc.mrbird.febs.common.core.entity.QueryRequest; import cc.mrbird.febs.common.core.entity.constant.StringConstant; import cc.mrbird.febs.common.core.entity.system.Log; import cc.mrbird.febs.common.core.utils.FebsUtil; import cc.mrbird.febs.server.system.annotation.ControllerEndpoint; import cc.mrbird.febs.server.system.service.ILogService; import com.wuwenze.poi.ExcelKit; import lombok.RequiredArgsConstructor; import lombok.extern.slf4j.Slf4j; import org.springframework.security.access.prepost.PreAuthorize; import org.springframework.web.bind.annotation.*; import javax.servlet.http.HttpServletResponse; import javax.validation.constraints.NotBlank; import java.util.List; import java.util.Map; /** * @author MrBird */ @Slf4j @RestController @RequiredArgsConstructor @RequestMapping("log") public class LogController { private final ILogService logService; @GetMapping public FebsResponse logList(Log log, QueryRequest request) { Map dataTable = FebsUtil.getDataTable(this.logService.findLogs(log, request)); return new FebsResponse().data(dataTable); } @DeleteMapping("{ids}") @PreAuthorize("hasAuthority('log:delete')") @ControllerEndpoint(exceptionMessage = "删除日志失败") public void deleteLogss(@NotBlank(message = "{required}") @PathVariable String ids) { String[] logIds = ids.split(StringConstant.COMMA); this.logService.deleteLogs(logIds); } @PostMapping("excel") @PreAuthorize("hasAuthority('log:export')") @ControllerEndpoint(exceptionMessage = "导出Excel失败") public void export(QueryRequest request, Log lg, HttpServletResponse response) { List logs = this.logService.findLogs(lg, request).getRecords(); ExcelKit.$Export(Log.class, response).downXlsx(logs, false); } }