From a4a7f27053cc28f3506c3fc8ab9ca51ed1f9a5aa Mon Sep 17 00:00:00 2001 From: dengzedong <dengzedong@email> Date: 星期四, 12 六月 2025 09:40:42 +0800 Subject: [PATCH] log.error("调度计算异常: " + System.currentTimeMillis(),ex); --- iailab-module-model/iailab-module-model-biz/src/main/java/com/iailab/module/model/api/controller/admin/McsApiController.java | 90 +++++++++++++++++++++++++++++++++++++++++++++ 1 files changed, 90 insertions(+), 0 deletions(-) diff --git a/iailab-module-model/iailab-module-model-biz/src/main/java/com/iailab/module/model/api/controller/admin/McsApiController.java b/iailab-module-model/iailab-module-model-biz/src/main/java/com/iailab/module/model/api/controller/admin/McsApiController.java index bd37854..ce65aa3 100644 --- a/iailab-module-model/iailab-module-model-biz/src/main/java/com/iailab/module/model/api/controller/admin/McsApiController.java +++ b/iailab-module-model/iailab-module-model-biz/src/main/java/com/iailab/module/model/api/controller/admin/McsApiController.java @@ -12,6 +12,7 @@ import io.swagger.v3.oas.annotations.tags.Tag; import lombok.extern.slf4j.Slf4j; import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.http.MediaType; import org.springframework.util.CollectionUtils; import org.springframework.web.bind.annotation.*; @@ -21,6 +22,8 @@ import java.io.IOException; import java.math.BigDecimal; import java.text.SimpleDateFormat; +import java.time.LocalDateTime; +import java.time.temporal.ChronoUnit; import java.util.*; import static com.iailab.framework.common.pojo.CommonResult.success; @@ -63,6 +66,53 @@ e.printStackTrace(); } return CommonResult.success(respVO); + } + + @PostMapping("/predict-data/missDataList") + @Operation(summary = "缺失历史数据表单") + public CommonResult<List<Map<String,Object>>> getPreDataMissDataList(HttpServletResponse response, HttpServletRequest + request, @RequestBody PreDataBarLineReqVO reqVO) throws Exception { + apiSecurityUtils.validate(request); + + PreDataBarLineRespVO respVO = new PreDataBarLineRespVO(); + List<Map<String,Object>> result = new ArrayList<>(); + try { + respVO = mcsApi.getPreDataCharts(reqVO); + for (int i = 0; i < respVO.getDataViewList().size()-1; i++) { + + Map<String,Object> real = getMissDataMap(respVO.getDataViewList().get(i).getRealData(),respVO.getDataViewList().get(i).getOutId(),respVO.getDataViewList().get(i).getResultName()+"(真实)"); + Map<String,Object> preN = getMissDataMap(respVO.getDataViewList().get(i).getPreDataN(),respVO.getDataViewList().get(i).getOutId(),respVO.getDataViewList().get(i).getResultName()+"(T+N)"); + Map<String,Object> preL = getMissDataMap(respVO.getDataViewList().get(i).getPreDataL(),respVO.getDataViewList().get(i).getOutId(),respVO.getDataViewList().get(i).getResultName()+"(T+L)"); + result.add(real); + result.add(preN); + result.add(preL); + } + } catch (Exception e) { + e.printStackTrace(); + } + return CommonResult.success(result); + } + + private Map<String,Object> getMissDataMap( List<Object[]> list,String outId,String resultName){ + Map<String,Object> missDataMap = new HashMap<>(); + + if (list == null || list.size() < 2) { + return missDataMap; + } + for (int i = 1; i < list.size(); i++) { + LocalDateTime startTime = (LocalDateTime) list.get(i-1)[0]; + LocalDateTime endTime = (LocalDateTime) list.get(i)[0]; + long gap = ChronoUnit.MINUTES.between(startTime, endTime); + if (gap > 10) { + missDataMap.put("outId",outId); + missDataMap.put("resultName",resultName); + missDataMap.put("startTime",startTime); + missDataMap.put("endTime",endTime); + missDataMap.put("random",10); + missDataMap.put("gap",gap); + } + } + return missDataMap; } @PostMapping("/predict-data/item-chart") @@ -282,4 +332,44 @@ mcsApi.updatePredictModelSetting(modelCode, key, value); return success( true); } + + @PostMapping("/schedule-suggest/use-suggest") + @Operation(summary = "采纳建议") + public CommonResult<Boolean> useSuggest(@RequestBody StAlarmAndSuggestReqVO reqVO){ + mcsApi.useSuggest(reqVO); + return success( true); + } + + @PostMapping("/schedule-suggest/cancel-use-suggest") + @Operation(summary = "取消采纳建议") + public CommonResult<Boolean> cancelUseSuggest(@RequestBody StAlarmAndSuggestReqVO reqVO){ + mcsApi.cancelUseSuggest(reqVO); + return success( true); + } + + @PostMapping(value = "/schedule-suggest/operation_record/save", consumes = MediaType.APPLICATION_JSON_VALUE) + @Operation(summary = "保存建议操作记录") + public CommonResult<Boolean> saveSuggestOperationRecord(@RequestBody SuggestOperationRecordReqVO reqVO){ + mcsApi.saveSuggestOperationRecord(reqVO); + return success( true); + } + + @PostMapping("/schedule-suggest/ignore-suggest") + @Operation(summary = "取消采纳建议") + public CommonResult<Boolean> ignoreSuggest(@RequestBody StAlarmAndSuggestReqVO reqVO){ + mcsApi.ignoreSuggest(reqVO); + return success( true); + } + + @GetMapping("/suggest/snapshot/getAllChartData") + @Operation(summary = "根据建议id获取建议快照全部图表数据") + public CommonResult<List<StSuggestSnapshotRecordRespVO>> getSuggestSnapshotAllChartData(@RequestParam("suggestId") String suggestId){ + return success( mcsApi.getSuggestSnapshotAllChartData(suggestId)); + } + + @PostMapping("/suggest/snapshot/conf-det/update-by-ext1") + @Operation(summary = "根据ext1修改快照配置上下限") + public CommonResult<Boolean> updateSuggestSnapshotConfDetByExt1(@RequestBody StSuggestSnapshotConfDetSaveReqVO updateReqVO) { + return success(mcsApi.updateSuggestSnapshotConfDetByExt1(updateReqVO)); + } } \ No newline at end of file -- Gitblit v1.9.3