修复设备编辑无法清理收流IP的BUG

pull/1684/head
648540858 2024-11-07 20:33:02 +08:00
parent 0b22f51be1
commit dbe4c80896
3 changed files with 12 additions and 54 deletions

View File

@ -296,14 +296,11 @@ public class DeviceQuery {
@Parameter(name = "device", description = "设备", required = true) @Parameter(name = "device", description = "设备", required = true)
@PostMapping("/device/update/") @PostMapping("/device/update/")
public void updateDevice(Device device){ public void updateDevice(Device device){
if (device == null || device.getDeviceId() == null || device.getId() <= 0) {
if (device != null && device.getDeviceId() != null) { throw new ControllerException(ErrorCode.ERROR400);
if (device.getSubscribeCycleForMobilePosition() > 0 && device.getMobilePositionSubmissionInterval() <= 0) {
device.setMobilePositionSubmissionInterval(5);
} }
deviceService.updateCustomDevice(device); deviceService.updateCustomDevice(device);
} }
}
/** /**
* API * API

View File

@ -246,24 +246,12 @@ public interface DeviceMapper {
@Update(value = {" <script>" + @Update(value = {" <script>" +
"UPDATE wvp_device " + "UPDATE wvp_device " +
"SET update_time=#{updateTime}" + "SET update_time=#{updateTime}, custom_name=#{name} , password=#{password}, stream_mode=#{streamMode}" +
"<if test=\"name != null\">, custom_name=#{name}</if>" + ", ip=#{ip}, sdp_ip=#{sdpIp}, port=#{port}, charset=#{charset}, subscribe_cycle_for_catalog=#{subscribeCycleForCatalog}" +
"<if test=\"password != null\">, password=#{password}</if>" + ", subscribe_cycle_for_mobile_position=#{subscribeCycleForMobilePosition}, mobile_position_submission_interval=#{mobilePositionSubmissionInterval}" +
"<if test=\"streamMode != null\">, stream_mode=#{streamMode}</if>" + ", subscribe_cycle_for_alarm=#{subscribeCycleForAlarm}, ssrc_check=#{ssrcCheck}, as_message_channel=#{asMessageChannel}" +
"<if test=\"ip != null\">, ip=#{ip}</if>" + ", broadcast_push_after_ack=#{broadcastPushAfterAck}, geo_coord_sys=#{geoCoordSys}, media_server_id=#{mediaServerId}" +
"<if test=\"sdpIp != null\">, sdp_ip=#{sdpIp}</if>" + " WHERE id=#{id}"+
"<if test=\"port != null\">, port=#{port}</if>" +
"<if test=\"charset != null\">, charset=#{charset}</if>" +
"<if test=\"subscribeCycleForCatalog != null\">, subscribe_cycle_for_catalog=#{subscribeCycleForCatalog}</if>" +
"<if test=\"subscribeCycleForMobilePosition != null\">, subscribe_cycle_for_mobile_position=#{subscribeCycleForMobilePosition}</if>" +
"<if test=\"mobilePositionSubmissionInterval != null\">, mobile_position_submission_interval=#{mobilePositionSubmissionInterval}</if>" +
"<if test=\"subscribeCycleForAlarm != null\">, subscribe_cycle_for_alarm=#{subscribeCycleForAlarm}</if>" +
"<if test=\"ssrcCheck != null\">, ssrc_check=#{ssrcCheck}</if>" +
"<if test=\"asMessageChannel != null\">, as_message_channel=#{asMessageChannel}</if>" +
"<if test=\"broadcastPushAfterAck != null\">, broadcast_push_after_ack=#{broadcastPushAfterAck}</if>" +
"<if test=\"geoCoordSys != null\">, geo_coord_sys=#{geoCoordSys}</if>" +
"<if test=\"mediaServerId != null\">, media_server_id=#{mediaServerId}</if>" +
"WHERE device_id=#{deviceId}"+
" </script>"}) " </script>"})
void updateCustom(Device device); void updateCustom(Device device);

View File

@ -421,34 +421,11 @@ public class DeviceServiceImpl implements IDeviceService {
@Override @Override
public void updateCustomDevice(Device device) { public void updateCustomDevice(Device device) {
Device deviceInStore = deviceMapper.getDeviceByDeviceId(device.getDeviceId()); Device deviceInStore = deviceMapper.query(device.getId());
if (deviceInStore == null) { if (deviceInStore == null) {
log.warn("更新设备时未找到设备信息"); log.warn("更新设备时未找到设备信息");
return; return;
} }
if (!ObjectUtils.isEmpty(device.getName())) {
deviceInStore.setName(device.getName());
}
if (!ObjectUtils.isEmpty(device.getCharset())) {
deviceInStore.setCharset(device.getCharset());
}
if (!ObjectUtils.isEmpty(device.getMediaServerId())) {
deviceInStore.setMediaServerId(device.getMediaServerId());
}
if (!ObjectUtils.isEmpty(device.getCharset())) {
deviceInStore.setCharset(device.getCharset());
}
if (!ObjectUtils.isEmpty(device.getSdpIp())) {
deviceInStore.setSdpIp(device.getSdpIp());
}
if (!ObjectUtils.isEmpty(device.getPassword())) {
deviceInStore.setPassword(device.getPassword());
}
if (!ObjectUtils.isEmpty(device.getStreamMode())) {
deviceInStore.setStreamMode(device.getStreamMode());
}
deviceInStore.setBroadcastPushAfterAck(device.isBroadcastPushAfterAck());
// 目录订阅相关的信息 // 目录订阅相关的信息
if (deviceInStore.getSubscribeCycleForCatalog() != device.getSubscribeCycleForCatalog()) { if (deviceInStore.getSubscribeCycleForCatalog() != device.getSubscribeCycleForCatalog()) {
if (device.getSubscribeCycleForCatalog() > 0) { if (device.getSubscribeCycleForCatalog() > 0) {
@ -513,13 +490,9 @@ public class DeviceServiceImpl implements IDeviceService {
if (device.getCharset() == null) { if (device.getCharset() == null) {
deviceInStore.setCharset("GB2312"); deviceInStore.setCharset("GB2312");
} }
//SSRC校验
deviceInStore.setSsrcCheck(device.isSsrcCheck());
//作为消息通道
deviceInStore.setAsMessageChannel(device.isAsMessageChannel());
deviceMapper.updateCustom(deviceInStore); deviceMapper.updateCustom(device);
redisCatchStorage.updateDevice(deviceInStore); redisCatchStorage.updateDevice(device);
} }
@Override @Override