mirror of
https://github.com/owntone/owntone-server.git
synced 2025-01-24 13:13:17 -05:00
[streaming] Remove timeout for mpeg stream requests
Remove the need for clients to regularly reconnect to the mp3 stream. As long as the connection is open, we are sending mp3 stream data.
This commit is contained in:
parent
98421aae4d
commit
7a2ba572f8
@ -46,8 +46,6 @@ extern struct event_base *evbase_httpd;
|
|||||||
#define STREAMING_SILENCE_INTERVAL 1
|
#define STREAMING_SILENCE_INTERVAL 1
|
||||||
// Buffer size for transmitting from player to httpd thread
|
// Buffer size for transmitting from player to httpd thread
|
||||||
#define STREAMING_RAWBUF_SIZE (STOB(AIRTUNES_V2_PACKET_SAMPLES))
|
#define STREAMING_RAWBUF_SIZE (STOB(AIRTUNES_V2_PACKET_SAMPLES))
|
||||||
// Should prevent that we keep transcoding to dead connections
|
|
||||||
#define STREAMING_CONNECTION_TIMEOUT 60
|
|
||||||
|
|
||||||
// Linked list of mp3 streaming requests
|
// Linked list of mp3 streaming requests
|
||||||
struct streaming_session {
|
struct streaming_session {
|
||||||
@ -74,6 +72,7 @@ static struct player_status streaming_player_status;
|
|||||||
static int streaming_player_changed;
|
static int streaming_player_changed;
|
||||||
static int streaming_pipe[2];
|
static int streaming_pipe[2];
|
||||||
|
|
||||||
|
|
||||||
static void
|
static void
|
||||||
streaming_fail_cb(struct evhttp_connection *evcon, void *arg)
|
streaming_fail_cb(struct evhttp_connection *evcon, void *arg)
|
||||||
{
|
{
|
||||||
@ -243,6 +242,8 @@ streaming_request(struct evhttp_request *req, struct httpd_uri_parsed *uri_parse
|
|||||||
evhttp_add_header(output_headers, "Pragma", "no-cache");
|
evhttp_add_header(output_headers, "Pragma", "no-cache");
|
||||||
evhttp_add_header(output_headers, "Expires", "Mon, 31 Aug 2015 06:00:00 GMT");
|
evhttp_add_header(output_headers, "Expires", "Mon, 31 Aug 2015 06:00:00 GMT");
|
||||||
evhttp_add_header(output_headers, "icy-name", name);
|
evhttp_add_header(output_headers, "icy-name", name);
|
||||||
|
evhttp_add_header(output_headers, "Access-Control-Allow-Origin", "*");
|
||||||
|
evhttp_add_header(output_headers, "Access-Control-Allow-Methods", "GET, POST, PUT, DELETE, OPTIONS");
|
||||||
|
|
||||||
// TODO ICY metaint
|
// TODO ICY metaint
|
||||||
evhttp_send_reply_start(req, HTTP_OK, "OK");
|
evhttp_send_reply_start(req, HTTP_OK, "OK");
|
||||||
@ -263,7 +264,6 @@ streaming_request(struct evhttp_request *req, struct httpd_uri_parsed *uri_parse
|
|||||||
session->next = streaming_sessions;
|
session->next = streaming_sessions;
|
||||||
streaming_sessions = session;
|
streaming_sessions = session;
|
||||||
|
|
||||||
evhttp_connection_set_timeout(evcon, STREAMING_CONNECTION_TIMEOUT);
|
|
||||||
evhttp_connection_set_closecb(evcon, streaming_fail_cb, session);
|
evhttp_connection_set_closecb(evcon, streaming_fail_cb, session);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user