|
@@ -7,6 +7,7 @@ import com.genersoft.iot.vmp.common.StreamInfo;
|
|
|
import com.genersoft.iot.vmp.gb28181.bean.Device;
|
|
import com.genersoft.iot.vmp.gb28181.bean.Device;
|
|
|
import com.genersoft.iot.vmp.gb28181.bean.DeviceChannel;
|
|
import com.genersoft.iot.vmp.gb28181.bean.DeviceChannel;
|
|
|
import com.genersoft.iot.vmp.gb28181.event.SipSubscribe;
|
|
import com.genersoft.iot.vmp.gb28181.event.SipSubscribe;
|
|
|
|
|
+import com.genersoft.iot.vmp.gb28181.session.VideoStreamSessionManager;
|
|
|
import com.genersoft.iot.vmp.gb28181.transmit.callback.DeferredResultHolder;
|
|
import com.genersoft.iot.vmp.gb28181.transmit.callback.DeferredResultHolder;
|
|
|
import com.genersoft.iot.vmp.gb28181.transmit.callback.RequestMessage;
|
|
import com.genersoft.iot.vmp.gb28181.transmit.callback.RequestMessage;
|
|
|
import com.genersoft.iot.vmp.gb28181.transmit.cmd.impl.SIPCommander;
|
|
import com.genersoft.iot.vmp.gb28181.transmit.cmd.impl.SIPCommander;
|
|
@@ -17,6 +18,7 @@ import com.genersoft.iot.vmp.storager.IVideoManagerStorager;
|
|
|
import com.genersoft.iot.vmp.vmanager.gb28181.play.bean.PlayResult;
|
|
import com.genersoft.iot.vmp.vmanager.gb28181.play.bean.PlayResult;
|
|
|
import com.genersoft.iot.vmp.service.IMediaService;
|
|
import com.genersoft.iot.vmp.service.IMediaService;
|
|
|
import com.genersoft.iot.vmp.service.IPlayService;
|
|
import com.genersoft.iot.vmp.service.IPlayService;
|
|
|
|
|
+import gov.nist.javax.sip.stack.SIPDialog;
|
|
|
import org.slf4j.Logger;
|
|
import org.slf4j.Logger;
|
|
|
import org.slf4j.LoggerFactory;
|
|
import org.slf4j.LoggerFactory;
|
|
|
import org.springframework.beans.factory.annotation.Autowired;
|
|
import org.springframework.beans.factory.annotation.Autowired;
|
|
@@ -24,6 +26,9 @@ import org.springframework.http.ResponseEntity;
|
|
|
import org.springframework.stereotype.Service;
|
|
import org.springframework.stereotype.Service;
|
|
|
import org.springframework.web.context.request.async.DeferredResult;
|
|
import org.springframework.web.context.request.async.DeferredResult;
|
|
|
|
|
|
|
|
|
|
+import javax.sip.ClientTransaction;
|
|
|
|
|
+import javax.sip.Dialog;
|
|
|
|
|
+import javax.sip.header.CallIdHeader;
|
|
|
import javax.sip.message.Response;
|
|
import javax.sip.message.Response;
|
|
|
import java.util.UUID;
|
|
import java.util.UUID;
|
|
|
|
|
|
|
@@ -50,6 +55,9 @@ public class PlayServiceImpl implements IPlayService {
|
|
|
@Autowired
|
|
@Autowired
|
|
|
private IMediaService mediaService;
|
|
private IMediaService mediaService;
|
|
|
|
|
|
|
|
|
|
+ @Autowired
|
|
|
|
|
+ private VideoStreamSessionManager streamSession;
|
|
|
|
|
+
|
|
|
|
|
|
|
|
@Override
|
|
@Override
|
|
|
public PlayResult play(String deviceId, String channelId, ZLMHttpHookSubscribe.Event hookEvent, SipSubscribe.Event errorEvent) {
|
|
public PlayResult play(String deviceId, String channelId, ZLMHttpHookSubscribe.Event hookEvent, SipSubscribe.Event errorEvent) {
|
|
@@ -141,7 +149,14 @@ public class PlayServiceImpl implements IPlayService {
|
|
|
deviceChannel.setStreamId(streamInfo.getStreamId());
|
|
deviceChannel.setStreamId(streamInfo.getStreamId());
|
|
|
storager.startPlay(deviceId, channelId, streamInfo.getStreamId());
|
|
storager.startPlay(deviceId, channelId, streamInfo.getStreamId());
|
|
|
}
|
|
}
|
|
|
-
|
|
|
|
|
|
|
+ ClientTransaction transaction = streamSession.getTransaction(deviceId, channelId);
|
|
|
|
|
+ SIPDialog dialog = (SIPDialog)transaction.getDialog();
|
|
|
|
|
+ StreamInfo.TransactionInfo transactionInfo = new StreamInfo.TransactionInfo();
|
|
|
|
|
+ transactionInfo.callId = dialog.getCallId().getCallId();
|
|
|
|
|
+ transactionInfo.localTag = dialog.getLocalTag();
|
|
|
|
|
+ transactionInfo.remoteTag = dialog.getRemoteTag();
|
|
|
|
|
+ transactionInfo.branch = dialog.getFirstTransactionInt().getBranchId();
|
|
|
|
|
+ streamInfo.setTransactionInfo(transactionInfo);
|
|
|
redisCatchStorage.startPlay(streamInfo);
|
|
redisCatchStorage.startPlay(streamInfo);
|
|
|
msg.setData(JSON.toJSONString(streamInfo));
|
|
msg.setData(JSON.toJSONString(streamInfo));
|
|
|
resultHolder.invokeResult(msg);
|
|
resultHolder.invokeResult(msg);
|