reactor:【IoT 物联网】增加 IotDataRuleDO 的定义,对标阿里云 IoT 的「云产品流转」

This commit is contained in:
YunaiV
2025-06-23 09:35:21 +08:00
parent 1ad4e08cb8
commit 1f5dff77c2
22 changed files with 223 additions and 77 deletions

View File

@@ -7,13 +7,13 @@ import lombok.RequiredArgsConstructor;
import java.util.Arrays; import java.util.Arrays;
/** /**
* IoT 数据桥接的类型枚举 * IoT 数据流转的数据目的的类型枚举
* *
* @author 芋道源码 * @author 芋道源码
*/ */
@RequiredArgsConstructor @RequiredArgsConstructor
@Getter @Getter
public enum IotDataBridgeTypeEnum implements ArrayValuable<Integer> { public enum IotDataRuleSinkTypeEnum implements ArrayValuable<Integer> {
HTTP(1, "HTTP"), HTTP(1, "HTTP"),
TCP(2, "TCP"), TCP(2, "TCP"),
@@ -32,7 +32,7 @@ public enum IotDataBridgeTypeEnum implements ArrayValuable<Integer> {
private final String name; private final String name;
public static final Integer[] ARRAYS = Arrays.stream(values()).map(IotDataBridgeTypeEnum::getType).toArray(Integer[]::new); public static final Integer[] ARRAYS = Arrays.stream(values()).map(IotDataRuleSinkTypeEnum::getType).toArray(Integer[]::new);
@Override @Override
public Integer[] array() { public Integer[] array() {

View File

@@ -7,7 +7,7 @@ import cn.iocoder.yudao.framework.common.util.object.BeanUtils;
import cn.iocoder.yudao.module.iot.controller.admin.rule.vo.databridge.IotDataBridgePageReqVO; import cn.iocoder.yudao.module.iot.controller.admin.rule.vo.databridge.IotDataBridgePageReqVO;
import cn.iocoder.yudao.module.iot.controller.admin.rule.vo.databridge.IotDataBridgeRespVO; import cn.iocoder.yudao.module.iot.controller.admin.rule.vo.databridge.IotDataBridgeRespVO;
import cn.iocoder.yudao.module.iot.controller.admin.rule.vo.databridge.IotDataBridgeSaveReqVO; import cn.iocoder.yudao.module.iot.controller.admin.rule.vo.databridge.IotDataBridgeSaveReqVO;
import cn.iocoder.yudao.module.iot.dal.dataobject.rule.IotDataBridgeDO; import cn.iocoder.yudao.module.iot.dal.dataobject.rule.IotDataRuleSinkDO;
import cn.iocoder.yudao.module.iot.service.rule.IotDataBridgeService; import cn.iocoder.yudao.module.iot.service.rule.IotDataBridgeService;
import io.swagger.v3.oas.annotations.Operation; import io.swagger.v3.oas.annotations.Operation;
import io.swagger.v3.oas.annotations.Parameter; import io.swagger.v3.oas.annotations.Parameter;
@@ -61,7 +61,7 @@ public class IotDataBridgeController {
@Parameter(name = "id", description = "编号", required = true, example = "1024") @Parameter(name = "id", description = "编号", required = true, example = "1024")
@PreAuthorize("@ss.hasPermission('iot:data-bridge:query')") @PreAuthorize("@ss.hasPermission('iot:data-bridge:query')")
public CommonResult<IotDataBridgeRespVO> getDataBridge(@RequestParam("id") Long id) { public CommonResult<IotDataBridgeRespVO> getDataBridge(@RequestParam("id") Long id) {
IotDataBridgeDO dataBridge = dataBridgeService.getDataBridge(id); IotDataRuleSinkDO dataBridge = dataBridgeService.getDataBridge(id);
return success(BeanUtils.toBean(dataBridge, IotDataBridgeRespVO.class)); return success(BeanUtils.toBean(dataBridge, IotDataBridgeRespVO.class));
} }
@@ -69,14 +69,14 @@ public class IotDataBridgeController {
@Operation(summary = "获得数据桥梁分页") @Operation(summary = "获得数据桥梁分页")
@PreAuthorize("@ss.hasPermission('iot:data-bridge:query')") @PreAuthorize("@ss.hasPermission('iot:data-bridge:query')")
public CommonResult<PageResult<IotDataBridgeRespVO>> getDataBridgePage(@Valid IotDataBridgePageReqVO pageReqVO) { public CommonResult<PageResult<IotDataBridgeRespVO>> getDataBridgePage(@Valid IotDataBridgePageReqVO pageReqVO) {
PageResult<IotDataBridgeDO> pageResult = dataBridgeService.getDataBridgePage(pageReqVO); PageResult<IotDataRuleSinkDO> pageResult = dataBridgeService.getDataBridgePage(pageReqVO);
return success(BeanUtils.toBean(pageResult, IotDataBridgeRespVO.class)); return success(BeanUtils.toBean(pageResult, IotDataBridgeRespVO.class));
} }
@GetMapping("/simple-list") @GetMapping("/simple-list")
@Operation(summary = "获取数据桥梁的精简信息列表", description = "主要用于前端的下拉选项") @Operation(summary = "获取数据桥梁的精简信息列表", description = "主要用于前端的下拉选项")
public CommonResult<List<IotDataBridgeRespVO>> getSimpleDataBridgeList() { public CommonResult<List<IotDataBridgeRespVO>> getSimpleDataBridgeList() {
List<IotDataBridgeDO> list = dataBridgeService.getDataBridgeList(CommonStatusEnum.ENABLE.getStatus()); List<IotDataRuleSinkDO> list = dataBridgeService.getDataBridgeList(CommonStatusEnum.ENABLE.getStatus());
return success(convertList(list, dataBridge -> // 只返回 id、name 字段 return success(convertList(list, dataBridge -> // 只返回 id、name 字段
new IotDataBridgeRespVO().setId(dataBridge.getId()).setName(dataBridge.getName()))); new IotDataBridgeRespVO().setId(dataBridge.getId()).setName(dataBridge.getName())));
} }

View File

@@ -4,7 +4,7 @@ import cn.iocoder.yudao.framework.common.enums.CommonStatusEnum;
import cn.iocoder.yudao.framework.common.validation.InEnum; import cn.iocoder.yudao.framework.common.validation.InEnum;
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 cn.iocoder.yudao.module.iot.enums.rule.IotDataBridgeDirectionEnum; import cn.iocoder.yudao.module.iot.enums.rule.IotDataBridgeDirectionEnum;
import cn.iocoder.yudao.module.iot.enums.rule.IotDataBridgeTypeEnum; import cn.iocoder.yudao.module.iot.enums.rule.IotDataRuleSinkTypeEnum;
import io.swagger.v3.oas.annotations.media.Schema; import io.swagger.v3.oas.annotations.media.Schema;
import jakarta.validation.constraints.NotEmpty; import jakarta.validation.constraints.NotEmpty;
import jakarta.validation.constraints.NotNull; import jakarta.validation.constraints.NotNull;
@@ -36,7 +36,7 @@ public class IotDataBridgeSaveReqVO {
@Schema(description = "桥梁类型", requiredMode = Schema.RequiredMode.REQUIRED, example = "1") @Schema(description = "桥梁类型", requiredMode = Schema.RequiredMode.REQUIRED, example = "1")
@NotNull(message = "桥梁类型不能为空") @NotNull(message = "桥梁类型不能为空")
@InEnum(IotDataBridgeTypeEnum.class) @InEnum(IotDataRuleSinkTypeEnum.class)
private Integer type; private Integer type;
@Schema(description = "桥梁配置") @Schema(description = "桥梁配置")

View File

@@ -1,6 +1,6 @@
package cn.iocoder.yudao.module.iot.controller.admin.rule.vo.databridge.config; package cn.iocoder.yudao.module.iot.controller.admin.rule.vo.databridge.config;
import cn.iocoder.yudao.module.iot.enums.rule.IotDataBridgeTypeEnum; import cn.iocoder.yudao.module.iot.enums.rule.IotDataRuleSinkTypeEnum;
import com.fasterxml.jackson.annotation.JsonSubTypes; import com.fasterxml.jackson.annotation.JsonSubTypes;
import com.fasterxml.jackson.annotation.JsonTypeInfo; import com.fasterxml.jackson.annotation.JsonTypeInfo;
import lombok.Data; import lombok.Data;
@@ -28,7 +28,7 @@ public abstract class IotDataBridgeAbstractConfig {
/** /**
* 配置类型 * 配置类型
* *
* 枚举 {@link IotDataBridgeTypeEnum#getType()} * 枚举 {@link IotDataRuleSinkTypeEnum#getType()}
*/ */
private String type; private String type;

View File

@@ -28,6 +28,11 @@ import java.util.Set;
@AllArgsConstructor @AllArgsConstructor
public class IotDeviceDO extends TenantBaseDO { public class IotDeviceDO extends TenantBaseDO {
/**
* 设备编号 - 全部设备
*/
public static final Long DEVICE_ID_ALL = 0L;
/** /**
* 设备 ID主键自增 * 设备 ID主键自增
*/ */

View File

@@ -0,0 +1,62 @@
package cn.iocoder.yudao.module.iot.dal.dataobject.rule;
import cn.iocoder.yudao.framework.common.enums.CommonStatusEnum;
import com.baomidou.mybatisplus.annotation.KeySequence;
import com.baomidou.mybatisplus.annotation.TableName;
import lombok.AllArgsConstructor;
import lombok.Builder;
import lombok.Data;
import lombok.NoArgsConstructor;
import java.util.List;
/**
* IoT 数据流转 DO
*
* 组合 {@link IotDataRuleSourceDO} => {@link IotDataRuleSinkDO}
*
* @author 芋道源码
*/
@TableName(value = "iot_data_flow", autoResultMap = true)
@KeySequence("iot_data_flow_seq") // 用于 Oracle、PostgreSQL、Kingbase、DB2、H2 数据库的主键自增。如果是 MySQL 等数据库,可不写。
@Data
@Builder
@NoArgsConstructor
@AllArgsConstructor
public class IotDataRuleDO {
/**
* 数据流转编号
*/
private Long id;
/**
* 数据流转名称
*/
private String name;
/**
* 数据流转描述
*/
private String description;
/**
* 数据流转状态
*
* 枚举 {@link CommonStatusEnum}
*/
private Integer status;
/**
* 数据源编号
*
* 关联 {@link IotDataRuleSourceDO#getId()}
*/
private List<Long> sourceIds;
/**
* 数据目的编号
*
* 关联 {@link IotDataRuleSinkDO#getId()}
*/
private List<Long> sinkIds;
// TODO @芋艿:未来考虑使用 groovy支持数据处理
}

View File

@@ -4,7 +4,7 @@ import cn.iocoder.yudao.framework.common.enums.CommonStatusEnum;
import cn.iocoder.yudao.framework.mybatis.core.dataobject.BaseDO; import cn.iocoder.yudao.framework.mybatis.core.dataobject.BaseDO;
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 cn.iocoder.yudao.module.iot.enums.rule.IotDataBridgeDirectionEnum; import cn.iocoder.yudao.module.iot.enums.rule.IotDataBridgeDirectionEnum;
import cn.iocoder.yudao.module.iot.enums.rule.IotDataBridgeTypeEnum; import cn.iocoder.yudao.module.iot.enums.rule.IotDataRuleSinkTypeEnum;
import com.baomidou.mybatisplus.annotation.KeySequence; import com.baomidou.mybatisplus.annotation.KeySequence;
import com.baomidou.mybatisplus.annotation.TableField; import com.baomidou.mybatisplus.annotation.TableField;
import com.baomidou.mybatisplus.annotation.TableId; import com.baomidou.mybatisplus.annotation.TableId;
@@ -13,7 +13,7 @@ import com.baomidou.mybatisplus.extension.handlers.JacksonTypeHandler;
import lombok.*; import lombok.*;
/** /**
* IoT 数据桥梁 DO * IoT 数据流转的数据目的 DO
* *
* @author 芋道源码 * @author 芋道源码
*/ */
@@ -23,19 +23,19 @@ import lombok.*;
@Builder @Builder
@NoArgsConstructor @NoArgsConstructor
@AllArgsConstructor @AllArgsConstructor
public class IotDataBridgeDO extends BaseDO { public class IotDataRuleSinkDO extends BaseDO {
/** /**
* 桥梁编号 * 数据目的编号
*/ */
@TableId @TableId
private Long id; private Long id;
/** /**
* 桥梁名称 * 数据目的名称
*/ */
private String name; private String name;
/** /**
* 桥梁描述 * 数据目的描述
*/ */
private String description; private String description;
/** /**
@@ -43,23 +43,25 @@ public class IotDataBridgeDO extends BaseDO {
* *
* 枚举 {@link CommonStatusEnum} * 枚举 {@link CommonStatusEnum}
*/ */
@Deprecated // TODO @puhui999这个删除
private Integer status; private Integer status;
/** /**
* 桥梁方向 * 桥梁方向
* *
* 枚举 {@link IotDataBridgeDirectionEnum} * 枚举 {@link IotDataBridgeDirectionEnum}
*/ */
@Deprecated // TODO @puhui999这个删除
private Integer direction; private Integer direction;
/** /**
* 桥梁类型 * 数据目的类型
* *
* 枚举 {@link IotDataBridgeTypeEnum} * 枚举 {@link IotDataRuleSinkTypeEnum}
*/ */
private Integer type; private Integer type;
/** /**
* 桥梁配置 * 数据目的配置
*/ */
@TableField(typeHandler = JacksonTypeHandler.class) @TableField(typeHandler = JacksonTypeHandler.class)
private IotDataBridgeAbstractConfig config; private IotDataBridgeAbstractConfig config;

View File

@@ -0,0 +1,79 @@
package cn.iocoder.yudao.module.iot.dal.dataobject.rule;
import cn.iocoder.yudao.module.iot.core.enums.IotDeviceMessageMethodEnum;
import cn.iocoder.yudao.module.iot.dal.dataobject.device.IotDeviceDO;
import cn.iocoder.yudao.module.iot.dal.dataobject.product.IotProductDO;
import cn.iocoder.yudao.module.iot.dal.dataobject.thingmodel.IotThingModelDO;
import com.baomidou.mybatisplus.annotation.KeySequence;
import com.baomidou.mybatisplus.annotation.TableName;
import lombok.AllArgsConstructor;
import lombok.Builder;
import lombok.Data;
import lombok.NoArgsConstructor;
import java.util.List;
/**
* IoT 数据流转的数据源 DO
*
* @author 芋道源码
*/
@TableName(value = "iot_data_flow_source", autoResultMap = true)
@KeySequence("iot_data_flow_source_seq") // 用于 Oracle、PostgreSQL、Kingbase、DB2、H2 数据库的主键自增。如果是 MySQL 等数据库,可不写。
@Data
@Builder
@NoArgsConstructor
@AllArgsConstructor
public class IotDataRuleSourceDO {
/**
* 数据源编号
*/
private Long id;
/**
* 数据源名称
*/
private String name;
/**
* 配置数组
*/
private List<Config> configs;
/**
* 配置
*/
@Data
public static class Config {
/**
* 消息方法
*
* 枚举 {@link IotDeviceMessageMethodEnum} 中的 upstream 上行部分
*/
private String method;
/**
* 产品编号
*
* 关联 {@link IotProductDO#getId()}
*/
private Long productId;
/**
* 设备编号
*
* 关联 {@link IotDeviceDO#getId()}
* 特殊:如果为 {@link IotDeviceDO#DEVICE_ID_ALL} 时,则是全部设备
*/
private Long deviceId;
/**
* 标识符
*
* 1. 物模型时,对应:{@link IotThingModelDO#getIdentifier()}
*/
private String identifier;
}
}

View File

@@ -201,7 +201,7 @@ public class IotRuleSceneDO extends TenantBaseDO {
* 数据桥接编号 * 数据桥接编号
* *
* 必填:当 {@link #type} 为 {@link IotRuleSceneActionTypeEnum#DATA_BRIDGE} 时 * 必填:当 {@link #type} 为 {@link IotRuleSceneActionTypeEnum#DATA_BRIDGE} 时
* 关联:{@link IotDataBridgeDO#getId()} * 关联:{@link IotDataRuleSinkDO#getId()}
*/ */
private Long dataBridgeId; private Long dataBridgeId;

View File

@@ -1,5 +1,6 @@
package cn.iocoder.yudao.module.iot.dal.dataobject.rule; package cn.iocoder.yudao.module.iot.dal.dataobject.rule;
import cn.iocoder.yudao.framework.common.enums.CommonStatusEnum;
import cn.iocoder.yudao.framework.tenant.core.db.TenantBaseDO; import cn.iocoder.yudao.framework.tenant.core.db.TenantBaseDO;
import cn.iocoder.yudao.module.iot.core.mq.message.IotDeviceMessage; import cn.iocoder.yudao.module.iot.core.mq.message.IotDeviceMessage;
import cn.iocoder.yudao.module.iot.dal.dataobject.device.IotDeviceDO; import cn.iocoder.yudao.module.iot.dal.dataobject.device.IotDeviceDO;
@@ -25,38 +26,35 @@ import java.util.List;
/** /**
* IoT 场景联动 DO * IoT 场景联动 DO
* *
* 基于 {@link Trigger} 触发 {@link Action}
*
* @author 芋道源码 * @author 芋道源码
*/ */
@TableName(value = "iot_rule_scene2", autoResultMap = true) @TableName(value = "iot_scene_rule", autoResultMap = true)
@KeySequence("iot_rule_scene_seq") // 用于 OraclePostgreSQLKingbaseDB2H2 数据库的主键自增如果是 MySQL 等数据库可不写 @KeySequence("iot_scene_rule_seq") // 用于 OraclePostgreSQLKingbaseDB2H2 数据库的主键自增如果是 MySQL 等数据库可不写
@Data @Data
@Builder @Builder
@NoArgsConstructor @NoArgsConstructor
@AllArgsConstructor @AllArgsConstructor
public class IotRuleScene2DO extends TenantBaseDO { public class IotSceneRuleDO extends TenantBaseDO {
/** /**
* 设备编号 - 全部设备 * 场景联动编号
*/
public static final Long DEVICE_ID_ALL = 0L;
/**
* 场景编号
*/ */
@TableId @TableId
private Long id; private Long id;
/** /**
* 场景名称 * 场景联动名称
*/ */
private String name; private String name;
/** /**
* 场景描述 * 场景联动描述
*/ */
private String description; private String description;
/** /**
* 场景状态 * 场景联动状态
* *
* 枚举 {@link cn.iocoder.yudao.framework.common.enums.CommonStatusEnum} * 枚举 {@link CommonStatusEnum}
*/ */
private Integer status; private Integer status;
@@ -103,7 +101,7 @@ public class IotRuleScene2DO extends TenantBaseDO {
* 设备编号 * 设备编号
* *
* 关联 {@link IotDeviceDO#getId()} * 关联 {@link IotDeviceDO#getId()}
* 特殊如果为 0则是全部 * 特殊如果为 {@link IotDeviceDO#DEVICE_ID_ALL} 则是全部设备
*/ */
private Long deviceId; private Long deviceId;
/** /**

View File

@@ -4,7 +4,7 @@ import cn.iocoder.yudao.framework.common.pojo.PageResult;
import cn.iocoder.yudao.framework.mybatis.core.mapper.BaseMapperX; import cn.iocoder.yudao.framework.mybatis.core.mapper.BaseMapperX;
import cn.iocoder.yudao.framework.mybatis.core.query.LambdaQueryWrapperX; import cn.iocoder.yudao.framework.mybatis.core.query.LambdaQueryWrapperX;
import cn.iocoder.yudao.module.iot.controller.admin.rule.vo.databridge.IotDataBridgePageReqVO; import cn.iocoder.yudao.module.iot.controller.admin.rule.vo.databridge.IotDataBridgePageReqVO;
import cn.iocoder.yudao.module.iot.dal.dataobject.rule.IotDataBridgeDO; import cn.iocoder.yudao.module.iot.dal.dataobject.rule.IotDataRuleSinkDO;
import org.apache.ibatis.annotations.Mapper; import org.apache.ibatis.annotations.Mapper;
import java.util.List; import java.util.List;
@@ -15,20 +15,20 @@ import java.util.List;
* @author HUIHUI * @author HUIHUI
*/ */
@Mapper @Mapper
public interface IotDataBridgeMapper extends BaseMapperX<IotDataBridgeDO> { public interface IotDataBridgeMapper extends BaseMapperX<IotDataRuleSinkDO> {
default PageResult<IotDataBridgeDO> selectPage(IotDataBridgePageReqVO reqVO) { default PageResult<IotDataRuleSinkDO> selectPage(IotDataBridgePageReqVO reqVO) {
return selectPage(reqVO, new LambdaQueryWrapperX<IotDataBridgeDO>() return selectPage(reqVO, new LambdaQueryWrapperX<IotDataRuleSinkDO>()
.likeIfPresent(IotDataBridgeDO::getName, reqVO.getName()) .likeIfPresent(IotDataRuleSinkDO::getName, reqVO.getName())
.eqIfPresent(IotDataBridgeDO::getStatus, reqVO.getStatus()) .eqIfPresent(IotDataRuleSinkDO::getStatus, reqVO.getStatus())
.betweenIfPresent(IotDataBridgeDO::getCreateTime, reqVO.getCreateTime()) .betweenIfPresent(IotDataRuleSinkDO::getCreateTime, reqVO.getCreateTime())
.orderByDesc(IotDataBridgeDO::getId)); .orderByDesc(IotDataRuleSinkDO::getId));
} }
default List<IotDataBridgeDO> selectList(Integer status) { default List<IotDataRuleSinkDO> selectList(Integer status) {
return selectList(new LambdaQueryWrapperX<IotDataBridgeDO>() return selectList(new LambdaQueryWrapperX<IotDataRuleSinkDO>()
.eqIfPresent(IotDataBridgeDO::getStatus, status) .eqIfPresent(IotDataRuleSinkDO::getStatus, status)
.orderByDesc(IotDataBridgeDO::getId)); .orderByDesc(IotDataRuleSinkDO::getId));
} }
} }

View File

@@ -3,7 +3,7 @@ package cn.iocoder.yudao.module.iot.service.rule;
import cn.iocoder.yudao.framework.common.pojo.PageResult; import cn.iocoder.yudao.framework.common.pojo.PageResult;
import cn.iocoder.yudao.module.iot.controller.admin.rule.vo.databridge.IotDataBridgePageReqVO; import cn.iocoder.yudao.module.iot.controller.admin.rule.vo.databridge.IotDataBridgePageReqVO;
import cn.iocoder.yudao.module.iot.controller.admin.rule.vo.databridge.IotDataBridgeSaveReqVO; import cn.iocoder.yudao.module.iot.controller.admin.rule.vo.databridge.IotDataBridgeSaveReqVO;
import cn.iocoder.yudao.module.iot.dal.dataobject.rule.IotDataBridgeDO; import cn.iocoder.yudao.module.iot.dal.dataobject.rule.IotDataRuleSinkDO;
import jakarta.validation.Valid; import jakarta.validation.Valid;
import java.util.List; import java.util.List;
@@ -43,7 +43,7 @@ public interface IotDataBridgeService {
* @param id 编号 * @param id 编号
* @return 数据桥梁 * @return 数据桥梁
*/ */
IotDataBridgeDO getDataBridge(Long id); IotDataRuleSinkDO getDataBridge(Long id);
/** /**
* 获得数据桥梁分页 * 获得数据桥梁分页
@@ -51,7 +51,7 @@ public interface IotDataBridgeService {
* @param pageReqVO 分页查询 * @param pageReqVO 分页查询
* @return 数据桥梁分页 * @return 数据桥梁分页
*/ */
PageResult<IotDataBridgeDO> getDataBridgePage(IotDataBridgePageReqVO pageReqVO); PageResult<IotDataRuleSinkDO> getDataBridgePage(IotDataBridgePageReqVO pageReqVO);
/** /**
* 获取数据桥梁列表 * 获取数据桥梁列表
@@ -59,6 +59,6 @@ public interface IotDataBridgeService {
* @param status 状态,如果为空,则不进行筛选 * @param status 状态,如果为空,则不进行筛选
* @return 数据桥梁列表 * @return 数据桥梁列表
*/ */
List<IotDataBridgeDO> getDataBridgeList(Integer status); List<IotDataRuleSinkDO> getDataBridgeList(Integer status);
} }

View File

@@ -4,7 +4,7 @@ import cn.iocoder.yudao.framework.common.pojo.PageResult;
import cn.iocoder.yudao.framework.common.util.object.BeanUtils; import cn.iocoder.yudao.framework.common.util.object.BeanUtils;
import cn.iocoder.yudao.module.iot.controller.admin.rule.vo.databridge.IotDataBridgePageReqVO; import cn.iocoder.yudao.module.iot.controller.admin.rule.vo.databridge.IotDataBridgePageReqVO;
import cn.iocoder.yudao.module.iot.controller.admin.rule.vo.databridge.IotDataBridgeSaveReqVO; import cn.iocoder.yudao.module.iot.controller.admin.rule.vo.databridge.IotDataBridgeSaveReqVO;
import cn.iocoder.yudao.module.iot.dal.dataobject.rule.IotDataBridgeDO; import cn.iocoder.yudao.module.iot.dal.dataobject.rule.IotDataRuleSinkDO;
import cn.iocoder.yudao.module.iot.dal.mysql.rule.IotDataBridgeMapper; import cn.iocoder.yudao.module.iot.dal.mysql.rule.IotDataBridgeMapper;
import jakarta.annotation.Resource; import jakarta.annotation.Resource;
import org.springframework.stereotype.Service; import org.springframework.stereotype.Service;
@@ -30,7 +30,7 @@ public class IotDataBridgeServiceImpl implements IotDataBridgeService {
@Override @Override
public Long createDataBridge(IotDataBridgeSaveReqVO createReqVO) { public Long createDataBridge(IotDataBridgeSaveReqVO createReqVO) {
// 插入 // 插入
IotDataBridgeDO dataBridge = BeanUtils.toBean(createReqVO, IotDataBridgeDO.class); IotDataRuleSinkDO dataBridge = BeanUtils.toBean(createReqVO, IotDataRuleSinkDO.class);
dataBridgeMapper.insert(dataBridge); dataBridgeMapper.insert(dataBridge);
// 返回 // 返回
return dataBridge.getId(); return dataBridge.getId();
@@ -41,7 +41,7 @@ public class IotDataBridgeServiceImpl implements IotDataBridgeService {
// 校验存在 // 校验存在
validateDataBridgeExists(updateReqVO.getId()); validateDataBridgeExists(updateReqVO.getId());
// 更新 // 更新
IotDataBridgeDO updateObj = BeanUtils.toBean(updateReqVO, IotDataBridgeDO.class); IotDataRuleSinkDO updateObj = BeanUtils.toBean(updateReqVO, IotDataRuleSinkDO.class);
dataBridgeMapper.updateById(updateObj); dataBridgeMapper.updateById(updateObj);
} }
@@ -60,17 +60,17 @@ public class IotDataBridgeServiceImpl implements IotDataBridgeService {
} }
@Override @Override
public IotDataBridgeDO getDataBridge(Long id) { public IotDataRuleSinkDO getDataBridge(Long id) {
return dataBridgeMapper.selectById(id); return dataBridgeMapper.selectById(id);
} }
@Override @Override
public PageResult<IotDataBridgeDO> getDataBridgePage(IotDataBridgePageReqVO pageReqVO) { public PageResult<IotDataRuleSinkDO> getDataBridgePage(IotDataBridgePageReqVO pageReqVO) {
return dataBridgeMapper.selectPage(pageReqVO); return dataBridgeMapper.selectPage(pageReqVO);
} }
@Override @Override
public List<IotDataBridgeDO> getDataBridgeList(Integer status) { public List<IotDataRuleSinkDO> getDataBridgeList(Integer status) {
return dataBridgeMapper.selectList(status); return dataBridgeMapper.selectList(status);
} }

View File

@@ -3,7 +3,7 @@ package cn.iocoder.yudao.module.iot.service.rule.action;
import cn.hutool.core.lang.Assert; import cn.hutool.core.lang.Assert;
import cn.iocoder.yudao.framework.common.enums.CommonStatusEnum; import cn.iocoder.yudao.framework.common.enums.CommonStatusEnum;
import cn.iocoder.yudao.module.iot.core.mq.message.IotDeviceMessage; import cn.iocoder.yudao.module.iot.core.mq.message.IotDeviceMessage;
import cn.iocoder.yudao.module.iot.dal.dataobject.rule.IotDataBridgeDO; import cn.iocoder.yudao.module.iot.dal.dataobject.rule.IotDataRuleSinkDO;
import cn.iocoder.yudao.module.iot.dal.dataobject.rule.IotRuleSceneDO; import cn.iocoder.yudao.module.iot.dal.dataobject.rule.IotRuleSceneDO;
import cn.iocoder.yudao.module.iot.enums.rule.IotRuleSceneActionTypeEnum; import cn.iocoder.yudao.module.iot.enums.rule.IotRuleSceneActionTypeEnum;
import cn.iocoder.yudao.module.iot.service.rule.IotDataBridgeService; import cn.iocoder.yudao.module.iot.service.rule.IotDataBridgeService;
@@ -36,7 +36,7 @@ public class IotRuleSceneDataBridgeAction implements IotRuleSceneAction {
} }
// 1.2 获得数据桥梁 // 1.2 获得数据桥梁
Assert.notNull(config.getDataBridgeId(), "数据桥梁编号不能为空"); Assert.notNull(config.getDataBridgeId(), "数据桥梁编号不能为空");
IotDataBridgeDO dataBridge = dataBridgeService.getDataBridge(config.getDataBridgeId()); IotDataRuleSinkDO dataBridge = dataBridgeService.getDataBridge(config.getDataBridgeId());
if (dataBridge == null || dataBridge.getConfig() == null) { if (dataBridge == null || dataBridge.getConfig() == null) {
log.error("[execute][message({}) config({}) 对应的数据桥梁不存在]", message, config); log.error("[execute][message({}) config({}) 对应的数据桥梁不存在]", message, config);
return; return;

View File

@@ -2,7 +2,7 @@ package cn.iocoder.yudao.module.iot.service.rule.action.databridge;
import cn.hutool.core.util.ObjUtil; import cn.hutool.core.util.ObjUtil;
import cn.iocoder.yudao.module.iot.core.mq.message.IotDeviceMessage; import cn.iocoder.yudao.module.iot.core.mq.message.IotDeviceMessage;
import cn.iocoder.yudao.module.iot.dal.dataobject.rule.IotDataBridgeDO; import cn.iocoder.yudao.module.iot.dal.dataobject.rule.IotDataRuleSinkDO;
import com.google.common.cache.CacheBuilder; import com.google.common.cache.CacheBuilder;
import com.google.common.cache.CacheLoader; import com.google.common.cache.CacheLoader;
import com.google.common.cache.LoadingCache; import com.google.common.cache.LoadingCache;
@@ -100,7 +100,7 @@ public abstract class AbstractCacheableDataBridgeExecute<Config, Producer> imple
@Override @Override
@SuppressWarnings({"unchecked"}) @SuppressWarnings({"unchecked"})
public void execute(IotDeviceMessage message, IotDataBridgeDO dataBridge) { public void execute(IotDeviceMessage message, IotDataRuleSinkDO dataBridge) {
if (ObjUtil.notEqual(dataBridge.getType(), getType())) { if (ObjUtil.notEqual(dataBridge.getType(), getType())) {
return; return;
} }

View File

@@ -1,7 +1,7 @@
package cn.iocoder.yudao.module.iot.service.rule.action.databridge; package cn.iocoder.yudao.module.iot.service.rule.action.databridge;
import cn.iocoder.yudao.module.iot.core.mq.message.IotDeviceMessage; import cn.iocoder.yudao.module.iot.core.mq.message.IotDeviceMessage;
import cn.iocoder.yudao.module.iot.dal.dataobject.rule.IotDataBridgeDO; import cn.iocoder.yudao.module.iot.dal.dataobject.rule.IotDataRuleSinkDO;
/** /**
* IoT 数据桥梁的执行器 execute 接口 * IoT 数据桥梁的执行器 execute 接口
@@ -24,7 +24,7 @@ public interface IotDataBridgeExecute<Config> {
* @param dataBridge 数据桥梁 * @param dataBridge 数据桥梁
*/ */
@SuppressWarnings({"unchecked"}) @SuppressWarnings({"unchecked"})
default void execute(IotDeviceMessage message, IotDataBridgeDO dataBridge) throws Exception { default void execute(IotDeviceMessage message, IotDataRuleSinkDO dataBridge) throws Exception {
// 1.1 校验数据桥梁类型 // 1.1 校验数据桥梁类型
if (!getType().equals(dataBridge.getType())) { if (!getType().equals(dataBridge.getType())) {
return; return;

View File

@@ -5,7 +5,7 @@ import cn.iocoder.yudao.framework.common.util.http.HttpUtils;
import cn.iocoder.yudao.framework.common.util.json.JsonUtils; import cn.iocoder.yudao.framework.common.util.json.JsonUtils;
import cn.iocoder.yudao.module.iot.controller.admin.rule.vo.databridge.config.IotDataBridgeHttpConfig; import cn.iocoder.yudao.module.iot.controller.admin.rule.vo.databridge.config.IotDataBridgeHttpConfig;
import cn.iocoder.yudao.module.iot.core.mq.message.IotDeviceMessage; import cn.iocoder.yudao.module.iot.core.mq.message.IotDeviceMessage;
import cn.iocoder.yudao.module.iot.enums.rule.IotDataBridgeTypeEnum; import cn.iocoder.yudao.module.iot.enums.rule.IotDataRuleSinkTypeEnum;
import jakarta.annotation.Resource; import jakarta.annotation.Resource;
import lombok.extern.slf4j.Slf4j; import lombok.extern.slf4j.Slf4j;
import org.springframework.http.*; import org.springframework.http.*;
@@ -30,7 +30,7 @@ public class IotHttpDataBridgeExecute implements IotDataBridgeExecute<IotDataBri
@Override @Override
public Integer getType() { public Integer getType() {
return IotDataBridgeTypeEnum.HTTP.getType(); return IotDataRuleSinkTypeEnum.HTTP.getType();
} }
@Override @Override

View File

@@ -2,7 +2,7 @@ package cn.iocoder.yudao.module.iot.service.rule.action.databridge;
import cn.iocoder.yudao.module.iot.controller.admin.rule.vo.databridge.config.IotDataBridgeKafkaMQConfig; import cn.iocoder.yudao.module.iot.controller.admin.rule.vo.databridge.config.IotDataBridgeKafkaMQConfig;
import cn.iocoder.yudao.module.iot.core.mq.message.IotDeviceMessage; import cn.iocoder.yudao.module.iot.core.mq.message.IotDeviceMessage;
import cn.iocoder.yudao.module.iot.enums.rule.IotDataBridgeTypeEnum; import cn.iocoder.yudao.module.iot.enums.rule.IotDataRuleSinkTypeEnum;
import lombok.extern.slf4j.Slf4j; import lombok.extern.slf4j.Slf4j;
import org.apache.kafka.clients.producer.ProducerConfig; import org.apache.kafka.clients.producer.ProducerConfig;
import org.apache.kafka.common.serialization.StringSerializer; import org.apache.kafka.common.serialization.StringSerializer;
@@ -31,7 +31,7 @@ public class IotKafkaMQDataBridgeExecute extends
@Override @Override
public Integer getType() { public Integer getType() {
return IotDataBridgeTypeEnum.KAFKA.getType(); return IotDataRuleSinkTypeEnum.KAFKA.getType();
} }
@Override @Override

View File

@@ -2,7 +2,7 @@ package cn.iocoder.yudao.module.iot.service.rule.action.databridge;
import cn.iocoder.yudao.module.iot.controller.admin.rule.vo.databridge.config.IotDataBridgeRabbitMQConfig; import cn.iocoder.yudao.module.iot.controller.admin.rule.vo.databridge.config.IotDataBridgeRabbitMQConfig;
import cn.iocoder.yudao.module.iot.core.mq.message.IotDeviceMessage; import cn.iocoder.yudao.module.iot.core.mq.message.IotDeviceMessage;
import cn.iocoder.yudao.module.iot.enums.rule.IotDataBridgeTypeEnum; import cn.iocoder.yudao.module.iot.enums.rule.IotDataRuleSinkTypeEnum;
import com.rabbitmq.client.Channel; import com.rabbitmq.client.Channel;
import com.rabbitmq.client.Connection; import com.rabbitmq.client.Connection;
import com.rabbitmq.client.ConnectionFactory; import com.rabbitmq.client.ConnectionFactory;
@@ -26,7 +26,7 @@ public class IotRabbitMQDataBridgeExecute extends
@Override @Override
public Integer getType() { public Integer getType() {
return IotDataBridgeTypeEnum.RABBITMQ.getType(); return IotDataRuleSinkTypeEnum.RABBITMQ.getType();
} }
@Override @Override

View File

@@ -3,7 +3,7 @@ package cn.iocoder.yudao.module.iot.service.rule.action.databridge;
import cn.hutool.core.util.StrUtil; import cn.hutool.core.util.StrUtil;
import cn.iocoder.yudao.module.iot.controller.admin.rule.vo.databridge.config.IotDataBridgeRedisStreamConfig; import cn.iocoder.yudao.module.iot.controller.admin.rule.vo.databridge.config.IotDataBridgeRedisStreamConfig;
import cn.iocoder.yudao.module.iot.core.mq.message.IotDeviceMessage; import cn.iocoder.yudao.module.iot.core.mq.message.IotDeviceMessage;
import cn.iocoder.yudao.module.iot.enums.rule.IotDataBridgeTypeEnum; import cn.iocoder.yudao.module.iot.enums.rule.IotDataRuleSinkTypeEnum;
import lombok.extern.slf4j.Slf4j; import lombok.extern.slf4j.Slf4j;
import org.redisson.Redisson; import org.redisson.Redisson;
import org.redisson.api.RedissonClient; import org.redisson.api.RedissonClient;
@@ -29,7 +29,7 @@ public class IotRedisStreamDataBridgeExecute extends
@Override @Override
public Integer getType() { public Integer getType() {
return IotDataBridgeTypeEnum.REDIS_STREAM.getType(); return IotDataRuleSinkTypeEnum.REDIS_STREAM.getType();
} }
@Override @Override

View File

@@ -2,7 +2,7 @@ package cn.iocoder.yudao.module.iot.service.rule.action.databridge;
import cn.iocoder.yudao.module.iot.controller.admin.rule.vo.databridge.config.IotDataBridgeRocketMQConfig; import cn.iocoder.yudao.module.iot.controller.admin.rule.vo.databridge.config.IotDataBridgeRocketMQConfig;
import cn.iocoder.yudao.module.iot.core.mq.message.IotDeviceMessage; import cn.iocoder.yudao.module.iot.core.mq.message.IotDeviceMessage;
import cn.iocoder.yudao.module.iot.enums.rule.IotDataBridgeTypeEnum; import cn.iocoder.yudao.module.iot.enums.rule.IotDataRuleSinkTypeEnum;
import lombok.extern.slf4j.Slf4j; import lombok.extern.slf4j.Slf4j;
import org.apache.rocketmq.client.producer.DefaultMQProducer; import org.apache.rocketmq.client.producer.DefaultMQProducer;
import org.apache.rocketmq.client.producer.SendResult; import org.apache.rocketmq.client.producer.SendResult;
@@ -25,7 +25,7 @@ public class IotRocketMQDataBridgeExecute extends
@Override @Override
public Integer getType() { public Integer getType() {
return IotDataBridgeTypeEnum.ROCKETMQ.getType(); return IotDataRuleSinkTypeEnum.ROCKETMQ.getType();
} }
@Override @Override

View File

@@ -3,7 +3,7 @@ package cn.iocoder.yudao.module.iot.service.rule.action.databridge;
import cn.iocoder.yudao.framework.test.core.ut.BaseMockitoUnitTest; import cn.iocoder.yudao.framework.test.core.ut.BaseMockitoUnitTest;
import cn.iocoder.yudao.module.iot.controller.admin.rule.vo.databridge.config.*; import cn.iocoder.yudao.module.iot.controller.admin.rule.vo.databridge.config.*;
import cn.iocoder.yudao.module.iot.core.mq.message.IotDeviceMessage; import cn.iocoder.yudao.module.iot.core.mq.message.IotDeviceMessage;
import cn.iocoder.yudao.module.iot.dal.dataobject.rule.IotDataBridgeDO; import cn.iocoder.yudao.module.iot.dal.dataobject.rule.IotDataRuleSinkDO;
import lombok.extern.slf4j.Slf4j; import lombok.extern.slf4j.Slf4j;
import org.junit.jupiter.api.BeforeEach; import org.junit.jupiter.api.BeforeEach;
import org.junit.jupiter.api.Disabled; import org.junit.jupiter.api.Disabled;
@@ -129,7 +129,7 @@ public class IotDataBridgeExecuteTest extends BaseMockitoUnitTest {
// 3. 执行测试 // 3. 执行测试
log.info("[testHttpDataBridge][执行HTTP数据桥接测试]"); log.info("[testHttpDataBridge][执行HTTP数据桥接测试]");
httpDataBridgeExecute.execute(message, new IotDataBridgeDO() httpDataBridgeExecute.execute(message, new IotDataRuleSinkDO()
.setType(httpDataBridgeExecute.getType()).setConfig(config)); .setType(httpDataBridgeExecute.getType()).setConfig(config));
} }
@@ -144,10 +144,10 @@ public class IotDataBridgeExecuteTest extends BaseMockitoUnitTest {
private void executeAndVerifyCache(IotDataBridgeExecute<?> action, IotDataBridgeAbstractConfig config, String type) private void executeAndVerifyCache(IotDataBridgeExecute<?> action, IotDataBridgeAbstractConfig config, String type)
throws Exception { throws Exception {
log.info("[test{}DataBridge][第一次执行,应该会创建新的 producer]", type); log.info("[test{}DataBridge][第一次执行,应该会创建新的 producer]", type);
action.execute(message, new IotDataBridgeDO().setType(action.getType()).setConfig(config)); action.execute(message, new IotDataRuleSinkDO().setType(action.getType()).setConfig(config));
log.info("[test{}DataBridge][第二次执行,应该会复用缓存的 producer]", type); log.info("[test{}DataBridge][第二次执行,应该会复用缓存的 producer]", type);
action.execute(message, new IotDataBridgeDO().setType(action.getType()).setConfig(config)); action.execute(message, new IotDataRuleSinkDO().setType(action.getType()).setConfig(config));
} }
} }