【代码评审】IOT:产品的管理

This commit is contained in:
YunaiV
2024-09-07 20:37:13 +08:00
parent c7b1cc9a43
commit 10334f3fb6
28 changed files with 135 additions and 281 deletions

View File

@@ -27,6 +27,7 @@ import java.util.List;
import static cn.iocoder.yudao.framework.apilog.core.enums.OperateTypeEnum.EXPORT;
import static cn.iocoder.yudao.framework.common.pojo.CommonResult.success;
// TODO @haohaoIot 前缀要加,不然很容易重复哈
@Tag(name = "管理后台 - IOT 产品")
@RestController
@RequestMapping("/iot/product")

View File

@@ -1,14 +1,18 @@
package cn.iocoder.yudao.module.iot.controller.admin.product.vo;
import lombok.*;
import java.util.*;
import io.swagger.v3.oas.annotations.media.Schema;
import cn.iocoder.yudao.framework.common.pojo.PageParam;
import io.swagger.v3.oas.annotations.media.Schema;
import lombok.Data;
import lombok.EqualsAndHashCode;
import lombok.ToString;
import org.springframework.format.annotation.DateTimeFormat;
import java.time.LocalDateTime;
import static cn.iocoder.yudao.framework.common.util.date.DateUtils.FORMAT_YEAR_MONTH_DAY_HOUR_MINUTE_SECOND;
// TODO @haohao涉及到 iot 的拼写,要不都用 IoT貌似更规范
// TODO 芋艿:需要清理掉一些无用字段
@Schema(description = "管理后台 - iot 产品分页 Request VO")
@Data
@EqualsAndHashCode(callSuper = true)
@@ -25,6 +29,9 @@ public class ProductPageReqVO extends PageParam {
@Schema(description = "产品标识")
private String productKey;
@Schema(description = "接入网关协议", example = "2")
private Integer protocolType;
@Schema(description = "协议编号(脚本解析 id", example = "13177")
private Long protocolId;
@@ -34,22 +41,19 @@ public class ProductPageReqVO extends PageParam {
@Schema(description = "产品描述", example = "你猜")
private String description;
@Schema(description = "数据校验级别, 0: 强校验, 1: 弱校验, 2: 免校验", example = "1")
@Schema(description = "数据校验级别", example = "1")
private Integer validateType;
@Schema(description = "产品状态, 0: DEVELOPMENT_STATUS, 1: RELEASE_STATUS", example = "1")
@Schema(description = "产品状态", example = "1")
private Integer status;
@Schema(description = "设备类型, 0: 直连设备, 1: 网关子设备, 2: 网关设备", example = "2")
@Schema(description = "设备类型", example = "2")
private Integer deviceType;
@Schema(description = "联网方式, 0: Wi-Fi, 1: Cellular, 2: Ethernet, 3: 其他", example = "2")
@Schema(description = "联网方式", example = "2")
private Integer netType;
@Schema(description = "接入网关协议, 0: modbus, 1: opc-ua, 2: customize, 3: ble, 4: zigbee", example = "2")
private Integer protocolType;
@Schema(description = "数据格式, 0: 透传模式, 1: Alink JSON")
@Schema(description = "数据格式", example = "0")
private Integer dataFormat;
}

View File

@@ -1,17 +1,21 @@
package cn.iocoder.yudao.module.iot.controller.admin.product.vo;
import com.alibaba.excel.annotation.ExcelIgnoreUnannotated;
import com.alibaba.excel.annotation.ExcelProperty;
import io.swagger.v3.oas.annotations.media.Schema;
import lombok.*;
import java.util.*;
import org.springframework.format.annotation.DateTimeFormat;
import lombok.Data;
import java.time.LocalDateTime;
import com.alibaba.excel.annotation.*;
@Schema(description = "管理后台 - iot 产品 Response VO")
@Data
@ExcelIgnoreUnannotated
public class ProductRespVO {
@Schema(description = "产品ID", requiredMode = Schema.RequiredMode.REQUIRED, example = "26087")
@ExcelProperty("产品ID")
private Long id;
@Schema(description = "产品名称", requiredMode = Schema.RequiredMode.REQUIRED, example = "李四")
@ExcelProperty("产品名称")
private String name;
@@ -20,14 +24,14 @@ public class ProductRespVO {
@ExcelProperty("创建时间")
private LocalDateTime createTime;
@Schema(description = "产品ID", requiredMode = Schema.RequiredMode.REQUIRED, example = "26087")
@ExcelProperty("产品ID")
private Long id;
@Schema(description = "产品标识", requiredMode = Schema.RequiredMode.REQUIRED)
@ExcelProperty("产品标识")
private String productKey;
@Schema(description = "接入网关协议", example = "2")
@ExcelProperty("接入网关协议")
private Integer protocolType;
@Schema(description = "协议编号(脚本解析 id", requiredMode = Schema.RequiredMode.REQUIRED, example = "13177")
@ExcelProperty("协议编号(脚本解析 id")
private Long protocolId;
@@ -40,28 +44,24 @@ public class ProductRespVO {
@ExcelProperty("产品描述")
private String description;
@Schema(description = "数据校验级别, 0: 强校验, 1: 弱校验, 2: 免校验", requiredMode = Schema.RequiredMode.REQUIRED, example = "1")
@ExcelProperty("数据校验级别, 0: 强校验, 1: 弱校验, 2: 免校验")
@Schema(description = "数据校验级别", requiredMode = Schema.RequiredMode.REQUIRED, example = "1")
@ExcelProperty("数据校验级别")
private Integer validateType;
@Schema(description = "产品状态, 0: DEVELOPMENT_STATUS, 1: RELEASE_STATUS", requiredMode = Schema.RequiredMode.REQUIRED, example = "1")
@ExcelProperty("产品状态, 0: DEVELOPMENT_STATUS, 1: RELEASE_STATUS")
@Schema(description = "产品状态", requiredMode = Schema.RequiredMode.REQUIRED, example = "1")
@ExcelProperty("产品状态")
private Integer status;
@Schema(description = "设备类型, 0: 直连设备, 1: 网关子设备, 2: 网关设备", requiredMode = Schema.RequiredMode.REQUIRED, example = "2")
@ExcelProperty("设备类型, 0: 直连设备, 1: 网关子设备, 2: 网关设备")
@Schema(description = "设备类型", requiredMode = Schema.RequiredMode.REQUIRED, example = "2")
@ExcelProperty("设备类型")
private Integer deviceType;
@Schema(description = "联网方式, 0: Wi-Fi, 1: Cellular, 2: Ethernet, 3: 其他", example = "2")
@ExcelProperty("联网方式, 0: Wi-Fi, 1: Cellular, 2: Ethernet, 3: 其他")
@Schema(description = "联网方式", example = "2")
@ExcelProperty("联网方式")
private Integer netType;
@Schema(description = "接入网关协议, 0: modbus, 1: opc-ua, 2: customize, 3: ble, 4: zigbee", example = "2")
@ExcelProperty("接入网关协议, 0: modbus, 1: opc-ua, 2: customize, 3: ble, 4: zigbee")
private Integer protocolType;
@Schema(description = "数据格式, 0: 透传模式, 1: Alink JSON")
@ExcelProperty("数据格式, 0: 透传模式, 1: Alink JSON")
@Schema(description = "数据格式")
@ExcelProperty("数据格式")
private Integer dataFormat;
}

View File

@@ -1,16 +1,15 @@
package cn.iocoder.yudao.module.iot.dal.dataobject.product;
import lombok.*;
import java.util.*;
import java.time.LocalDateTime;
import java.time.LocalDateTime;
import com.baomidou.mybatisplus.annotation.*;
import cn.iocoder.yudao.framework.mybatis.core.dataobject.BaseDO;
import com.baomidou.mybatisplus.annotation.KeySequence;
import com.baomidou.mybatisplus.annotation.TableId;
import com.baomidou.mybatisplus.annotation.TableName;
import lombok.*;
/**
* iot 产品 DO
*
* @author 芋道源码
* @author ahh
*/
@TableName("iot_product")
@KeySequence("iot_product_seq") // 用于 Oracle、PostgreSQL、Kingbase、DB2、H2 数据库的主键自增。如果是 MySQL 等数据库,可不写。
@@ -22,54 +21,73 @@ import cn.iocoder.yudao.framework.mybatis.core.dataobject.BaseDO;
@AllArgsConstructor
public class ProductDO extends BaseDO {
/**
* 产品名称
*/
private String name;
/**
* 产品ID
*/
@TableId
private Long id;
/**
* 产品名称
*/
private String name;
// TODO @haohao这个字段要不改成 identifier和阿里云更统一些
/**
* 产品标识
*/
private String productKey;
/**
* 协议编号(脚本解析 id
*/
private Long protocolId;
/**
* 产品所属品类标识符
* 产品所属品类编号
*
* TODO 外键:后续加
*/
private Long categoryId;
/**
* 产品描述
*/
private String description;
/**
* 数据校验级别, 0: 强校验, 1: 弱校验, 2: 免校验
*/
private Integer validateType;
/**
* 产品状态, 0: DEVELOPMENT_STATUS, 1: RELEASE_STATUS
* 产品状态
*
* 枚举 {@link cn.iocoder.yudao.module.iot.enums.product.IotProductStatusEnum}
*/
private Integer status;
/**
* 设备类型, 0: 直连设备, 1: 网关子设备, 2: 网关设备
* 设备类型
*
* 枚举 {@link cn.iocoder.yudao.module.iot.enums.product.IotProductDeviceTypeEnum}
*/
private Integer deviceType;
/**
* 联网方式, 0: Wi-Fi, 1: Cellular, 2: Ethernet, 3: 其他
* 联网方式
*
* 枚举 {@link cn.iocoder.yudao.module.iot.enums.product.IotNetTypeEnum}
*/
private Integer netType;
/**
* 接入网关协议, 0: modbus, 1: opc-ua, 2: customize, 3: ble, 4: zigbee
* 接入网关协议
*
* 枚举 {@link cn.iocoder.yudao.module.iot.enums.product.IotProtocolTypeEnum}
*/
private Integer protocolType;
/**
* 数据格式, 0: 透传模式, 1: Alink JSON
* 协议编号
*
* TODO 外键:后续加
*/
private Long protocolId;
/**
* 数据格式
*
* 枚举 {@link cn.iocoder.yudao.module.iot.enums.product.IotDataFormatEnum}
*/
private Integer dataFormat;
/**
* 数据校验级别
*
* 枚举 {@link cn.iocoder.yudao.module.iot.enums.product.IotValidateTypeEnum}
*/
private Integer validateType;
}

View File

@@ -10,7 +10,7 @@ import org.apache.ibatis.annotations.Mapper;
/**
* iot 产品 Mapper
*
* @author 芋道源码
* @author ahh
*/
@Mapper
public interface ProductMapper extends BaseMapperX<ProductDO> {

View File

@@ -10,6 +10,7 @@ import org.eclipse.paho.client.mqttv3.MqttMessage;
import org.springframework.context.annotation.Lazy;
import org.springframework.stereotype.Component;
// TODO @芋艿:详细再瞅瞅
/**
* 用于处理MQTT连接的回调如连接断开、消息到达、消息发布完成、连接完成等事件。
*

View File

@@ -4,6 +4,8 @@ import lombok.Data;
import org.springframework.boot.context.properties.ConfigurationProperties;
import org.springframework.stereotype.Component;
// TODO @芋艿:详细再瞅瞅
/**
* 配置类用于读取MQTT连接的配置信息如用户名、密码、连接地址等
*

View File

@@ -3,6 +3,7 @@ package cn.iocoder.yudao.module.iot.emq.service;
import org.eclipse.paho.client.mqttv3.MqttClient;
import org.eclipse.paho.client.mqttv3.MqttMessage;
// TODO @芋艿:在瞅瞅
/**
* 用于处理MQTT消息的具体业务逻辑如订阅回调
*

View File

@@ -5,6 +5,8 @@ import org.eclipse.paho.client.mqttv3.MqttClient;
import org.eclipse.paho.client.mqttv3.MqttMessage;
import org.springframework.stereotype.Service;
// TODO @芋艿:在瞅瞅
/**
* 用于处理MQTT消息的具体业务逻辑如订阅回调
*

View File

@@ -6,6 +6,8 @@ import org.springframework.boot.ApplicationArguments;
import org.springframework.boot.ApplicationRunner;
import org.springframework.stereotype.Component;
// TODO @芋艿:在瞅瞅
/**
* 用于在应用启动时自动连接MQTT服务器
*

View File

@@ -1,6 +1,6 @@
/**
* 属于 iot 模块的 framework 封装
*
* @author 芋道源码
* @author ahh
*/
package cn.iocoder.yudao.module.iot.framework;

View File

@@ -8,7 +8,7 @@ import org.springframework.context.annotation.Configuration;
/**
* iot 模块的 web 组件的 Configuration
*
* @author 芋道源码
* @author ahh
*/
@Configuration(proxyBeanMethods = false)
public class IotWebConfiguration {

View File

@@ -9,7 +9,7 @@ import jakarta.validation.Valid;
/**
* IOT 产品 Service 接口
*
* @author 芋道源码
* @author ahh
*/
public interface ProductService {

View File

@@ -21,7 +21,7 @@ import static cn.iocoder.yudao.module.iot.enums.ErrorCodeConstants.PRODUCT_STATU
/**
* IOT 产品 Service 实现类
*
* @author 芋道源码
* @author ahh
*/
@Service
@Validated
@@ -37,7 +37,6 @@ public class ProductServiceImpl implements ProductService {
// 插入
ProductDO product = BeanUtils.toBean(createReqVO, ProductDO.class);
productMapper.insert(product);
// 返回
return product.getId();
}
@@ -47,6 +46,7 @@ public class ProductServiceImpl implements ProductService {
* @param createReqVO 创建信息
*/
private void createProductKey(ProductSaveReqVO createReqVO) {
// TODO @haohao应该前端没传递的时候才生成哇ps需要校验下唯一性万一有重复
// 生成随机的 11 位字符串
String productKey = UUID.randomUUID().toString().replace("-", "").substring(0, 11);
createReqVO.setProductKey(productKey);
@@ -54,8 +54,10 @@ public class ProductServiceImpl implements ProductService {
@Override
public void updateProduct(ProductSaveReqVO updateReqVO) {
updateReqVO.setProductKey(null); // 不更新产品标识
// 校验存在
validateProductExists(updateReqVO.getId());
// TODO @haohao如果已经发布允许编辑么
// 更新
ProductDO updateObj = BeanUtils.toBean(updateReqVO, ProductDO.class);
productMapper.updateById(updateObj);
@@ -63,11 +65,12 @@ public class ProductServiceImpl implements ProductService {
@Override
public void deleteProduct(Long id) {
// 校验存在
// TODO @haohao这里最好只查询一次哈
// 1.1 校验存在
validateProductExists(id);
// 发布状态不可删除
// 1.2 发布状态不可删除
validateProductStatus(id);
// 删除
// 2. 删除
productMapper.deleteById(id);
}

View File

@@ -1,12 +0,0 @@
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="cn.iocoder.yudao.module.iot.dal.mysql.product.ProductMapper">
<!--
一般情况下,尽可能使用 Mapper 进行 CRUD 增删改查即可。
无法满足的场景,例如说多表关联查询,才使用 XML 编写 SQL。
代码生成器暂时只生成 Mapper XML 文件本身,更多推荐 MybatisX 快速开发插件来生成查询。
文档可见https://www.iocoder.cn/MyBatis/x-plugins/
-->
</mapper>