From ae084b7ab31c38588928afb770cec1320c8c27f0 Mon Sep 17 00:00:00 2001 From: jiazx0107@163.com <jiazx0107@163.com> Date: 星期四, 07 十二月 2023 12:26:24 +0800 Subject: [PATCH] 提交粮情协协议-控制柜-3 --- src/main/java/com/fzzy/gateway/service/GatewayDeviceService.java | 94 ++++++++++++++++++++++++++++++++++++++++++----- 1 files changed, 84 insertions(+), 10 deletions(-) diff --git a/src/main/java/com/fzzy/gateway/service/GatewayDeviceService.java b/src/main/java/com/fzzy/gateway/service/GatewayDeviceService.java index e7a1784..bda41b6 100644 --- a/src/main/java/com/fzzy/gateway/service/GatewayDeviceService.java +++ b/src/main/java/com/fzzy/gateway/service/GatewayDeviceService.java @@ -3,21 +3,31 @@ import com.bstek.dorado.annotation.DataProvider; import com.bstek.dorado.annotation.DataResolver; import com.bstek.dorado.annotation.Expose; +import com.fzzy.api.Constant; +import com.fzzy.api.data.ApiCommonDevice; import com.fzzy.api.utils.ContextUtil; +import com.fzzy.async.fzzy40.Fzzy40CommonService; +import com.fzzy.gateway.GatewayUtils; +import com.fzzy.gateway.api.GatewayRemoteManager; import com.fzzy.gateway.entity.GatewayDevice; import com.fzzy.gateway.service.repository.GatewayDeviceRep; +import com.fzzy.mqtt.MqttProviderConfig; +import com.fzzy.mqtt.MqttPublishService; +import lombok.extern.slf4j.Slf4j; import org.springframework.beans.BeanUtils; +import org.springframework.data.domain.Sort; import org.springframework.stereotype.Component; import javax.annotation.Resource; +import java.util.ArrayList; import java.util.List; +@Slf4j @Component public class GatewayDeviceService { @Resource private GatewayDeviceRep gatewayDeviceRep; - /** * gatewayDeviceService#listAll @@ -26,26 +36,71 @@ */ @DataProvider public List<GatewayDevice> listAll() { + Sort sort = new Sort(Sort.Direction.ASC, "deviceId"); - List<GatewayDevice> list = gatewayDeviceRep.findAll(); - return list; + List<GatewayDevice> list = gatewayDeviceRep.findAll(sort); + + if (null == list || list.isEmpty()) return list; + + List<GatewayDevice> result = new ArrayList<>(); + + ApiCommonDevice apiCommonDevice; + for (GatewayDevice device : list) { + + apiCommonDevice = Constant.getCommonDeviceCache(device.getDeviceSn()); + if (null != apiCommonDevice) { + device.setIp(apiCommonDevice.getIp()); + device.setPort(apiCommonDevice.getPort()); + device.setStatus(apiCommonDevice.getStatus()); + device.setOnlineTime(apiCommonDevice.getOnlineTime()); + } + result.add(device); + } + return result; } + +// /** +// * gatewayDeviceService#getQuery +// * +// * @return +// */ +// @DataProvider +// public GateWayTestParam getQuery() { +// GateWayTestParam param = new GateWayTestParam(); +// param.setDayTime(new Date()); +// param.setCarNumber("宸滱12345"); +// param.setEnd(new Date()); +// param.setStart(new Date()); +// param.setWeight(25000.00); +// return param; +// } /** * 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 == data2.getDeviceSn()) { + if (null != data2.getIp()) { + data.setDeviceSn(data2.getIp()); + } else { + data.setDeviceSn(data2.getDeviceId()); + } } - gatewayDeviceRep.save(data); + + if (null == data2.getId()) { + data2.setId(ContextUtil.getUUID()); + gatewayDeviceRep.save(data2); + } else { + gatewayDeviceRep.save(data2); + } + flushCache(); } /** @@ -58,6 +113,25 @@ GatewayDevice data2 = new GatewayDevice(); BeanUtils.copyProperties(data, data2); gatewayDeviceRep.delete(data2); + + GatewayUtils.removeCache(data2); + + flushCache(); return null; } + + public void flushCache() { + List<GatewayDevice> list = listAll(); + if (null == list || list.isEmpty()) return; + for (GatewayDevice device : list) { + GatewayUtils.add2Cache(device); + } + } + + + @Expose + public String test() { + log.info("-----------test-------------------"); + return "SUCCESS"; + } } -- Gitblit v1.9.3