| 
					
				 | 
			
			
				@@ -16,8 +16,11 @@ import com.genersoft.iot.vmp.gb28181.transmit.event.request.SIPRequestProcessorP 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				 import com.genersoft.iot.vmp.media.service.IMediaServerService; 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				 import com.genersoft.iot.vmp.media.zlm.ZLMServerFactory; 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				 import com.genersoft.iot.vmp.media.zlm.dto.MediaServerItem; 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+import com.genersoft.iot.vmp.media.zlm.dto.StreamPushItem; 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				 import com.genersoft.iot.vmp.service.*; 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				 import com.genersoft.iot.vmp.service.bean.MessageForPushChannel; 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+import com.genersoft.iot.vmp.service.bean.RequestStopPushStreamMsg; 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+import com.genersoft.iot.vmp.service.redisMsg.RedisGbPlayMsgListener; 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				 import com.genersoft.iot.vmp.storager.IRedisCatchStorage; 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				 import com.genersoft.iot.vmp.storager.IVideoManagerStorage; 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				 import gov.nist.javax.sip.message.SIPRequest; 
			 | 
		
	
	
		
			
				| 
					
				 | 
			
			
				@@ -93,6 +96,12 @@ public class ByeRequestProcessor extends SIPRequestProcessorParent implements In 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				 	@Autowired 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				 	private UserSetting userSetting; 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				  
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+	@Autowired 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+	private IStreamPushService pushService; 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+ 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+	@Autowired 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+	private RedisGbPlayMsgListener redisGbPlayMsgListener; 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+ 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				 	@Override 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				 	public void afterPropertiesSet() throws Exception { 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				 		// 添加消息处理的订阅 
			 | 
		
	
	
		
			
				| 
					
				 | 
			
			
				@@ -116,7 +125,7 @@ public class ByeRequestProcessor extends SIPRequestProcessorParent implements In 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				  
			 | 
		
	
		
			
				 | 
				 | 
			
			
				 		// 收流端发送的停止 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				 		if (sendRtpItem != null){ 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				-			logger.info("[收到bye] 来自{},停止通道:{}, 类型: {}", sendRtpItem.getPlatformId(), sendRtpItem.getChannelId(), sendRtpItem.getPlayType()); 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+			logger.info("[收到bye] 来自{},停止通道:{}, 类型: {}, callId: {}", sendRtpItem.getPlatformId(), sendRtpItem.getChannelId(), sendRtpItem.getPlayType(), callIdHeader.getCallId()); 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				  
			 | 
		
	
		
			
				 | 
				 | 
			
			
				 			String streamId = sendRtpItem.getStream(); 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				 			Map<String, Object> param = new HashMap<>(); 
			 | 
		
	
	
		
			
				| 
					
				 | 
			
			
				@@ -124,59 +133,82 @@ public class ByeRequestProcessor extends SIPRequestProcessorParent implements In 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				 			param.put("app",sendRtpItem.getApp()); 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				 			param.put("stream",streamId); 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				 			param.put("ssrc",sendRtpItem.getSsrc()); 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				-			logger.info("[收到bye] 停止推流:{}", streamId); 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				-			MediaServerItem mediaInfo = mediaServerService.getOne(sendRtpItem.getMediaServerId()); 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				-			redisCatchStorage.deleteSendRTPServer(sendRtpItem.getPlatformId(), sendRtpItem.getChannelId(), 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				-					callIdHeader.getCallId(), null); 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				-			zlmServerFactory.stopSendRtpStream(mediaInfo, param); 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				-			if (userSetting.getUseCustomSsrcForParentInvite()) { 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				-				mediaServerService.releaseSsrc(mediaInfo.getId(), sendRtpItem.getSsrc()); 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				-			} 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+			logger.info("[收到bye] 停止推流:{}, 媒体节点: {}", streamId, sendRtpItem.getMediaServerId()); 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+ 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				 			if (sendRtpItem.getPlayType().equals(InviteStreamType.PUSH)) { 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				-				ParentPlatform platform = platformService.queryPlatformByServerGBId(sendRtpItem.getPlatformId()); 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				-				if (platform != null) { 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				-					MessageForPushChannel messageForPushChannel = MessageForPushChannel.getInstance(0, 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				-							sendRtpItem.getApp(), sendRtpItem.getStream(), sendRtpItem.getChannelId(), 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				-							sendRtpItem.getPlatformId(), platform.getName(), userSetting.getServerId(), sendRtpItem.getMediaServerId()); 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				-					messageForPushChannel.setPlatFormIndex(platform.getId()); 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				-					redisCatchStorage.sendPlatformStopPlayMsg(messageForPushChannel); 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+				// 查询这路流是否是本平台的 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+				StreamPushItem push = pushService.getPush(sendRtpItem.getApp(), sendRtpItem.getStream()); 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+				if (push!= null && !push.isSelf()) { 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+					// 不是本平台的就发送redis消息让其他wvp停止发流 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+					ParentPlatform platform = platformService.queryPlatformByServerGBId(sendRtpItem.getPlatformId()); 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+					if (platform != null) { 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+						RequestStopPushStreamMsg streamMsg = RequestStopPushStreamMsg.getInstance(sendRtpItem, platform.getName(), platform.getId()); 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+						redisGbPlayMsgListener.sendMsgForStopSendRtpStream(sendRtpItem.getServerId(), streamMsg); 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+					} 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				 				}else { 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				-					logger.info("[上级平台停止观看] 未找到平台{}的信息,发送redis消息失败", sendRtpItem.getPlatformId()); 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				-				} 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				-			} 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+					MediaServerItem mediaInfo = mediaServerService.getOne(sendRtpItem.getMediaServerId()); 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+					redisCatchStorage.deleteSendRTPServer(sendRtpItem.getPlatformId(), sendRtpItem.getChannelId(), 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+							callIdHeader.getCallId(), null); 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+					zlmServerFactory.stopSendRtpStream(mediaInfo, param); 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+					if (userSetting.getUseCustomSsrcForParentInvite()) { 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+						mediaServerService.releaseSsrc(mediaInfo.getId(), sendRtpItem.getSsrc()); 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+					} 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				  
			 | 
		
	
		
			
				 | 
				 | 
			
			
				-			AudioBroadcastCatch audioBroadcastCatch = audioBroadcastManager.get(sendRtpItem.getDeviceId(), sendRtpItem.getChannelId()); 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				-			if (audioBroadcastCatch != null && audioBroadcastCatch.getSipTransactionInfo().getCallId().equals(callIdHeader.getCallId())) { 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				-				// 来自上级平台的停止对讲 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				-				logger.info("[停止对讲] 来自上级,平台:{}, 通道:{}", sendRtpItem.getDeviceId(), sendRtpItem.getChannelId()); 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				-				audioBroadcastManager.del(sendRtpItem.getDeviceId(), sendRtpItem.getChannelId()); 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+					ParentPlatform platform = platformService.queryPlatformByServerGBId(sendRtpItem.getPlatformId()); 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+					if (platform != null) { 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+						MessageForPushChannel messageForPushChannel = MessageForPushChannel.getInstance(0, 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+								sendRtpItem.getApp(), sendRtpItem.getStream(), sendRtpItem.getChannelId(), 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+								sendRtpItem.getPlatformId(), platform.getName(), userSetting.getServerId(), sendRtpItem.getMediaServerId()); 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+						messageForPushChannel.setPlatFormIndex(platform.getId()); 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+						redisCatchStorage.sendPlatformStopPlayMsg(messageForPushChannel); 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+					}else { 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+						logger.info("[上级平台停止观看] 未找到平台{}的信息,发送redis消息失败", sendRtpItem.getPlatformId()); 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+					} 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+				} 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+			}else { 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+				MediaServerItem mediaInfo = mediaServerService.getOne(sendRtpItem.getMediaServerId()); 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+				redisCatchStorage.deleteSendRTPServer(sendRtpItem.getPlatformId(), sendRtpItem.getChannelId(), 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+						callIdHeader.getCallId(), null); 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+				zlmServerFactory.stopSendRtpStream(mediaInfo, param); 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+				if (userSetting.getUseCustomSsrcForParentInvite()) { 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+					mediaServerService.releaseSsrc(mediaInfo.getId(), sendRtpItem.getSsrc()); 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+				} 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				 			} 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+			MediaServerItem mediaInfo = mediaServerService.getOne(sendRtpItem.getMediaServerId()); 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+			if (mediaInfo != null) { 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+				AudioBroadcastCatch audioBroadcastCatch = audioBroadcastManager.get(sendRtpItem.getDeviceId(), sendRtpItem.getChannelId()); 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+				if (audioBroadcastCatch != null && audioBroadcastCatch.getSipTransactionInfo().getCallId().equals(callIdHeader.getCallId())) { 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+					// 来自上级平台的停止对讲 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+					logger.info("[停止对讲] 来自上级,平台:{}, 通道:{}", sendRtpItem.getDeviceId(), sendRtpItem.getChannelId()); 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+					audioBroadcastManager.del(sendRtpItem.getDeviceId(), sendRtpItem.getChannelId()); 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+				} 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				  
			 | 
		
	
		
			
				 | 
				 | 
			
			
				-			int totalReaderCount = zlmServerFactory.totalReaderCount(mediaInfo, sendRtpItem.getApp(), streamId); 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				-			if (totalReaderCount <= 0) { 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				-				logger.info("[收到bye] {} 无其它观看者,通知设备停止推流", streamId); 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				-				if (sendRtpItem.getPlayType().equals(InviteStreamType.PLAY)) { 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				-					Device device = deviceService.getDevice(sendRtpItem.getDeviceId()); 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				-					if (device == null) { 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				-						logger.info("[收到bye] {} 通知设备停止推流时未找到设备信息", streamId); 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				-					} 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				-					try { 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				-						logger.info("[停止点播] {}/{}", sendRtpItem.getDeviceId(), sendRtpItem.getChannelId()); 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				-						cmder.streamByeCmd(device, sendRtpItem.getChannelId(), streamId, null); 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				-					} catch (InvalidArgumentException | ParseException | SipException | 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				-							 SsrcTransactionNotFoundException e) { 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				-						logger.error("[收到bye] {} 无其它观看者,通知设备停止推流, 发送BYE失败 {}",streamId, e.getMessage()); 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+				int totalReaderCount = zlmServerFactory.totalReaderCount(mediaInfo, sendRtpItem.getApp(), streamId); 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+				if (totalReaderCount <= 0) { 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+					logger.info("[收到bye] {} 无其它观看者,通知设备停止推流", streamId); 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+					if (sendRtpItem.getPlayType().equals(InviteStreamType.PLAY)) { 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+						Device device = deviceService.getDevice(sendRtpItem.getDeviceId()); 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+						if (device == null) { 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+							logger.info("[收到bye] {} 通知设备停止推流时未找到设备信息", streamId); 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+						} 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+						try { 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+							logger.info("[停止点播] {}/{}", sendRtpItem.getDeviceId(), sendRtpItem.getChannelId()); 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+							cmder.streamByeCmd(device, sendRtpItem.getChannelId(), streamId, null); 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+						} catch (InvalidArgumentException | ParseException | SipException | 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+								 SsrcTransactionNotFoundException e) { 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+							logger.error("[收到bye] {} 无其它观看者,通知设备停止推流, 发送BYE失败 {}",streamId, e.getMessage()); 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+						} 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				 					} 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				 				} 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				 			} 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				 		} 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				  
			 | 
		
	
		
			
				 | 
				 | 
			
			
				-			// 可能是设备发送的停止 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				-			SsrcTransaction ssrcTransaction = streamSession.getSsrcTransactionByCallId(callIdHeader.getCallId()); 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				-			if (ssrcTransaction == null) { 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				-				return; 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				-			} 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				-			logger.info("[收到bye] 来自设备:{}, 通道已停止推流: {}", ssrcTransaction.getDeviceId(), ssrcTransaction.getChannelId()); 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+		// 可能是设备发送的停止 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+		SsrcTransaction ssrcTransaction = streamSession.getSsrcTransactionByCallId(callIdHeader.getCallId()); 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+		if (ssrcTransaction == null) { 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+			return; 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+		} 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+		logger.info("[收到bye] 来自设备:{}, 通道已停止推流: {}", ssrcTransaction.getDeviceId(), ssrcTransaction.getChannelId()); 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				  
			 | 
		
	
		
			
				 | 
				 | 
			
			
				 		ParentPlatform platform = platformService.queryPlatformByServerGBId(ssrcTransaction.getDeviceId()); 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				 		if (platform != null ) { 
			 |