| 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 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"); | 
|     } | 
| } |