diff options
author | Frank Schmirler <vdr@schmirler.de> | 2012-11-02 09:09:15 +0100 |
---|---|---|
committer | Frank Schmirler <vdr@schmirler.de> | 2012-11-02 09:09:15 +0100 |
commit | be9da74958088474231b080ee1b72f2cb9d69418 (patch) | |
tree | 773d135cf8c4b0c30f7bb552187163007fbe4229 /server | |
parent | e7bcc9349c6cf4549bd845067acd7b70b655cddc (diff) | |
download | vdr-plugin-streamdev-be9da74958088474231b080ee1b72f2cb9d69418.tar.gz vdr-plugin-streamdev-be9da74958088474231b080ee1b72f2cb9d69418.tar.bz2 |
Support HTTP HEAD requests with external remuxer
Diffstat (limited to 'server')
-rw-r--r-- | server/connectionHTTP.c | 16 |
1 files changed, 11 insertions, 5 deletions
diff --git a/server/connectionHTTP.c b/server/connectionHTTP.c index d420c25..b9f98b4 100644 --- a/server/connectionHTTP.c +++ b/server/connectionHTTP.c @@ -188,34 +188,40 @@ bool cConnectionHTTP::ProcessRequest(void) && Respond(""); } } else if (it_method->second.compare("HEAD") == 0 && ProcessURI(it_pathinfo->second)) { - DeferClose(); - if (m_ChannelList) + if (m_ChannelList) { + DeferClose(); return Respond("%s", true, m_ChannelList->HttpHeader().c_str()); + } else if (m_Channel != NULL) { if (ProvidesChannel(m_Channel, StreamdevServerSetup.HTTPPriority)) { if (m_StreamType == stEXT) { - // TODO - return Respond("HTTP/1.0 200 OK") - && Respond(""); + m_LiveStreamer = new cStreamdevLiveStreamer(StreamdevServerSetup.HTTPPriority, this); + m_LiveStreamer->SetChannel(m_Channel, m_StreamType, m_Apid[0] ? m_Apid : NULL, m_Dpid[0] ? m_Dpid : NULL); + return Respond("HTTP/1.0 200 OK"); } else if (m_StreamType == stES && (m_Apid[0] || m_Dpid[0] || ISRADIO(m_Channel))) { + DeferClose(); return Respond("HTTP/1.0 200 OK") && Respond("Content-Type: audio/mpeg") && Respond("icy-name: %s", true, m_Channel->Name()) && Respond(""); } else if (ISRADIO(m_Channel)) { + DeferClose(); return Respond("HTTP/1.0 200 OK") && Respond("Content-Type: audio/mpeg") && Respond(""); } else { + DeferClose(); return Respond("HTTP/1.0 200 OK") && Respond("Content-Type: video/mpeg") && Respond(""); } } + DeferClose(); return Respond("HTTP/1.0 503 Service unavailable") && Respond(""); } else { + DeferClose(); return Respond("HTTP/1.0 404 not found") && Respond(""); } |