From e62ad1beef37ffc8f4aa5a886069a6641ca3df2e Mon Sep 17 00:00:00 2001
From: 潘志宝 <979469083@qq.com>
Date: 星期五, 28 三月 2025 10:19:01 +0800
Subject: [PATCH] ASDC

---
 iailab-module-data/iailab-module-data-biz/src/main/java/com/iailab/module/data/channel/http/collector/HttpCollector.java             |    5 +
 iailab-module-data/iailab-module-data-biz/src/main/java/com/iailab/module/data/channel/http/collector/asdb/HttpCollectorForAsdc.java |  120 ++++++++++++++++++++++++++++++++++++++++
 iailab-module-data/iailab-module-data-biz/src/main/java/com/iailab/module/data/point/collection/handler/MeasureHandle.java           |   12 ++++
 iailab-module-data/iailab-module-data-biz/src/main/java/com/iailab/module/data/channel/http/collector/SourceApiEnum.java             |    3 
 4 files changed, 139 insertions(+), 1 deletions(-)

diff --git a/iailab-module-data/iailab-module-data-biz/src/main/java/com/iailab/module/data/channel/http/collector/HttpCollector.java b/iailab-module-data/iailab-module-data-biz/src/main/java/com/iailab/module/data/channel/http/collector/HttpCollector.java
index 4ed6805..6d2a18e 100644
--- a/iailab-module-data/iailab-module-data-biz/src/main/java/com/iailab/module/data/channel/http/collector/HttpCollector.java
+++ b/iailab-module-data/iailab-module-data-biz/src/main/java/com/iailab/module/data/channel/http/collector/HttpCollector.java
@@ -37,6 +37,9 @@
     @Autowired
     private HttpCollectorForAsde httpCollectorForAsde;
 
+    @Autowired
+    private HttpCollectorForAsde httpCollectorForAsdc;
+
     public Object getTagValue(String apiId, String tag) {
         HttpApiEntity httpApi = httpApiService.getFromCatch(apiId);
         if (httpApi == null) {
@@ -51,6 +54,8 @@
             valueMap = httpCollectorForAsdb.getTagValues(apiId, tagNames);
         } else if (SourceApiEnum.ASDE.getCode().equals(httpApi.getCode())) {
             valueMap = httpCollectorForAsde.getTagValues(apiId, tagNames);
+        } else if (SourceApiEnum.ASDC.getCode().equals(httpApi.getCode())) {
+            valueMap = httpCollectorForAsdc.getTagValues(apiId, tagNames);
         }
         if (valueMap.get(tag) == null) {
             return CommonConstant.BAD_VALUE;
diff --git a/iailab-module-data/iailab-module-data-biz/src/main/java/com/iailab/module/data/channel/http/collector/SourceApiEnum.java b/iailab-module-data/iailab-module-data-biz/src/main/java/com/iailab/module/data/channel/http/collector/SourceApiEnum.java
index 6355c3f..7a5d41d 100644
--- a/iailab-module-data/iailab-module-data-biz/src/main/java/com/iailab/module/data/channel/http/collector/SourceApiEnum.java
+++ b/iailab-module-data/iailab-module-data-biz/src/main/java/com/iailab/module/data/channel/http/collector/SourceApiEnum.java
@@ -13,7 +13,8 @@
 public enum SourceApiEnum {
     iHyperDB("iHyperDB", "宝信IHD"),
     ASDB("ASDB", "鞍钢DB"),
-    ASDE("ASDE", "鞍钢电力");
+    ASDE("ASDE", "鞍钢电力"),
+    ASDC("ASDC", "鞍钢煤气");
 
     private String code;
     private String desc;
diff --git a/iailab-module-data/iailab-module-data-biz/src/main/java/com/iailab/module/data/channel/http/collector/asdb/HttpCollectorForAsdc.java b/iailab-module-data/iailab-module-data-biz/src/main/java/com/iailab/module/data/channel/http/collector/asdb/HttpCollectorForAsdc.java
new file mode 100644
index 0000000..94b1e61
--- /dev/null
+++ b/iailab-module-data/iailab-module-data-biz/src/main/java/com/iailab/module/data/channel/http/collector/asdb/HttpCollectorForAsdc.java
@@ -0,0 +1,120 @@
+package com.iailab.module.data.channel.http.collector.asdb;
+
+import com.alibaba.fastjson.JSON;
+import com.iailab.framework.common.constant.CommonConstant;
+import com.iailab.framework.common.util.http.HttpUtils;
+import com.iailab.module.data.channel.http.collector.asdb.vo.HttpAsdbRespDataVO;
+import com.iailab.module.data.channel.http.entity.HttpApiEntity;
+import com.iailab.module.data.channel.http.service.HttpApiService;
+import com.iailab.module.data.common.enums.DataSourceType;
+import com.iailab.module.data.common.utils.TagUtils;
+import lombok.extern.slf4j.Slf4j;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.data.redis.core.RedisTemplate;
+import org.springframework.stereotype.Component;
+import org.springframework.util.CollectionUtils;
+
+import java.math.BigDecimal;
+import java.util.Date;
+import java.util.HashMap;
+import java.util.List;
+import java.util.Map;
+import java.util.concurrent.TimeUnit;
+
+/**
+ * @author PanZhibao
+ * @Description
+ * @createTime 2025年03月28日
+ */
+@Slf4j
+@Component
+public class HttpCollectorForAsdc {
+    private static Map<String, HttpApiEntity> apiMap = new HashMap<>();
+
+    @Autowired
+    private HttpApiService httpApiService;
+
+    @Autowired
+    private RedisTemplate redisTemplate;
+
+    public static final long offset = 10;
+
+    private HttpApiEntity getHttpApi(String id) {
+        if (apiMap.containsKey(id)) {
+            return apiMap.get(id);
+        }
+        HttpApiEntity httpApi = httpApiService.info(id);
+        apiMap.put(id, httpApi);
+        return httpApi;
+    }
+
+    public BigDecimal getTagValue(String sourceId, String tagNo) {
+        BigDecimal value = CommonConstant.BAD_VALUE;
+        HttpApiEntity httpApi = this.getHttpApi(sourceId);
+        //先查缓存
+        String catchKey = "IailabData:" + httpApi.getCode() + ":" + tagNo;
+        if (redisTemplate.hasKey(catchKey)) {
+            log.info("查找IailabData缓存: " + catchKey);
+            return new BigDecimal(redisTemplate.opsForValue().get(catchKey).toString());
+        }
+        String responseStr = HttpUtils.sendGet(httpApi.getUrl(), null, "");
+        List<HttpAsdbRespDataVO> dataList = JSON.parseArray(responseStr, HttpAsdbRespDataVO.class);
+        log.info("存入IailabData缓存: " + catchKey);
+        dataList.forEach(item -> {
+            redisTemplate.opsForValue().set(catchKey, item.getValue().toString(), offset, TimeUnit.SECONDS);
+        });
+        for (HttpAsdbRespDataVO data : dataList){
+            if (tagNo.equals(data.getPoint())){
+                value = data.getValue();
+                break;
+            }
+        }
+        return value;
+    }
+
+    public Map<String, Object> getTagValues(String sourceId, List<String> tagNames) {
+        Map<String, Object> result = new HashMap<>();
+        try {
+            if (CollectionUtils.isEmpty(tagNames)) {
+                return result;
+            }
+            for (String tagName : tagNames) {
+                result.put(tagName, getTagValue(sourceId, tagName));
+            }
+        } catch (Exception ex) {
+            log.info("getCurrentValue异常");
+            ex.printStackTrace();
+            throw ex;
+        }
+        return result;
+    }
+
+    public Map<String, Object> getTagValues(List<Object[]> params, Date collectTime) {
+        Map<String, Object> result = new HashMap<>();
+        if (CollectionUtils.isEmpty(params)) {
+            return new HashMap<>();
+        }
+        try {
+            HttpApiEntity httpApi = this.getHttpApi(params.get(0)[0].toString());
+            this.getByHtp(httpApi.getUrl(), httpApi.getCode(), result, params);
+        } catch (Exception ex) {
+            ex.printStackTrace();
+        }
+        return result;
+    }
+
+    private void getByHtp(String url, String sourceName, Map<String, Object> result, List<Object[]> params) {
+        String responseStr = HttpUtils.sendGet(url, null, "");
+        List<HttpAsdbRespDataVO> dataList = JSON.parseArray(responseStr, HttpAsdbRespDataVO.class);
+        Map<String, HttpAsdbRespDataVO> valueGroup = new HashMap<>();
+        for (HttpAsdbRespDataVO data : dataList) {
+            valueGroup.put(data.getPoint(), data);
+        }
+        for (Object[] item : params) {
+            if (valueGroup.containsKey(item[1].toString())) {
+                HttpAsdbRespDataVO data = valueGroup.get(item[1].toString());
+                result.put(TagUtils.genTagId(DataSourceType.HTTP.getCode(), sourceName, data.getPoint()), data.getValue());
+            }
+        }
+    }
+}
\ No newline at end of file
diff --git a/iailab-module-data/iailab-module-data-biz/src/main/java/com/iailab/module/data/point/collection/handler/MeasureHandle.java b/iailab-module-data/iailab-module-data-biz/src/main/java/com/iailab/module/data/point/collection/handler/MeasureHandle.java
index d3c6d26..6e06075 100644
--- a/iailab-module-data/iailab-module-data-biz/src/main/java/com/iailab/module/data/point/collection/handler/MeasureHandle.java
+++ b/iailab-module-data/iailab-module-data-biz/src/main/java/com/iailab/module/data/point/collection/handler/MeasureHandle.java
@@ -3,6 +3,7 @@
 import com.iailab.framework.common.util.string.StrUtils;
 import com.iailab.module.data.channel.http.collector.SourceApiEnum;
 import com.iailab.module.data.channel.http.collector.asdb.HttpCollectorForAsdb;
+import com.iailab.module.data.channel.http.collector.asdb.HttpCollectorForAsdc;
 import com.iailab.module.data.channel.http.collector.asdb.HttpCollectorForAsde;
 import com.iailab.module.data.channel.http.collector.ihdb.HttpCollectorForIhd;
 import com.iailab.module.data.channel.opcda.collector.OpcDACollector;
@@ -63,6 +64,9 @@
     @Autowired
     private HttpCollectorForAsde httpCollectorForAsde;
 
+    @Autowired
+    private HttpCollectorForAsdc httpCollectorForAsdc;
+
     @Resource
     private DaPointService daPointService;
 
@@ -83,6 +87,7 @@
         List<Object[]> httpTagIhd = new ArrayList<>();
         List<Object[]> httpTagAsdb = new ArrayList<>();
         List<Object[]> httpTagAsde = new ArrayList<>();
+        List<Object[]> httpTagAsdc = new ArrayList<>();
 
         dtos.stream().forEach(item -> {
             if (DataSourceType.OPCUA.getCode().equals(item.getSourceType())) {
@@ -105,6 +110,10 @@
                 } else if (SourceApiEnum.ASDE.getCode().equals(item.getSourceName())) {
                     if (item.getTagNo() != null && item.getDimension() != null && item.getValueType() != null) {
                         httpTagAsde.add(new Object[]{item.getSourceId(), item.getTagNo(), item.getDimension(), item.getValueType()});
+                    }
+                } else if (SourceApiEnum.ASDC.getCode().equals(item.getSourceName())) {
+                    if (item.getTagNo() != null && item.getDimension() != null && item.getValueType() != null) {
+                        httpTagAsdc.add(new Object[]{item.getSourceId(), item.getTagNo(), item.getDimension(), item.getValueType()});
                     }
                 }
             }
@@ -132,6 +141,9 @@
         if (!CollectionUtils.isEmpty(httpTagAsde)) {
             tagValues.putAll(httpCollectorForAsde.getTagValues(httpTagAsde, collectTime));
         }
+        if (!CollectionUtils.isEmpty(httpTagAsdc)) {
+            tagValues.putAll(httpCollectorForAsdc.getTagValues(httpTagAsdc, collectTime));
+        }
         this.toCommonResult(collectTime, dtos, tagValues, dataMap, result,listGood,listBad);
         log.info("测量点处理结束");
         return result;

--
Gitblit v1.9.3