From a730fc904b1f479a58b8b5ffd0d593a27e72221e Mon Sep 17 00:00:00 2001 From: 648540858 <648540858@qq.com> Date: Wed, 30 Aug 2023 15:05:52 +0800 Subject: [PATCH] =?UTF-8?q?=E6=B7=BB=E5=8A=A0=E4=BB=8E=E5=9B=BD=E6=A0=87?= =?UTF-8?q?=E9=80=9A=E9=81=93=E5=90=8C=E6=AD=A5=E7=9A=84=E6=96=B9=E6=B3=95?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../vmp/service/ICommonGbChannelService.java | 3 + .../impl/CommonGbChannelServiceImpl.java | 236 +++++++++++------- .../vmp/storager/dao/BusinessGroupMapper.java | 4 +- 3 files changed, 147 insertions(+), 96 deletions(-) diff --git a/src/main/java/com/genersoft/iot/vmp/service/ICommonGbChannelService.java b/src/main/java/com/genersoft/iot/vmp/service/ICommonGbChannelService.java index f0025ede..5ef11d0e 100644 --- a/src/main/java/com/genersoft/iot/vmp/service/ICommonGbChannelService.java +++ b/src/main/java/com/genersoft/iot/vmp/service/ICommonGbChannelService.java @@ -1,6 +1,7 @@ package com.genersoft.iot.vmp.service; import com.genersoft.iot.vmp.common.CommonGbChannel; +import com.genersoft.iot.vmp.gb28181.bean.DeviceChannel; import java.util.List; @@ -10,6 +11,8 @@ public interface ICommonGbChannelService { int add(CommonGbChannel channel); + int addFromGbChannel(DeviceChannel channel); + int delete(String channelId); int update(CommonGbChannel channel); diff --git a/src/main/java/com/genersoft/iot/vmp/service/impl/CommonGbChannelServiceImpl.java b/src/main/java/com/genersoft/iot/vmp/service/impl/CommonGbChannelServiceImpl.java index 15c8857d..90fab55b 100644 --- a/src/main/java/com/genersoft/iot/vmp/service/impl/CommonGbChannelServiceImpl.java +++ b/src/main/java/com/genersoft/iot/vmp/service/impl/CommonGbChannelServiceImpl.java @@ -6,6 +6,8 @@ import com.genersoft.iot.vmp.service.ICommonGbChannelService; import com.genersoft.iot.vmp.storager.dao.CommonGbChannelMapper; import com.genersoft.iot.vmp.storager.dao.DeviceChannelMapper; import org.apache.commons.lang3.math.NumberUtils; +import org.slf4j.Logger; +import org.slf4j.LoggerFactory; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.jdbc.datasource.DataSourceTransactionManager; import org.springframework.stereotype.Service; @@ -18,6 +20,8 @@ import java.util.List; @Service public class CommonGbChannelServiceImpl implements ICommonGbChannelService { + private final static Logger logger = LoggerFactory.getLogger(CommonGbChannelServiceImpl.class); + @Autowired private CommonGbChannelMapper commonGbChannelMapper; @@ -41,6 +45,18 @@ public class CommonGbChannelServiceImpl implements ICommonGbChannelService { return commonGbChannelMapper.add(channel); } + @Override + public int addFromGbChannel(DeviceChannel channel) { + CommonGbChannel commonGbChannel = commonGbChannelMapper.queryByDeviceID(channel.getChannelId()); + logger.info("[添加通用通道]来自国标通道,国标编号: {}, 同步所有字段", channel.getChannelId()); + if (commonGbChannel != null) { + logger.info("[添加通用通道]来自国标通道,失败,已存在。国标编号: {}", channel.getChannelId()); + return 0; + } + CommonGbChannel commonChannelFromDeviceChannel = getCommonChannelFromDeviceChannel(channel, null); + return commonGbChannelMapper.add(commonChannelFromDeviceChannel); + } + @Override public int delete(String channelId) { return commonGbChannelMapper.deleteByDeviceID(channelId); @@ -58,6 +74,7 @@ public class CommonGbChannelServiceImpl implements ICommonGbChannelService { @Override public boolean SyncChannelFromGb28181Device(String gbDeviceId, List syncKeys) { + logger.info("同步通用通道]来自国标设备,国标编号: {}", gbDeviceId); List deviceChannels = deviceChannelMapper.queryAllChannels(gbDeviceId); if (deviceChannels.isEmpty()) { return false; @@ -92,107 +109,138 @@ public class CommonGbChannelServiceImpl implements ICommonGbChannelService { } private CommonGbChannel getCommonChannelFromDeviceChannel(DeviceChannel deviceChannel, List syncKeys) { - if (deviceChannel == null || syncKeys == null || syncKeys.isEmpty()) { + if (deviceChannel == null) { return null; } CommonGbChannel commonGbChannel = new CommonGbChannel(); commonGbChannel.setCommonGbDeviceID(deviceChannel.getChannelId()); - for (String key : syncKeys) { - switch (key) { - case "commonGbName": - commonGbChannel.setCommonGbName(deviceChannel.getName()); - break; - case "commonGbManufacturer": - commonGbChannel.setCommonGbManufacturer(deviceChannel.getManufacture()); - break; - case "commonGbModel": - commonGbChannel.setCommonGbModel(deviceChannel.getModel()); - break; - case "commonGbOwner": - commonGbChannel.setCommonGbOwner(deviceChannel.getOwner()); - break; - case "commonGbCivilCode": - commonGbChannel.setCommonGbCivilCode(deviceChannel.getCivilCode()); - break; - case "commonGbBlock": - commonGbChannel.setCommonGbBlock(deviceChannel.getBlock()); - break; - case "commonGbAddress": - commonGbChannel.setCommonGbAddress(deviceChannel.getAddress()); - break; - case "commonGbParental": - commonGbChannel.setCommonGbParental(deviceChannel.getParental()); - break; - case "commonGbParentID": - commonGbChannel.setCommonGbParentID(deviceChannel.getParentId()); - break; - case "commonGbSafetyWay": - commonGbChannel.setCommonGbSafetyWay(deviceChannel.getSafetyWay()); - break; - case "commonGbRegisterWay": - commonGbChannel.setCommonGbRegisterWay(deviceChannel.getRegisterWay()); - break; - case "commonGbCertNum": - commonGbChannel.setCommonGbCertNum(deviceChannel.getCertNum()); - break; - case "commonGbCertifiable": - commonGbChannel.setCommonGbCertifiable(deviceChannel.getCertifiable()); - break; - case "commonGbErrCode": - commonGbChannel.setCommonGbErrCode(deviceChannel.getErrCode()); - break; - case "commonGbEndTime": - commonGbChannel.setCommonGbEndTime(deviceChannel.getEndTime()); - break; - case "commonGbSecrecy": - if (NumberUtils.isParsable(deviceChannel.getSecrecy())) { - commonGbChannel.setCommonGbSecrecy(Integer.parseInt(deviceChannel.getSecrecy())); - } - break; - case "commonGbIPAddress": - commonGbChannel.setCommonGbIPAddress(deviceChannel.getIpAddress()); - break; - case "commonGbPort": - commonGbChannel.setCommonGbPort(deviceChannel.getPort()); - break; - case "commonGbPassword": - commonGbChannel.setCommonGbPassword(deviceChannel.getPassword()); - break; - case "commonGbStatus": - commonGbChannel.setCommonGbStatus(deviceChannel.isStatus()); - break; - case "commonGbLongitude": - commonGbChannel.setCommonGbLongitude(deviceChannel.getLongitude()); - break; - case "commonGbLatitude": - commonGbChannel.setCommonGbLatitude(deviceChannel.getLatitude()); - break; - case "commonGbPtzType": - commonGbChannel.setCommonGbPtzType(deviceChannel.getPTZType()); - break; - case "commonGbPositionType": - commonGbChannel.setCommonGbPositionType(deviceChannel.getCommonGbPositionType()); - break; - case "commonGbRoomType": - break; - case "commonGbUseType": - break; - case "commonGbSupplyLightType": - break; - case "commonGbDirectionType": - break; - case "commonGbResolution": - break; - case "commonGbBusinessGroupID": - commonGbChannel.setCommonGbBusinessGroupID(deviceChannel.getBusinessGroupId()); - break; - case "commonGbDownloadSpeed": - break; - case "commonGbSVCTimeSupportMode": - break; + if (syncKeys == null || syncKeys.isEmpty()) { + commonGbChannel.setCommonGbName(deviceChannel.getName()); + commonGbChannel.setCommonGbManufacturer(deviceChannel.getManufacture()); + commonGbChannel.setCommonGbModel(deviceChannel.getModel()); + commonGbChannel.setCommonGbOwner(deviceChannel.getOwner()); + commonGbChannel.setCommonGbCivilCode(deviceChannel.getCivilCode()); + commonGbChannel.setCommonGbBlock(deviceChannel.getBlock()); + commonGbChannel.setCommonGbAddress(deviceChannel.getAddress()); + commonGbChannel.setCommonGbParental(deviceChannel.getParental()); + commonGbChannel.setCommonGbParentID(deviceChannel.getParentId()); + commonGbChannel.setCommonGbSafetyWay(deviceChannel.getSafetyWay()); + commonGbChannel.setCommonGbRegisterWay(deviceChannel.getRegisterWay()); + commonGbChannel.setCommonGbCertNum(deviceChannel.getCertNum()); + commonGbChannel.setCommonGbCertifiable(deviceChannel.getCertifiable()); + commonGbChannel.setCommonGbErrCode(deviceChannel.getErrCode()); + commonGbChannel.setCommonGbEndTime(deviceChannel.getEndTime()); + if (NumberUtils.isParsable(deviceChannel.getSecrecy())) { + commonGbChannel.setCommonGbSecrecy(Integer.parseInt(deviceChannel.getSecrecy())); + } + commonGbChannel.setCommonGbIPAddress(deviceChannel.getIpAddress()); + commonGbChannel.setCommonGbPort(deviceChannel.getPort()); + commonGbChannel.setCommonGbPassword(deviceChannel.getPassword()); + commonGbChannel.setCommonGbStatus(deviceChannel.isStatus()); + commonGbChannel.setCommonGbLongitude(deviceChannel.getLongitude()); + commonGbChannel.setCommonGbLatitude(deviceChannel.getLatitude()); + commonGbChannel.setCommonGbPtzType(deviceChannel.getPTZType()); + commonGbChannel.setCommonGbPositionType(deviceChannel.getCommonGbPositionType()); + commonGbChannel.setCommonGbBusinessGroupID(deviceChannel.getBusinessGroupId()); + } else { + for (String key : syncKeys) { + switch (key) { + case "commonGbName": + commonGbChannel.setCommonGbName(deviceChannel.getName()); + break; + case "commonGbManufacturer": + commonGbChannel.setCommonGbManufacturer(deviceChannel.getManufacture()); + break; + case "commonGbModel": + commonGbChannel.setCommonGbModel(deviceChannel.getModel()); + break; + case "commonGbOwner": + commonGbChannel.setCommonGbOwner(deviceChannel.getOwner()); + break; + case "commonGbCivilCode": + commonGbChannel.setCommonGbCivilCode(deviceChannel.getCivilCode()); + break; + case "commonGbBlock": + commonGbChannel.setCommonGbBlock(deviceChannel.getBlock()); + break; + case "commonGbAddress": + commonGbChannel.setCommonGbAddress(deviceChannel.getAddress()); + break; + case "commonGbParental": + commonGbChannel.setCommonGbParental(deviceChannel.getParental()); + break; + case "commonGbParentID": + commonGbChannel.setCommonGbParentID(deviceChannel.getParentId()); + break; + case "commonGbSafetyWay": + commonGbChannel.setCommonGbSafetyWay(deviceChannel.getSafetyWay()); + break; + case "commonGbRegisterWay": + commonGbChannel.setCommonGbRegisterWay(deviceChannel.getRegisterWay()); + break; + case "commonGbCertNum": + commonGbChannel.setCommonGbCertNum(deviceChannel.getCertNum()); + break; + case "commonGbCertifiable": + commonGbChannel.setCommonGbCertifiable(deviceChannel.getCertifiable()); + break; + case "commonGbErrCode": + commonGbChannel.setCommonGbErrCode(deviceChannel.getErrCode()); + break; + case "commonGbEndTime": + commonGbChannel.setCommonGbEndTime(deviceChannel.getEndTime()); + break; + case "commonGbSecrecy": + if (NumberUtils.isParsable(deviceChannel.getSecrecy())) { + commonGbChannel.setCommonGbSecrecy(Integer.parseInt(deviceChannel.getSecrecy())); + } + break; + case "commonGbIPAddress": + commonGbChannel.setCommonGbIPAddress(deviceChannel.getIpAddress()); + break; + case "commonGbPort": + commonGbChannel.setCommonGbPort(deviceChannel.getPort()); + break; + case "commonGbPassword": + commonGbChannel.setCommonGbPassword(deviceChannel.getPassword()); + break; + case "commonGbStatus": + commonGbChannel.setCommonGbStatus(deviceChannel.isStatus()); + break; + case "commonGbLongitude": + commonGbChannel.setCommonGbLongitude(deviceChannel.getLongitude()); + break; + case "commonGbLatitude": + commonGbChannel.setCommonGbLatitude(deviceChannel.getLatitude()); + break; + case "commonGbPtzType": + commonGbChannel.setCommonGbPtzType(deviceChannel.getPTZType()); + break; + case "commonGbPositionType": + commonGbChannel.setCommonGbPositionType(deviceChannel.getCommonGbPositionType()); + break; + case "commonGbRoomType": + break; + case "commonGbUseType": + break; + case "commonGbSupplyLightType": + break; + case "commonGbDirectionType": + break; + case "commonGbResolution": + break; + case "commonGbBusinessGroupID": + commonGbChannel.setCommonGbBusinessGroupID(deviceChannel.getBusinessGroupId()); + break; + case "commonGbDownloadSpeed": + break; + case "commonGbSVCTimeSupportMode": + break; + } } } + return commonGbChannel; } } diff --git a/src/main/java/com/genersoft/iot/vmp/storager/dao/BusinessGroupMapper.java b/src/main/java/com/genersoft/iot/vmp/storager/dao/BusinessGroupMapper.java index c1704c28..fc7a7bb1 100644 --- a/src/main/java/com/genersoft/iot/vmp/storager/dao/BusinessGroupMapper.java +++ b/src/main/java/com/genersoft/iot/vmp/storager/dao/BusinessGroupMapper.java @@ -10,13 +10,13 @@ import java.util.List; @Repository public interface BusinessGroupMapper { - @Select(value = {" "}) + " ") List getNodes(String parentId); @Select(" select * from wvp_common_business_group " +