|  |  |  | 
|---|
|  |  |  | import com.genersoft.iot.vmp.gb28181.transmit.request.SIPRequestAbstractProcessor; | 
|---|
|  |  |  | import com.genersoft.iot.vmp.media.zlm.ZLMRTPServerFactory; | 
|---|
|  |  |  | import com.genersoft.iot.vmp.storager.IRedisCatchStorage; | 
|---|
|  |  |  | import org.slf4j.Logger; | 
|---|
|  |  |  | import org.slf4j.LoggerFactory; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * @Description:ACK请求处理器 | 
|---|
|  |  |  | 
|---|
|  |  |  | * @date:   2020年5月3日 下午5:31:45 | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | public class AckRequestProcessor extends SIPRequestAbstractProcessor { | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | private Logger logger = LoggerFactory.getLogger(AckRequestProcessor.class); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | private IRedisCatchStorage redisCatchStorage; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | 
|---|
|  |  |  | SendRtpItem sendRtpItem =  redisCatchStorage.querySendRTPServer(platformGbId, channelId); | 
|---|
|  |  |  | String is_Udp = sendRtpItem.isTcp() ? "0" : "1"; | 
|---|
|  |  |  | String deviceId = sendRtpItem.getDeviceId(); | 
|---|
|  |  |  | StreamInfo streamInfo = redisCatchStorage.queryPlayByDevice(deviceId, channelId); | 
|---|
|  |  |  | sendRtpItem.setStreamId(streamInfo.getStreamId()); | 
|---|
|  |  |  | StreamInfo streamInfo = null; | 
|---|
|  |  |  | if (deviceId == null) { | 
|---|
|  |  |  | streamInfo = new StreamInfo(); | 
|---|
|  |  |  | streamInfo.setApp(sendRtpItem.getApp()); | 
|---|
|  |  |  | streamInfo.setStreamId(sendRtpItem.getStreamId()); | 
|---|
|  |  |  | }else { | 
|---|
|  |  |  | streamInfo = redisCatchStorage.queryPlayByDevice(deviceId, channelId); | 
|---|
|  |  |  | sendRtpItem.setStreamId(streamInfo.getStreamId()); | 
|---|
|  |  |  | streamInfo.setApp("rtp"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | redisCatchStorage.updateSendRTPSever(sendRtpItem); | 
|---|
|  |  |  | System.out.println(platformGbId); | 
|---|
|  |  |  | System.out.println(channelId); | 
|---|
|  |  |  | logger.info(platformGbId); | 
|---|
|  |  |  | logger.info(channelId); | 
|---|
|  |  |  | Map<String, Object> param = new HashMap<>(); | 
|---|
|  |  |  | param.put("vhost","__defaultVhost__"); | 
|---|
|  |  |  | param.put("app","rtp"); | 
|---|
|  |  |  | param.put("app",streamInfo.getApp()); | 
|---|
|  |  |  | param.put("stream",streamInfo.getStreamId()); | 
|---|
|  |  |  | param.put("ssrc", sendRtpItem.getSsrc()); | 
|---|
|  |  |  | param.put("dst_url",sendRtpItem.getIp()); | 
|---|
|  |  |  | 
|---|
|  |  |  | while (!rtpPushed) { | 
|---|
|  |  |  | try { | 
|---|
|  |  |  | if (System.currentTimeMillis() - startTime < 30 * 1000) { | 
|---|
|  |  |  | if (zlmrtpServerFactory.isRtpReady(streamInfo.getStreamId())) { | 
|---|
|  |  |  | if (zlmrtpServerFactory.isStreamReady(streamInfo.getApp(), streamInfo.getStreamId())) { | 
|---|
|  |  |  | rtpPushed = true; | 
|---|
|  |  |  | System.out.println("已获取设备推流,开始向上级推流"); | 
|---|
|  |  |  | logger.info("已获取设备推流,开始向上级推流"); | 
|---|
|  |  |  | zlmrtpServerFactory.startSendRtpStream(param); | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | System.out.println("等待设备推流......."); | 
|---|
|  |  |  | Thread.sleep(2000); | 
|---|
|  |  |  | logger.info("等待设备推流......."); | 
|---|
|  |  |  | Thread.sleep(1000); | 
|---|
|  |  |  | continue; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | rtpPushed = true; | 
|---|
|  |  |  | System.out.println("设备推流超时,终止向上级推流"); | 
|---|
|  |  |  | logger.info("设备推流超时,终止向上级推流"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } catch (InterruptedException e) { | 
|---|
|  |  |  | e.printStackTrace(); | 
|---|
|  |  |  | 
|---|
|  |  |  | //    CSeq csReq = (CSeq) request.getHeader(CSeq.NAME); | 
|---|
|  |  |  | //    ackRequest = dialog.createAck(csReq.getSeqNumber()); | 
|---|
|  |  |  | //    dialog.sendAck(ackRequest); | 
|---|
|  |  |  | //    System.out.println("send ack to callee:" + ackRequest.toString()); | 
|---|
|  |  |  | //    logger.info("send ack to callee:" + ackRequest.toString()); | 
|---|
|  |  |  | // } catch (SipException e) { | 
|---|
|  |  |  | //    e.printStackTrace(); | 
|---|
|  |  |  | // } catch (InvalidArgumentException e) { | 
|---|