From 0cd82338d4f3cef13359d32e4b948c03cd0dd959 Mon Sep 17 00:00:00 2001
From: liriming <1343021927@qq.com>
Date: 星期三, 11 十二月 2024 11:59:32 +0800
Subject: [PATCH] MQ

---
 shasteel-biz/src/main/java/com/iailab/module/shasteel/mq/consumer/ModelPredictFinishConsumer.java |   80 +++++++++++++++++++++++++++++++++++++--
 1 files changed, 75 insertions(+), 5 deletions(-)

diff --git a/shasteel-biz/src/main/java/com/iailab/module/shasteel/mq/consumer/ModelPredictFinishConsumer.java b/shasteel-biz/src/main/java/com/iailab/module/shasteel/mq/consumer/ModelPredictFinishConsumer.java
index fac7816..971d2a9 100644
--- a/shasteel-biz/src/main/java/com/iailab/module/shasteel/mq/consumer/ModelPredictFinishConsumer.java
+++ b/shasteel-biz/src/main/java/com/iailab/module/shasteel/mq/consumer/ModelPredictFinishConsumer.java
@@ -1,10 +1,24 @@
 package com.iailab.module.shasteel.mq.consumer;
 
+import com.alibaba.fastjson.JSONObject;
+import com.iailab.framework.common.util.date.DateUtils;
+import com.iailab.module.model.api.mcs.McsApi;
+import com.iailab.module.model.api.mcs.dto.AlarmConfigRespDTO;
+import com.iailab.module.model.api.mcs.dto.AlarmMessageRespDTO;
+import com.iailab.module.model.api.mcs.dto.PreDataJsonReqVO;
 import com.iailab.module.shasteel.mq.config.QueuePredictFinishConfig;
 import lombok.extern.slf4j.Slf4j;
 import org.springframework.amqp.core.Message;
 import org.springframework.amqp.rabbit.annotation.RabbitListener;
 import org.springframework.stereotype.Component;
+import org.springframework.util.CollectionUtils;
+
+import javax.annotation.Resource;
+import java.math.BigDecimal;
+import java.util.ArrayList;
+import java.util.HashMap;
+import java.util.List;
+import java.util.Map;
 
 /**
  * @author PanZhibao
@@ -15,16 +29,72 @@
 @Component
 public class ModelPredictFinishConsumer {
 
+    @Resource
+    private McsApi mcsApi;
+
+    @Resource
+    private AlarmConsumer alarmConsumer;
+
     @RabbitListener(queues = QueuePredictFinishConfig.QUEUE_NAME)
     public void listen(Message message) {
         String routingKey = message.getMessageProperties().getReceivedRoutingKey();
         log.info("routingKey:" + routingKey);
         String messageBody = new String(message.getBody());
         log.info("messageBody:" + messageBody);
-
-
-
-
-
+        JSONObject messageJson = JSONObject.parseObject(messageBody);
+        List<AlarmConfigRespDTO> configList = mcsApi.listAlarmConfig(new HashMap<String, Object>());
+        if (CollectionUtils.isEmpty(configList)) {
+            return;
+        }
+        List<String> OutputIdList = new ArrayList<>();
+        configList.forEach(item -> {
+            OutputIdList.add(item.getOutId());
+        });
+        configList.forEach(item -> {
+            PreDataJsonReqVO reqVO = new PreDataJsonReqVO();
+            reqVO.setPredictTime(DateUtils.parse(messageJson.get("predictTime").toString(), DateUtils.FORMAT_YEAR_MONTH_DAY_HOUR_MINUTE_SECOND));
+            reqVO.setOutputIdList(OutputIdList);
+            Map<String, List<Object[]>> preData = mcsApi.getPreDataCur(reqVO);
+            if (CollectionUtils.isEmpty(preData)) {
+                return;
+            }
+            List<Object[]> result = preData.get(item.getOutId());
+            int toIndex = result.size();
+            if (toIndex <= 0) {
+                return;
+            }
+            int fromIndex = result.size() - item.getCompLength();
+            List<Object[]> predictList = result.subList(fromIndex, toIndex);
+            for (Object[] data : predictList) {
+                BigDecimal dataValue = new BigDecimal(Double.parseDouble(data[1].toString())).setScale(2, BigDecimal.ROUND_HALF_UP);
+                if (!(dataValue.compareTo(item.getLowerLimit()) >= 0 && dataValue.compareTo(item.getUpperLimit()) <= 0)) {
+                    AlarmMessage alarmMessage = new AlarmMessage();
+                    AlarmMessageRespDTO alarmMessageRespDTO = new AlarmMessageRespDTO();
+                    alarmMessageRespDTO.setConfigId(item.getId());
+                    if (dataValue.compareTo(item.getLowerLimit()) < 0) {
+                        alarmMessageRespDTO.setAlarmType("1");//超下限
+                    } else if (dataValue.compareTo(item.getUpperLimit()) > 0) {
+                        alarmMessageRespDTO.setAlarmType("2");//超上限
+                    }
+                    alarmMessageRespDTO.setAlarmTime(DateUtils.parse(data[0].toString(), DateUtils.FORMAT_YEAR_MONTH_DAY_HOUR_MINUTE_SECOND));
+                    JSONObject content = new JSONObject();
+                    content.put("alarmObj", item.getAlarmObj());
+                    content.put("alarmType", alarmMessageRespDTO.getAlarmType());
+                    content.put("unit", item.getUnit());
+                    content.put("overLimitTime", data[0]);
+                    content.put("overLimitValue", dataValue);
+                    alarmMessageRespDTO.setContent(JSONObject.toJSONString(content));
+                    System.out.println("预警消息=" + alarmMessageRespDTO);
+                    alarmMessage.setAlarmMessageRespDTO(alarmMessageRespDTO);
+                    try {
+                        alarmConsumer.process(alarmMessage);
+                    } catch (InterruptedException e) {
+                        throw new RuntimeException(e);
+                    }
+                    break;
+                }
+            }
+            System.out.println(preData);
+        });
     }
 }
\ No newline at end of file

--
Gitblit v1.9.3