diff options
Diffstat (limited to 'src/output/httpd_internal.h')
-rw-r--r-- | src/output/httpd_internal.h | 112 |
1 files changed, 112 insertions, 0 deletions
diff --git a/src/output/httpd_internal.h b/src/output/httpd_internal.h new file mode 100644 index 000000000..d19909c83 --- /dev/null +++ b/src/output/httpd_internal.h @@ -0,0 +1,112 @@ +/* + * Copyright (C) 2003-2009 The Music Player Daemon Project + * http://www.musicpd.org + * + * This program is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation; either version 2 of the License, or + * (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License along + * with this program; if not, write to the Free Software Foundation, Inc., + * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. + */ + +/** \file + * + * Internal declarations for the "httpd" audio output plugin. + */ + +#ifndef MPD_OUTPUT_HTTPD_INTERNAL_H +#define MPD_OUTPUT_HTTPD_INTERNAL_H + +#include "timer.h" + +#include <glib.h> + +#include <sys/socket.h> + +struct httpd_client; + +struct httpd_output { + /** + * The configured encoder plugin. + */ + struct encoder *encoder; + + /** + * The MIME type produced by the #encoder. + */ + const char *content_type; + + /** + * The configured address of the listener socket. + */ + struct sockaddr_storage address; + + /** + * The size of #address. + */ + socklen_t address_size; + + /** + * This mutex protects the listener socket and the client + * list. + */ + GMutex *mutex; + + /** + * A #Timer object to synchronize this output with the + * wallclock. + */ + Timer *timer; + + /** + * The listener socket. + */ + int fd; + + /** + * A GLib main loop source id for the listener socket. + */ + guint source_id; + + /** + * The header page, which is sent to every client on connect. + */ + struct page *header; + + /** + * A linked list containing all clients which are currently + * connected. + */ + GList *clients; + + /** + * A temporary buffer for the httpd_output_read_page() + * function. + */ + char buffer[32768]; +}; + +/** + * Removes a client from the httpd_output.clients linked list. + */ +void +httpd_output_remove_client(struct httpd_output *httpd, + struct httpd_client *client); + +/** + * Sends the encoder header to the client. This is called right after + * the response headers have been sent. + */ +void +httpd_output_send_header(struct httpd_output *httpd, + struct httpd_client *client); + +#endif |