Jay
2025-06-13 f067cd34563c054887edd315270eaa7b6deb0ccf
iailab-module-model/iailab-module-model-biz/src/main/java/com/iailab/module/model/api/controller/admin/McsApiController.java
@@ -5,13 +5,16 @@
import com.iailab.framework.common.util.object.BeanUtils;
import com.iailab.module.model.api.mcs.McsApi;
import com.iailab.module.model.api.mcs.dto.*;
import com.iailab.module.model.api.mdk.dto.MdkPredictDataDTO;
import com.iailab.module.model.api.mdk.dto.StScheduleRecordVO;
import com.iailab.module.model.common.utils.ApiSecurityUtils;
import com.iailab.module.model.common.utils.ExcelUtil;
import com.iailab.module.model.mdk.vo.DataValueVO;
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.http.MediaType;
import org.springframework.util.CollectionUtils;
import org.springframework.web.bind.annotation.*;
@@ -21,6 +24,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;
@@ -65,6 +70,53 @@
        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")
    @Operation(summary = "预测数据图表")
    public CommonResult<PreDataItemChartRespVO> getPreDataItemChart(HttpServletResponse response, HttpServletRequest
@@ -100,6 +152,13 @@
        reqVO.setPredictTime(new Date());
        Map<String, List<Object[]>> map = mcsApi.getPreDataCur(reqVO);
        return CommonResult.success(map);
    }
    @PostMapping("/predict-data/tn-value")
    @Operation(summary = "获取T+N预测数据")
    public CommonResult<List<MdkPredictDataDTO>> getPredictTnValue(PredictTnValueReqVO reqVO) {
        List<MdkPredictDataDTO> list = mcsApi.getPredictTnValue(reqVO);
        return success(list);
    }
    @GetMapping("/predict-data/exportValue")
@@ -275,4 +334,51 @@
        List<ScheduleSuggestRespDTO> data = mcsApi.getLastSuggest(params);
        return CommonResult.success(data);
    }
    @GetMapping("/predict/model/setting/update")
    @Operation(summary = "修改调度模型配置")
    public CommonResult<Boolean> updatePredictModelSetting(@RequestParam("modelCode") String modelCode, @RequestParam("key") String key, @RequestParam("value") String value){
        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));
    }
}