支持多WVP的推流播放

pull/1642/head
648540858 2024-08-09 17:55:39 +08:00
parent 16708e385b
commit d8d9f76d89
2 changed files with 7 additions and 5 deletions

View File

@ -174,19 +174,20 @@ public class RedisRpcController {
if (streamInfoInServer != null) { if (streamInfoInServer != null) {
log.info("[redis-rpc] 监听流上线时发现流已存在直接返回: {}/{}", streamInfo.getApp(), streamInfo.getStream()); log.info("[redis-rpc] 监听流上线时发现流已存在直接返回: {}/{}", streamInfo.getApp(), streamInfo.getStream());
RedisRpcResponse response = request.getResponse(); RedisRpcResponse response = request.getResponse();
response.setBody(streamInfoInServer); response.setBody(JSONObject.toJSONString(streamInfoInServer));
response.setStatusCode(200); response.setStatusCode(200);
return response; return response;
} }
// 监听流上线。 流上线直接发送sendRtpItem消息给实际的信令处理者 // 监听流上线。 流上线直接发送sendRtpItem消息给实际的信令处理者
Hook hook = Hook.getInstance(HookType.on_media_arrival, streamInfo.getApp(), streamInfo.getStream(), null); Hook hook = Hook.getInstance(HookType.on_media_arrival, streamInfo.getApp(), streamInfo.getStream());
hookSubscribe.addSubscribe(hook, (hookData) -> { hookSubscribe.addSubscribe(hook, (hookData) -> {
log.info("[redis-rpc] 监听流上线,流已上线: {}/{}", streamInfo.getApp(), streamInfo.getStream()); log.info("[redis-rpc] 监听流上线,流已上线: {}/{}", streamInfo.getApp(), streamInfo.getStream());
// 读取redis中的上级点播信息生成sendRtpItm发送出去 // 读取redis中的上级点播信息生成sendRtpItm发送出去
RedisRpcResponse response = request.getResponse(); RedisRpcResponse response = request.getResponse();
response.setBody(mediaServerService.getStreamInfoByAppAndStream(hookData.getMediaServer(), StreamInfo streamInfoByAppAndStream = mediaServerService.getStreamInfoByAppAndStream(hookData.getMediaServer(),
streamInfo.getApp(), streamInfo.getStream(), hookData.getMediaInfo(), streamInfo.getApp(), streamInfo.getStream(), hookData.getMediaInfo(),
hookData.getMediaInfo() != null ? hookData.getMediaInfo().getCallId() : null)); hookData.getMediaInfo() != null ? hookData.getMediaInfo().getCallId() : null);
response.setBody(JSONObject.toJSONString(streamInfoByAppAndStream));
response.setStatusCode(200); response.setStatusCode(200);
// 手动发送结果 // 手动发送结果
sendResponse(response); sendResponse(response);

View File

@ -164,6 +164,7 @@ public class RedisRpcServiceImpl implements IRedisRpcService {
streamInfoParam.setStream(stream); streamInfoParam.setStream(stream);
RedisRpcRequest request = buildRequest("onStreamOnlineEvent", streamInfoParam); RedisRpcRequest request = buildRequest("onStreamOnlineEvent", streamInfoParam);
hookSubscribe.addSubscribe(hook, (hookData) -> { hookSubscribe.addSubscribe(hook, (hookData) -> {
log.info("[请求所有WVP监听流上线] 监听流上线 {}/{}", app, stream);
if (callback != null) { if (callback != null) {
callback.run(mediaServerService.getStreamInfoByAppAndStream(hookData.getMediaServer(), callback.run(mediaServerService.getStreamInfoByAppAndStream(hookData.getMediaServer(),
app, stream, hookData.getMediaInfo(), app, stream, hookData.getMediaInfo(),
@ -181,7 +182,7 @@ public class RedisRpcServiceImpl implements IRedisRpcService {
log.info("[请求所有WVP监听流上线] 流上线 {}/{}", app, stream); log.info("[请求所有WVP监听流上线] 流上线 {}/{}", app, stream);
if (callback != null) { if (callback != null) {
callback.run((StreamInfo) response.getBody()); callback.run(JSON.parseObject(response.getBody().toString(), StreamInfo.class));
} }
hookSubscribe.removeSubscribe(hook); hookSubscribe.removeSubscribe(hook);
}); });