mirror of
https://github.com/ZLMediaKit/ZLMediaKit.git
synced 2024-11-30 07:26:53 +08:00
c72cf4cbcc
* feat: remove using namespace mediakit in header files. (cherry picked from commit d44aeb339a8a0e1f0455be82b21fe4b1b536299f) * feat: remove using namespace mediakit in FFmpegSource.h * feat: remove using namespace mediakit in RtpExt.h * feat: remove using namespace mediakit in header files. * feat: remove using namespace std in header files. * feat: remove using namespace std in header files when zltoolkit remove std in header * 补充命名空间 * 整理命名空间 * 整理命名空间2 * 修复macos ci * 修复编译问题 * 修复编译问题2 * 修复编译问题3 Co-authored-by: Johnny <hellojinqiang@gmail.com> Co-authored-by: Xiaofeng Wang <wasphin@gmail.com>
166 lines
7.0 KiB
C++
166 lines
7.0 KiB
C++
/*
|
|
* Copyright (c) 2016 The ZLMediaKit project authors. All Rights Reserved.
|
|
*
|
|
* This file is part of ZLMediaKit(https://github.com/xia-chu/ZLMediaKit).
|
|
*
|
|
* Use of this source code is governed by MIT license that can be found in the
|
|
* LICENSE file in the root of the source tree. All contributing project authors
|
|
* may be found in the AUTHORS file in the root of the source tree.
|
|
*/
|
|
|
|
#include "mk_events.h"
|
|
#include "Common/config.h"
|
|
#include "Common/MediaSource.h"
|
|
#include "Http/HttpSession.h"
|
|
#include "Rtsp/RtspSession.h"
|
|
#include "Record/MP4Recorder.h"
|
|
|
|
using namespace toolkit;
|
|
using namespace mediakit;
|
|
|
|
static void* s_tag;
|
|
static mk_events s_events = {0};
|
|
|
|
API_EXPORT void API_CALL mk_events_listen(const mk_events *events){
|
|
if (events) {
|
|
memcpy(&s_events, events, sizeof(s_events));
|
|
} else {
|
|
memset(&s_events, 0, sizeof(s_events));
|
|
}
|
|
|
|
static onceToken token([]{
|
|
NoticeCenter::Instance().addListener(&s_tag,Broadcast::kBroadcastMediaChanged,[](BroadcastMediaChangedArgs){
|
|
if(s_events.on_mk_media_changed){
|
|
s_events.on_mk_media_changed(bRegist,
|
|
(mk_media_source)&sender);
|
|
}
|
|
});
|
|
|
|
NoticeCenter::Instance().addListener(&s_tag,Broadcast::kBroadcastRecordMP4,[](BroadcastRecordMP4Args){
|
|
if(s_events.on_mk_record_mp4){
|
|
s_events.on_mk_record_mp4((mk_mp4_info)&info);
|
|
}
|
|
});
|
|
|
|
NoticeCenter::Instance().addListener(&s_tag,Broadcast::kBroadcastHttpRequest,[](BroadcastHttpRequestArgs){
|
|
if(s_events.on_mk_http_request){
|
|
int consumed_int = consumed;
|
|
s_events.on_mk_http_request((mk_parser)&parser,
|
|
(mk_http_response_invoker)&invoker,
|
|
&consumed_int,
|
|
(mk_sock_info)&sender);
|
|
consumed = consumed_int;
|
|
}
|
|
});
|
|
|
|
NoticeCenter::Instance().addListener(&s_tag,Broadcast::kBroadcastHttpAccess,[](BroadcastHttpAccessArgs){
|
|
if(s_events.on_mk_http_access){
|
|
s_events.on_mk_http_access((mk_parser)&parser,
|
|
path.c_str(),
|
|
is_dir,
|
|
(mk_http_access_path_invoker)&invoker,
|
|
(mk_sock_info)&sender);
|
|
} else{
|
|
invoker("","",0);
|
|
}
|
|
});
|
|
|
|
NoticeCenter::Instance().addListener(&s_tag,Broadcast::kBroadcastHttpBeforeAccess,[](BroadcastHttpBeforeAccessArgs){
|
|
if(s_events.on_mk_http_before_access){
|
|
char path_c[4 * 1024] = {0};
|
|
strcpy(path_c,path.c_str());
|
|
s_events.on_mk_http_before_access((mk_parser) &parser,
|
|
path_c,
|
|
(mk_sock_info) &sender);
|
|
path = path_c;
|
|
}
|
|
});
|
|
|
|
|
|
NoticeCenter::Instance().addListener(&s_tag,Broadcast::kBroadcastOnGetRtspRealm,[](BroadcastOnGetRtspRealmArgs){
|
|
if (s_events.on_mk_rtsp_get_realm) {
|
|
s_events.on_mk_rtsp_get_realm((mk_media_info) &args,
|
|
(mk_rtsp_get_realm_invoker) &invoker,
|
|
(mk_sock_info) &sender);
|
|
}else{
|
|
invoker("");
|
|
}
|
|
});
|
|
|
|
NoticeCenter::Instance().addListener(&s_tag,Broadcast::kBroadcastOnRtspAuth,[](BroadcastOnRtspAuthArgs){
|
|
if (s_events.on_mk_rtsp_auth) {
|
|
s_events.on_mk_rtsp_auth((mk_media_info) &args,
|
|
realm.c_str(),
|
|
user_name.c_str(),
|
|
must_no_encrypt,
|
|
(mk_rtsp_auth_invoker) &invoker,
|
|
(mk_sock_info) &sender);
|
|
}
|
|
});
|
|
|
|
NoticeCenter::Instance().addListener(&s_tag,Broadcast::kBroadcastMediaPublish,[](BroadcastMediaPublishArgs){
|
|
if (s_events.on_mk_media_publish) {
|
|
s_events.on_mk_media_publish((mk_media_info) &args,
|
|
(mk_publish_auth_invoker) &invoker,
|
|
(mk_sock_info) &sender);
|
|
} else {
|
|
GET_CONFIG(bool, toHls, General::kPublishToHls);
|
|
GET_CONFIG(bool, toMP4, General::kPublishToMP4);
|
|
invoker("", toHls, toMP4);
|
|
}
|
|
});
|
|
|
|
NoticeCenter::Instance().addListener(&s_tag,Broadcast::kBroadcastMediaPlayed,[](BroadcastMediaPlayedArgs){
|
|
if (s_events.on_mk_media_play) {
|
|
s_events.on_mk_media_play((mk_media_info) &args,
|
|
(mk_auth_invoker) &invoker,
|
|
(mk_sock_info) &sender);
|
|
}else{
|
|
invoker("");
|
|
}
|
|
});
|
|
|
|
NoticeCenter::Instance().addListener(&s_tag,Broadcast::kBroadcastShellLogin,[](BroadcastShellLoginArgs){
|
|
if (s_events.on_mk_shell_login) {
|
|
s_events.on_mk_shell_login(user_name.c_str(),
|
|
passwd.c_str(),
|
|
(mk_auth_invoker) &invoker,
|
|
(mk_sock_info) &sender);
|
|
}else{
|
|
invoker("");
|
|
}
|
|
});
|
|
|
|
NoticeCenter::Instance().addListener(&s_tag,Broadcast::kBroadcastFlowReport,[](BroadcastFlowReportArgs){
|
|
if (s_events.on_mk_flow_report) {
|
|
s_events.on_mk_flow_report((mk_media_info) &args,
|
|
totalBytes,
|
|
totalDuration,
|
|
isPlayer,
|
|
(mk_sock_info)&sender);
|
|
}
|
|
});
|
|
|
|
NoticeCenter::Instance().addListener(&s_tag,Broadcast::kBroadcastNotFoundStream,[](BroadcastNotFoundStreamArgs){
|
|
if (s_events.on_mk_media_not_found) {
|
|
s_events.on_mk_media_not_found((mk_media_info) &args,
|
|
(mk_sock_info) &sender);
|
|
}
|
|
});
|
|
|
|
NoticeCenter::Instance().addListener(&s_tag,Broadcast::kBroadcastStreamNoneReader,[](BroadcastStreamNoneReaderArgs){
|
|
if (s_events.on_mk_media_no_reader) {
|
|
s_events.on_mk_media_no_reader((mk_media_source) &sender);
|
|
}
|
|
});
|
|
|
|
NoticeCenter::Instance().addListener(&s_tag, EventChannel::kBroadcastLogEvent,[](BroadcastLogEventArgs){
|
|
if (s_events.on_mk_log) {
|
|
auto log = ctx->str();
|
|
s_events.on_mk_log((int) ctx->_level, ctx->_file.data(), ctx->_line, ctx->_function.data(), log.data());
|
|
}
|
|
});
|
|
});
|
|
|
|
}
|