From 46203ee88249d9a4046f3d453deb41edc562cf6c Mon Sep 17 00:00:00 2001 From: jiazx0107@163.com <jiazx0107@163.com> Date: 星期二, 12 十二月 2023 12:36:53 +0800 Subject: [PATCH] 提交网关心跳和设备状态 --- src/main/java/com/fzzy/gateway/service/GatewayDeviceService.java | 108 +++++++++++++++++++++++++++++++++++++++++------------ 1 files changed, 83 insertions(+), 25 deletions(-) diff --git a/src/main/java/com/fzzy/gateway/service/GatewayDeviceService.java b/src/main/java/com/fzzy/gateway/service/GatewayDeviceService.java index fd196ab..4f68178 100644 --- a/src/main/java/com/fzzy/gateway/service/GatewayDeviceService.java +++ b/src/main/java/com/fzzy/gateway/service/GatewayDeviceService.java @@ -3,20 +3,23 @@ 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.api.utils.RedisConst; -import com.fzzy.api.utils.RedisUtil; import com.fzzy.gateway.GatewayUtils; import com.fzzy.gateway.entity.GatewayDevice; import com.fzzy.gateway.service.repository.GatewayDeviceRep; +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.HashMap; +import java.util.ArrayList; +import java.util.Date; import java.util.List; -import java.util.Map; +@Slf4j @Component public class GatewayDeviceService { @@ -30,34 +33,54 @@ */ @DataProvider public List<GatewayDevice> listAll() { - return gatewayDeviceRep.findAll(); + Sort sort = new Sort(Sort.Direction.ASC, "deviceId"); + + + List<GatewayDevice> list = gatewayDeviceRep.findAll(sort); + + if (null == list || list.isEmpty()) return list; + + List<GatewayDevice> result = new ArrayList<>(); + + GatewayDevice cacheDevice; + for (GatewayDevice device : list) { + device.setStatus(Constant.YN_Y); + cacheDevice = GatewayUtils.getCacheByDeviceId(device.getDeviceId()); + if (null != cacheDevice) { + device.setIp(cacheDevice.getIp()); + device.setPort(cacheDevice.getPort()); + device.setStatus(cacheDevice.getStatus()); + device.setOnlineTime(cacheDevice.getOnlineTime()); + } + result.add(device); + } + return result; } /** * 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(); } @@ -78,11 +101,6 @@ return null; } - - /** - * gatewayDeviceService#flushCache - */ - @Expose public void flushCache() { List<GatewayDevice> list = listAll(); if (null == list || list.isEmpty()) return; @@ -90,4 +108,44 @@ GatewayUtils.add2Cache(device); } } + + + @Expose + public String test() { + log.info("-----------test-------------------"); + return "SUCCESS"; + } + + /** + * 鏍规嵁瀹為檯閫氳鍒嗘満璁剧疆锛屽綋鍓嶅垎鏈哄湪绾� + * + * @param commonDevice 瀹為檯閫氳璁惧 + */ + public void onlineByCommonDevice(ApiCommonDevice commonDevice) { + List<GatewayDevice> list = GatewayUtils.getCacheByDeviceSn2(commonDevice.getSn()); + if (null == list || list.isEmpty()) return; + + for (GatewayDevice device : list) { + device.setIp(commonDevice.getIp()); + device.setPort(commonDevice.getPort()); + device.setOnlineTime(new Date()); + device.setStatus(Constant.YN_Y); + + GatewayUtils.add2Cache(device); + } + } + + public void OfflineByCommonDevice(ApiCommonDevice commonDevice) { + List<GatewayDevice> list = GatewayUtils.getCacheByDeviceSn2(commonDevice.getSn()); + if (null == list || list.isEmpty()) return; + + for (GatewayDevice device : list) { + device.setIp(commonDevice.getIp()); + device.setPort(commonDevice.getPort()); + //device.setOnlineTime(new Date()); + device.setStatus(Constant.YN_N); + + GatewayUtils.add2Cache(device); + } + } } -- Gitblit v1.9.3