|
|
@@ -4,13 +4,16 @@ import java.math.BigInteger;
|
|
|
import java.text.DecimalFormat;
|
|
|
import java.util.ArrayList;
|
|
|
import java.util.List;
|
|
|
+import java.util.UUID;
|
|
|
|
|
|
import com.alibaba.fastjson.JSON;
|
|
|
import com.alibaba.fastjson.JSONArray;
|
|
|
import com.genersoft.iot.vmp.common.StreamInfo;
|
|
|
import com.genersoft.iot.vmp.conf.MediaServerConfig;
|
|
|
+import com.genersoft.iot.vmp.gb28181.bean.Device;
|
|
|
import com.genersoft.iot.vmp.storager.IVideoManagerStorager;
|
|
|
import com.genersoft.iot.vmp.utils.IpUtil;
|
|
|
+import com.genersoft.iot.vmp.vmanager.service.IPlayService;
|
|
|
import org.slf4j.Logger;
|
|
|
import org.slf4j.LoggerFactory;
|
|
|
import org.springframework.beans.factory.annotation.Autowired;
|
|
|
@@ -43,6 +46,9 @@ public class ZLMHttpHookListener {
|
|
|
@Autowired
|
|
|
private SIPCommander cmder;
|
|
|
|
|
|
+ @Autowired
|
|
|
+ private IPlayService playService;
|
|
|
+
|
|
|
@Autowired
|
|
|
private IVideoManagerStorager storager;
|
|
|
|
|
|
@@ -52,6 +58,9 @@ public class ZLMHttpHookListener {
|
|
|
@Autowired
|
|
|
private ZLMHttpHookSubscribe subscribe;
|
|
|
|
|
|
+ @Value("${media.autoApplyPlay}")
|
|
|
+ private boolean autoApplyPlay;
|
|
|
+
|
|
|
@Value("${media.ip}")
|
|
|
private String mediaIp;
|
|
|
|
|
|
@@ -135,34 +144,6 @@ public class ZLMHttpHookListener {
|
|
|
ZLMHttpHookSubscribe.Event subscribe = this.subscribe.getSubscribe(ZLMHttpHookSubscribe.HookType.on_publish, json);
|
|
|
if (subscribe != null) subscribe.response(json);
|
|
|
|
|
|
-// if ("rtp".equals(app)) {
|
|
|
-// String ssrc = new DecimalFormat("0000000000").format(Integer.parseInt(streamId, 16));
|
|
|
-// StreamInfo streamInfoForPlay = storager.queryPlayBySSRC(ssrc);
|
|
|
-// if ("rtp".equals(app) && streamInfoForPlay != null ) {
|
|
|
-// MediaServerConfig mediaInfo = storager.getMediaInfo();
|
|
|
-// streamInfoForPlay.setFlv(String.format("http://%s:%s/rtp/%s.flv", mediaInfo.getWanIp(), mediaInfo.getHttpPort(), streamId));
|
|
|
-// streamInfoForPlay.setWs_flv(String.format("ws://%s:%s/rtp/%s.flv", mediaInfo.getWanIp(), mediaInfo.getHttpPort(), streamId));
|
|
|
-// streamInfoForPlay.setFmp4(String.format("http://%s:%s/rtp/%s.live.mp4", mediaInfo.getWanIp(), mediaInfo.getHttpPort(), streamId));
|
|
|
-// streamInfoForPlay.setWs_fmp4(String.format("ws://%s:%s/rtp/%s.live.mp4", mediaInfo.getWanIp(), mediaInfo.getHttpPort(), streamId));
|
|
|
-// streamInfoForPlay.setRtmp(String.format("rtmp://%s:%s/rtp/%s", mediaInfo.getWanIp(), mediaInfo.getRtmpPort(), streamId));
|
|
|
-// streamInfoForPlay.setHls(String.format("http://%s:%s/rtp/%s/hls.m3u8", mediaInfo.getWanIp(), mediaInfo.getHttpPort(), streamId));
|
|
|
-// streamInfoForPlay.setRtsp(String.format("rtsp://%s:%s/rtp/%s", mediaInfo.getWanIp(), mediaInfo.getRtspPort(), streamId));
|
|
|
-// storager.startPlay(streamInfoForPlay);
|
|
|
-// }
|
|
|
-//
|
|
|
-// StreamInfo streamInfoForPlayBack = storager.queryPlaybackBySSRC(ssrc);
|
|
|
-// if ("rtp".equals(app) && streamInfoForPlayBack != null ) {
|
|
|
-// MediaServerConfig mediaInfo = storager.getMediaInfo();
|
|
|
-// streamInfoForPlayBack.setFlv(String.format("http://%s:%s/rtp/%s.flv", mediaInfo.getWanIp(), mediaInfo.getHttpPort(), streamId));
|
|
|
-// streamInfoForPlayBack.setWs_flv(String.format("ws://%s:%s/rtp/%s.flv", mediaInfo.getWanIp(), mediaInfo.getHttpPort(), streamId));
|
|
|
-// streamInfoForPlayBack.setFmp4(String.format("http://%s:%s/rtp/%s.live.mp4", mediaInfo.getWanIp(), mediaInfo.getHttpPort(), streamId));
|
|
|
-// streamInfoForPlayBack.setWs_fmp4(String.format("ws://%s:%s/rtp/%s.live.mp4", mediaInfo.getWanIp(), mediaInfo.getHttpPort(), streamId));
|
|
|
-// streamInfoForPlayBack.setRtmp(String.format("rtmp://%s:%s/rtp/%s", mediaInfo.getWanIp(), mediaInfo.getRtmpPort(), streamId));
|
|
|
-// streamInfoForPlayBack.setHls(String.format("http://%s:%s/rtp/%s/hls.m3u8", mediaInfo.getWanIp(), mediaInfo.getHttpPort(), streamId));
|
|
|
-// streamInfoForPlayBack.setRtsp(String.format("rtsp://%s:%s/rtp/%s", mediaInfo.getWanIp(), mediaInfo.getRtspPort(), streamId));
|
|
|
-// storager.startPlayback(streamInfoForPlayBack);
|
|
|
-// }
|
|
|
-// }
|
|
|
|
|
|
// TODO Auto-generated method stub
|
|
|
|
|
|
@@ -268,14 +249,12 @@ public class ZLMHttpHookListener {
|
|
|
String app = json.getString("app");
|
|
|
String streamId = json.getString("stream");
|
|
|
boolean regist = json.getBoolean("regist");
|
|
|
-// String ssrc = String.format("%10d", Integer.parseInt(streamId, 16)); // ZLM 要求大写且首位补零
|
|
|
- String ssrc = new DecimalFormat("0000000000").format(Integer.parseInt(streamId, 16));
|
|
|
- StreamInfo streamInfo = storager.queryPlayBySSRC(ssrc);
|
|
|
+ StreamInfo streamInfo = storager.queryPlayByStreamId(streamId);
|
|
|
if ("rtp".equals(app) && !regist ) {
|
|
|
if (streamInfo!=null){
|
|
|
storager.stopPlay(streamInfo);
|
|
|
}else{
|
|
|
- streamInfo = storager.queryPlaybackBySSRC(ssrc);
|
|
|
+ streamInfo = storager.queryPlaybackByStreamId(streamId);
|
|
|
storager.stopPlayback(streamInfo);
|
|
|
}
|
|
|
}
|
|
|
@@ -299,16 +278,14 @@ public class ZLMHttpHookListener {
|
|
|
logger.debug("ZLM HOOK on_stream_none_reader API调用,参数:" + json.toString());
|
|
|
}
|
|
|
|
|
|
- BigInteger bigint=new BigInteger(json.getString("stream"), 16);
|
|
|
- int numb=bigint.intValue();
|
|
|
- String ssrc = String.format("%010d", numb);
|
|
|
-
|
|
|
- cmder.streamByeCmd(ssrc);
|
|
|
- StreamInfo streamInfo = storager.queryPlayBySSRC(ssrc);
|
|
|
+ String streamId = json.getString("stream");
|
|
|
+
|
|
|
+ cmder.streamByeCmd(streamId);
|
|
|
+ StreamInfo streamInfo = storager.queryPlayByStreamId(streamId);
|
|
|
if (streamInfo!=null){
|
|
|
storager.stopPlay(streamInfo);
|
|
|
}else{
|
|
|
- streamInfo = storager.queryPlaybackBySSRC(ssrc);
|
|
|
+ streamInfo = storager.queryPlaybackByStreamId(streamId);
|
|
|
storager.stopPlayback(streamInfo);
|
|
|
}
|
|
|
|
|
|
@@ -330,7 +307,30 @@ public class ZLMHttpHookListener {
|
|
|
logger.debug("ZLM HOOK on_stream_not_found API调用,参数:" + json.toString());
|
|
|
}
|
|
|
// TODO Auto-generated method stub
|
|
|
-
|
|
|
+
|
|
|
+ if (autoApplyPlay) {
|
|
|
+ String app = json.getString("app");
|
|
|
+ String streamId = json.getString("stream");
|
|
|
+ if ("rtp".equals(app) && streamId.indexOf("gb_play") > -1) {
|
|
|
+ String[] s = streamId.split("_");
|
|
|
+ if (s.length == 4) {
|
|
|
+ String deviceId = s[2];
|
|
|
+ String channelId = s[3];
|
|
|
+ Device device = storager.queryVideoDevice(deviceId);
|
|
|
+ if (device != null) {
|
|
|
+ UUID uuid = UUID.randomUUID();
|
|
|
+ cmder.playStreamCmd(device, channelId, (JSONObject response) -> {
|
|
|
+ logger.info("收到订阅消息: " + response.toJSONString());
|
|
|
+ playService.onPublishHandlerForPlay(response, deviceId, channelId, uuid.toString());
|
|
|
+ });
|
|
|
+ }
|
|
|
+
|
|
|
+ }
|
|
|
+
|
|
|
+ }
|
|
|
+
|
|
|
+ }
|
|
|
+
|
|
|
JSONObject ret = new JSONObject();
|
|
|
ret.put("code", 0);
|
|
|
ret.put("msg", "success");
|