临时提交

pull/1642/head
648540858 2024-08-02 14:46:20 +08:00
parent 3f2c9f6451
commit 55c534ac90
8 changed files with 120 additions and 113 deletions

View File

@ -1,12 +0,0 @@
package com.genersoft.iot.vmp.gb28181.bean;
import io.swagger.v3.oas.annotations.media.Schema;
import lombok.Data;
@Data
@Schema(description = "国标通道关联分组表ID")
public class CommonGBChannelWitchGroupChannelId extends CommonGBChannel {
private int groupChannelId;
}

View File

@ -356,12 +356,16 @@ public interface CommonGBChannelMapper {
List<CommonGBChannel> queryByGbDeviceIds(List<Integer> deviceIds); List<CommonGBChannel> queryByGbDeviceIds(List<Integer> deviceIds);
@SelectProvider(type = ChannelProvider.class, method = "queryByGroupList") @SelectProvider(type = ChannelProvider.class, method = "queryByGroupList")
List<CommonGBChannelWitchGroupChannelId> queryByGroupList(List<Group> groupList); List<CommonGBChannel> queryByGroupList(List<Group> groupList);
@Delete(value = {" <script>" + @Update(value = {" <script>" +
" delete from wvp_common_group_channel" + " UPDATE wvp_device_channel " +
" where id in " + " SET gb_parent_id = null" +
" <foreach collection='channels' item='item' open='(' separator=',' close=')' > #{item.groupChannelId}</foreach>" + " WHERE id in "+
"</script>"}) " <foreach collection='channelList' item='item' open='(' separator=',' close=')' > #{item.gbId}</foreach>" +
int batchDeleteGroup(List<CommonGBChannelWitchGroupChannelId> channels); " </script>"})
int removeParentIdByChannels(List<CommonGBChannel> channelList);
@SelectProvider(type = ChannelProvider.class, method = "queryByBusinessGroup")
List<CommonGBChannel> queryByBusinessGroup(@Param("businessGroup") String businessGroup);
} }

View File

@ -11,8 +11,8 @@ import java.util.Set;
@Mapper @Mapper
public interface GroupMapper { public interface GroupMapper {
@Insert("INSERT INTO wvp_common_group (device_id, name, parent_device_id, business_group, create_time, update_time) " + @Insert("INSERT INTO wvp_common_group (device_id, name, parent_device_id, business_group, platform_id, create_time, update_time) " +
"VALUES (#{deviceId}, #{name}, #{parentDeviceId}, #{businessGroup}, #{createTime}, #{updateTime})") "VALUES (#{deviceId}, #{name}, #{parentDeviceId}, #{businessGroup}, #{platformId}, #{createTime}, #{updateTime})")
@Options(useGeneratedKeys = true, keyProperty = "id", keyColumn = "id") @Options(useGeneratedKeys = true, keyProperty = "id", keyColumn = "id")
int add(Group group); int add(Group group);
@ -89,11 +89,14 @@ public interface GroupMapper {
" DELETE FROM wvp_common_group WHERE id in " + " DELETE FROM wvp_common_group WHERE id in " +
" <foreach collection='allChildren' item='item' open='(' separator=',' close=')' > #{item.id}</foreach>" + " <foreach collection='allChildren' item='item' open='(' separator=',' close=')' > #{item.id}</foreach>" +
" </script>") " </script>")
void batchDelete(List<Group> allChildren); int batchDelete(List<Group> allChildren);
@Select("SELECT * from wvp_common_group WHERE device_id = #{businessGroup} and business_group = #{businessGroup} ") @Select("SELECT * from wvp_common_group WHERE device_id = #{businessGroup} and business_group = #{businessGroup} ")
Group queryBusinessGroup(@Param("businessGroup") String businessGroup); Group queryBusinessGroup(@Param("businessGroup") String businessGroup);
@Select("SELECT * from wvp_common_group WHERE business_group = #{businessGroup} ") @Select("SELECT * from wvp_common_group WHERE business_group = #{businessGroup} ")
List<Group> queryByBusinessGroup(@Param("businessGroup") String businessGroup); List<Group> queryByBusinessGroup(@Param("businessGroup") String businessGroup);
@Delete("DELETE FROM wvp_common_group WHERE business_group = #{businessGroup}")
int deleteByBusinessGroup(@Param("businessGroup") String businessGroup);
} }

View File

@ -11,68 +11,65 @@ public class ChannelProvider {
public String getBaseSelectSql(){ public String getBaseSelectSql(){
return "select\n" + return "select\n" +
" wdc.id as gb_id,\n" + " id as gb_id,\n" +
" wdc.device_db_id as gb_device_db_id,\n" + " device_db_id as gb_device_db_id,\n" +
" wcg.id as group_channel_id,\n" + " stream_push_id,\n" +
" wdc.stream_push_id,\n" + " stream_proxy_id,\n" +
" wdc.stream_proxy_id,\n" + " create_time,\n" +
" wdc.create_time,\n" + " update_time,\n" +
" wdc.update_time,\n" + " coalesce(gb_device_id, device_id) as gb_device_id,\n" +
" coalesce(wdc.gb_device_id, wdc.device_id) as gb_device_id,\n" + " coalesce(gb_name, name) as gb_name,\n" +
" coalesce(wdc.gb_name, wdc.name) as gb_name,\n" + " coalesce(gb_manufacturer, manufacturer) as gb_manufacturer,\n" +
" coalesce(wdc.gb_manufacturer, manufacturer) as gb_manufacturer,\n" + " coalesce(gb_model, model) as gb_model,\n" +
" coalesce(wdc.gb_model, wdc.model) as gb_model,\n" + " coalesce(gb_owner, owner) as gb_owner,\n" +
" coalesce(wdc.gb_owner, wdc.owner) as gb_owner,\n" +
" gb_civil_code,\n" + " gb_civil_code,\n" +
" coalesce(wdc.gb_block, wdc.block) as gb_block,\n" + " coalesce(gb_block, block) as gb_block,\n" +
" coalesce(wdc.gb_address, wdc.address) as gb_address,\n" + " coalesce(gb_address, address) as gb_address,\n" +
" coalesce(wdc.gb_parental, wdc.parental) as gb_parental,\n" + " coalesce(gb_parental, parental) as gb_parental,\n" +
" wcg.device_id as gb_parent_id,\n" + " coalesce(gb_parent_id, parent_id) as gb_parent_id,\n" +
" coalesce(wdc.gb_safety_way, wdc.safety_way) as gb_safety_way,\n" + " coalesce(gb_safety_way, safety_way) as gb_safety_way,\n" +
" coalesce(wdc.gb_register_way, wdc.register_way) as gb_register_way,\n" + " coalesce(gb_register_way, register_way) as gb_register_way,\n" +
" coalesce(wdc.gb_cert_num, wdc.cert_num) as gb_cert_num,\n" + " coalesce(gb_cert_num, cert_num) as gb_cert_num,\n" +
" coalesce(wdc.gb_certifiable, wdc.certifiable) as gb_certifiable,\n" + " coalesce(gb_certifiable, certifiable) as gb_certifiable,\n" +
" coalesce(wdc.gb_err_code, wdc.err_code) as gb_err_code,\n" + " coalesce(gb_err_code, err_code) as gb_err_code,\n" +
" coalesce(wdc.gb_end_time, wdc.end_time) as gb_end_time,\n" + " coalesce(gb_end_time, end_time) as gb_end_time,\n" +
" coalesce(wdc.gb_secrecy, wdc.secrecy) as gb_secrecy,\n" + " coalesce(gb_secrecy, secrecy) as gb_secrecy,\n" +
" coalesce(wdc.gb_ip_address, wdc.ip_address) as gb_ip_address,\n" + " coalesce(gb_ip_address, ip_address) as gb_ip_address,\n" +
" coalesce(wdc.gb_port, port) wdc.as gb_port,\n" + " coalesce(gb_port, port) as gb_port,\n" +
" coalesce(wdc.gb_password, wdc.password) as gb_password,\n" + " coalesce(gb_password, password) as gb_password,\n" +
" coalesce(wdc.gb_status, wdc.status) as gb_status,\n" + " coalesce(gb_status, status) as gb_status,\n" +
" coalesce(wdc.gb_longitude, wdc.longitude) as gb_longitude,\n" + " coalesce(gb_longitude, longitude) as gb_longitude,\n" +
" coalesce(wdc.gb_latitude, wdc.latitude) as gb_latitude,\n" + " coalesce(gb_latitude, latitude) as gb_latitude,\n" +
" coalesce(wdc.gb_ptz_type, wdc.ptz_type) as gb_ptz_type,\n" + " coalesce(gb_ptz_type, ptz_type) as gb_ptz_type,\n" +
" coalesce(wdc.gb_position_type, wdc.position_type) as gb_position_type,\n" + " coalesce(gb_position_type, position_type) as gb_position_type,\n" +
" coalesce(wdc.gb_room_type, wdc.room_type) as gb_room_type,\n" + " coalesce(gb_room_type, room_type) as gb_room_type,\n" +
" coalesce(wdc.gb_use_type, wdc.use_type) as gb_use_type,\n" + " coalesce(gb_use_type, use_type) as gb_use_type,\n" +
" coalesce(wdc.gb_supply_light_type, wdc.supply_light_type) as gb_supply_light_type,\n" + " coalesce(gb_supply_light_type, supply_light_type) as gb_supply_light_type,\n" +
" coalesce(wdc.gb_direction_type, wdc.direction_type) as gb_direction_type,\n" + " coalesce(gb_direction_type, direction_type) as gb_direction_type,\n" +
" coalesce(wdc.gb_resolution, wdc.resolution) as gb_resolution,\n" + " coalesce(gb_resolution, resolution) as gb_resolution,\n" +
" wcg.business_group as gb_business_group_id,\n" + " gb_business_group_id,\n" +
" coalesce(wdc.gb_download_speed, wdc.download_speed) as gb_download_speed,\n" + " coalesce(gb_download_speed, download_speed) as gb_download_speed,\n" +
" coalesce(wdc.gb_svc_space_support_mod, wdc.svc_space_support_mod) as gb_svc_space_support_mod,\n" + " coalesce(gb_svc_space_support_mod, svc_space_support_mod) as gb_svc_space_support_mod,\n" +
" coalesce(wdc.gb_svc_time_support_mode, wdc.svc_time_support_mode) as gb_svc_time_support_mode\n" + " coalesce(gb_svc_time_support_mode,svc_time_support_mode) as gb_svc_time_support_mode\n" +
" from wvp_device_channel wdc\n" + " from wvp_device_channel\n"
" left jon wvp_common_group_channel wcgc on wcgc.channel_id = wdc.id\n" +
" left jon wvp_common_group wcg on wcgc.group_id = wcg.id\n"
; ;
} }
public String queryByDeviceId(Map<String, Object> params ){ public String queryByDeviceId(Map<String, Object> params ){
return getBaseSelectSql() + " where wdc.gb_device_id = #{gbDeviceId} or wdc.device_id = #{gbDeviceId}"; return getBaseSelectSql() + " where gb_device_id = #{gbDeviceId} or device_id = #{gbDeviceId}";
} }
public String queryById(Map<String, Object> params ){ public String queryById(Map<String, Object> params ){
return getBaseSelectSql() + " where wdc.id = #{gbId}"; return getBaseSelectSql() + " where id = #{gbId}";
} }
public String queryByStreamPushId(Map<String, Object> params ){ public String queryByStreamPushId(Map<String, Object> params ){
return getBaseSelectSql() + " where wdc.stream_push_id = #{streamPushId}"; return getBaseSelectSql() + " where stream_push_id = #{streamPushId}";
} }
public String queryByStreamProxyId(Map<String, Object> params ){ public String queryByStreamProxyId(Map<String, Object> params ){
return getBaseSelectSql() + " where wdc.stream_proxy_id = #{streamProxyId}"; return getBaseSelectSql() + " where stream_proxy_id = #{streamProxyId}";
} }
@ -81,21 +78,21 @@ public class ChannelProvider {
sqlBuild.append(getBaseSelectSql()); sqlBuild.append(getBaseSelectSql());
sqlBuild.append(" where 1 = 1 "); sqlBuild.append(" where 1 = 1 ");
if (params.get("query") != null) { if (params.get("query") != null) {
sqlBuild.append(" AND (coalesce(wdc.gb_device_id, device_id) LIKE concat('%',#{query},'%')" + sqlBuild.append(" AND (coalesce(gb_device_id, device_id) LIKE concat('%',#{query},'%')" +
" OR coalesce(wdc.gb_name, name) LIKE concat('%',#{query},'%') )") " OR coalesce(gb_name, name) LIKE concat('%',#{query},'%') )")
; ;
} }
if (params.get("online") != null && (Boolean)params.get("online")) { if (params.get("online") != null && (Boolean)params.get("online")) {
sqlBuild.append(" AND coalesce(wdc.gb_status, status) = 'ON'"); sqlBuild.append(" AND coalesce(gb_status, status) = 'ON'");
} }
if (params.get("online") != null && !(Boolean)params.get("online")) { if (params.get("online") != null && !(Boolean)params.get("online")) {
sqlBuild.append(" AND coalesce(wdc.gb_status, status) = 'OFF'"); sqlBuild.append(" AND coalesce(gb_status, status) = 'OFF'");
} }
if (params.get("hasCivilCode") != null && (Boolean)params.get("hasCivilCode")) { if (params.get("hasCivilCode") != null && (Boolean)params.get("hasCivilCode")) {
sqlBuild.append(" AND wdc.gb_civil_code is not null"); sqlBuild.append(" AND gb_civil_code is not null");
} }
if (params.get("hasCivilCode") != null && !(Boolean)params.get("hasCivilCode")) { if (params.get("hasCivilCode") != null && !(Boolean)params.get("hasCivilCode")) {
sqlBuild.append(" AND wdc.gb_civil_code is null"); sqlBuild.append(" AND gb_civil_code is null");
} }
return sqlBuild.toString(); return sqlBuild.toString();
} }
@ -103,7 +100,7 @@ public class ChannelProvider {
public String queryInListByStatus(Map<String, Object> params ){ public String queryInListByStatus(Map<String, Object> params ){
StringBuilder sqlBuild = new StringBuilder(); StringBuilder sqlBuild = new StringBuilder();
sqlBuild.append(getBaseSelectSql()); sqlBuild.append(getBaseSelectSql());
sqlBuild.append("where wdc.gb_status=#{status} and wdc.id in ( "); sqlBuild.append("where gb_status=#{status} and id in ( ");
List<CommonGBChannel> commonGBChannelList = (List<CommonGBChannel>)params.get("ids"); List<CommonGBChannel> commonGBChannelList = (List<CommonGBChannel>)params.get("ids");
boolean first = true; boolean first = true;
@ -121,7 +118,7 @@ public class ChannelProvider {
public String queryByIds(Map<String, Object> params ){ public String queryByIds(Map<String, Object> params ){
StringBuilder sqlBuild = new StringBuilder(); StringBuilder sqlBuild = new StringBuilder();
sqlBuild.append(getBaseSelectSql()); sqlBuild.append(getBaseSelectSql());
sqlBuild.append("where wdc.id in ( "); sqlBuild.append("where id in ( ");
Collection<Integer> ids = (Collection<Integer>)params.get("ids"); Collection<Integer> ids = (Collection<Integer>)params.get("ids");
boolean first = true; boolean first = true;
@ -139,7 +136,7 @@ public class ChannelProvider {
public String queryByGbDeviceIds(Map<String, Object> params ){ public String queryByGbDeviceIds(Map<String, Object> params ){
StringBuilder sqlBuild = new StringBuilder(); StringBuilder sqlBuild = new StringBuilder();
sqlBuild.append(getBaseSelectSql()); sqlBuild.append(getBaseSelectSql());
sqlBuild.append("where wdc.device_db_id in ( "); sqlBuild.append("where device_db_id in ( ");
Collection<Integer> ids = (Collection<Integer>)params.get("deviceIds"); Collection<Integer> ids = (Collection<Integer>)params.get("deviceIds");
boolean first = true; boolean first = true;
@ -159,13 +156,13 @@ public class ChannelProvider {
sqlBuild.append(getBaseSelectSql()); sqlBuild.append(getBaseSelectSql());
sqlBuild.append("where "); sqlBuild.append("where ");
if (params.get("civilCode") != null) { if (params.get("civilCode") != null) {
sqlBuild.append(" wdc.gb_civil_code = #{civilCode} "); sqlBuild.append(" gb_civil_code = #{civilCode} ");
if (params.get("ids") != null) { if (params.get("ids") != null) {
sqlBuild.append(" OR "); sqlBuild.append(" OR ");
} }
} }
if (params.get("ids") != null) { if (params.get("ids") != null) {
sqlBuild.append(" wdc.id in ( "); sqlBuild.append(" id in ( ");
Collection<Integer> ids = (Collection<Integer>)params.get("ids"); Collection<Integer> ids = (Collection<Integer>)params.get("ids");
boolean first = true; boolean first = true;
for (Integer id : ids) { for (Integer id : ids) {
@ -183,7 +180,14 @@ public class ChannelProvider {
public String queryByCivilCode(Map<String, Object> params ){ public String queryByCivilCode(Map<String, Object> params ){
StringBuilder sqlBuild = new StringBuilder(); StringBuilder sqlBuild = new StringBuilder();
sqlBuild.append(getBaseSelectSql()); sqlBuild.append(getBaseSelectSql());
sqlBuild.append("where wdc.gb_civil_code = #{civilCode} "); sqlBuild.append("where gb_civil_code = #{civilCode} ");
return sqlBuild.toString() ;
}
public String queryByBusinessGroup(Map<String, Object> params ){
StringBuilder sqlBuild = new StringBuilder();
sqlBuild.append(getBaseSelectSql());
sqlBuild.append("where gb_business_group_id = #{businessGroup} ");
return sqlBuild.toString() ; return sqlBuild.toString() ;
} }
@ -191,14 +195,14 @@ public class ChannelProvider {
StringBuilder sqlBuild = new StringBuilder(); StringBuilder sqlBuild = new StringBuilder();
sqlBuild.append(getBaseSelectSql()); sqlBuild.append(getBaseSelectSql());
sqlBuild.append(" wcg.id in ( "); sqlBuild.append(" gb_business_group_id in ( ");
Collection<Group> ids = (Collection<Group>)params.get("groupList"); Collection<Group> ids = (Collection<Group>)params.get("groupList");
boolean first = true; boolean first = true;
for (Group group : ids) { for (Group group : ids) {
if (!first) { if (!first) {
sqlBuild.append(","); sqlBuild.append(",");
} }
sqlBuild.append(group.getId()); sqlBuild.append(group.getDeviceId());
first = false; first = false;
} }
sqlBuild.append(" )"); sqlBuild.append(" )");

View File

@ -57,4 +57,8 @@ public interface IGbChannelService {
void addChannelToRegionBYGbDevice(String civilCode, List<Integer> deviceIds); void addChannelToRegionBYGbDevice(String civilCode, List<Integer> deviceIds);
void deleteChannelToRegionBYGbDevice(List<Integer> deviceIds); void deleteChannelToRegionBYGbDevice(List<Integer> deviceIds);
void removeParentIdByBusinessGroup(String businessGroup);
void removeParentIdByGroupList(List<Group> groupList);
} }

View File

@ -14,6 +14,7 @@ import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.factory.annotation.Autowired; import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service; import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional; import org.springframework.transaction.annotation.Transactional;
import org.springframework.util.Assert;
import org.springframework.util.ObjectUtils; import org.springframework.util.ObjectUtils;
import java.util.ArrayList; import java.util.ArrayList;
@ -425,4 +426,25 @@ public class GbChannelServiceImpl implements IGbChannelService {
} }
int result = commonGBChannelMapper.removeCivilCodeByChannels(channelList); int result = commonGBChannelMapper.removeCivilCodeByChannels(channelList);
} }
@Override
public void removeParentIdByBusinessGroup(String businessGroup) {
List<CommonGBChannel> channelList = commonGBChannelMapper.queryByBusinessGroup(businessGroup);
Assert.notEmpty(channelList, "所有业务分组的通道不存在");
if (channelList.isEmpty()) {
throw new ControllerException(ErrorCode.ERROR100.getCode(), "所有通道Id不存在");
}
int result = commonGBChannelMapper.removeParentIdByChannels(channelList);
}
@Override
public void removeParentIdByGroupList(List<Group> groupList) {
List<CommonGBChannel> channelList = commonGBChannelMapper.queryByGroupList(groupList);
Assert.notEmpty(channelList, "所有业务分组的通道不存在");
if (channelList.isEmpty()) {
throw new ControllerException(ErrorCode.ERROR100.getCode(), "所有通道Id不存在");
}
int result = commonGBChannelMapper.removeParentIdByChannels(channelList);
}
} }

View File

@ -11,6 +11,7 @@ import com.genersoft.iot.vmp.utils.DateUtil;
import lombok.extern.slf4j.Slf4j; import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.factory.annotation.Autowired; import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service; import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;
import org.springframework.util.Assert; import org.springframework.util.Assert;
import org.springframework.util.ObjectUtils; import org.springframework.util.ObjectUtils;
@ -85,6 +86,7 @@ public class GroupServiceImpl implements IGroupService {
} }
@Override @Override
@Transactional
public boolean deleteByDeviceId(String deviceId, String groupId) { public boolean deleteByDeviceId(String deviceId, String groupId) {
Assert.notNull(deviceId, "编号不可为NULL"); Assert.notNull(deviceId, "编号不可为NULL");
Assert.notNull(groupId, "业务分组不可为NULL"); Assert.notNull(groupId, "业务分组不可为NULL");
@ -92,38 +94,24 @@ public class GroupServiceImpl implements IGroupService {
Group businessGroup = groupManager.queryBusinessGroup(groupId); Group businessGroup = groupManager.queryBusinessGroup(groupId);
Assert.notNull(businessGroup, "业务分组不存在"); Assert.notNull(businessGroup, "业务分组不存在");
// 待删除的分组
List<Group> groupList;
// 是否需要清理业务分组字段 // 是否需要清理业务分组字段
if (gbCode.getTypeCode().equals("215")) { if (gbCode.getTypeCode().equals("215")) {
// 删除业务分组 // 删除业务分组
// 获取所有的虚拟组织 // 获取所有的虚拟组织
groupList = groupManager.queryByBusinessGroup(deviceId); int result = groupManager.deleteByBusinessGroup(deviceId);
if (groupList.isEmpty()) { Assert.isTrue(result > 0, "分组不存在");
return false; gbChannelService.removeParentIdByBusinessGroup(deviceId);
}
}else { }else {
// 删除虚拟组织 // 删除虚拟组织
Group group = groupManager.queryOneByDeviceId(deviceId, groupId); Group group = groupManager.queryOneByDeviceId(deviceId, groupId);
Assert.notNull(group, "分组不存在"); Assert.notNull(group, "分组不存在");
// 获取所有子分组 // 获取所有子分组
groupList = queryAllChildren(deviceId, groupId); List<Group> groupList = queryAllChildren(deviceId, groupId);
if (groupList.isEmpty()) { groupList.add(group);
return false; int result = groupManager.batchDelete(groupList);
Assert.isTrue(result> 0, "删除分组失败");
gbChannelService.removeParentIdByGroupList(groupList);
} }
}
List<CommonGBChannelWitchGroupChannelId> channels = commonGBChannelMapper.queryByGroupList(groupList);
if (channels.isEmpty()) {
return false;
}
commonGBChannelMapper.batchDeleteGroup(channels);
// TODO 待定 是否需要发送catalog事件还是等分配的时候发送UPDATE事件
groupManager.batchDelete(groupList);
return true; return true;
} }

View File

@ -407,16 +407,10 @@ CREATE TABLE wvp_common_group
name varchar(255) NOT NULL, name varchar(255) NOT NULL,
parent_device_id varchar(50) DEFAULT NULL, parent_device_id varchar(50) DEFAULT NULL,
business_group varchar(50) NOT NULL, business_group varchar(50) NOT NULL,
platform_id int,
create_time varchar(50) NOT NULL, create_time varchar(50) NOT NULL,
update_time varchar(50) NOT NULL, update_time varchar(50) NOT NULL,
UNIQUE KEY common_group_device_id (device_id) UNIQUE KEY common_group_device_platform (device_id, platform_id)
);
CREATE TABLE wvp_common_group_channel
(
id serial primary key,
group_id integer,
channel_id integer
); );
CREATE TABLE wvp_common_region CREATE TABLE wvp_common_region