old mode 100644
new mode 100755
|  |  |  | 
|---|
|  |  |  | package com.genersoft.iot.vmp.gb28181.transmit.cmd.impl; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | import com.alibaba.fastjson2.JSONObject; | 
|---|
|  |  |  | import com.genersoft.iot.vmp.common.InviteSessionType; | 
|---|
|  |  |  | import com.genersoft.iot.vmp.common.StreamInfo; | 
|---|
|  |  |  | import com.genersoft.iot.vmp.conf.SipConfig; | 
|---|
|  |  |  | import com.genersoft.iot.vmp.conf.UserSetting; | 
|---|
|  |  |  | import com.genersoft.iot.vmp.conf.exception.SsrcTransactionNotFoundException; | 
|---|
|  |  |  | import com.genersoft.iot.vmp.gb28181.SipLayer; | 
|---|
|  |  |  | import com.genersoft.iot.vmp.gb28181.bean.*; | 
|---|
|  |  |  | import com.genersoft.iot.vmp.gb28181.bean.Device; | 
|---|
|  |  |  | import com.genersoft.iot.vmp.gb28181.bean.DeviceAlarm; | 
|---|
|  |  |  | import com.genersoft.iot.vmp.gb28181.bean.DeviceChannel; | 
|---|
|  |  |  | import com.genersoft.iot.vmp.gb28181.bean.SsrcTransaction; | 
|---|
|  |  |  | import com.genersoft.iot.vmp.gb28181.event.SipSubscribe; | 
|---|
|  |  |  | import com.genersoft.iot.vmp.gb28181.session.VideoStreamSessionManager; | 
|---|
|  |  |  | import com.genersoft.iot.vmp.gb28181.transmit.SIPSender; | 
|---|
|  |  |  | 
|---|
|  |  |  | import com.genersoft.iot.vmp.gb28181.transmit.cmd.SIPRequestHeaderProvider; | 
|---|
|  |  |  | import com.genersoft.iot.vmp.gb28181.utils.NumericUtil; | 
|---|
|  |  |  | import com.genersoft.iot.vmp.gb28181.utils.SipUtils; | 
|---|
|  |  |  | import com.genersoft.iot.vmp.media.zlm.ZLMRTPServerFactory; | 
|---|
|  |  |  | import com.genersoft.iot.vmp.media.zlm.ZLMServerFactory; | 
|---|
|  |  |  | import com.genersoft.iot.vmp.media.zlm.ZlmHttpHookSubscribe; | 
|---|
|  |  |  | import com.genersoft.iot.vmp.media.zlm.dto.HookSubscribeFactory; | 
|---|
|  |  |  | import com.genersoft.iot.vmp.media.zlm.dto.HookSubscribeForStreamChange; | 
|---|
|  |  |  | import com.genersoft.iot.vmp.media.zlm.dto.HookSubscribeForStreamPush; | 
|---|
|  |  |  | import com.genersoft.iot.vmp.utils.DateUtil; | 
|---|
|  |  |  | import com.genersoft.iot.vmp.gb28181.utils.NumericUtil; | 
|---|
|  |  |  | import com.genersoft.iot.vmp.media.zlm.ZlmHttpHookSubscribe; | 
|---|
|  |  |  | import com.genersoft.iot.vmp.media.zlm.dto.MediaServerItem; | 
|---|
|  |  |  | import com.genersoft.iot.vmp.media.zlm.dto.hook.HookParam; | 
|---|
|  |  |  | import com.genersoft.iot.vmp.service.IMediaServerService; | 
|---|
|  |  |  | import com.genersoft.iot.vmp.service.bean.SSRCInfo; | 
|---|
|  |  |  | import com.genersoft.iot.vmp.utils.GitUtil; | 
|---|
|  |  |  | import gov.nist.javax.sip.SipProviderImpl; | 
|---|
|  |  |  | import com.genersoft.iot.vmp.utils.DateUtil; | 
|---|
|  |  |  | import gov.nist.javax.sip.message.SIPRequest; | 
|---|
|  |  |  | import gov.nist.javax.sip.message.SIPResponse; | 
|---|
|  |  |  | 
|---|
|  |  |  | import javax.sip.InvalidArgumentException; | 
|---|
|  |  |  | import javax.sip.ResponseEvent; | 
|---|
|  |  |  | import javax.sip.SipException; | 
|---|
|  |  |  | import javax.sip.SipFactory; | 
|---|
|  |  |  | import javax.sip.header.CallIdHeader; | 
|---|
|  |  |  | import javax.sip.*; | 
|---|
|  |  |  | import javax.sip.header.*; | 
|---|
|  |  |  | import javax.sip.message.Request; | 
|---|
|  |  |  | import java.text.ParseException; | 
|---|
|  |  |  | import java.util.ArrayList; | 
|---|
|  |  |  | import java.util.List; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * @description:设备能力接口,用于定义设备的控制、查询能力 | 
|---|
|  |  |  | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private ZlmHttpHookSubscribe subscribe; | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private IMediaServerService mediaServerService; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private ZLMRTPServerFactory zlmrtpServerFactory; | 
|---|
|  |  |  | private ZLMServerFactory zlmServerFactory; | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | 
|---|
|  |  |  | builder.append(strTmp, 0, 2); | 
|---|
|  |  |  | strTmp = String.format("%02X", parameter2); | 
|---|
|  |  |  | builder.append(strTmp, 0, 2); | 
|---|
|  |  |  | //优化zoom变倍速率 | 
|---|
|  |  |  | if ((combineCode2 > 0) && (combineCode2 <16)) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | combineCode2 = 16; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | strTmp = String.format("%X", combineCode2); | 
|---|
|  |  |  | builder.append(strTmp, 0, 1).append("0"); | 
|---|
|  |  |  | //计算校验码 | 
|---|
|  |  |  | 
|---|
|  |  |  | * 请求预览视频流 | 
|---|
|  |  |  | * | 
|---|
|  |  |  | * @param device     视频设备 | 
|---|
|  |  |  | * @param channelId  预览通道 | 
|---|
|  |  |  | * @param channel  预览通道 | 
|---|
|  |  |  | * @param event      hook订阅 | 
|---|
|  |  |  | * @param errorEvent sip错误订阅 | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public void playStreamCmd(MediaServerItem mediaServerItem, SSRCInfo ssrcInfo, Device device, String channelId, | 
|---|
|  |  |  | public void playStreamCmd(MediaServerItem mediaServerItem, SSRCInfo ssrcInfo, Device device, DeviceChannel channel, | 
|---|
|  |  |  | ZlmHttpHookSubscribe.Event event, SipSubscribe.Event okEvent, SipSubscribe.Event errorEvent) throws InvalidArgumentException, SipException, ParseException { | 
|---|
|  |  |  | String stream = ssrcInfo.getStream(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | 
|---|
|  |  |  | return; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | logger.info("{} 分配的ZLM为: {} [{}:{}]", stream, mediaServerItem.getId(), mediaServerItem.getIp(), ssrcInfo.getPort()); | 
|---|
|  |  |  | logger.info("{} 分配的ZLM为: {} [{}:{}]", stream, mediaServerItem.getId(), mediaServerItem.getSdpIp(), ssrcInfo.getPort()); | 
|---|
|  |  |  | HookSubscribeForStreamChange hookSubscribe = HookSubscribeFactory.on_stream_changed("rtp", stream, true, "rtsp", mediaServerItem.getId()); | 
|---|
|  |  |  | subscribe.addSubscribe(hookSubscribe, (MediaServerItem mediaServerItemInUse, JSONObject json) -> { | 
|---|
|  |  |  | subscribe.addSubscribe(hookSubscribe, (MediaServerItem mediaServerItemInUse, HookParam hookParam) -> { | 
|---|
|  |  |  | if (event != null) { | 
|---|
|  |  |  | event.response(mediaServerItemInUse, json); | 
|---|
|  |  |  | event.response(mediaServerItemInUse, hookParam); | 
|---|
|  |  |  | subscribe.removeSubscribe(hookSubscribe); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | StringBuffer content = new StringBuffer(200); | 
|---|
|  |  |  | content.append("v=0\r\n"); | 
|---|
|  |  |  | content.append("o=" + channelId + " 0 0 IN IP4 " + sdpIp + "\r\n"); | 
|---|
|  |  |  | content.append("o=" + channel.getChannelId() + " 0 0 IN IP4 " + sdpIp + "\r\n"); | 
|---|
|  |  |  | content.append("s=Play\r\n"); | 
|---|
|  |  |  | content.append("c=IN IP4 " + sdpIp + "\r\n"); | 
|---|
|  |  |  | content.append("t=0 0\r\n"); | 
|---|
|  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if (!ObjectUtils.isEmpty(channel.getStreamIdentification())) { | 
|---|
|  |  |  | content.append("a=" + channel.getStreamIdentification() + "\r\n"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | content.append("y=" + ssrcInfo.getSsrc() + "\r\n");//ssrc | 
|---|
|  |  |  | // f字段:f= v/编码格式/分辨率/帧率/码率类型/码率大小a/编码格式/码率大小/采样率 | 
|---|
|  |  |  | //         content.append("f=v/2/5/25/1/4000a/1/8/1" + "\r\n"); // 未发现支持此特性的设备 | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | Request request = headerProvider.createInviteRequest(device, channelId, content.toString(), SipUtils.getNewViaTag(), SipUtils.getNewFromTag(), null, ssrcInfo.getSsrc(),sipSender.getNewCallIdHeader(sipLayer.getLocalIp(device.getLocalIp()),device.getTransport())); | 
|---|
|  |  |  | Request request = headerProvider.createInviteRequest(device, channel.getChannelId(), content.toString(), SipUtils.getNewViaTag(), SipUtils.getNewFromTag(), null, ssrcInfo.getSsrc(),sipSender.getNewCallIdHeader(sipLayer.getLocalIp(device.getLocalIp()),device.getTransport())); | 
|---|
|  |  |  | sipSender.transmitRequest(sipLayer.getLocalIp(device.getLocalIp()), request, (e -> { | 
|---|
|  |  |  | streamSession.remove(device.getDeviceId(), channelId, ssrcInfo.getStream()); | 
|---|
|  |  |  | streamSession.remove(device.getDeviceId(), channel.getChannelId(), ssrcInfo.getStream()); | 
|---|
|  |  |  | mediaServerService.releaseSsrc(mediaServerItem.getId(), ssrcInfo.getSsrc()); | 
|---|
|  |  |  | errorEvent.response(e); | 
|---|
|  |  |  | }), e -> { | 
|---|
|  |  |  | // 这里为例避免一个通道的点播只有一个callID这个参数使用一个固定值 | 
|---|
|  |  |  | ResponseEvent responseEvent = (ResponseEvent) e.event; | 
|---|
|  |  |  | SIPResponse response = (SIPResponse) responseEvent.getResponse(); | 
|---|
|  |  |  | streamSession.put(device.getDeviceId(), channelId, "play", stream, ssrcInfo.getSsrc(), mediaServerItem.getId(), response, VideoStreamSessionManager.SessionType.play); | 
|---|
|  |  |  | String callId = response.getCallIdHeader().getCallId(); | 
|---|
|  |  |  | streamSession.put(device.getDeviceId(), channel.getChannelId(), callId, stream, ssrcInfo.getSsrc(), mediaServerItem.getId(), response, | 
|---|
|  |  |  | InviteSessionType.PLAY); | 
|---|
|  |  |  | okEvent.response(e); | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public void playbackStreamCmd(MediaServerItem mediaServerItem, SSRCInfo ssrcInfo, Device device, String channelId, | 
|---|
|  |  |  | String startTime, String endTime, InviteStreamCallback inviteStreamCallback, InviteStreamCallback hookEvent, | 
|---|
|  |  |  | String startTime, String endTime, ZlmHttpHookSubscribe.Event hookEvent, | 
|---|
|  |  |  | SipSubscribe.Event okEvent, SipSubscribe.Event errorEvent) throws InvalidArgumentException, SipException, ParseException { | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | logger.info("{} 分配的ZLM为: {} [{}:{}]", ssrcInfo.getStream(), mediaServerItem.getId(), mediaServerItem.getIp(), ssrcInfo.getPort()); | 
|---|
|  |  |  | logger.info("{} 分配的ZLM为: {} [{}:{}]", ssrcInfo.getStream(), mediaServerItem.getId(), mediaServerItem.getSdpIp(), ssrcInfo.getPort()); | 
|---|
|  |  |  | String sdpIp; | 
|---|
|  |  |  | if (!ObjectUtils.isEmpty(device.getSdpIp())) { | 
|---|
|  |  |  | sdpIp = device.getSdpIp(); | 
|---|
|  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | HookSubscribeForStreamChange hookSubscribe = HookSubscribeFactory.on_stream_changed("rtp", ssrcInfo.getStream(), true, "rtsp", mediaServerItem.getId()); | 
|---|
|  |  |  | // 添加订阅 | 
|---|
|  |  |  | subscribe.addSubscribe(hookSubscribe, (MediaServerItem mediaServerItemInUse, JSONObject json) -> { | 
|---|
|  |  |  | subscribe.addSubscribe(hookSubscribe, (MediaServerItem mediaServerItemInUse, HookParam hookParam) -> { | 
|---|
|  |  |  | if (hookEvent != null) { | 
|---|
|  |  |  | InviteStreamInfo inviteStreamInfo = new InviteStreamInfo(mediaServerItemInUse, json,sipSender.getNewCallIdHeader(sipLayer.getLocalIp(device.getLocalIp()),device.getTransport()).getCallId(), "rtp", ssrcInfo.getStream()); | 
|---|
|  |  |  | hookEvent.call(inviteStreamInfo); | 
|---|
|  |  |  | hookEvent.response(mediaServerItemInUse, hookParam); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | subscribe.removeSubscribe(hookSubscribe); | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | Request request = headerProvider.createPlaybackInviteRequest(device, channelId, content.toString(), null, SipUtils.getNewFromTag(), null,sipSender.getNewCallIdHeader(sipLayer.getLocalIp(device.getLocalIp()),device.getTransport()), ssrcInfo.getSsrc()); | 
|---|
|  |  |  | Request request = headerProvider.createPlaybackInviteRequest(device, channelId, content.toString(), SipUtils.getNewViaTag(), SipUtils.getNewFromTag(), null,sipSender.getNewCallIdHeader(sipLayer.getLocalIp(device.getLocalIp()),device.getTransport()), ssrcInfo.getSsrc()); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | sipSender.transmitRequest(sipLayer.getLocalIp(device.getLocalIp()), request, errorEvent, event -> { | 
|---|
|  |  |  | ResponseEvent responseEvent = (ResponseEvent) event.event; | 
|---|
|  |  |  | SIPResponse response = (SIPResponse) responseEvent.getResponse(); | 
|---|
|  |  |  | streamSession.put(device.getDeviceId(), channelId,sipSender.getNewCallIdHeader(sipLayer.getLocalIp(device.getLocalIp()),device.getTransport()).getCallId(), ssrcInfo.getStream(), ssrcInfo.getSsrc(), mediaServerItem.getId(), response, VideoStreamSessionManager.SessionType.playback); | 
|---|
|  |  |  | streamSession.put(device.getDeviceId(), channelId,sipSender.getNewCallIdHeader(sipLayer.getLocalIp(device.getLocalIp()),device.getTransport()).getCallId(), ssrcInfo.getStream(), ssrcInfo.getSsrc(), mediaServerItem.getId(), response, InviteSessionType.PLAYBACK); | 
|---|
|  |  |  | okEvent.response(event); | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | if (inviteStreamCallback != null) { | 
|---|
|  |  |  | inviteStreamCallback.call(new InviteStreamInfo(mediaServerItem, null,sipSender.getNewCallIdHeader(sipLayer.getLocalIp(device.getLocalIp()),device.getTransport()).getCallId(), "rtp", ssrcInfo.getStream())); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public void downloadStreamCmd(MediaServerItem mediaServerItem, SSRCInfo ssrcInfo, Device device, String channelId, | 
|---|
|  |  |  | String startTime, String endTime, int downloadSpeed, InviteStreamCallback inviteStreamCallback, InviteStreamCallback hookEvent, | 
|---|
|  |  |  | SipSubscribe.Event errorEvent) throws InvalidArgumentException, SipException, ParseException { | 
|---|
|  |  |  | String startTime, String endTime, int downloadSpeed, | 
|---|
|  |  |  | ZlmHttpHookSubscribe.Event hookEvent, | 
|---|
|  |  |  | SipSubscribe.Event errorEvent,SipSubscribe.Event okEvent) throws InvalidArgumentException, SipException, ParseException { | 
|---|
|  |  |  |  | 
|---|
|  |  |  | logger.info("{} 分配的ZLM为: {} [{}:{}]", ssrcInfo.getStream(), mediaServerItem.getId(), mediaServerItem.getIp(), ssrcInfo.getPort()); | 
|---|
|  |  |  | logger.info("{} 分配的ZLM为: {} [{}:{}]", ssrcInfo.getStream(), mediaServerItem.getId(), mediaServerItem.getSdpIp(), ssrcInfo.getPort()); | 
|---|
|  |  |  | String sdpIp; | 
|---|
|  |  |  | if (!ObjectUtils.isEmpty(device.getSdpIp())) { | 
|---|
|  |  |  | sdpIp = device.getSdpIp(); | 
|---|
|  |  |  | 
|---|
|  |  |  | content.append("a=downloadspeed:" + downloadSpeed + "\r\n"); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | content.append("y=" + ssrcInfo.getSsrc() + "\r\n");//ssrc | 
|---|
|  |  |  |  | 
|---|
|  |  |  | HookSubscribeForStreamChange hookSubscribe = HookSubscribeFactory.on_stream_changed("rtp", ssrcInfo.getStream(), true, null, mediaServerItem.getId()); | 
|---|
|  |  |  | logger.debug("此时请求下载信令的ssrc===>{}",ssrcInfo.getSsrc()); | 
|---|
|  |  |  | HookSubscribeForStreamChange hookSubscribe = HookSubscribeFactory.on_stream_changed("rtp", ssrcInfo.getStream(), true, "rtsp", mediaServerItem.getId()); | 
|---|
|  |  |  | // 添加订阅 | 
|---|
|  |  |  | subscribe.addSubscribe(hookSubscribe, (MediaServerItem mediaServerItemInUse, JSONObject json) -> { | 
|---|
|  |  |  | hookEvent.call(new InviteStreamInfo(mediaServerItem, json,sipSender.getNewCallIdHeader(sipLayer.getLocalIp(device.getLocalIp()),device.getTransport()).getCallId(), "rtp", ssrcInfo.getStream())); | 
|---|
|  |  |  | CallIdHeader newCallIdHeader = sipSender.getNewCallIdHeader(sipLayer.getLocalIp(device.getLocalIp()), device.getTransport()); | 
|---|
|  |  |  | String callId= newCallIdHeader.getCallId(); | 
|---|
|  |  |  | subscribe.addSubscribe(hookSubscribe, (mediaServerItemInUse, hookParam) -> { | 
|---|
|  |  |  | logger.debug("sipc 添加订阅===callId {}",callId); | 
|---|
|  |  |  | hookEvent.response(mediaServerItemInUse, hookParam); | 
|---|
|  |  |  | subscribe.removeSubscribe(hookSubscribe); | 
|---|
|  |  |  | hookSubscribe.getContent().put("regist", false); | 
|---|
|  |  |  | hookSubscribe.getContent().put("schema", "rtsp"); | 
|---|
|  |  |  | // 添加流注销的订阅,注销了后向设备发送bye | 
|---|
|  |  |  | subscribe.addSubscribe(hookSubscribe, | 
|---|
|  |  |  | (MediaServerItem mediaServerItemForEnd, JSONObject jsonForEnd) -> { | 
|---|
|  |  |  | (mediaServerItemForEnd, hookParam1) -> { | 
|---|
|  |  |  | logger.info("[录像]下载结束, 发送BYE"); | 
|---|
|  |  |  | try { | 
|---|
|  |  |  | streamByeCmd(device, channelId, ssrcInfo.getStream(),sipSender.getNewCallIdHeader(sipLayer.getLocalIp(device.getLocalIp()),device.getTransport()).getCallId()); | 
|---|
|  |  |  | streamByeCmd(device, channelId, ssrcInfo.getStream(), callId); | 
|---|
|  |  |  | } catch (InvalidArgumentException | ParseException | SipException | | 
|---|
|  |  |  | SsrcTransactionNotFoundException e) { | 
|---|
|  |  |  | logger.error("[录像]下载结束, 发送BYE失败 {}", e.getMessage()); | 
|---|
|  |  |  | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | }); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | Request request = headerProvider.createPlaybackInviteRequest(device, channelId, content.toString(), null, SipUtils.getNewFromTag(), null,sipSender.getNewCallIdHeader(sipLayer.getLocalIp(device.getLocalIp()),device.getTransport()), ssrcInfo.getSsrc()); | 
|---|
|  |  |  | if (inviteStreamCallback != null) { | 
|---|
|  |  |  | inviteStreamCallback.call(new InviteStreamInfo(mediaServerItem, null,sipSender.getNewCallIdHeader(sipLayer.getLocalIp(device.getLocalIp()),device.getTransport()).getCallId(), "rtp", ssrcInfo.getStream())); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | sipSender.transmitRequest(sipLayer.getLocalIp(device.getLocalIp()), request, errorEvent, okEvent -> { | 
|---|
|  |  |  | ResponseEvent responseEvent = (ResponseEvent) okEvent.event; | 
|---|
|  |  |  | Request request = headerProvider.createPlaybackInviteRequest(device, channelId, content.toString(), SipUtils.getNewViaTag(), SipUtils.getNewFromTag(), null,newCallIdHeader, ssrcInfo.getSsrc()); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | sipSender.transmitRequest(sipLayer.getLocalIp(device.getLocalIp()), request, errorEvent, event -> { | 
|---|
|  |  |  | ResponseEvent responseEvent = (ResponseEvent) event.event; | 
|---|
|  |  |  | SIPResponse response = (SIPResponse) responseEvent.getResponse(); | 
|---|
|  |  |  | streamSession.put(device.getDeviceId(), channelId,sipSender.getNewCallIdHeader(sipLayer.getLocalIp(device.getLocalIp()),device.getTransport()).getCallId(), ssrcInfo.getStream(), ssrcInfo.getSsrc(), mediaServerItem.getId(), response, VideoStreamSessionManager.SessionType.download); | 
|---|
|  |  |  | String contentString =new String(response.getRawContent()); | 
|---|
|  |  |  | String ssrc = SipUtils.getSsrcFromSdp(contentString); | 
|---|
|  |  |  | streamSession.put(device.getDeviceId(), channelId, response.getCallIdHeader().getCallId(), ssrcInfo.getStream(), ssrc, mediaServerItem.getId(), response, InviteSessionType.DOWNLOAD); | 
|---|
|  |  |  | okEvent.response(event); | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public void talkStreamCmd(MediaServerItem mediaServerItem, SSRCInfo ssrcInfo, Device device, String channelId, String callId, ZlmHttpHookSubscribe.Event event, ZlmHttpHookSubscribe.Event eventForPush, SipSubscribe.Event okEvent, SipSubscribe.Event errorEvent) throws InvalidArgumentException, SipException, ParseException { | 
|---|
|  |  |  | public void talkStreamCmd(MediaServerItem mediaServerItem, SendRtpItem sendRtpItem, Device device, String channelId, String callId, ZlmHttpHookSubscribe.Event event, ZlmHttpHookSubscribe.Event eventForPush, SipSubscribe.Event okEvent, SipSubscribe.Event errorEvent) throws InvalidArgumentException, SipException, ParseException { | 
|---|
|  |  |  |  | 
|---|
|  |  |  | String stream = ssrcInfo.getStream(); | 
|---|
|  |  |  | String stream = sendRtpItem.getStream(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if (device == null) { | 
|---|
|  |  |  | return; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (!mediaServerItem.isRtpEnable()) { | 
|---|
|  |  |  | // 单端口暂不支持语音对讲 | 
|---|
|  |  |  | logger.info("[语音对讲] 单端口暂不支持此操作"); | 
|---|
|  |  |  | // 单端口暂不支持语音喊话 | 
|---|
|  |  |  | logger.info("[语音喊话] 单端口暂不支持此操作"); | 
|---|
|  |  |  | return; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | logger.info("[语音对讲] {} 分配的ZLM为: {} [{}:{}]", stream, mediaServerItem.getId(), mediaServerItem.getIp(), ssrcInfo.getPort()); | 
|---|
|  |  |  | logger.info("[语音喊话] {} 分配的ZLM为: {} [{}:{}]", stream, mediaServerItem.getId(), mediaServerItem.getIp(), sendRtpItem.getPort()); | 
|---|
|  |  |  | HookSubscribeForStreamChange hookSubscribeForStreamChange = HookSubscribeFactory.on_stream_changed("rtp", stream, true, "rtsp", mediaServerItem.getId()); | 
|---|
|  |  |  | subscribe.addSubscribe(hookSubscribeForStreamChange, (MediaServerItem mediaServerItemInUse, JSONObject json) -> { | 
|---|
|  |  |  | subscribe.addSubscribe(hookSubscribeForStreamChange, (mediaServerItemInUse, hookParam) -> { | 
|---|
|  |  |  | if (event != null) { | 
|---|
|  |  |  | event.response(mediaServerItemInUse, json); | 
|---|
|  |  |  | event.response(mediaServerItemInUse, hookParam); | 
|---|
|  |  |  | subscribe.removeSubscribe(hookSubscribeForStreamChange); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | CallIdHeader callIdHeader = device.getTransport().equalsIgnoreCase("TCP") ? tcpSipProvider.getNewCallId() | 
|---|
|  |  |  | : udpSipProvider.getNewCallId(); | 
|---|
|  |  |  | CallIdHeader callIdHeader = sipSender.getNewCallIdHeader(sipLayer.getLocalIp(device.getLocalIp()), device.getTransport()); | 
|---|
|  |  |  | callIdHeader.setCallId(callId); | 
|---|
|  |  |  | HookSubscribeForStreamPush hookSubscribeForStreamPush = HookSubscribeFactory.on_publish("rtp", stream,  null, mediaServerItem.getId()); | 
|---|
|  |  |  | subscribe.addSubscribe(hookSubscribeForStreamPush, (MediaServerItem mediaServerItemInUse, JSONObject json) -> { | 
|---|
|  |  |  | subscribe.addSubscribe(hookSubscribeForStreamPush, (mediaServerItemInUse, hookParam) -> { | 
|---|
|  |  |  | if (eventForPush != null) { | 
|---|
|  |  |  | eventForPush.response(mediaServerItemInUse, json); | 
|---|
|  |  |  | eventForPush.response(mediaServerItemInUse, hookParam); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | // | 
|---|
|  |  |  | 
|---|
|  |  |  | content.append("c=IN IP4 " + mediaServerItem.getSdpIp() + "\r\n"); | 
|---|
|  |  |  | content.append("t=0 0\r\n"); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | content.append("m=audio " + ssrcInfo.getPort() + " RTP/AVP 8\r\n"); | 
|---|
|  |  |  | content.append("m=audio " + sendRtpItem.getPort() + " TCP/RTP/AVP 8\r\n"); | 
|---|
|  |  |  | content.append("a=setup:passive\r\n"); | 
|---|
|  |  |  | content.append("a=connection:new\r\n"); | 
|---|
|  |  |  | content.append("a=sendrecv\r\n"); | 
|---|
|  |  |  | content.append("a=rtpmap:8 PCMA/8000\r\n"); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | content.append("y=" + ssrcInfo.getSsrc() + "\r\n");//ssrc | 
|---|
|  |  |  | content.append("y=" + sendRtpItem.getSsrc() + "\r\n");//ssrc | 
|---|
|  |  |  | // f字段:f= v/编码格式/分辨率/帧率/码率类型/码率大小a/编码格式/码率大小/采样率 | 
|---|
|  |  |  | content.append("f=v/////a/1/8/1" + "\r\n"); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | Request request = headerProvider.createInviteRequest(device, channelId, content.toString(), SipUtils.getNewViaTag(), SipUtils.getNewFromTag(), null, ssrcInfo.getSsrc(), callIdHeader); | 
|---|
|  |  |  | transmitRequest(device.getTransport(), request, (e -> { | 
|---|
|  |  |  | streamSession.remove(device.getDeviceId(), channelId, ssrcInfo.getStream()); | 
|---|
|  |  |  | mediaServerService.releaseSsrc(mediaServerItem.getId(), ssrcInfo.getSsrc()); | 
|---|
|  |  |  | Request request = headerProvider.createInviteRequest(device, channelId, content.toString(), | 
|---|
|  |  |  | SipUtils.getNewViaTag(), SipUtils.getNewFromTag(), null, sendRtpItem.getSsrc(), callIdHeader); | 
|---|
|  |  |  | sipSender.transmitRequest(sipLayer.getLocalIp(device.getLocalIp()), request, (e -> { | 
|---|
|  |  |  | streamSession.remove(device.getDeviceId(), channelId, sendRtpItem.getStream()); | 
|---|
|  |  |  | mediaServerService.releaseSsrc(mediaServerItem.getId(), sendRtpItem.getSsrc()); | 
|---|
|  |  |  | errorEvent.response(e); | 
|---|
|  |  |  | }), e -> { | 
|---|
|  |  |  | // 这里为例避免一个通道的点播只有一个callID这个参数使用一个固定值 | 
|---|
|  |  |  | ResponseEvent responseEvent = (ResponseEvent) e.event; | 
|---|
|  |  |  | SIPResponse response = (SIPResponse) responseEvent.getResponse(); | 
|---|
|  |  |  | streamSession.put(device.getDeviceId(), channelId, "talk", stream, ssrcInfo.getSsrc(), mediaServerItem.getId(), response, VideoStreamSessionManager.SessionType.play); | 
|---|
|  |  |  | streamSession.put(device.getDeviceId(), channelId, "talk", stream, sendRtpItem.getSsrc(), mediaServerItem.getId(), response, InviteSessionType.TALK); | 
|---|
|  |  |  | okEvent.response(e); | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | * 视频流停止, 不使用回调 | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public synchronized void streamByeCmd(Device device, String channelId, String stream, String callId) throws InvalidArgumentException, ParseException, SipException, SsrcTransactionNotFoundException { | 
|---|
|  |  |  | public void streamByeCmd(Device device, String channelId, String stream, String callId) throws InvalidArgumentException, ParseException, SipException, SsrcTransactionNotFoundException { | 
|---|
|  |  |  | streamByeCmd(device, channelId, stream, callId, null); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | 
|---|
|  |  |  | * 视频流停止 | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public synchronized void streamByeCmd(Device device, String channelId, String stream, String callId, SipSubscribe.Event okEvent) throws InvalidArgumentException, SipException, ParseException, SsrcTransactionNotFoundException { | 
|---|
|  |  |  | SsrcTransaction ssrcTransaction = streamSession.getSsrcTransaction(device.getDeviceId(), channelId, callId, stream); | 
|---|
|  |  |  | if (ssrcTransaction == null) { | 
|---|
|  |  |  | public void streamByeCmd(Device device, String channelId, String stream, String callId, SipSubscribe.Event okEvent) throws InvalidArgumentException, SipException, ParseException, SsrcTransactionNotFoundException { | 
|---|
|  |  |  | if (device == null) { | 
|---|
|  |  |  | logger.warn("[发送BYE] device为null"); | 
|---|
|  |  |  | return; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | List<SsrcTransaction> ssrcTransactionList = streamSession.getSsrcTransactionForAll(device.getDeviceId(), channelId, callId, stream); | 
|---|
|  |  |  | if (ssrcTransactionList == null || ssrcTransactionList.isEmpty()) { | 
|---|
|  |  |  | logger.info("[发送BYE] 未找到事务信息,设备: device: {}, channel: {}", device.getDeviceId(), channelId); | 
|---|
|  |  |  | throw new SsrcTransactionNotFoundException(device.getDeviceId(), channelId, callId, stream); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | mediaServerService.releaseSsrc(ssrcTransaction.getMediaServerId(), ssrcTransaction.getSsrc()); | 
|---|
|  |  |  | mediaServerService.closeRTPServer(ssrcTransaction.getMediaServerId(), ssrcTransaction.getStream()); | 
|---|
|  |  |  | streamSession.remove(ssrcTransaction.getDeviceId(), ssrcTransaction.getChannelId(), ssrcTransaction.getStream()); | 
|---|
|  |  |  | for (SsrcTransaction ssrcTransaction : ssrcTransactionList) { | 
|---|
|  |  |  | logger.info("[发送BYE] 设备: device: {}, channel: {}, callId: {}", device.getDeviceId(), channelId, ssrcTransaction.getCallId()); | 
|---|
|  |  |  | mediaServerService.releaseSsrc(ssrcTransaction.getMediaServerId(), ssrcTransaction.getSsrc()); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | Request byteRequest = headerProvider.createByteRequest(device, channelId, ssrcTransaction.getSipTransactionInfo()); | 
|---|
|  |  |  | mediaServerService.closeRTPServer(ssrcTransaction.getMediaServerId(), ssrcTransaction.getStream()); | 
|---|
|  |  |  | streamSession.removeByCallId(ssrcTransaction.getDeviceId(), ssrcTransaction.getChannelId(), ssrcTransaction.getCallId()); | 
|---|
|  |  |  | Request byteRequest = headerProvider.createByteRequest(device, channelId, ssrcTransaction.getSipTransactionInfo()); | 
|---|
|  |  |  | sipSender.transmitRequest(sipLayer.getLocalIp(device.getLocalIp()), byteRequest, null, okEvent); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public void streamByeCmd(Device device, String channelId, SipTransactionInfo sipTransactionInfo, SipSubscribe.Event okEvent) throws InvalidArgumentException, SipException, ParseException, SsrcTransactionNotFoundException { | 
|---|
|  |  |  | Request byteRequest = headerProvider.createByteRequest(device, channelId, sipTransactionInfo); | 
|---|
|  |  |  | sipSender.transmitRequest(sipLayer.getLocalIp(device.getLocalIp()), byteRequest, null, okEvent); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public synchronized void streamByeCmd(Device device, String channelId, SipTransactionInfo sipTransactionInfo, SipSubscribe.Event okEvent) throws InvalidArgumentException, SipException, ParseException, SsrcTransactionNotFoundException { | 
|---|
|  |  |  | Request byteRequest = headerProvider.createByteRequest(device, channelId, sipTransactionInfo); | 
|---|
|  |  |  | transmitRequest(device.getTransport(), byteRequest, null, okEvent); | 
|---|
|  |  |  | public void streamByeCmdForDeviceInvite(Device device, String channelId, SipTransactionInfo sipTransactionInfo, SipSubscribe.Event okEvent) throws InvalidArgumentException, SipException, ParseException, SsrcTransactionNotFoundException { | 
|---|
|  |  |  | Request byteRequest = headerProvider.createByteRequestForDeviceInvite(device, channelId, sipTransactionInfo); | 
|---|
|  |  |  | sipSender.transmitRequest(sipLayer.getLocalIp(device.getLocalIp()), byteRequest, null, okEvent); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 语音广播 | 
|---|
|  |  |  | * | 
|---|
|  |  |  | * @param device 视频设备 | 
|---|
|  |  |  | 
|---|
|  |  |  | broadcastXml.append("<TargetID>" + channelId + "</TargetID>\r\n"); | 
|---|
|  |  |  | broadcastXml.append("</Notify>\r\n"); | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | Request request = headerProvider.createMessageRequest(device, broadcastXml.toString(), SipUtils.getNewViaTag(), SipUtils.getNewFromTag(), null,sipSender.getNewCallIdHeader(sipLayer.getLocalIp(device.getLocalIp()),device.getTransport())); | 
|---|
|  |  |  | sipSender.transmitRequest(sipLayer.getLocalIp(device.getLocalIp()), request); | 
|---|
|  |  |  | sipSender.transmitRequest(sipLayer.getLocalIp(device.getLocalIp()), request, errorEvent, okEvent); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | 
|---|
|  |  |  | * @param recordCmdStr 录像命令:Record / StopRecord | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public void recordCmd(Device device, String channelId, String recordCmdStr, SipSubscribe.Event errorEvent) throws InvalidArgumentException, SipException, ParseException { | 
|---|
|  |  |  | public void recordCmd(Device device, String channelId, String recordCmdStr, SipSubscribe.Event errorEvent, SipSubscribe.Event okEvent) throws InvalidArgumentException, SipException, ParseException { | 
|---|
|  |  |  | StringBuffer cmdXml = new StringBuffer(200); | 
|---|
|  |  |  | String charset = device.getCharset(); | 
|---|
|  |  |  | cmdXml.append("<?xml version=\"1.0\" encoding=\"" + charset + "\"?>\r\n"); | 
|---|
|  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | Request request = headerProvider.createMessageRequest(device, cmdXml.toString(), null, SipUtils.getNewFromTag(), null,sipSender.getNewCallIdHeader(sipLayer.getLocalIp(device.getLocalIp()),device.getTransport())); | 
|---|
|  |  |  | sipSender.transmitRequest(sipLayer.getLocalIp(device.getLocalIp()), request, errorEvent); | 
|---|
|  |  |  | sipSender.transmitRequest(sipLayer.getLocalIp(device.getLocalIp()), request, errorEvent,okEvent); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | 
|---|
|  |  |  | * @param guardCmdStr "SetGuard"/"ResetGuard" | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public void guardCmd(Device device, String guardCmdStr, SipSubscribe.Event errorEvent) throws InvalidArgumentException, SipException, ParseException { | 
|---|
|  |  |  | public void guardCmd(Device device, String guardCmdStr, SipSubscribe.Event errorEvent, SipSubscribe.Event okEvent) throws InvalidArgumentException, SipException, ParseException { | 
|---|
|  |  |  |  | 
|---|
|  |  |  | StringBuffer cmdXml = new StringBuffer(200); | 
|---|
|  |  |  | String charset = device.getCharset(); | 
|---|
|  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | Request request = headerProvider.createMessageRequest(device, cmdXml.toString(), null, SipUtils.getNewFromTag(), null,sipSender.getNewCallIdHeader(sipLayer.getLocalIp(device.getLocalIp()),device.getTransport())); | 
|---|
|  |  |  | sipSender.transmitRequest(sipLayer.getLocalIp(device.getLocalIp()), request, errorEvent); | 
|---|
|  |  |  | sipSender.transmitRequest(sipLayer.getLocalIp(device.getLocalIp()), request, errorEvent,okEvent); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | 
|---|
|  |  |  | * @param device 视频设备 | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public void alarmCmd(Device device, String alarmMethod, String alarmType, SipSubscribe.Event errorEvent) throws InvalidArgumentException, SipException, ParseException { | 
|---|
|  |  |  | public void alarmCmd(Device device, String alarmMethod, String alarmType, SipSubscribe.Event errorEvent, SipSubscribe.Event okEvent) throws InvalidArgumentException, SipException, ParseException { | 
|---|
|  |  |  |  | 
|---|
|  |  |  | StringBuffer cmdXml = new StringBuffer(200); | 
|---|
|  |  |  | String charset = device.getCharset(); | 
|---|
|  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | Request request = headerProvider.createMessageRequest(device, cmdXml.toString(), null, SipUtils.getNewFromTag(), null,sipSender.getNewCallIdHeader(sipLayer.getLocalIp(device.getLocalIp()),device.getTransport())); | 
|---|
|  |  |  | sipSender.transmitRequest(sipLayer.getLocalIp(device.getLocalIp()), request, errorEvent); | 
|---|
|  |  |  | sipSender.transmitRequest(sipLayer.getLocalIp(device.getLocalIp()), request, errorEvent,okEvent); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | 
|---|
|  |  |  | * 看守位控制命令 | 
|---|
|  |  |  | * | 
|---|
|  |  |  | * @param device      视频设备 | 
|---|
|  |  |  | * @param channelId      通道id,非通道则是设备本身 | 
|---|
|  |  |  | * @param enabled     看守位使能:1 = 开启,0 = 关闭 | 
|---|
|  |  |  | * @param resetTime   自动归位时间间隔,开启看守位时使用,单位:秒(s) | 
|---|
|  |  |  | * @param presetIndex 调用预置位编号,开启看守位时使用,取值范围0~255 | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public void homePositionCmd(Device device, String channelId, String enabled, String resetTime, String presetIndex, SipSubscribe.Event errorEvent) throws InvalidArgumentException, SipException, ParseException { | 
|---|
|  |  |  | public void homePositionCmd(Device device, String channelId, Boolean enabled, Integer resetTime, Integer presetIndex, SipSubscribe.Event errorEvent,SipSubscribe.Event okEvent) throws InvalidArgumentException, SipException, ParseException { | 
|---|
|  |  |  |  | 
|---|
|  |  |  | StringBuffer cmdXml = new StringBuffer(200); | 
|---|
|  |  |  | String charset = device.getCharset(); | 
|---|
|  |  |  | 
|---|
|  |  |  | cmdXml.append("<DeviceID>" + channelId + "</DeviceID>\r\n"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | cmdXml.append("<HomePosition>\r\n"); | 
|---|
|  |  |  | if (NumericUtil.isInteger(enabled) && (!enabled.equals("0"))) { | 
|---|
|  |  |  | if (enabled) { | 
|---|
|  |  |  | cmdXml.append("<Enabled>1</Enabled>\r\n"); | 
|---|
|  |  |  | if (NumericUtil.isInteger(resetTime)) { | 
|---|
|  |  |  | cmdXml.append("<ResetTime>" + resetTime + "</ResetTime>\r\n"); | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | cmdXml.append("<ResetTime>0</ResetTime>\r\n"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (NumericUtil.isInteger(presetIndex)) { | 
|---|
|  |  |  | cmdXml.append("<PresetIndex>" + presetIndex + "</PresetIndex>\r\n"); | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | cmdXml.append("<PresetIndex>0</PresetIndex>\r\n"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | cmdXml.append("<ResetTime>" + resetTime + "</ResetTime>\r\n"); | 
|---|
|  |  |  | cmdXml.append("<PresetIndex>" + presetIndex + "</PresetIndex>\r\n"); | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | cmdXml.append("<Enabled>0</Enabled>\r\n"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | Request request = headerProvider.createMessageRequest(device, cmdXml.toString(), null, SipUtils.getNewFromTag(), null,sipSender.getNewCallIdHeader(sipLayer.getLocalIp(device.getLocalIp()),device.getTransport())); | 
|---|
|  |  |  | sipSender.transmitRequest(sipLayer.getLocalIp(device.getLocalIp()), request, errorEvent); | 
|---|
|  |  |  | sipSender.transmitRequest(sipLayer.getLocalIp(device.getLocalIp()), request, errorEvent,okEvent); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | 
|---|
|  |  |  | cmdXml.append("</Query>\r\n"); | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | Request request = headerProvider.createMessageRequest(device, cmdXml.toString(), null, SipUtils.getNewFromTag(), null,sipSender.getNewCallIdHeader(sipLayer.getLocalIp(device.getLocalIp()),device.getTransport())); | 
|---|
|  |  |  | sipSender.transmitRequest(sipLayer.getLocalIp(device.getLocalIp()), request, errorEvent); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | CallIdHeader callIdHeader; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if (requestOld != null) { | 
|---|
|  |  |  | callIdHeader = sipLayer.getSipFactory().createHeaderFactory().createCallIdHeader(requestOld.getCallIdHeader().getCallId()); | 
|---|
|  |  |  | callIdHeader = SipFactory.getInstance().createHeaderFactory().createCallIdHeader(requestOld.getCallIdHeader().getCallId()); | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | callIdHeader = sipSender.getNewCallIdHeader(sipLayer.getLocalIp(device.getLocalIp()),device.getTransport()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | * @return true = 命令发送成功 | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public void alarmSubscribe(Device device, int expires, String startPriority, String endPriority, String alarmMethod, String alarmType, String startTime, String endTime) throws InvalidArgumentException, SipException, ParseException { | 
|---|
|  |  |  | public void alarmSubscribe(Device device, int expires, String startPriority, String endPriority, String alarmMethod, String startTime, String endTime) throws InvalidArgumentException, SipException, ParseException { | 
|---|
|  |  |  |  | 
|---|
|  |  |  | StringBuffer cmdXml = new StringBuffer(200); | 
|---|
|  |  |  | String charset = device.getCharset(); | 
|---|
|  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (!ObjectUtils.isEmpty(alarmMethod)) { | 
|---|
|  |  |  | cmdXml.append("<AlarmMethod>" + alarmMethod + "</AlarmMethod>\r\n"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (!ObjectUtils.isEmpty(alarmType)) { | 
|---|
|  |  |  | cmdXml.append("<AlarmType>" + alarmType + "</AlarmType>\r\n"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (!ObjectUtils.isEmpty(startTime)) { | 
|---|
|  |  |  | cmdXml.append("<StartAlarmTime>" + startTime + "</StartAlarmTime>\r\n"); | 
|---|
|  |  |  | 
|---|
|  |  |  | CallIdHeader callIdHeader; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if (requestOld != null) { | 
|---|
|  |  |  | callIdHeader = sipLayer.getSipFactory().createHeaderFactory().createCallIdHeader(requestOld.getCallIdHeader().getCallId()); | 
|---|
|  |  |  | callIdHeader = SipFactory.getInstance().createHeaderFactory().createCallIdHeader(requestOld.getCallIdHeader().getCallId()); | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | callIdHeader = sipSender.getNewCallIdHeader(sipLayer.getLocalIp(device.getLocalIp()),device.getTransport()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | logger.debug("拉框信令: " + request.toString()); | 
|---|
|  |  |  | sipSender.transmitRequest(sipLayer.getLocalIp(device.getLocalIp()),request); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | 
|---|
|  |  |  | if (device == null) { | 
|---|
|  |  |  | return; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | logger.info("[发送 报警通知] {}/{}->{},{}", device.getDeviceId(), deviceAlarm.getChannelId(), | 
|---|
|  |  |  | logger.info("[发送报警通知]设备: {}/{}->{},{}", device.getDeviceId(), deviceAlarm.getChannelId(), | 
|---|
|  |  |  | deviceAlarm.getLongitude(), deviceAlarm.getLatitude()); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | String characterSet = device.getCharset(); | 
|---|
|  |  |  | 
|---|
|  |  |  | deviceStatusXml.append("<DeviceID>" + deviceAlarm.getChannelId() + "</DeviceID>\r\n"); | 
|---|
|  |  |  | deviceStatusXml.append("<AlarmPriority>" + deviceAlarm.getAlarmPriority() + "</AlarmPriority>\r\n"); | 
|---|
|  |  |  | deviceStatusXml.append("<AlarmMethod>" + deviceAlarm.getAlarmMethod() + "</AlarmMethod>\r\n"); | 
|---|
|  |  |  | deviceStatusXml.append("<AlarmTime>" + deviceAlarm.getAlarmTime() + "</AlarmTime>\r\n"); | 
|---|
|  |  |  | deviceStatusXml.append("<AlarmTime>" + DateUtil.yyyy_MM_dd_HH_mm_ssToISO8601(deviceAlarm.getAlarmTime()) + "</AlarmTime>\r\n"); | 
|---|
|  |  |  | deviceStatusXml.append("<AlarmDescription>" + deviceAlarm.getAlarmDescription() + "</AlarmDescription>\r\n"); | 
|---|
|  |  |  | deviceStatusXml.append("<Longitude>" + deviceAlarm.getLongitude() + "</Longitude>\r\n"); | 
|---|
|  |  |  | deviceStatusXml.append("<Latitude>" + deviceAlarm.getLatitude() + "</Latitude>\r\n"); | 
|---|