添加踢出推流器功能

This commit is contained in:
xiongziliang 2018-02-06 10:56:58 +08:00
parent cf8b6f6b91
commit 4f072eb36a
6 changed files with 49 additions and 9 deletions

View File

@ -55,11 +55,17 @@ public:
virtual ~MediaSourceEvent(){}; virtual ~MediaSourceEvent(){};
public: public:
virtual bool seekTo(uint32_t ui32Stamp){ virtual bool seekTo(uint32_t ui32Stamp){
//拖动进度条
return false; return false;
} }
virtual uint32_t getStamp() { virtual uint32_t getStamp() {
//获取时间戳
return 0; return 0;
} }
virtual bool shutDown() {
//通知其停止推流
return false;
}
}; };
class MediaInfo class MediaInfo
{ {
@ -151,9 +157,30 @@ public:
} }
return listener->getStamp(); return listener->getStamp();
} }
bool shutDown() {
auto listener = m_listener.lock();
if(!listener){
return false;
}
return listener->shutDown();
}
void setListener(const std::weak_ptr<MediaSourceEvent> &listener){ void setListener(const std::weak_ptr<MediaSourceEvent> &listener){
m_listener = listener; m_listener = listener;
} }
template <typename FUN>
static void for_each_media(FUN && fun){
lock_guard<recursive_mutex> lock(g_mtxMediaSrc);
for (auto &pr0 : g_mapMediaSrc){
for(auto &pr1 : pr0.second){
for(auto &pr2 : pr1.second){
for(auto &pr3 : pr2.second){
fun(pr0.first,pr1.first,pr2.first,pr3.first,pr3.second.lock());
}
}
}
}
}
private: private:
template <typename FUN> template <typename FUN>
static bool searchMedia(const string &schema, static bool searchMedia(const string &schema,
@ -195,6 +222,7 @@ private:
} }
} }
}; };
void unregisted(); void unregisted();
protected: protected:
std::weak_ptr<MediaSourceEvent> m_listener; std::weak_ptr<MediaSourceEvent> m_listener;

View File

@ -181,6 +181,10 @@ void MediaReader::startReadMP4() {
uint32_t MediaReader::getStamp() { uint32_t MediaReader::getStamp() {
return m_iSeekTime + m_ticker.elapsedTime(); return m_iSeekTime + m_ticker.elapsedTime();
} }
bool MediaReader::shutDown(){
AsyncTaskThread::Instance().CancelTask(reinterpret_cast<uint64_t>(this));
return true;
}
bool MediaReader::readSample(int iTimeInc) { bool MediaReader::readSample(int iTimeInc) {
TimeTicker(); TimeTicker();

View File

@ -51,6 +51,7 @@ public:
public: public:
bool seekTo(uint32_t ui32Stamp) override; bool seekTo(uint32_t ui32Stamp) override;
uint32_t getStamp() override; uint32_t getStamp() override;
bool shutDown() override;
private: private:
#ifdef ENABLE_MP4V2 #ifdef ENABLE_MP4V2

View File

@ -145,7 +145,7 @@ void RtmpSession::onCmd_publish(AMFDecoder &dec) {
sendReply("onStatus", nullptr, status); sendReply("onStatus", nullptr, status);
if (!ok) { if (!ok) {
WarnL << "onPublish:" WarnL << "onPublish:"
<< (authSuccess ? "Already publishing:" : err.data()) << (authSuccess ? "Already publishing:" : err.data()) << " "
<< m_mediaInfo.m_vhost << " " << m_mediaInfo.m_vhost << " "
<< m_mediaInfo.m_app << " " << m_mediaInfo.m_app << " "
<< m_mediaInfo.m_streamid << endl; << m_mediaInfo.m_streamid << endl;
@ -154,6 +154,7 @@ void RtmpSession::onCmd_publish(AMFDecoder &dec) {
} }
m_bPublisherSrcRegisted = false; m_bPublisherSrcRegisted = false;
m_pPublisherSrc.reset(new RtmpToRtspMediaSource(m_mediaInfo.m_vhost,m_mediaInfo.m_app,m_mediaInfo.m_streamid)); m_pPublisherSrc.reset(new RtmpToRtspMediaSource(m_mediaInfo.m_vhost,m_mediaInfo.m_app,m_mediaInfo.m_streamid));
m_pPublisherSrc->setListener(dynamic_pointer_cast<MediaSourceEvent>(shared_from_this()));
}; };
weak_ptr<RtmpSession> weakSelf = dynamic_pointer_cast<RtmpSession>(shared_from_this()); weak_ptr<RtmpSession> weakSelf = dynamic_pointer_cast<RtmpSession>(shared_from_this());
@ -213,7 +214,7 @@ void RtmpSession::doPlay(AMFDecoder &dec){
sendReply("onStatus", nullptr, status); sendReply("onStatus", nullptr, status);
if (!ok) { if (!ok) {
WarnL << "onPlayed:" WarnL << "onPlayed:"
<< (authSuccess ? "No such stream:" : err.data()) << (authSuccess ? "No such stream:" : err.data()) << " "
<< m_mediaInfo.m_vhost << " " << m_mediaInfo.m_vhost << " "
<< m_mediaInfo.m_app << " " << m_mediaInfo.m_app << " "
<< m_mediaInfo.m_streamid << m_mediaInfo.m_streamid

View File

@ -44,7 +44,7 @@ using namespace ZL::Network;
namespace ZL { namespace ZL {
namespace Rtmp { namespace Rtmp {
class RtmpSession: public TcpLimitedSession<MAX_TCP_SESSION> ,public RtmpProtocol{ class RtmpSession: public TcpLimitedSession<MAX_TCP_SESSION> ,public RtmpProtocol , public MediaSourceEvent{
public: public:
typedef std::shared_ptr<RtmpSession> Ptr; typedef std::shared_ptr<RtmpSession> Ptr;
RtmpSession(const std::shared_ptr<ThreadPool> &_th, const Socket::Ptr &_sock); RtmpSession(const std::shared_ptr<ThreadPool> &_th, const Socket::Ptr &_sock);
@ -95,6 +95,12 @@ private:
invoke << str << m_dNowReqID << reply << status; invoke << str << m_dNowReqID << reply << status;
sendResponse(MSG_CMD, invoke.data()); sendResponse(MSG_CMD, invoke.data());
} }
bool shutDown() override {
InfoL << "kick out:" << m_mediaInfo.m_vhost << " " << m_mediaInfo.m_app << " " << m_mediaInfo.m_streamid;
safeShutdown();
return true;
}
}; };
} /* namespace Rtmp */ } /* namespace Rtmp */

View File

@ -114,7 +114,7 @@ public:
auto field = FindField(line.c_str(), NULL, ": "); auto field = FindField(line.c_str(), NULL, ": ");
auto value = FindField(line.c_str(), ": ", NULL); auto value = FindField(line.c_str(), ": ", NULL);
if (field.size() != 0) { if (field.size() != 0) {
m_mapValues[field] = value; m_mapHeaders[field] = value;
} }
} }
start = start + line.size() + 2; start = start + line.size() + 2;
@ -142,8 +142,8 @@ public:
} }
const string& operator[](const char *name) const { const string& operator[](const char *name) const {
//rtsp field //rtsp field
auto it = m_mapValues.find(name); auto it = m_mapHeaders.find(name);
if (it == m_mapValues.end()) { if (it == m_mapHeaders.end()) {
return m_strNull; return m_strNull;
} }
return it->second; return it->second;
@ -157,7 +157,7 @@ public:
m_strFullUrl.clear(); m_strFullUrl.clear();
m_strTail.clear(); m_strTail.clear();
m_strContent.clear(); m_strContent.clear();
m_mapValues.clear(); m_mapHeaders.clear();
m_mapUrlArgs.clear(); m_mapUrlArgs.clear();
} }
@ -169,7 +169,7 @@ public:
} }
StrCaseMap& getValues() const { StrCaseMap& getValues() const {
return m_mapValues; return m_mapHeaders;
} }
StrCaseMap& getUrlArgs() const { StrCaseMap& getUrlArgs() const {
return m_mapUrlArgs; return m_mapUrlArgs;
@ -195,7 +195,7 @@ private:
string m_strContent; string m_strContent;
string m_strNull; string m_strNull;
string m_strFullUrl; string m_strFullUrl;
mutable StrCaseMap m_mapValues; mutable StrCaseMap m_mapHeaders;
mutable StrCaseMap m_mapUrlArgs; mutable StrCaseMap m_mapUrlArgs;
}; };