package com.dy.pipIrrBase.rtuUpgrade.task;
|
|
import com.alibaba.excel.EasyExcel;
|
import com.alibaba.excel.support.ExcelTypeEnum;
|
import com.dy.common.aop.SsoAop;
|
import com.dy.common.webUtil.BaseResponse;
|
import com.dy.common.webUtil.BaseResponseUtils;
|
import com.dy.common.webUtil.QueryResultVo;
|
import com.dy.common.webUtil.ResultCodeMsg;
|
import com.dy.pipIrrGlobal.pojoUg.UgRtuTask;
|
import com.dy.pipIrrGlobal.voUg.VoUgResult;
|
import com.dy.pipIrrGlobal.voUg.VoUgRtuResult;
|
import io.swagger.v3.oas.annotations.Operation;
|
import io.swagger.v3.oas.annotations.media.Content;
|
import io.swagger.v3.oas.annotations.media.Schema;
|
import io.swagger.v3.oas.annotations.responses.ApiResponse;
|
import io.swagger.v3.oas.annotations.responses.ApiResponses;
|
import io.swagger.v3.oas.annotations.tags.Tag;
|
import jakarta.servlet.http.HttpServletResponse;
|
import lombok.extern.slf4j.Slf4j;
|
import org.springframework.beans.factory.annotation.Autowired;
|
import org.springframework.http.MediaType;
|
import org.springframework.web.bind.annotation.GetMapping;
|
import org.springframework.web.bind.annotation.RequestMapping;
|
import org.springframework.web.bind.annotation.RequestMethod;
|
import org.springframework.web.bind.annotation.RestController;
|
|
import java.io.UnsupportedEncodingException;
|
import java.net.URLEncoder;
|
import java.util.List;
|
|
/**
|
* @Author: liurunyu
|
* @Date: 2024/11/13 16:10
|
* @Description
|
*/
|
@Slf4j
|
@Tag(name = "RTU升级结果", description = "RTU升级结果")
|
@RestController
|
@RequestMapping(path = "ugRtuResult")
|
@SuppressWarnings("unchecked")
|
//java版本越高,对泛型约束越严,所以配置SuppressWarnings("unchecked")
|
public class UgRtuResultCtrl {
|
|
private UgRtuResultSv sv;
|
|
@Autowired
|
private void setSv(UgRtuResultSv sv) { this.sv = sv; }
|
|
/**
|
* 客户端分页查询一个升级任务的所有控制器
|
* @return 一些RTU升级任务数据
|
*/
|
@Operation(summary = "分页查询一个升级任务中所有控制器升级结查", description = "客户端分页查询一个升级任务中所有控制器升级结查")
|
@ApiResponses(value = {
|
@ApiResponse(
|
responseCode = ResultCodeMsg.RsCode.SUCCESS_CODE,
|
description = "返回一些RTU升级任务控制器升级数据(BaseResponse.content:QueryResultVo[{}])",
|
content = {@Content(mediaType = MediaType.APPLICATION_JSON_VALUE,
|
schema = @Schema(implementation = UgRtuTask.class))}
|
)
|
})
|
@GetMapping(path = "/some")
|
@SsoAop()
|
public BaseResponse<QueryResultVo<List<VoUgResult>>> some(QueryUgResultVo vo) {
|
if (vo.taskId == null) {
|
return BaseResponseUtils.buildErrorMsg("升级任务id不能为空");
|
}
|
if(vo.state != null && vo.state == 1){
|
//查询升级成功的
|
vo.fail = null ;
|
}
|
if(vo.state == null && vo.fail != null){
|
//查询升级失败的
|
vo.state = 0 ;
|
}
|
QueryResultVo<List<VoUgResult>> res = this.sv.selectSome(vo);
|
return BaseResponseUtils.buildSuccess(res);
|
}
|
|
/**
|
* 导出升级结果RTU列表
|
* @param response
|
*/
|
@RequestMapping(value = "/exportAll", method = RequestMethod.GET)
|
@SsoAop()
|
public void exportAll(HttpServletResponse response, QueryUgResultVo vo) throws Exception {
|
if(vo.state != null && vo.state == 1){
|
//查询升级成功的
|
vo.fail = null ;
|
}
|
if(vo.state == null && vo.fail != null){
|
//查询升级失败的
|
vo.state = 0 ;
|
}
|
setExcelRespProp(response, "升级结果列表");
|
List<VoUgResult> rsList = this.sv.selectAll(vo);
|
EasyExcel.write(response.getOutputStream())
|
.head(VoUgResult.class)
|
.excelType(ExcelTypeEnum.XLSX)
|
.sheet("升级结果列表")
|
.doWrite(rsList);
|
}
|
|
|
/**
|
* 设置excel下载响应头属性
|
*/
|
private void setExcelRespProp(HttpServletResponse response, String rawFileName) throws UnsupportedEncodingException {
|
response.setContentType("application/vnd.openxmlformats-officedocument.spreadsheetml.sheet");
|
response.setCharacterEncoding("utf-8");
|
String fileName = URLEncoder.encode(rawFileName, "UTF-8").replaceAll("\\+", "%20");
|
response.setHeader("Content-disposition", "attachment;filename*=utf-8''" + fileName + ".xlsx");
|
}
|
}
|