Merge branch '648540858:wvp-28181-2.0' into wvp-28181-2.0
commit
124d83fc0c
|
@ -162,7 +162,7 @@ public class PlatformChannelServiceImpl implements IPlatformChannelService {
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
if (ObjectUtils.isEmpty(catalogId)) {
|
if (ObjectUtils.isEmpty(catalogId)) {
|
||||||
catalogId = platform.getDeviceGBId();
|
catalogId = null;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ((result = platformChannelMapper.delChannelForGBByCatalogId(platformId, catalogId)) > 0) {
|
if ((result = platformChannelMapper.delChannelForGBByCatalogId(platformId, catalogId)) > 0) {
|
||||||
|
|
|
@ -31,8 +31,8 @@ public interface PlatformCatalogMapper {
|
||||||
|
|
||||||
@Update(value = {" <script>" +
|
@Update(value = {" <script>" +
|
||||||
"UPDATE wvp_platform_catalog " +
|
"UPDATE wvp_platform_catalog " +
|
||||||
"SET name=#{name}" +
|
"SET name=#{platformCatalog.name}" +
|
||||||
"WHERE id=#{id} and platform_id=#{platformId}"+
|
"WHERE id=#{platformCatalog.id} and platform_id=#{platformCatalog.platformId}"+
|
||||||
"</script>"})
|
"</script>"})
|
||||||
int update(@Param("platformCatalog") PlatformCatalog platformCatalog);
|
int update(@Param("platformCatalog") PlatformCatalog platformCatalog);
|
||||||
|
|
||||||
|
@ -51,4 +51,16 @@ public interface PlatformCatalogMapper {
|
||||||
" from wvp_platform_catalog pc " +
|
" from wvp_platform_catalog pc " +
|
||||||
" WHERE pc.id=#{id} and pc.platform_id=#{platformId}")
|
" WHERE pc.id=#{id} and pc.platform_id=#{platformId}")
|
||||||
PlatformCatalog selectByPlatFormAndCatalogId(@Param("platformId") String platformId, @Param("id") String id);
|
PlatformCatalog selectByPlatFormAndCatalogId(@Param("platformId") String platformId, @Param("id") String id);
|
||||||
|
|
||||||
|
|
||||||
|
@Delete("<script> "+
|
||||||
|
"DELETE from wvp_platform_catalog where platform_id=#{platformId} and id in " +
|
||||||
|
"<foreach collection='ids' item='item' open='(' separator=',' close=')'>" +
|
||||||
|
"#{item} " +
|
||||||
|
"</foreach>" +
|
||||||
|
"</script>")
|
||||||
|
int deleteAll(String platformId, List<String> ids);
|
||||||
|
|
||||||
|
@Select("SELECT id from wvp_platform_catalog WHERE platform_id=#{platformId} and parent_id = #{id}")
|
||||||
|
List<String> queryCatalogFromParent(@Param("id") String id, @Param("platformId") String platformId);
|
||||||
}
|
}
|
||||||
|
|
|
@ -105,7 +105,8 @@ public interface PlatformChannelMapper {
|
||||||
void delByPlatformId(String serverGBId);
|
void delByPlatformId(String serverGBId);
|
||||||
|
|
||||||
@Delete("<script> " +
|
@Delete("<script> " +
|
||||||
"DELETE from wvp_platform_gb_channel WHERE platform_id=#{platformId} and catalog_id=#{catalogId}" +
|
"DELETE from wvp_platform_gb_channel WHERE platform_id=#{platformId} " +
|
||||||
|
" <if test=\"catalogId != null\" > and catalog_id=#{catalogId}</if>" +
|
||||||
"</script>")
|
"</script>")
|
||||||
int delChannelForGBByCatalogId(@Param("platformId") String platformId, @Param("catalogId") String catalogId);
|
int delChannelForGBByCatalogId(@Param("platformId") String platformId, @Param("catalogId") String catalogId);
|
||||||
|
|
||||||
|
|
|
@ -73,6 +73,9 @@ public class VideoManagerStorageImpl implements IVideoManagerStorage {
|
||||||
@Autowired
|
@Autowired
|
||||||
private PlatformChannelMapper platformChannelMapper;
|
private PlatformChannelMapper platformChannelMapper;
|
||||||
|
|
||||||
|
@Autowired
|
||||||
|
private PlatformCatalogMapper platformCatalogMapper;
|
||||||
|
|
||||||
@Autowired
|
@Autowired
|
||||||
private StreamProxyMapper streamProxyMapper;
|
private StreamProxyMapper streamProxyMapper;
|
||||||
|
|
||||||
|
@ -166,7 +169,7 @@ public class VideoManagerStorageImpl implements IVideoManagerStorage {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (channels.size() > 0) {
|
if (!channels.isEmpty()) {
|
||||||
for (DeviceChannel channel : channels) {
|
for (DeviceChannel channel : channels) {
|
||||||
if (subContMap.get(channel.getChannelId()) != null){
|
if (subContMap.get(channel.getChannelId()) != null){
|
||||||
Integer count = subContMap.get(channel.getChannelId());
|
Integer count = subContMap.get(channel.getChannelId());
|
||||||
|
@ -187,19 +190,7 @@ public class VideoManagerStorageImpl implements IVideoManagerStorage {
|
||||||
}
|
}
|
||||||
try {
|
try {
|
||||||
int limitCount = 50;
|
int limitCount = 50;
|
||||||
int cleanChannelsResult = 0;
|
boolean result = false;
|
||||||
if (channels.size() > limitCount) {
|
|
||||||
for (int i = 0; i < channels.size(); i += limitCount) {
|
|
||||||
int toIndex = i + limitCount;
|
|
||||||
if (i + limitCount > channels.size()) {
|
|
||||||
toIndex = channels.size();
|
|
||||||
}
|
|
||||||
cleanChannelsResult += this.deviceChannelMapper.cleanChannelsNotInList(deviceId, channels.subList(i, toIndex));
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
cleanChannelsResult = this.deviceChannelMapper.cleanChannelsNotInList(deviceId, channels);
|
|
||||||
}
|
|
||||||
boolean result = cleanChannelsResult < 0;
|
|
||||||
if (!result && addChannels.size() > 0) {
|
if (!result && addChannels.size() > 0) {
|
||||||
if (addChannels.size() > limitCount) {
|
if (addChannels.size() > limitCount) {
|
||||||
for (int i = 0; i < addChannels.size(); i += limitCount) {
|
for (int i = 0; i < addChannels.size(); i += limitCount) {
|
||||||
|
@ -910,9 +901,43 @@ public class VideoManagerStorageImpl implements IVideoManagerStorage {
|
||||||
eventPublisher.catalogEventPublish(platformId, deviceChannelList, CatalogEvent.DEL);
|
eventPublisher.catalogEventPublish(platformId, deviceChannelList, CatalogEvent.DEL);
|
||||||
}
|
}
|
||||||
int delChannelresult = platformChannelMapper.delByCatalogId(platformId, id);
|
int delChannelresult = platformChannelMapper.delByCatalogId(platformId, id);
|
||||||
|
// 查看是否存在子目录,如果存在一并删除
|
||||||
|
List<String> allChildCatalog = getAllChildCatalog(id, platformId);
|
||||||
|
if (!allChildCatalog.isEmpty()) {
|
||||||
|
int limitCount = 50;
|
||||||
|
if (allChildCatalog.size() > limitCount) {
|
||||||
|
for (int i = 0; i < allChildCatalog.size(); i += limitCount) {
|
||||||
|
int toIndex = i + limitCount;
|
||||||
|
if (i + limitCount > allChildCatalog.size()) {
|
||||||
|
toIndex = allChildCatalog.size();
|
||||||
|
}
|
||||||
|
delChannelresult += platformCatalogMapper.deleteAll(platformId, allChildCatalog.subList(i, toIndex));
|
||||||
|
}
|
||||||
|
}else {
|
||||||
|
delChannelresult += platformCatalogMapper.deleteAll(platformId, allChildCatalog);
|
||||||
|
}
|
||||||
|
}
|
||||||
return delresult + delChannelresult + delStreamresult;
|
return delresult + delChannelresult + delStreamresult;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private List<String> getAllChildCatalog(String id, String platformId) {
|
||||||
|
List<String> catalogList = platformCatalogMapper.queryCatalogFromParent(id, platformId);
|
||||||
|
List<String> catalogListChild = new ArrayList<>();
|
||||||
|
if (catalogList != null && !catalogList.isEmpty()) {
|
||||||
|
for (String childId : catalogList) {
|
||||||
|
List<String> allChildCatalog = getAllChildCatalog(childId, platformId);
|
||||||
|
if (allChildCatalog != null && !allChildCatalog.isEmpty()) {
|
||||||
|
catalogListChild.addAll(allChildCatalog);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (!catalogListChild.isEmpty()) {
|
||||||
|
catalogList.addAll(catalogListChild);
|
||||||
|
}
|
||||||
|
return catalogList;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public int updateCatalog(PlatformCatalog platformCatalog) {
|
public int updateCatalog(PlatformCatalog platformCatalog) {
|
||||||
|
|
Loading…
Reference in New Issue