mirror of
https://github.com/ZLMediaKit/ZLMediaKit.git
synced 2026-06-14 12:05:58 +08:00
整理MediaSource代码
This commit is contained in:
@@ -16,39 +16,35 @@ class CMD_media: public CMD {
|
||||
public:
|
||||
CMD_media(){
|
||||
_parser.reset(new OptionParser([](const std::shared_ptr<ostream> &stream,mINI &ini){
|
||||
MediaSource::for_each_media([&](const string &schema,
|
||||
const string &vhost,
|
||||
const string &app,
|
||||
const string &streamid,
|
||||
const MediaSource::Ptr &media){
|
||||
if(!ini["schema"].empty() && ini["schema"] != schema){
|
||||
MediaSource::for_each_media([&](const MediaSource::Ptr &media){
|
||||
if(!ini["schema"].empty() && ini["schema"] != media->getSchema()){
|
||||
//筛选协议不匹配
|
||||
return;
|
||||
}
|
||||
if(!ini["vhost"].empty() && ini["vhost"] != vhost){
|
||||
if(!ini["vhost"].empty() && ini["vhost"] != media->getVhost()){
|
||||
//筛选虚拟主机不匹配
|
||||
return;
|
||||
}
|
||||
if(!ini["app"].empty() && ini["app"] != app){
|
||||
if(!ini["app"].empty() && ini["app"] != media->getApp()){
|
||||
//筛选应用名不匹配
|
||||
return;
|
||||
}
|
||||
if(!ini["stream"].empty() && ini["stream"] != streamid){
|
||||
if(!ini["stream"].empty() && ini["stream"] != media->getId()){
|
||||
//流id不匹配
|
||||
return;
|
||||
}
|
||||
if(ini.find("list") != ini.end()){
|
||||
//列出源
|
||||
(*stream) << "\t"
|
||||
<< schema << "/"
|
||||
<< vhost << "/"
|
||||
<< app << "/"
|
||||
<< streamid
|
||||
<< media->getSchema() << "/"
|
||||
<< media->getVhost() << "/"
|
||||
<< media->getApp() << "/"
|
||||
<< media->getId()
|
||||
<< "\r\n";
|
||||
return;
|
||||
}
|
||||
|
||||
EventPollerPool::Instance().getPoller()->async([ini,media,stream,schema,vhost,app,streamid](){
|
||||
EventPollerPool::Instance().getPoller()->async([ini,media,stream](){
|
||||
if(ini.find("kick") != ini.end()){
|
||||
//踢出源
|
||||
do{
|
||||
@@ -59,18 +55,18 @@ public:
|
||||
break;
|
||||
}
|
||||
(*stream) << "\t踢出成功:"
|
||||
<< schema << "/"
|
||||
<< vhost << "/"
|
||||
<< app << "/"
|
||||
<< streamid
|
||||
<< media->getSchema() << "/"
|
||||
<< media->getVhost() << "/"
|
||||
<< media->getApp() << "/"
|
||||
<< media->getId()
|
||||
<< "\r\n";
|
||||
return;
|
||||
}while(0);
|
||||
(*stream) << "\t踢出失败:"
|
||||
<< schema << "/"
|
||||
<< vhost << "/"
|
||||
<< app << "/"
|
||||
<< streamid
|
||||
<< media->getSchema() << "/"
|
||||
<< media->getVhost() << "/"
|
||||
<< media->getApp() << "/"
|
||||
<< media->getId()
|
||||
<< "\r\n";
|
||||
}
|
||||
},false);
|
||||
|
||||
Reference in New Issue
Block a user