package com.iailab.module.data.api.controller.admin; import com.iailab.framework.common.pojo.CommonResult; import com.iailab.framework.common.pojo.PageResult; import com.iailab.framework.common.util.date.DateUtils; import com.iailab.framework.common.util.object.BeanUtils; import com.iailab.framework.common.util.object.ConvertUtils; import com.iailab.framework.excel.core.util.ExcelUtils; import com.iailab.module.data.api.dto.DeviceValueDTO; import com.iailab.module.data.api.dto.IndexQueryDTO; import com.iailab.module.data.api.dto.echarts.BarLineDTO; import com.iailab.module.data.api.dto.echarts.SeriesItem; import com.iailab.module.data.api.ind.dto.ApiIndItemQueryDTO; import com.iailab.module.data.api.ind.dto.ApiIndItemValueDTO; import com.iailab.module.data.api.plan.PlanItemApi; import com.iailab.module.data.api.plan.dto.ApiPlanDataDTO; import com.iailab.module.data.api.point.DataPointApi; import com.iailab.module.data.api.point.dto.*; import com.iailab.module.data.common.ApiDataQueryDTO; import com.iailab.module.data.common.ApiDataValueDTO; import com.iailab.module.data.common.utils.ApiSecurityUtils; import com.iailab.module.data.ind.collection.IndItemCollector; import com.iailab.module.data.ind.item.vo.IndItemValueVO; import com.iailab.module.data.plan.item.entity.PlanItemEntity; import com.iailab.module.data.plan.item.service.PlanItemService; import com.iailab.module.data.plan.item.vo.PlanItemValueExportVO; import com.iailab.module.data.point.common.PointDataTypeEnum; import com.iailab.module.data.point.dto.DaPointDTO; import com.iailab.module.data.point.service.DaPointService; import io.swagger.v3.oas.annotations.Operation; import io.swagger.v3.oas.annotations.tags.Tag; import lombok.extern.slf4j.Slf4j; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.util.CollectionUtils; import org.springframework.web.bind.annotation.*; import javax.annotation.Resource; import javax.annotation.security.PermitAll; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import java.math.BigDecimal; import java.math.RoundingMode; import java.util.*; import java.util.stream.Collectors; import static com.iailab.framework.common.pojo.CommonResult.success; /** * @author PanZhibao * @Description * @createTime 2023å¹´05月02æ—¥ 10:58:00 */ @Slf4j @RestController @RequestMapping("/data/api") @Tag(name = "æ•°æ®") public class ApiDataController { @Resource private DaPointService daPointService; @Resource private ApiSecurityUtils apiSecurityUtils; @Autowired private DataPointApi dataPointApi; @Autowired private PlanItemApi planItemApi; @Autowired private IndItemCollector indItemCollector; @Autowired private PlanItemService planItemService; @PermitAll @PostMapping("/query-points/history-value") @Operation(summary = "查询多个测点历å²å€¼") public CommonResult<Map<String, List<Map<String, Object>>>> queryPointsRealValue(HttpServletResponse response, HttpServletRequest request, @RequestBody ApiPointsValueQueryDTO queryDto) { Map<String, List<Map<String, Object>>> data = new HashMap<>(); try { apiSecurityUtils.validate(request); data = dataPointApi.queryPointsHistoryValue(queryDto); return success(data); } catch (Exception ex) { return new CommonResult<Map<String, List<Map<String, Object>>>>().setMsg(ex.getMessage()); } } @PermitAll @PostMapping("/query-point/history-value") @Operation(summary = "查询å•ä¸ªæµ‹ç‚¹åŽ†å²å€¼") public CommonResult<List<ApiPointValueDTO>> queryPointHistoryValue(HttpServletResponse response, HttpServletRequest request, @RequestBody ApiPointValueQueryDTO queryDto) { List<ApiPointValueDTO> pointValueList = new ArrayList<>(); try { apiSecurityUtils.validate(request); pointValueList = dataPointApi.queryPointHistoryValue(queryDto); return success(pointValueList); } catch (Exception ex) { return new CommonResult<List<ApiPointValueDTO>>().setMsg(ex.getMessage()); } } @PostMapping("/query-points/real-value") @Operation(summary = "查询多个测点当å‰å€¼") public CommonResult<Map<String, Object>> queryPointsRealValue(HttpServletResponse response, HttpServletRequest request, @RequestBody List<String> pointNos) { Map<String, Object> data = new HashMap<>(); try { apiSecurityUtils.validate(request); data = dataPointApi.queryPointsRealValue(pointNos); return success(data); } catch (Exception ex) { return new CommonResult<Map<String, Object>>().setMsg(ex.getMessage()); } } @PostMapping("/query-points/chart") public CommonResult<BarLineDTO> queryPointsChart(HttpServletResponse response, HttpServletRequest request, @RequestBody IndexQueryDTO dto) { BarLineDTO CommonResult = new BarLineDTO(); try { apiSecurityUtils.validate(request); List<String> legend = new ArrayList<>(); List<SeriesItem> series = new ArrayList<>(); String endDateStr = dto.getEndDate() == null ? DateUtils.format(new Date(), "yyyy-MM-dd HH:mm:ss") : DateUtils.format(dto.getEndDate(), "yyyy-MM-dd HH:mm:ss"); Date endDate = DateUtils.parse(endDateStr, "yyyy-MM-dd HH:mm"); Date startDate = dto.getStartDate() == null ? DateUtils.addDateHours(endDate, -2) : dto.getStartDate(); List<String> categories = DateUtils.getTimeScale(startDate, endDate, dto.getGranularity() == null ? 60 : dto.getGranularity()); if (CollectionUtils.isEmpty(dto.getCodes())) { return new CommonResult<BarLineDTO>().setData(CommonResult); } List<DaPointDTO> pointList = new ArrayList<>(); dto.getCodes().forEach(item -> { pointList.add(daPointService.getByNo(item)); }); pointList.forEach(item -> { legend.add(item.getPointName()); SeriesItem seriesItem = new SeriesItem(); seriesItem.setName(item.getPointName()); ApiPointValueQueryDTO queryDto = new ApiPointValueQueryDTO(); queryDto.setStart(startDate); queryDto.setEnd(endDate); queryDto.setPointNo(item.getPointNo()); List<ApiPointValueDTO> list = dataPointApi.queryPointHistoryValue(queryDto); List<Object[]> sData = list.stream().map(dataItem -> { Object[] valueArray = new Object[]{DateUtils.format(dataItem.getT(), DateUtils.FORMAT_YEAR_MONTH_DAY_HOUR_MINUTE_SECOND), getFormatValue(item.getDataType(), dataItem.getV())}; return valueArray; }).collect(Collectors.toList()); seriesItem.setData(sData); series.add(seriesItem); }); CommonResult.setLegend(legend); CommonResult.setCategories(categories); CommonResult.setSeries(series); } catch (Exception ex) { ex.printStackTrace(); } return new CommonResult<BarLineDTO>().setData(CommonResult); } private Object getFormatValue(String dataType, Object value) { if (!PointDataTypeEnum.BOOLEAN.getCode().equals(dataType)) { BigDecimal decValue = new BigDecimal(value.toString()); if (PointDataTypeEnum.FLOAT.getCode().equals(dataType)) { return decValue.setScale(2, BigDecimal.ROUND_HALF_UP); } else if (PointDataTypeEnum.INT.getCode().equals(dataType)) { decValue = decValue.setScale(0, BigDecimal.ROUND_HALF_UP); } } return value; } @GetMapping("/device-value") public List<DeviceValueDTO> getDeviceValue(@RequestParam Map<String, Object> params) { List<DeviceValueDTO> CommonResult = new ArrayList<>(); if (params.get("pointNos") == null) { return CommonResult; } List<String> pointNos = Arrays.asList(params.get("pointNos").toString().split(",")); Map<String, Object> data = dataPointApi.queryPointsRealValue(pointNos); if (!CollectionUtils.isEmpty(data)) { data.forEach((k, v) -> { DeviceValueDTO dto = new DeviceValueDTO(); dto.setDataId(k); dto.setValue(new BigDecimal(v.toString())); CommonResult.add(dto); }); } return CommonResult; } @PermitAll @PostMapping("/query-plan/history-value") @Operation(summary = "查询å•ä¸ªè®¡åˆ’历å²å€¼") public CommonResult<List<ApiDataValueDTO>> queryPlanItemHistoryValue(HttpServletResponse response, HttpServletRequest request, @RequestBody ApiDataQueryDTO dto) { List<ApiDataValueDTO> result = new ArrayList<>(); try { apiSecurityUtils.validate(request); result = planItemApi.queryPlanItemHistoryValue(dto); return new CommonResult<List<ApiDataValueDTO>>().setData(result); } catch (Exception ex) { return new CommonResult<List<ApiDataValueDTO>>().setMsg(ex.getMessage()); } } @PermitAll @PostMapping("/query-plan/record-value") @Operation(summary = "查询å•ä¸ªè®¡åˆ’历å²å€¼") public CommonResult<LinkedHashMap<String, List<ApiPlanDataDTO>>> queryPlanItemRecordValue(HttpServletResponse response, HttpServletRequest request, @RequestBody ApiDataQueryDTO dto) { LinkedHashMap<String, List<ApiPlanDataDTO>> result = new LinkedHashMap<>(); try { apiSecurityUtils.validate(request); result = planItemApi.queryPlanItemRecordValue(dto); return new CommonResult<LinkedHashMap<String, List<ApiPlanDataDTO>>>().setData(result); } catch (Exception ex) { return new CommonResult<LinkedHashMap<String, List<ApiPlanDataDTO>>>().setMsg(ex.getMessage()); } } @PostMapping("/query-plans/chart") public CommonResult<BarLineDTO> queryPlansChart(HttpServletResponse response, HttpServletRequest request, @RequestBody ApiDataQueryDTO dto) { BarLineDTO CommonResult = new BarLineDTO(); try { apiSecurityUtils.validate(request); List<String> legend = new ArrayList<>(); List<SeriesItem> series = new ArrayList<>(); Calendar calendar = Calendar.getInstance(); calendar.set(Calendar.MILLISECOND, 0); calendar.set(Calendar.SECOND, 0); Date endDate = dto.getEnd() == null ? DateUtils.addDateHours(calendar.getTime(), 2) : dto.getEnd(); Date startDate = dto.getStart() == null ? calendar.getTime() : dto.getStart(); List<String> categories = DateUtils.getTimeScale(startDate, endDate, dto.getGranularity() == null ? 60 : dto.getGranularity()); if (CollectionUtils.isEmpty(dto.getItemNos())) { return new CommonResult<BarLineDTO>().setData(CommonResult); } List<PlanItemEntity> planItemList = new ArrayList<>(); dto.getItemNos().forEach(item -> { planItemList.add(planItemService.getInfoByNo(item)); }); planItemList.forEach(item -> { legend.add(item.getItemName()); SeriesItem seriesItem = new SeriesItem(); seriesItem.setName(item.getItemName()); ApiDataQueryDTO queryDto = new ApiDataQueryDTO(); queryDto.setItemNo(item.getItemNo()); queryDto.setStart(startDate); queryDto.setEnd(endDate); List<ApiDataValueDTO> list = planItemApi.queryPlanItemHistoryValue(queryDto); List<Object[]> sData = list.stream().map(dataItem -> { Object[] valueArray = new Object[]{DateUtils.format(dataItem.getDataTime(), DateUtils.FORMAT_YEAR_MONTH_DAY_HOUR_MINUTE_SECOND), dataItem.getDataValue()}; return valueArray; }).collect(Collectors.toList()); seriesItem.setData(sData); series.add(seriesItem); }); CommonResult.setLegend(legend); CommonResult.setCategories(categories); CommonResult.setSeries(series); } catch (Exception ex) { ex.printStackTrace(); } return new CommonResult<BarLineDTO>().setData(CommonResult); } @PostMapping("/export-plan/history-value") @Operation(summary = "导出计划数æ®") public void exportPlanHistoryValue(HttpServletResponse response, HttpServletRequest request, @RequestBody ApiDataQueryDTO dto) throws Exception { apiSecurityUtils.validate(request); Calendar calendar = Calendar.getInstance(); calendar.set(Calendar.MILLISECOND, 0); calendar.set(Calendar.SECOND, 0); Date endDate = dto.getEnd() == null ? DateUtils.addDateHours(calendar.getTime(), 2) : dto.getEnd(); Date startDate = dto.getStart() == null ? calendar.getTime() : dto.getStart(); ApiDataQueryDTO queryDto = new ApiDataQueryDTO(); queryDto.setItemNo(dto.getItemNo()); queryDto.setStart(startDate); queryDto.setEnd(endDate); List<ApiDataValueDTO> list = planItemApi.queryPlanItemHistoryValue(queryDto); List<PlanItemValueExportVO> exportList = list.stream().map(item -> { PlanItemValueExportVO exportVO = new PlanItemValueExportVO(); exportVO.setDataTime(DateUtils.format(item.getDataTime(), DateUtils.FORMAT_YEAR_MONTH_DAY_HOUR_MINUTE_SECOND)); exportVO.setDataValue(BigDecimal.valueOf(item.getDataValue()).setScale(0, RoundingMode.HALF_UP).toString()); return exportVO; }).collect(Collectors.toList()); ExcelUtils.write(response, "计划数æ®.xls", "计划数æ®", PlanItemValueExportVO.class, exportList); } @PermitAll @GetMapping("/query-ind/default-value") @Operation(summary = "æŸ¥è¯¢æŒ‡æ ‡é»˜è®¤å€¼") public CommonResult<List<ApiIndItemValueDTO>> queryIndItemDefaultValue(HttpServletResponse response, HttpServletRequest request,@RequestParam String itemNo) throws Exception { apiSecurityUtils.validate(request); List<IndItemValueVO> list = indItemCollector.queryValue(itemNo); List<ApiIndItemValueDTO> dtoList = new ArrayList<>(); list.forEach(item -> { ApiIndItemValueDTO dto = new ApiIndItemValueDTO(); dto.setDataTime(item.getDataTime()); dto.setDataValue(item.getDataValue().doubleValue()); dtoList.add(dto); }); return success(dtoList); } @PermitAll @GetMapping("/query-ind/history-value") @Operation(summary = "æŸ¥è¯¢æŒ‡æ ‡åŽ†å²å€¼") public CommonResult<List<ApiIndItemValueDTO>> queryIndItemHistoryValue(@RequestParam ApiIndItemQueryDTO dto) { List<IndItemValueVO> list = indItemCollector.queryValue(dto.getItemNo(), dto.getStart(), dto.getEnd()); return success(ConvertUtils.sourceToTarget(list, ApiIndItemValueDTO.class)); } @PermitAll @PostMapping("/query-math-point/current-value") @Operation(summary = "æ ¹æ®è®¡ç®—点编å·æŸ¥è¯¢æµ‹ç‚¹é›†åˆ") public CommonResult<PageResult<ApiPointDTO>> queryMathPointCurrentValue(@RequestBody ApiPointPageReqVO reqVO) { PageResult<ApiPointDTO> data = dataPointApi.queryMathPointCurrentValue(reqVO); return success(data); } }