summaryrefslogtreecommitdiff
path: root/server
diff options
context:
space:
mode:
authorFrank Schmirler <vdr@schmirler.de>2012-11-02 09:09:15 +0100
committerFrank Schmirler <vdr@schmirler.de>2012-11-02 09:09:15 +0100
commitbe9da74958088474231b080ee1b72f2cb9d69418 (patch)
tree773d135cf8c4b0c30f7bb552187163007fbe4229 /server
parente7bcc9349c6cf4549bd845067acd7b70b655cddc (diff)
downloadvdr-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.c16
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("");
}