【代码评审】IoT:OTA 的实现

This commit is contained in:
YunaiV 2025-03-16 22:40:41 +08:00
parent 8203e074ac
commit b6c7937aeb
21 changed files with 39 additions and 31 deletions

View File

@ -1,6 +1,8 @@
package cn.iocoder.yudao.module.iot.controller.admin.rule.vo.databridge; package cn.iocoder.yudao.module.iot.controller.admin.rule.vo.databridge;
import cn.iocoder.yudao.framework.common.enums.CommonStatusEnum;
import cn.iocoder.yudao.framework.common.pojo.PageParam; import cn.iocoder.yudao.framework.common.pojo.PageParam;
import cn.iocoder.yudao.framework.common.validation.InEnum;
import io.swagger.v3.oas.annotations.media.Schema; import io.swagger.v3.oas.annotations.media.Schema;
import lombok.Data; import lombok.Data;
import org.springframework.format.annotation.DateTimeFormat; import org.springframework.format.annotation.DateTimeFormat;
@ -16,7 +18,8 @@ public class IotDataBridgePageReqVO extends PageParam {
@Schema(description = "桥梁名称", example = "赵六") @Schema(description = "桥梁名称", example = "赵六")
private String name; private String name;
@Schema(description = "桥梁状态", example = "2") @Schema(description = "桥梁状态", example = "1")
@InEnum(CommonStatusEnum.class)
private Integer status; private Integer status;
@Schema(description = "创建时间") @Schema(description = "创建时间")

View File

@ -1,7 +1,6 @@
package cn.iocoder.yudao.module.iot.controller.admin.rule.vo.databridge; package cn.iocoder.yudao.module.iot.controller.admin.rule.vo.databridge;
import cn.iocoder.yudao.module.iot.controller.admin.rule.vo.databridge.config.IotDataBridgeAbstractConfig; import cn.iocoder.yudao.module.iot.controller.admin.rule.vo.databridge.config.IotDataBridgeAbstractConfig;
import com.alibaba.excel.annotation.ExcelIgnoreUnannotated;
import io.swagger.v3.oas.annotations.media.Schema; import io.swagger.v3.oas.annotations.media.Schema;
import lombok.Data; import lombok.Data;
@ -20,7 +19,7 @@ public class IotDataBridgeRespVO {
@Schema(description = "桥梁描述", example = "随便") @Schema(description = "桥梁描述", example = "随便")
private String description; private String description;
@Schema(description = "桥梁状态", requiredMode = Schema.RequiredMode.REQUIRED, example = "2") @Schema(description = "桥梁状态", requiredMode = Schema.RequiredMode.REQUIRED, example = "1")
private Integer status; private Integer status;
@Schema(description = "桥梁方向", requiredMode = Schema.RequiredMode.REQUIRED) @Schema(description = "桥梁方向", requiredMode = Schema.RequiredMode.REQUIRED)

View File

@ -6,7 +6,7 @@ import com.fasterxml.jackson.annotation.JsonTypeInfo;
import lombok.Data; import lombok.Data;
/** /**
* 抽象类 IotDataBridgeConfig * IoT IotDataBridgeConfig 抽象类
* *
* 用于表示数据桥梁配置数据的通用类型根据具体的 "type" 字段动态映射到对应的子类 * 用于表示数据桥梁配置数据的通用类型根据具体的 "type" 字段动态映射到对应的子类
* 提供多态支持适用于不同类型的数据结构序列化和反序列化场景 * 提供多态支持适用于不同类型的数据结构序列化和反序列化场景

View File

@ -5,7 +5,7 @@ import lombok.Data;
import java.util.Map; import java.util.Map;
/** /**
* HTTP 配置 * IoT HTTP 配置 {@link IotDataBridgeAbstractConfig} 实现类
* *
* @author HUIHUI * @author HUIHUI
*/ */

View File

@ -3,7 +3,7 @@ package cn.iocoder.yudao.module.iot.controller.admin.rule.vo.databridge.config;
import lombok.Data; import lombok.Data;
/** /**
* Kafka 配置 * IoT Kafka 配置 {@link IotDataBridgeAbstractConfig} 实现类
* *
* @author HUIHUI * @author HUIHUI
*/ */

View File

@ -3,7 +3,7 @@ package cn.iocoder.yudao.module.iot.controller.admin.rule.vo.databridge.config;
import lombok.Data; import lombok.Data;
/** /**
* MQTT 配置 * IoT MQTT 配置 {@link IotDataBridgeAbstractConfig} 实现类
* *
* @author HUIHUI * @author HUIHUI
*/ */

View File

@ -3,7 +3,7 @@ package cn.iocoder.yudao.module.iot.controller.admin.rule.vo.databridge.config;
import lombok.Data; import lombok.Data;
/** /**
* RabbitMQ 配置 * IoT RabbitMQ 配置 {@link IotDataBridgeAbstractConfig} 实现类
* *
* @author HUIHUI * @author HUIHUI
*/ */

View File

@ -2,8 +2,9 @@ package cn.iocoder.yudao.module.iot.controller.admin.rule.vo.databridge.config;
import lombok.Data; import lombok.Data;
// TODO @puhui999MQ 可以去掉哈stream 更精准
/** /**
* Redis Stream MQ 配置 * IoT Redis Stream 配置 {@link IotDataBridgeAbstractConfig} 实现类
* *
* @author HUIHUI * @author HUIHUI
*/ */

View File

@ -3,7 +3,7 @@ package cn.iocoder.yudao.module.iot.controller.admin.rule.vo.databridge.config;
import lombok.Data; import lombok.Data;
/** /**
* RocketMQ 配置 * IoT RocketMQ 配置 {@link IotDataBridgeAbstractConfig} 实现类
* *
* @author HUIHUI * @author HUIHUI
*/ */

View File

@ -1 +1,2 @@
// TODO @芋艿占位
package cn.iocoder.yudao.module.iot.controller.admin.rule.vo; package cn.iocoder.yudao.module.iot.controller.admin.rule.vo;

View File

@ -21,6 +21,8 @@ import org.springframework.web.bind.annotation.RestController;
import java.time.LocalDateTime; import java.time.LocalDateTime;
import java.util.Map; import java.util.Map;
import static cn.iocoder.yudao.framework.common.pojo.CommonResult.*;
@Tag(name = "管理后台 - IoT 数据统计") @Tag(name = "管理后台 - IoT 数据统计")
@RestController @RestController
@RequestMapping("/iot/statistics") @RequestMapping("/iot/statistics")
@ -61,7 +63,7 @@ public class IotStatisticsController {
respVO.setDeviceOnlineCount(deviceCountMap.getOrDefault(IotDeviceStateEnum.ONLINE.getState(), 0L)); respVO.setDeviceOnlineCount(deviceCountMap.getOrDefault(IotDeviceStateEnum.ONLINE.getState(), 0L));
respVO.setDeviceOfflineCount(deviceCountMap.getOrDefault(IotDeviceStateEnum.OFFLINE.getState(), 0L)); respVO.setDeviceOfflineCount(deviceCountMap.getOrDefault(IotDeviceStateEnum.OFFLINE.getState(), 0L));
respVO.setDeviceInactiveCount(deviceCountMap.getOrDefault(IotDeviceStateEnum.INACTIVE.getState(), 0L)); respVO.setDeviceInactiveCount(deviceCountMap.getOrDefault(IotDeviceStateEnum.INACTIVE.getState(), 0L));
return CommonResult.success(respVO); return success(respVO);
} }
// TODO @super要不干掉 IotStatisticsReqVO 参数直接使用 @RequestParam 接收简单一些 // TODO @super要不干掉 IotStatisticsReqVO 参数直接使用 @RequestParam 接收简单一些
@ -69,7 +71,7 @@ public class IotStatisticsController {
@Operation(summary = "获取 IoT 设备上下行消息数据统计") @Operation(summary = "获取 IoT 设备上下行消息数据统计")
public CommonResult<IotStatisticsDeviceMessageSummaryRespVO> getIotStatisticsDeviceMessageSummary( public CommonResult<IotStatisticsDeviceMessageSummaryRespVO> getIotStatisticsDeviceMessageSummary(
@Valid IotStatisticsReqVO reqVO) { @Valid IotStatisticsReqVO reqVO) {
return CommonResult.success(new IotStatisticsDeviceMessageSummaryRespVO() return success(new IotStatisticsDeviceMessageSummaryRespVO()
.setDownstreamCounts(deviceLogService.getDeviceLogUpCountByHour(null, reqVO.getStartTime(), reqVO.getEndTime())) .setDownstreamCounts(deviceLogService.getDeviceLogUpCountByHour(null, reqVO.getStartTime(), reqVO.getEndTime()))
.setDownstreamCounts((deviceLogService.getDeviceLogDownCountByHour(null, reqVO.getStartTime(), reqVO.getEndTime())))); .setDownstreamCounts((deviceLogService.getDeviceLogDownCountByHour(null, reqVO.getStartTime(), reqVO.getEndTime()))));
} }

View File

@ -10,7 +10,7 @@ import lombok.Data;
import java.util.List; import java.util.List;
/** /**
* 物模型中的事件 * IoT 物模型中的事件
* *
* @author HUIHUI * @author HUIHUI
*/ */

View File

@ -11,7 +11,7 @@ import lombok.Data;
import java.util.List; import java.util.List;
/** /**
* 物模型中的属性 * IoT 物模型中的属性
* *
* dataSpecs dataSpecsList 之中必须传入且只能传入一个 * dataSpecs dataSpecsList 之中必须传入且只能传入一个
* *

View File

@ -10,7 +10,7 @@ import lombok.Data;
import java.util.List; import java.util.List;
/** /**
* 物模型中的服务 * IoT 物模型中的服务
* *
* @author HUIHUI * @author HUIHUI
*/ */

View File

@ -7,25 +7,25 @@ import lombok.EqualsAndHashCode;
import java.util.List; import java.util.List;
/** /**
* 物模型数据类型为数组的 DataSpec 定义 * IoT 物模型数据类型为数组的 DataSpec 定义
* *
* @author HUIHUI * @author HUIHUI
*/ */
@Data @Data
@EqualsAndHashCode(callSuper = true) @EqualsAndHashCode(callSuper = true)
@JsonIgnoreProperties({"dataType"}) // 忽略子类中的 dataType 字段从而避免重复 @JsonIgnoreProperties({"dataType"}) // 忽略子类中的 dataType 字段从而避免重复
public class ThingModelArrayDataSpecs extends ThingModelDataSpecs { public class ThingModelArrayDataSpecs extends ThingModelDataSpecs {
/** /**
* 数组中的元素个数 * 数组中的元素个数
*/ */
private Integer size; private Integer size;
/** /**
* 数组中的元素的数据类型可选值structintfloatdouble text * 数组中的元素的数据类型可选值structintfloatdouble text
*/ */
private String childDataType; private String childDataType;
/** /**
* 数据类型childDataType为列表型 struct 的数据规范存储在 dataSpecsList * 数据类型childDataType为列表型 struct 的数据规范存储在 dataSpecsList
* 此时 struct 取值范围为intfloatdoubletextdateenumbool * 此时 struct 取值范围为intfloatdoubletextdateenumbool
*/ */
private List<ThingModelDataSpecs> dataSpecsList; private List<ThingModelDataSpecs> dataSpecsList;

View File

@ -5,7 +5,7 @@ import lombok.Data;
import lombok.EqualsAndHashCode; import lombok.EqualsAndHashCode;
/** /**
* 物模型数据类型为布尔型或枚举型的 DataSpec 定义 * IoT 物模型数据类型为布尔型或枚举型的 DataSpec 定义
* *
* 数据类型取值为 bool enum * 数据类型取值为 bool enum
* *
@ -13,13 +13,14 @@ import lombok.EqualsAndHashCode;
*/ */
@Data @Data
@EqualsAndHashCode(callSuper = true) @EqualsAndHashCode(callSuper = true)
@JsonIgnoreProperties({"dataType"}) // 忽略子类中的 dataType 字段从而避免重复 @JsonIgnoreProperties({"dataType"}) // 忽略子类中的 dataType 字段从而避免重复
public class ThingModelBoolOrEnumDataSpecs extends ThingModelDataSpecs { public class ThingModelBoolOrEnumDataSpecs extends ThingModelDataSpecs {
// TODO @puhui999要不写下参数校验这样注释可以简洁一点
/** /**
* 枚举项的名称 * 枚举项的名称
* 可包含中文大小写英文字母数字下划线_和短划线- * 可包含中文大小写英文字母数字下划线_和短划线-
* 必须以中文英文字母或数字开头长度不超过 20 个字符 * 必须以中文英文字母或数字开头长度不超过 20 个字符
*/ */
private String name; private String name;
/** /**

View File

@ -5,7 +5,7 @@ import com.fasterxml.jackson.annotation.JsonTypeInfo;
import lombok.Data; import lombok.Data;
/** /**
* 抽象类 ThingModelDataSpecs * IoT ThingModelDataSpecs 抽象类
* *
* 用于表示物模型数据的通用类型根据具体的 "dataType" 字段动态映射到对应的子类 * 用于表示物模型数据的通用类型根据具体的 "dataType" 字段动态映射到对应的子类
* 提供多态支持适用于不同类型的数据结构序列化和反序列化场景 * 提供多态支持适用于不同类型的数据结构序列化和反序列化场景

View File

@ -5,7 +5,7 @@ import lombok.Data;
import lombok.EqualsAndHashCode; import lombok.EqualsAndHashCode;
/** /**
* 物模型数据类型为时间型或文本型的 DataSpec 定义 * IoT 物模型数据类型为时间型或文本型的 DataSpec 定义
* *
* 数据类型取值为 date text * 数据类型取值为 date text
* *
@ -13,7 +13,7 @@ import lombok.EqualsAndHashCode;
*/ */
@Data @Data
@EqualsAndHashCode(callSuper = true) @EqualsAndHashCode(callSuper = true)
@JsonIgnoreProperties({"dataType"}) // 忽略子类中的 dataType 字段从而避免重复 @JsonIgnoreProperties({"dataType"}) // 忽略子类中的 dataType 字段从而避免重复
public class ThingModelDateOrTextDataSpecs extends ThingModelDataSpecs { public class ThingModelDateOrTextDataSpecs extends ThingModelDataSpecs {
/** /**

View File

@ -5,7 +5,7 @@ import lombok.Data;
import lombok.EqualsAndHashCode; import lombok.EqualsAndHashCode;
/** /**
* 物模型数据类型为数值的 DataSpec 定义 * IoT 物模型数据类型为数值的 DataSpec 定义
* *
* 数据类型取值为 intfloat double * 数据类型取值为 intfloat double
* *
@ -13,7 +13,7 @@ import lombok.EqualsAndHashCode;
*/ */
@Data @Data
@EqualsAndHashCode(callSuper = true) @EqualsAndHashCode(callSuper = true)
@JsonIgnoreProperties({"dataType"}) // 忽略子类中的 dataType 字段从而避免重复 @JsonIgnoreProperties({"dataType"}) // 忽略子类中的 dataType 字段从而避免重复
public class ThingModelNumericDataSpec extends ThingModelDataSpecs { public class ThingModelNumericDataSpec extends ThingModelDataSpecs {
/** /**

View File

@ -8,13 +8,13 @@ import lombok.EqualsAndHashCode;
import java.util.List; import java.util.List;
/** /**
* 物模型数据类型为 struct DataSpec 定义 * IoT 物模型数据类型为 struct DataSpec 定义
* *
* @author HUIHUI * @author HUIHUI
*/ */
@Data @Data
@EqualsAndHashCode(callSuper = true) @EqualsAndHashCode(callSuper = true)
@JsonIgnoreProperties({"dataType"}) // 忽略子类中的 dataType 字段从而避免重复 @JsonIgnoreProperties({"dataType"}) // 忽略子类中的 dataType 字段从而避免重复
public class ThingModelStructDataSpecs extends ThingModelDataSpecs { public class ThingModelStructDataSpecs extends ThingModelDataSpecs {
/** /**

View File

@ -47,6 +47,7 @@ public interface IotDeviceLogService {
*/ */
Long getDeviceLogCount(@Nullable LocalDateTime createTime); Long getDeviceLogCount(@Nullable LocalDateTime createTime);
// TODO @superdeviceKey 是不是用不上哈
/** /**
* 获得每个小时设备上行消息数量统计 * 获得每个小时设备上行消息数量统计
* *