From 1f5947ccb5b02817dbe5aaae943c0a7fcfc2cd62 Mon Sep 17 00:00:00 2001 From: jiazx0107@163.com <jiazx0107@163.com> Date: 星期四, 09 十一月 2023 00:54:24 +0800 Subject: [PATCH] Merge remote-tracking branch 'origin/igds-api-gateway' into igds-api-gateway --- src/main/java/com/fzzy/gateway/service/GatewayDeviceService.java | 192 +++++++++++++++++++++++++++++++++++++---------- 1 files changed, 151 insertions(+), 41 deletions(-) diff --git a/src/main/java/com/fzzy/gateway/service/GatewayDeviceService.java b/src/main/java/com/fzzy/gateway/service/GatewayDeviceService.java index b3b59e9..55c6cf2 100644 --- a/src/main/java/com/fzzy/gateway/service/GatewayDeviceService.java +++ b/src/main/java/com/fzzy/gateway/service/GatewayDeviceService.java @@ -1,9 +1,11 @@ package com.fzzy.gateway.service; +import com.alibaba.fastjson.JSON; import com.alibaba.fastjson2.JSONObject; import com.bstek.dorado.annotation.DataProvider; import com.bstek.dorado.annotation.DataResolver; import com.bstek.dorado.annotation.Expose; +import com.fzzy.api.data.GatewayDeviceType; import com.fzzy.api.utils.ContextUtil; import com.fzzy.api.utils.DateUtil; import com.fzzy.async.fzzy40.Fzzy40CommonService; @@ -11,28 +13,28 @@ import com.fzzy.gateway.GatewayUtils; import com.fzzy.gateway.api.DeviceReportService; import com.fzzy.gateway.api.GatewayRemoteManager; +import com.fzzy.gateway.data.BaseResp; import com.fzzy.gateway.entity.GatewayDevice; import com.fzzy.gateway.hx2023.ScConstant; -import com.fzzy.gateway.hx2023.data.KafaGrainData; -import com.fzzy.gateway.hx2023.data.KafkaGrainDataDetail; -import com.fzzy.gateway.hx2023.data.KafkaGrainTH; -import com.fzzy.gateway.hx2023.data.TRHInfo; +import com.fzzy.gateway.hx2023.data.*; import com.fzzy.gateway.service.repository.GatewayDeviceRep; +import com.fzzy.mqtt.MqttProviderConfig; +import com.fzzy.mqtt.MqttPublishService; import lombok.extern.slf4j.Slf4j; import org.apache.commons.lang.StringUtils; +import org.apache.commons.lang.math.RandomUtils; import org.apache.commons.lang.time.DateFormatUtils; import org.springframework.beans.BeanUtils; +import org.springframework.beans.factory.annotation.Autowired; import org.springframework.data.domain.Sort; import org.springframework.stereotype.Component; import javax.annotation.Resource; -import java.util.ArrayList; -import java.util.Date; -import java.util.List; -import java.util.Map; +import java.util.*; +import java.util.stream.Collectors; @Slf4j @Component @@ -44,6 +46,10 @@ private Fzzy40CommonService fzzy40CommonService; @Resource private GatewayRemoteManager gatewayRemoteManager; + @Resource + private MqttPublishService mqttPublishService; + @Resource + private MqttProviderConfig providerClient; /** * gatewayDeviceService#listAll @@ -59,28 +65,27 @@ /** * gatewayDeviceService#updateSave * - * @param entity + * @param data */ @DataResolver - public void updateSave(GatewayDevice entity) { - GatewayDevice data = new GatewayDevice(); - BeanUtils.copyProperties(entity, data); + public void updateSave(GatewayDevice data) { + GatewayDevice data2 = new GatewayDevice(); + BeanUtils.copyProperties(data, data2); - if (null == data.getId()) { - data.setId(ContextUtil.getUUID()); - } - - - if (null == data.getDeviceSn()) { - if (null != entity.getIp()) { - data.setDeviceSn(entity.getIp()); + if (null == data2.getDeviceSn()) { + if (null != data2.getIp()) { + data.setDeviceSn(data2.getIp()); } else { - data.setDeviceSn(data.getDeviceId()); + data.setDeviceSn(data2.getDeviceId()); } } - gatewayDeviceRep.save(data); - + if (null == data2.getId()) { + data2.setId(ContextUtil.getUUID()); + gatewayDeviceRep.save(data2); + } else { + gatewayDeviceRep.save(data2); + } flushCache(); } @@ -102,10 +107,6 @@ } - /** - * gatewayDeviceService#flushCache - */ - @Expose public void flushCache() { List<GatewayDevice> list = listAll(); if (null == list || list.isEmpty()) return; @@ -116,6 +117,109 @@ /** + * gatewayDeviceService#ajaxTestWeight + * 鍦扮鎺ㄩ�佹祴璇� + * + * @param parameter + * @return + */ + @Expose + public String ajaxTestWeight() { + //double weigh = (double) parameter.getWeight(); + double weigh = Math.random() * (35000 - 16000 + 1) + 16000; + List<GatewayDevice> devices = listAll(); + if (devices == null || devices.size() <= 0) { + return "娌℃湁璁惧"; + } + List<GatewayDevice> weights = devices.stream().filter(s -> (GatewayDeviceType.TYPE_01.getCode().equals(s.getType()))).collect(Collectors.toList()); + if (weights == null || weights.size() <= 0) { + return "娌℃湁鑾峰彇鍒板湴纾呰澶�"; + } + String topic = "/device/hx-weigh-big-01/91511424746940066Y001_91511424746940066Y0010000_002_004_002_001/message/property/report"; + + for (GatewayDevice device : weights) { + + WebSocketPacket packet = new WebSocketPacket(); + + //productId鐨勫�煎湪webSocket鎵ц鍙戦�佹柟娉曚腑琛ュ厖 + WebSocketPacketHeader header = new WebSocketPacketHeader(); + header.setDeviceName(device.getDeviceName()); + header.setProductId("hx-weigh-big-01"); + //header.set + packet.setHeaders(header); + packet.setMessageType(ScConstant.MESSAGE_TYPE_REPORT_PROPERTY); + packet.setDeviceId(device.getDeviceId()); + + //璁剧疆淇℃伅涓讳綋 + WeightInfo weightInfo = new WeightInfo(); + weightInfo.setGrossWeight(weigh); + weightInfo.setNetWeight(weigh); + weightInfo.setNetWeight(weigh); + weightInfo.setWeightUnit("KG"); + JSONObject jsonObject = new JSONObject(); + jsonObject.put("weightInfo", JSONObject.toJSONString(weightInfo)); + + packet.setProperties(jsonObject); + + packet.setTimestamp(System.currentTimeMillis()); + + topic = "/device/" + header.getProductId() + "/" + device.getDeviceId() + "/message/property/report"; + mqttPublishService.publishMsg(topic, JSON.toJSONString(packet)); + } + return "SUCCESS"; + } + + /** + * gatewayDeviceService#ajaxTestLpr + * 鍦扮鎺ㄩ�佹祴璇� + * + * @return + */ + @Expose + public String ajaxTestLpr() { + //String carNumber = parameter.getCarNumber(); + String carNumber = "宸滱12345"; + List<GatewayDevice> devices = listAll(); + if (devices == null || devices.size() <= 0) { + return "娌℃湁璁惧"; + } + List<GatewayDevice> weights = devices.stream().filter(s -> (GatewayDeviceType.TYPE_02.getCode().equals(s.getType()))).collect(Collectors.toList()); + if (weights == null || weights.size() <= 0) { + return "娌℃湁鑾峰彇鍒拌澶�"; + } + String topic = "/device/hx-weigh-big-01/91511424746940066Y001_91511424746940066Y0010000_002_004_002_001/message/property/report"; + + for (GatewayDevice device : weights) { + + WebSocketPacket packet = new WebSocketPacket(); + + //productId鐨勫�煎湪webSocket鎵ц鍙戦�佹柟娉曚腑琛ュ厖 + WebSocketPacketHeader header = new WebSocketPacketHeader(); + header.setDeviceName(device.getDeviceName()); + header.setProductId("hx-catch-01"); + //header.set + packet.setHeaders(header); + packet.setMessageType(ScConstant.MESSAGE_TYPE_REPORT_PROPERTY); + packet.setDeviceId(device.getDeviceId()); + packet.setMessageId(System.currentTimeMillis() + ""); + //璁剧疆淇℃伅涓讳綋 + LprData lpr = new LprData(); + lpr.setDeviceId(device.getDeviceId()); + lpr.setCarNumber(carNumber); + JSONObject jsonObject = new JSONObject(); + jsonObject.put("carNumber", carNumber); + jsonObject.put("position", "big"); + packet.setProperties(jsonObject); + + packet.setTimestamp(System.currentTimeMillis()); + + topic = "/device/" + header.getProductId() + "/" + device.getDeviceId() + "/message/property/report"; + mqttPublishService.publishMsg(topic, JSON.toJSONString(packet)); + } + return "SUCCESS"; + } + + /** * gatewayDeviceService#ajaxTestGrain * 绮儏鎺ㄩ�佹祴璇� * @@ -123,7 +227,7 @@ * @return */ @Expose - public String ajaxTestGrain(Map<String, Object> parameter) { + public String ajaxTestGrain(GateWayTestParam parameter) { //鑾峰彇璁惧閰嶇疆锛屽彧閽堝绮儏璁惧杩涜鎵ц @@ -133,7 +237,7 @@ return "ERROR锛氫负鑾峰彇鍒扮郴缁熶腑璁惧閰嶇疆锛屽彇娑堟墽琛�"; } - Date dayTime = (Date) parameter.get("dayTime"); + Date dayTime = (Date) parameter.getDayTime(); if (null == dayTime) dayTime = new Date(); Date start = DateUtil.getCurZero(dayTime); @@ -144,6 +248,9 @@ return this.pushByV40(list, start, end); } + + + private String pushByV40(List<GatewayDevice> list, Date start, Date end) { @@ -199,6 +306,7 @@ KafaGrainData result = new KafaGrainData(); result.setMessageId(ScConstant.getMessageId()); + result.setMessgeId(result.getMessageId()); result.setDeviceID(device.getDeviceId()); result.setAvgTemperature(lastData.getTempAve() + ""); result.setMinTemperature(lastData.getTempMin() + ""); @@ -225,7 +333,7 @@ int cableNum = 1, position = 0; String curTemp; - List<KafkaGrainDataDetail> temperature = new ArrayList<>(); + List<KafkaGrainDataDetail1> temperature = new ArrayList<>(); int x = 0, y = 0, z = 0; for (int i = 0; i < attr.length; i++) { @@ -248,25 +356,27 @@ //鍒ゆ柇鏈�澶� if (curTemp.equals(result.getMaxTemperature())) { - result.setMaxX(x); - result.setMaxY(y); - result.setMaxZ(position); + result.setMaxX(x + ""); + result.setMaxY(y + ""); + result.setMaxZ(position + ""); } //鍒ゆ柇鏈�灏� if (curTemp.equals(result.getMinTemperature())) { - result.setMinX(x); - result.setMinY(y); - result.setMinZ(position); + result.setMinX(x + ""); + result.setMinY(y + ""); + result.setMinZ(position + ""); } - temperature.add(new KafkaGrainDataDetail(cableNum + "", z + "", curTemp, position + "", x, y)); + temperature.add(new KafkaGrainDataDetail1(cableNum + "", z + "", curTemp, position + "", x + "", y + "")); } //绮俯淇℃伅 - TRHInfo trhInfo = new TRHInfo(); - trhInfo.setTemperature(temperature); + + JSONObject trhInfo = new JSONObject(); + // TRHInfo trhInfo = new TRHInfo(); + trhInfo.put("temperature", temperature); //浠撴俯搴︿俊鎭� @@ -279,8 +389,8 @@ List<KafkaGrainTH> temperatureAndhumidity = new ArrayList<>(); temperatureAndhumidity.add(grainTH); - trhInfo.setTemperatureAndhumidity(temperatureAndhumidity); - + trhInfo.put("temperatureAndhumidity", temperatureAndhumidity); + //trhInfo.put("temperatureAndhumidity",grainTH); JSONObject params = new JSONObject(); params.put("TRHInfo", trhInfo); -- Gitblit v1.9.3