修复bug与目录订阅添加最小值60
parent
9be861abcc
commit
e8090bc84c
|
@ -62,6 +62,7 @@ public class CatalogEventLister implements ApplicationListener<CatalogEvent> {
|
||||||
if (!parentPlatform.isStatus())return;
|
if (!parentPlatform.isStatus())return;
|
||||||
String key = VideoManagerConstants.SIP_SUBSCRIBE_PREFIX + userSetup.getServerId() + "_Catalog_" + event.getPlatformId();
|
String key = VideoManagerConstants.SIP_SUBSCRIBE_PREFIX + userSetup.getServerId() + "_Catalog_" + event.getPlatformId();
|
||||||
subscribe = redisCatchStorage.getSubscribe(key);
|
subscribe = redisCatchStorage.getSubscribe(key);
|
||||||
|
if (subscribe == null) return;
|
||||||
}else {
|
}else {
|
||||||
// 获取所用订阅
|
// 获取所用订阅
|
||||||
List<String> platforms = redisCatchStorage.getAllSubscribePlatform();
|
List<String> platforms = redisCatchStorage.getAllSubscribePlatform();
|
||||||
|
@ -107,9 +108,10 @@ public class CatalogEventLister implements ApplicationListener<CatalogEvent> {
|
||||||
List<ParentPlatform> parentPlatforms = parentPlatformMap.get(gbId);
|
List<ParentPlatform> parentPlatforms = parentPlatformMap.get(gbId);
|
||||||
if (parentPlatforms != null && parentPlatforms.size() > 0) {
|
if (parentPlatforms != null && parentPlatforms.size() > 0) {
|
||||||
for (ParentPlatform platform : parentPlatforms) {
|
for (ParentPlatform platform : parentPlatforms) {
|
||||||
logger.info("[Catalog事件: {}]平台:{},影响通道{}", event.getType(), platform.getServerGBId(), gbId);
|
|
||||||
String key = VideoManagerConstants.SIP_SUBSCRIBE_PREFIX + userSetup.getServerId() + "_Catalog_" + platform.getServerGBId();
|
String key = VideoManagerConstants.SIP_SUBSCRIBE_PREFIX + userSetup.getServerId() + "_Catalog_" + platform.getServerGBId();
|
||||||
SubscribeInfo subscribeInfo = redisCatchStorage.getSubscribe(key);
|
SubscribeInfo subscribeInfo = redisCatchStorage.getSubscribe(key);
|
||||||
|
if (subscribeInfo == null) continue;
|
||||||
|
logger.info("[Catalog事件: {}]平台:{},影响通道{}", event.getType(), platform.getServerGBId(), gbId);
|
||||||
List<DeviceChannel> deviceChannelList = new ArrayList<>();
|
List<DeviceChannel> deviceChannelList = new ArrayList<>();
|
||||||
DeviceChannel deviceChannel = new DeviceChannel();
|
DeviceChannel deviceChannel = new DeviceChannel();
|
||||||
deviceChannel.setChannelId(gbId);
|
deviceChannel.setChannelId(gbId);
|
||||||
|
@ -146,9 +148,10 @@ public class CatalogEventLister implements ApplicationListener<CatalogEvent> {
|
||||||
List<ParentPlatform> parentPlatforms = parentPlatformMap.get(gbId);
|
List<ParentPlatform> parentPlatforms = parentPlatformMap.get(gbId);
|
||||||
if (parentPlatforms != null && parentPlatforms.size() > 0) {
|
if (parentPlatforms != null && parentPlatforms.size() > 0) {
|
||||||
for (ParentPlatform platform : parentPlatforms) {
|
for (ParentPlatform platform : parentPlatforms) {
|
||||||
logger.info("[Catalog事件: {}]平台:{},影响通道{}", event.getType(), platform.getServerGBId(), gbId);
|
|
||||||
String key = VideoManagerConstants.SIP_SUBSCRIBE_PREFIX + userSetup.getServerId() + "_Catalog_" + platform.getServerGBId();
|
String key = VideoManagerConstants.SIP_SUBSCRIBE_PREFIX + userSetup.getServerId() + "_Catalog_" + platform.getServerGBId();
|
||||||
SubscribeInfo subscribeInfo = redisCatchStorage.getSubscribe(key);
|
SubscribeInfo subscribeInfo = redisCatchStorage.getSubscribe(key);
|
||||||
|
if (subscribeInfo == null) continue;
|
||||||
|
logger.info("[Catalog事件: {}]平台:{},影响通道{}", event.getType(), platform.getServerGBId(), gbId);
|
||||||
List<DeviceChannel> deviceChannelList = new ArrayList<>();
|
List<DeviceChannel> deviceChannelList = new ArrayList<>();
|
||||||
DeviceChannel deviceChannel = storager.queryChannelInParentPlatform(platform.getServerGBId(), gbId);
|
DeviceChannel deviceChannel = storager.queryChannelInParentPlatform(platform.getServerGBId(), gbId);
|
||||||
deviceChannelList.add(deviceChannel);
|
deviceChannelList.add(deviceChannel);
|
||||||
|
|
|
@ -1498,7 +1498,10 @@ public class SIPCommander implements ISIPCommander {
|
||||||
CallIdHeader callIdHeader = device.getTransport().equals("TCP") ? tcpSipProvider.getNewCallId()
|
CallIdHeader callIdHeader = device.getTransport().equals("TCP") ? tcpSipProvider.getNewCallId()
|
||||||
: udpSipProvider.getNewCallId();
|
: udpSipProvider.getNewCallId();
|
||||||
|
|
||||||
Request request = headerProvider.createSubscribeRequest(device, cmdXml.toString(), "z9hG4bK-viaPos-" + tm, "fromTagPos" + tm, null, device.getSubscribeCycleForCatalog(), "Catalog" , callIdHeader);
|
// 有效时间默认为60秒以上
|
||||||
|
Request request = headerProvider.createSubscribeRequest(device, cmdXml.toString(), "z9hG4bK-viaPos-" + tm,
|
||||||
|
"fromTagPos" + tm, null, device.getSubscribeCycleForCatalog() + 60, "Catalog" ,
|
||||||
|
callIdHeader);
|
||||||
transmitRequest(device, request, errorEvent, okEvent);
|
transmitRequest(device, request, errorEvent, okEvent);
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
|
|
|
@ -370,10 +370,7 @@ public class SIPCommanderFroPlatform implements ISIPCommanderForPlatform {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean sendNotifyForCatalogAddOrUpdate(String type, ParentPlatform parentPlatform, List<DeviceChannel> deviceChannels, SubscribeInfo subscribeInfo) {
|
public boolean sendNotifyForCatalogAddOrUpdate(String type, ParentPlatform parentPlatform, List<DeviceChannel> deviceChannels, SubscribeInfo subscribeInfo) {
|
||||||
if (parentPlatform == null) {
|
if (parentPlatform == null || deviceChannels == null || deviceChannels.size() == 0 || subscribeInfo == null) {
|
||||||
return false;
|
|
||||||
}
|
|
||||||
if (deviceChannels == null || deviceChannels.size() == 0) {
|
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
for (DeviceChannel channel : deviceChannels) {
|
for (DeviceChannel channel : deviceChannels) {
|
||||||
|
@ -431,10 +428,10 @@ public class SIPCommanderFroPlatform implements ISIPCommanderForPlatform {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean sendNotifyForCatalogOther(String type, ParentPlatform parentPlatform, List<DeviceChannel> deviceChannels, SubscribeInfo subscribeInfo) {
|
public boolean sendNotifyForCatalogOther(String type, ParentPlatform parentPlatform, List<DeviceChannel> deviceChannels, SubscribeInfo subscribeInfo) {
|
||||||
if (parentPlatform == null) {
|
if (parentPlatform == null
|
||||||
return false;
|
|| deviceChannels == null
|
||||||
}
|
|| deviceChannels.size() == 0
|
||||||
if (deviceChannels == null || deviceChannels.size() == 0) {
|
|| subscribeInfo == null) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -26,20 +26,8 @@ public class CatalogSubscribeTask implements Runnable{
|
||||||
ResponseEvent event = (ResponseEvent) eventResult.event;
|
ResponseEvent event = (ResponseEvent) eventResult.event;
|
||||||
Element rootElement = null;
|
Element rootElement = null;
|
||||||
if (event.getResponse().getRawContent() != null) {
|
if (event.getResponse().getRawContent() != null) {
|
||||||
try {
|
|
||||||
rootElement = XmlUtil.getRootElement(event.getResponse().getRawContent(), "gb2312");
|
|
||||||
} catch (DocumentException e) {
|
|
||||||
e.printStackTrace();
|
|
||||||
}
|
|
||||||
Element resultElement = rootElement.element("Result");
|
|
||||||
String result = resultElement.getText();
|
|
||||||
if (result.toUpperCase().equals("OK")){
|
|
||||||
// 成功
|
// 成功
|
||||||
logger.info("[目录订阅]成功: {}", device.getDeviceId());
|
logger.info("[目录订阅]成功: {}", device.getDeviceId());
|
||||||
}else {
|
|
||||||
// 失败
|
|
||||||
logger.info("[目录订阅]失败: {}-{}", device.getDeviceId(), result);
|
|
||||||
}
|
|
||||||
}else {
|
}else {
|
||||||
// 成功
|
// 成功
|
||||||
logger.info("[目录订阅]成功: {}", device.getDeviceId());
|
logger.info("[目录订阅]成功: {}", device.getDeviceId());
|
||||||
|
|
|
@ -5,15 +5,20 @@ import com.alibaba.excel.event.AnalysisEventListener;
|
||||||
import com.genersoft.iot.vmp.media.zlm.dto.StreamPushItem;
|
import com.genersoft.iot.vmp.media.zlm.dto.StreamPushItem;
|
||||||
import com.genersoft.iot.vmp.service.IStreamPushService;
|
import com.genersoft.iot.vmp.service.IStreamPushService;
|
||||||
import com.genersoft.iot.vmp.vmanager.bean.StreamPushExcelDto;
|
import com.genersoft.iot.vmp.vmanager.bean.StreamPushExcelDto;
|
||||||
|
import org.springframework.util.StringUtils;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
|
import java.util.HashSet;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
import java.util.Set;
|
||||||
|
|
||||||
public class StreamPushUploadFileHandler extends AnalysisEventListener<StreamPushExcelDto> {
|
public class StreamPushUploadFileHandler extends AnalysisEventListener<StreamPushExcelDto> {
|
||||||
|
|
||||||
private IStreamPushService pushService;
|
private IStreamPushService pushService;
|
||||||
private String defaultMediaServerId;
|
private String defaultMediaServerId;
|
||||||
private List<StreamPushItem> streamPushItems = new ArrayList<>();
|
private List<StreamPushItem> streamPushItems = new ArrayList<>();
|
||||||
|
private Set<String> streamPushStreamSet = new HashSet<>();
|
||||||
|
private Set<String> streamPushGBSet = new HashSet<>();
|
||||||
|
|
||||||
public StreamPushUploadFileHandler(IStreamPushService pushService, String defaultMediaServerId) {
|
public StreamPushUploadFileHandler(IStreamPushService pushService, String defaultMediaServerId) {
|
||||||
this.pushService = pushService;
|
this.pushService = pushService;
|
||||||
|
@ -22,6 +27,14 @@ public class StreamPushUploadFileHandler extends AnalysisEventListener<StreamPus
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void invoke(StreamPushExcelDto streamPushExcelDto, AnalysisContext analysisContext) {
|
public void invoke(StreamPushExcelDto streamPushExcelDto, AnalysisContext analysisContext) {
|
||||||
|
if (StringUtils.isEmpty(streamPushExcelDto.getApp())
|
||||||
|
|| StringUtils.isEmpty(streamPushExcelDto.getStream())
|
||||||
|
|| StringUtils.isEmpty(streamPushExcelDto.getGbId())) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if (streamPushGBSet.contains(streamPushExcelDto.getGbId()) || streamPushStreamSet.contains(streamPushExcelDto.getApp() + streamPushExcelDto.getStream())) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
StreamPushItem streamPushItem = new StreamPushItem();
|
StreamPushItem streamPushItem = new StreamPushItem();
|
||||||
streamPushItem.setApp(streamPushExcelDto.getApp());
|
streamPushItem.setApp(streamPushExcelDto.getApp());
|
||||||
streamPushItem.setStream(streamPushExcelDto.getStream());
|
streamPushItem.setStream(streamPushExcelDto.getStream());
|
||||||
|
@ -35,6 +48,8 @@ public class StreamPushUploadFileHandler extends AnalysisEventListener<StreamPus
|
||||||
streamPushItem.setOriginTypeStr("rtsp_push");
|
streamPushItem.setOriginTypeStr("rtsp_push");
|
||||||
streamPushItem.setTotalReaderCount("0");
|
streamPushItem.setTotalReaderCount("0");
|
||||||
streamPushItems.add(streamPushItem);
|
streamPushItems.add(streamPushItem);
|
||||||
|
streamPushGBSet.add(streamPushExcelDto.getGbId());
|
||||||
|
streamPushStreamSet.add(streamPushExcelDto.getApp()+streamPushExcelDto.getStream());
|
||||||
if (streamPushItems.size() > 300) {
|
if (streamPushItems.size() > 300) {
|
||||||
pushService.batchAdd(streamPushItems);
|
pushService.batchAdd(streamPushItems);
|
||||||
// 存储完成清理 list
|
// 存储完成清理 list
|
||||||
|
@ -46,5 +61,7 @@ public class StreamPushUploadFileHandler extends AnalysisEventListener<StreamPus
|
||||||
public void doAfterAllAnalysed(AnalysisContext analysisContext) {
|
public void doAfterAllAnalysed(AnalysisContext analysisContext) {
|
||||||
// 这里也要保存数据,确保最后遗留的数据也存储到数据库
|
// 这里也要保存数据,确保最后遗留的数据也存储到数据库
|
||||||
pushService.batchAdd(streamPushItems);
|
pushService.batchAdd(streamPushItems);
|
||||||
|
streamPushGBSet.clear();
|
||||||
|
streamPushStreamSet.clear();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -316,7 +316,8 @@ public class DeviceQuery {
|
||||||
if (!StringUtils.isEmpty(device.getCharset())) deviceInStore.setCharset(device.getCharset());
|
if (!StringUtils.isEmpty(device.getCharset())) deviceInStore.setCharset(device.getCharset());
|
||||||
if (!StringUtils.isEmpty(device.getMediaServerId())) deviceInStore.setMediaServerId(device.getMediaServerId());
|
if (!StringUtils.isEmpty(device.getMediaServerId())) deviceInStore.setMediaServerId(device.getMediaServerId());
|
||||||
|
|
||||||
if (deviceInStore.getSubscribeCycleForCatalog() <=0 && device.getSubscribeCycleForCatalog() > 0) {
|
if ((deviceInStore.getSubscribeCycleForCatalog() <=0 && device.getSubscribeCycleForCatalog() > 0)
|
||||||
|
|| deviceInStore.getSubscribeCycleForCatalog() != device.getSubscribeCycleForCatalog()) {
|
||||||
deviceInStore.setSubscribeCycleForCatalog(device.getSubscribeCycleForCatalog());
|
deviceInStore.setSubscribeCycleForCatalog(device.getSubscribeCycleForCatalog());
|
||||||
// 开启订阅
|
// 开启订阅
|
||||||
deviceService.addCatalogSubscribe(deviceInStore);
|
deviceService.addCatalogSubscribe(deviceInStore);
|
||||||
|
|
|
@ -10,7 +10,7 @@
|
||||||
@close="close()"
|
@close="close()"
|
||||||
>
|
>
|
||||||
<div id="shared" style="margin-top: 1rem;margin-right: 100px;">
|
<div id="shared" style="margin-top: 1rem;margin-right: 100px;">
|
||||||
<el-form ref="form" :rules="rules" :model="form" label-width="140px" >
|
<el-form ref="form" :rules="rules" :model="form" label-width="240px" >
|
||||||
<el-form-item label="设备编号" >
|
<el-form-item label="设备编号" >
|
||||||
<el-input v-model="form.deviceId" disabled></el-input>
|
<el-input v-model="form.deviceId" disabled></el-input>
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
|
@ -36,7 +36,7 @@
|
||||||
<el-option key="UTF-8" label="UTF-8" value="utf-8"></el-option>
|
<el-option key="UTF-8" label="UTF-8" value="utf-8"></el-option>
|
||||||
</el-select>
|
</el-select>
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
<el-form-item label="目录订阅周期" prop="subscribeCycleForCatalog" >
|
<el-form-item label="目录订阅周期(0为停用订阅)" prop="subscribeCycleForCatalog" >
|
||||||
<el-input v-model="form.subscribeCycleForCatalog" clearable ></el-input>
|
<el-input v-model="form.subscribeCycleForCatalog" clearable ></el-input>
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
<el-form-item>
|
<el-form-item>
|
||||||
|
|
Loading…
Reference in New Issue