设备解绑功能完善

This commit is contained in:
kerwincui
2022-06-09 17:09:07 +08:00
parent 0052178b5a
commit 44ed5a27b3
18 changed files with 161 additions and 72 deletions

View File

@@ -187,7 +187,7 @@ public class DeviceController extends BaseController
@DeleteMapping("/{deviceIds}") @DeleteMapping("/{deviceIds}")
@ApiOperation("批量删除设备") @ApiOperation("批量删除设备")
public AjaxResult remove(@PathVariable Long[] deviceIds) throws SchedulerException { public AjaxResult remove(@PathVariable Long[] deviceIds) throws SchedulerException {
return toAjax(deviceService.deleteDeviceByDeviceIds(deviceIds)); return toAjax(deviceService.deleteDeviceByDeviceId(deviceIds[0]));
} }
@PreAuthorize("@ss.hasPermi('iot:device:edit')") @PreAuthorize("@ss.hasPermi('iot:device:edit')")

View File

@@ -83,10 +83,10 @@ public interface DeviceLogMapper
/** /**
* 根据设备Ids批量删除设备日志 * 根据设备Ids批量删除设备日志
* *
* @param deviceIds 需要删除的数据设备Ids * @param deviceId 需要删除的数据设备Id
* @return 结果 * @return 结果
*/ */
public int deleteDeviceLogByDeviceIds(Long[] deviceIds); public int deleteDeviceLogByDeviceId(Long deviceId);
// List<DeviceLog> selectLogList(Long deviceId,String serialNumber,Long isMonitor,Long logType, Date beginDate, Date endDate); // List<DeviceLog> selectLogList(Long deviceId,String serialNumber,Long isMonitor,Long logType, Date beginDate, Date endDate);

View File

@@ -180,7 +180,7 @@ public interface DeviceMapper
* @param deviceIds * @param deviceIds
* @return * @return
*/ */
public int deleteDeviceGroupByDeviceIds(Long[] deviceIds); public int deleteDeviceGroupByDeviceId(UserIdAndDeviceIdModel userIdAndDeviceIdModel);
/** /**
* 重置设备状态 * 重置设备状态

View File

@@ -2,6 +2,7 @@ package com.ruoyi.iot.mapper;
import java.util.List; import java.util.List;
import com.ruoyi.iot.domain.DeviceUser; import com.ruoyi.iot.domain.DeviceUser;
import com.ruoyi.iot.model.UserIdAndDeviceIdModel;
import org.apache.ibatis.annotations.Param; import org.apache.ibatis.annotations.Param;
import org.springframework.stereotype.Repository; import org.springframework.stereotype.Repository;
@@ -49,10 +50,10 @@ public interface DeviceUserMapper
/** /**
* 删除设备用户 * 删除设备用户
* *
* @param deviceId 设备用户主键 * @param UserIdAndDeviceIdModel 用户ID和设备ID
* @return 结果 * @return 结果
*/ */
public int deleteDeviceUserByDeviceId(Long deviceId); public int deleteDeviceUserByDeviceId(UserIdAndDeviceIdModel userIdAndDeviceIdModel);
/** /**
* 批量删除设备用户 * 批量删除设备用户

View File

@@ -0,0 +1,35 @@
package com.ruoyi.iot.model;
/**
* 用户ID和设备ID模型
*
* @author kerwincui
* @date 2021-12-16
*/
public class UserIdAndDeviceIdModel
{
private Long userId;
private Long deviceId;
public UserIdAndDeviceIdModel(Long userId,Long deviceId){
this.userId=userId;
this.deviceId=deviceId;
}
public Long getUserId() {
return userId;
}
public void setUserId(Long userId) {
this.userId = userId;
}
public Long getDeviceId() {
return deviceId;
}
public void setDeviceId(Long deviceId) {
this.deviceId = deviceId;
}
}

View File

@@ -70,10 +70,10 @@ public interface IDeviceLogService
public int deleteDeviceLogByLogId(Long logId); public int deleteDeviceLogByLogId(Long logId);
/** /**
* 根据设备IDs批量删除设备日志 * 根据设备ID批量删除设备日志
* *
* @param deviceIds 需要删除的设备日志IDs * @param deviceId 需要删除的设备日志ID
* @return 结果 * @return 结果
*/ */
public int deleteDeviceLogByDeviceIds(Long[] deviceIds); public int deleteDeviceLogByDeviceId(Long deviceId);
} }

View File

@@ -155,20 +155,13 @@ public interface IDeviceService
public int reportDevice(Device device); public int reportDevice(Device device);
/** /**
* 批量删除设备 * 删除设备
* *
* @param deviceIds 需要删除的设备主键集合 * @param deviceId 需要删除的设备主键集合
* @return 结果 * @return 结果
*/ */
public int deleteDeviceByDeviceIds(Long[] deviceIds) throws SchedulerException; public int deleteDeviceByDeviceId(Long deviceId) throws SchedulerException;
/**
* 删除设备信息
*
* @param deviceId 设备主键
* @return 结果
*/
public int deleteDeviceByDeviceId(Long deviceId);
/** /**
* 生成设备唯一编号 * 生成设备唯一编号

View File

@@ -102,13 +102,13 @@ public class DeviceLogServiceImpl implements IDeviceLogService
/** /**
* 根据设备Ids批量删除设备日志 * 根据设备Ids批量删除设备日志
* *
* @param deviceIds 需要删除数据的设备Ids * @param deviceId 需要删除数据的设备Ids
* @return 结果 * @return 结果
*/ */
@Override @Override
public int deleteDeviceLogByDeviceIds(Long[] deviceIds) public int deleteDeviceLogByDeviceId(Long deviceId)
{ {
return deviceLogMapper.deleteDeviceLogByDeviceIds(deviceIds); return deviceLogMapper.deleteDeviceLogByDeviceId(deviceId);
} }
/** /**

View File

@@ -796,34 +796,44 @@ public class DeviceServiceImpl implements IDeviceService {
} }
/** /**
* 批量删除设备 * 删除设备
* @param deviceIds 需要删除的设备主键 * @param deviceId 需要删除的设备主键
* @return 结果 * @return 结果
*/ */
@Override @Override
@Transactional(rollbackFor = Exception.class) @Transactional(rollbackFor = Exception.class)
public int deleteDeviceByDeviceIds(Long[] deviceIds) throws SchedulerException { public int deleteDeviceByDeviceId(Long deviceId) throws SchedulerException {
// 删除设备分组 SysUser user=getLoginUser().getUser();
deviceMapper.deleteDeviceGroupByDeviceIds(deviceIds); // 是否为普通用户,普通用户如果不是设备所有者,只能删除设备用户和用户自己的设备关联分组信息
// TODO 删除设备日志 td里面删除 boolean isGeneralUser=false;
deviceLogMapper.deleteDeviceLogByDeviceIds(deviceIds); List<SysRole> roles=user.getRoles();
// TODO 删除设备告警记录 for(int i=0;i<roles.size();i++){
if (roles.get(i).getRoleKey().equals("general")){
isGeneralUser=true;
break;
}
}
// 删除定时任务 Device device=deviceMapper.selectDeviceByDeviceId(deviceId);
deviceJobService.deleteJobByDeviceIds(deviceIds); if(isGeneralUser && device.getUserId().longValue()!=user.getUserId()){
// 删除设备用户 // 删除用户的设备用户信息。 普通用户,且不是设备所有者。
deviceUserMapper.deleteDeviceUserByDeviceIds(deviceIds); deviceUserMapper.deleteDeviceUserByDeviceId(new UserIdAndDeviceIdModel(user.getUserId(),deviceId));
// 删除设备 // 删除用户的设备分组
return deviceMapper.deleteDeviceByDeviceIds(deviceIds); deviceMapper.deleteDeviceGroupByDeviceId(new UserIdAndDeviceIdModel(user.getUserId(),deviceId));
} }else{
// 删除设备用户。 租户、管理员和设备所有者
deviceUserMapper.deleteDeviceUserByDeviceId(new UserIdAndDeviceIdModel(null,deviceId));
// 删除设备分组。
deviceMapper.deleteDeviceGroupByDeviceId(new UserIdAndDeviceIdModel(null,deviceId));
// 删除定时任务
deviceJobService.deleteJobByDeviceIds(new Long[]{deviceId});
// 批量删除设备日志
logService.deleteDeviceLogByDeviceId(deviceId);
// TODO 删除设备告警记录
/** // 删除设备
* 删除设备信息 deviceMapper.deleteDeviceByDeviceIds(new Long[]{deviceId});
* @param deviceId 设备主键 }
* @return 结果 return 1;
*/
@Override
public int deleteDeviceByDeviceId(Long deviceId) {
return deviceMapper.deleteDeviceByDeviceId(deviceId);
} }
} }

View File

@@ -4,6 +4,7 @@ import com.ruoyi.common.core.domain.entity.SysUser;
import com.ruoyi.common.utils.DateUtils; import com.ruoyi.common.utils.DateUtils;
import com.ruoyi.iot.domain.DeviceUser; import com.ruoyi.iot.domain.DeviceUser;
import com.ruoyi.iot.mapper.DeviceUserMapper; import com.ruoyi.iot.mapper.DeviceUserMapper;
import com.ruoyi.iot.model.UserIdAndDeviceIdModel;
import com.ruoyi.iot.service.IDeviceUserService; import com.ruoyi.iot.service.IDeviceUserService;
import org.springframework.beans.factory.annotation.Autowired; import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.dao.DuplicateKeyException; import org.springframework.dao.DuplicateKeyException;
@@ -103,7 +104,7 @@ public class DeviceUserServiceImpl implements IDeviceUserService
@Override @Override
public int deleteDeviceUserByDeviceId(Long deviceId) public int deleteDeviceUserByDeviceId(Long deviceId)
{ {
return deviceUserMapper.deleteDeviceUserByDeviceId(deviceId); return deviceUserMapper.deleteDeviceUserByDeviceId(new UserIdAndDeviceIdModel(null,deviceId));
} }
@Override @Override

View File

@@ -33,7 +33,9 @@ public interface TDDeviceLogDAO {
int delete(String dbName, DeviceLog deviceLog); int delete(String dbName, DeviceLog deviceLog);
// List<DeviceLog> selectLogListByPage(String dbName, Integer pageSize, Integer pageNum, String deviceNum, Date beginDate, Date endDate); int deleteDeviceLogByDeviceId(String dbName,Long deviceId);
// List<DeviceLog> selectLogListByPage(String dbName, Integer pageSize, Integer pageNum, String deviceNum, Date beginDate, Date endDate);
List<DeviceLog> selectLogList(String dbName, Long deviceId, String serialNumber, Long isMonitor, Long logType, Date beginDate, Date endDate); List<DeviceLog> selectLogList(String dbName, Long deviceId, String serialNumber, Long isMonitor, Long logType, Date beginDate, Date endDate);

View File

@@ -18,8 +18,12 @@ import java.util.List;
*/ */
public interface ILogService { public interface ILogService {
/** 保存设备日志 **/
int saveDeviceLog(DeviceLog deviceLog); int saveDeviceLog(DeviceLog deviceLog);
/** 根据设备ID删除设备日志 **/
int deleteDeviceLogByDeviceId(Long deviceId);
/** 设备属性、功能、事件总数 **/ /** 设备属性、功能、事件总数 **/
DeviceStatistic selectCategoryLogCount(); DeviceStatistic selectCategoryLogCount();

View File

@@ -22,11 +22,24 @@ public class MySqlLogServiceImpl implements ILogService {
this.deviceLogMapper=_deviceLogMapper; this.deviceLogMapper=_deviceLogMapper;
} }
/***
* 新增设备日志
* @return
*/
@Override @Override
public int saveDeviceLog(DeviceLog deviceLog) { public int saveDeviceLog(DeviceLog deviceLog) {
return deviceLogMapper.insertDeviceLog(deviceLog); return deviceLogMapper.insertDeviceLog(deviceLog);
} }
/***
* 根据设备ID删除设备日志
* @return
*/
@Override
public int deleteDeviceLogByDeviceId(Long deviceId) {
return deviceLogMapper.deleteDeviceLogByDeviceId(deviceId);
}
/*** /***
* 设备属性、功能、事件和监测数据总数 * 设备属性、功能、事件和监测数据总数
* @return * @return

View File

@@ -36,6 +36,10 @@ public class TdengineLogServiceImpl implements ILogService {
this.dbName=_tDengineConfig.getDbName(); this.dbName=_tDengineConfig.getDbName();
} }
/***
* 新增设备日志
* @return
*/
@Override @Override
public int saveDeviceLog(DeviceLog deviceLog) { public int saveDeviceLog(DeviceLog deviceLog) {
long logId = snowflakeIdWorker.nextId(); long logId = snowflakeIdWorker.nextId();
@@ -43,17 +47,37 @@ public class TdengineLogServiceImpl implements ILogService {
return tdDeviceLogDAO.save(dbName,deviceLog); return tdDeviceLogDAO.save(dbName,deviceLog);
} }
/** 设备属性、功能、事件和监测数据总数 **/ /***
* 根据设备ID删除设备日志
* @return
*/
@Override
public int deleteDeviceLogByDeviceId(Long deviceId) {
return tdDeviceLogDAO.deleteDeviceLogByDeviceId(dbName,deviceId);
}
/***
* 设备属性、功能、事件和监测数据总数
* @return
*/
@Override @Override
public DeviceStatistic selectCategoryLogCount(){ public DeviceStatistic selectCategoryLogCount(){
return tdDeviceLogDAO.selectCategoryLogCount(dbName); return tdDeviceLogDAO.selectCategoryLogCount(dbName);
} }
/***
* 日志列表
* @return
*/
@Override @Override
public List<DeviceLog> selectDeviceLogList(DeviceLog deviceLog) { public List<DeviceLog> selectDeviceLogList(DeviceLog deviceLog) {
return tdDeviceLogDAO.selectDeviceLogList(dbName,deviceLog); return tdDeviceLogDAO.selectDeviceLogList(dbName,deviceLog);
} }
/***
* 监测数据列表
* @return
*/
@Override @Override
public List<MonitorModel> selectMonitorList(DeviceLog deviceLog) { public List<MonitorModel> selectMonitorList(DeviceLog deviceLog) {
if(deviceLog.getIdentity()!=null){ if(deviceLog.getIdentity()!=null){

View File

@@ -120,10 +120,7 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
</foreach> </foreach>
</delete> </delete>
<delete id="deleteDeviceLogByDeviceIds" parameterType="String"> <delete id="deleteDeviceLogByDeviceId" parameterType="Long">
delete from iot_device_log where device_id in delete from iot_device_log where device_id = #{deviceId}
<foreach item="deviceId" collection="array" open="(" separator="," close=")">
#{deviceId}
</foreach>
</delete> </delete>
</mapper> </mapper>

View File

@@ -151,7 +151,7 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
select d.device_id, d.device_name, d.product_name, d.user_name, d.serial_number, d.firmware_version, d.status,d.rssi,d.is_shadow , select d.device_id, d.device_name, d.product_name, d.user_name, d.serial_number, d.firmware_version, d.status,d.rssi,d.is_shadow ,
d.location_way, d.active_time,d.network_address,d.longitude,latitude d.location_way, d.active_time,d.network_address,d.longitude,latitude
from iot_device d from iot_device d
left join iot_device_user u on u.device_id = d.device_id inner join iot_device_user u on u.device_id = d.device_id
<where> <where>
<if test="userId != null "> and u.user_id = #{userId}</if> <if test="userId != null "> and u.user_id = #{userId}</if>
<if test="deviceName != null and deviceName != ''"> and d.device_name like concat('%', #{deviceName}, '%')</if> <if test="deviceName != null and deviceName != ''"> and d.device_name like concat('%', #{deviceName}, '%')</if>
@@ -169,7 +169,7 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
select d.device_id, d.device_name, d.product_name, d.user_name, d.serial_number, d.firmware_version, d.status,d.rssi,d.is_shadow , select d.device_id, d.device_name, d.product_name, d.user_name, d.serial_number, d.firmware_version, d.status,d.rssi,d.is_shadow ,
d.location_way, d.active_time,d.network_address,d.longitude,latitude d.location_way, d.active_time,d.network_address,d.longitude,latitude
from iot_device d from iot_device d
left join iot_device_user u on u.device_id = d.device_id inner join iot_device_user u on u.device_id = d.device_id
<where> <where>
<if test="userId != null "> and u.user_id = #{userId}</if> <if test="userId != null "> and u.user_id = #{userId}</if>
<if test="tenantId != null "> and d.tenant_id = #{tenantId}</if> <if test="tenantId != null "> and d.tenant_id = #{tenantId}</if>
@@ -191,7 +191,7 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
d.firmware_version, d.status,d.rssi,d.is_shadow ,d.location_way, d.firmware_version, d.status,d.rssi,d.is_shadow ,d.location_way,
d.things_model_value, d.active_time,d.img_url,u.user_id d.things_model_value, d.active_time,d.img_url,u.user_id
from iot_device d from iot_device d
left join iot_device_user u on u.device_id = d.device_id inner join iot_device_user u on u.device_id = d.device_id
<if test="groupId != null and groupId !=0 "> left join iot_device_group g on g.device_id=d.device_id </if> <if test="groupId != null and groupId !=0 "> left join iot_device_group g on g.device_id=d.device_id </if>
<where> <where>
<if test="groupId != null and groupId !=0 "> and g.group_id = #{groupId}</if> <if test="groupId != null and groupId !=0 "> and g.group_id = #{groupId}</if>
@@ -406,10 +406,11 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
select count(*) from iot_device where serial_number = #{deviceNum} select count(*) from iot_device where serial_number = #{deviceNum}
</select> </select>
<delete id="deleteDeviceGroupByDeviceIds" parameterType="String"> <delete id="deleteDeviceGroupByDeviceId" parameterType="com.ruoyi.iot.model.UserIdAndDeviceIdModel">
delete from iot_device_group where device_id in delete from iot_device_group
<foreach item="deviceId" collection="array" open="(" separator="," close=")"> <where>
#{deviceId} <if test="1==1"> and device_id = #{deviceId}</if>
</foreach> <if test="userId != null">user_id = #{userId}</if>
</where>
</delete> </delete>
</mapper> </mapper>

View File

@@ -106,8 +106,12 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
where device_id = #{deviceId} and user_id = #{userId} where device_id = #{deviceId} and user_id = #{userId}
</update> </update>
<delete id="deleteDeviceUserByDeviceId" parameterType="Long"> <delete id="deleteDeviceUserByDeviceId" parameterType="com.ruoyi.iot.model.UserIdAndDeviceIdModel">
delete from iot_device_user where device_id = #{deviceId} and is_owner !=1 delete from iot_device_user
<where>
<if test="1==1"> and device_id = #{deviceId}</if>
<if test="userId != null">user_id = #{userId}</if>
</where>
</delete> </delete>
<delete id="deleteDeviceUserByDeviceIds" parameterType="String"> <delete id="deleteDeviceUserByDeviceIds" parameterType="String">

View File

@@ -95,18 +95,22 @@
<delete id="delete" parameterType="com.ruoyi.iot.domain.DeviceLog"> <delete id="delete" parameterType="com.ruoyi.iot.domain.DeviceLog">
delete from ${database}.device_${device.serialNumber} delete from ${database}.device_${device.serialNumber}
<where> <where>
<if test="logId !=null"> <if test="logId !=null"> log_id = #{logId} </if>
log_id = #{logId} <if test="deviceId !=null and deviceId!=''"> device_id = #{deviceId} </if>
</if> <if test="serialNumber !=null and serialNumber!=''"> serial_number = #{serialNumber} </if>
<if test="deviceId !=null and deviceId!=''">
device_id = #{deviceId}
</if>
<if test="serialNumber !=null and serialNumber!=''">
serial_number = #{serialNumber}
</if>
</where> </where>
</delete> </delete>
<delete id="deleteDeviceLogByDeviceId" parameterType="com.ruoyi.iot.domain.DeviceLog">
delete from ${database}.device_${device.serialNumber}
<where>
<if test="logId !=null"> log_id = #{logId} </if>
<if test="deviceId !=null and deviceId!=''"> device_id = #{deviceId} </if>
<if test="serialNumber !=null and serialNumber!=''"> serial_number = #{serialNumber} </if>
</where>
</delete>
<select id="selectLogList" resultMap="BaseResultMap"> <select id="selectLogList" resultMap="BaseResultMap">
select * from ${database}.device_log select * from ${database}.device_log
<where> <where>