audiotracy: always request the timestamp during the syncing phase
[vlc.git] / include / vlc_httpd.h
blob0b8f8c26bd9a65c22c7b7ce2dc3b921c291cf120
1 /*****************************************************************************
2 * vlc_httpd.h: builtin HTTP/RTSP server.
3 *****************************************************************************
4 * Copyright (C) 2004-2006 VLC authors and VideoLAN
6 * Authors: Laurent Aimar <fenrir@via.ecp.fr>
8 * This program is free software; you can redistribute it and/or modify it
9 * under the terms of the GNU Lesser General Public License as published by
10 * the Free Software Foundation; either version 2.1 of the License, or
11 * (at your option) any later version.
13 * This program is distributed in the hope that it will be useful,
14 * but WITHOUT ANY WARRANTY; without even the implied warranty of
15 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16 * GNU Lesser General Public License for more details.
18 * You should have received a copy of the GNU Lesser General Public License
19 * along with this program; if not, write to the Free Software Foundation,
20 * Inc., 51 Franklin Street, Fifth Floor, Boston MA 02110-1301, USA.
21 *****************************************************************************/
23 #ifndef VLC_HTTPD_H
24 #define VLC_HTTPD_H 1
26 /**
27 * \file
28 * HTTP/RTSP server API.
31 enum
33 HTTPD_MSG_NONE,
35 /* answer */
36 HTTPD_MSG_ANSWER,
38 /* http request */
39 HTTPD_MSG_GET,
40 HTTPD_MSG_HEAD,
41 HTTPD_MSG_POST,
43 /* rtsp request */
44 HTTPD_MSG_OPTIONS,
45 HTTPD_MSG_DESCRIBE,
46 HTTPD_MSG_SETUP,
47 HTTPD_MSG_PLAY,
48 HTTPD_MSG_PAUSE,
49 HTTPD_MSG_GETPARAMETER,
50 HTTPD_MSG_TEARDOWN,
52 /* just to track the count of MSG */
53 HTTPD_MSG_MAX
56 enum
58 HTTPD_PROTO_NONE,
59 HTTPD_PROTO_HTTP, /* HTTP/1.x */
60 HTTPD_PROTO_RTSP, /* RTSP/1.x */
61 HTTPD_PROTO_HTTP0, /* HTTP/0.x */
64 typedef struct httpd_host_t httpd_host_t;
65 typedef struct httpd_client_t httpd_client_t;
66 /* create a new host */
67 VLC_API httpd_host_t *vlc_http_HostNew( vlc_object_t * ) VLC_USED;
68 VLC_API httpd_host_t *vlc_https_HostNew( vlc_object_t * ) VLC_USED;
69 VLC_API httpd_host_t *vlc_rtsp_HostNew( vlc_object_t * ) VLC_USED;
70 /* delete a host */
71 VLC_API void httpd_HostDelete( httpd_host_t * );
73 typedef struct
75 char * name;
76 char * value;
77 } httpd_header;
79 typedef struct httpd_message_t
81 httpd_client_t *cl; /* NULL if not throught a connection e vlc internal */
83 uint8_t i_type;
84 uint8_t i_proto;
85 uint8_t i_version;
87 /* for an answer */
88 int i_status;
90 /* for a query */
91 char *psz_url;
92 /* FIXME find a clean way to handle GET(psz_args)
93 and POST(body) through the same code */
94 uint8_t *psz_args;
96 /* options */
97 size_t i_headers;
98 httpd_header *p_headers;
100 /* body */
101 int64_t i_body_offset;
102 int i_body;
103 uint8_t *p_body;
105 } httpd_message_t;
107 typedef struct httpd_url_t httpd_url_t;
108 typedef struct httpd_callback_sys_t httpd_callback_sys_t;
109 typedef int (*httpd_callback_t)( httpd_callback_sys_t *, httpd_client_t *, httpd_message_t *answer, const httpd_message_t *query );
110 /* register a new url */
111 VLC_API httpd_url_t * httpd_UrlNew( httpd_host_t *, const char *psz_url, const char *psz_user, const char *psz_password ) VLC_USED;
112 /* register callback on a url */
113 VLC_API int httpd_UrlCatch( httpd_url_t *, int i_msg, httpd_callback_t, httpd_callback_sys_t * );
114 /* delete a url */
115 VLC_API void httpd_UrlDelete( httpd_url_t * );
117 VLC_API char* httpd_ClientIP( const httpd_client_t *cl, char *, int * );
118 VLC_API char* httpd_ServerIP( const httpd_client_t *cl, char *, int * );
120 /* High level */
122 typedef struct httpd_file_t httpd_file_t;
123 typedef struct httpd_file_sys_t httpd_file_sys_t;
124 typedef int (*httpd_file_callback_t)( httpd_file_sys_t *, httpd_file_t *, uint8_t *psz_request, uint8_t **pp_data, int *pi_data );
125 VLC_API httpd_file_t * httpd_FileNew( httpd_host_t *, const char *psz_url, const char *psz_mime, const char *psz_user, const char *psz_password, httpd_file_callback_t pf_fill, httpd_file_sys_t * ) VLC_USED;
126 VLC_API httpd_file_sys_t * httpd_FileDelete( httpd_file_t * );
129 typedef struct httpd_handler_t httpd_handler_t;
130 typedef int (*httpd_handler_callback_t)( void *, httpd_handler_t *, char *psz_url, uint8_t *psz_request, int i_type, uint8_t *p_in, int i_in, char *psz_remote_addr, char *psz_remote_host, uint8_t **pp_data, int *pi_data );
131 VLC_API httpd_handler_t * httpd_HandlerNew( httpd_host_t *, const char *psz_url, const char *psz_user, const char *psz_password, httpd_handler_callback_t pf_fill, void * ) VLC_USED;
132 VLC_API void * httpd_HandlerDelete( httpd_handler_t * );
134 typedef struct httpd_redirect_t httpd_redirect_t;
135 VLC_API httpd_redirect_t * httpd_RedirectNew( httpd_host_t *, const char *psz_url_dst, const char *psz_url_src ) VLC_USED;
136 VLC_API void httpd_RedirectDelete( httpd_redirect_t * );
139 typedef struct httpd_stream_t httpd_stream_t;
140 VLC_API httpd_stream_t * httpd_StreamNew( httpd_host_t *, const char *psz_url, const char *psz_mime, const char *psz_user, const char *psz_password ) VLC_USED;
141 VLC_API void httpd_StreamDelete( httpd_stream_t * );
142 VLC_API int httpd_StreamHeader( httpd_stream_t *, uint8_t *p_data, int i_data );
143 VLC_API int httpd_StreamSend( httpd_stream_t *, const block_t *p_block );
144 VLC_API int httpd_StreamSetHTTPHeaders(httpd_stream_t *, const httpd_header *, size_t);
146 /* Msg functions facilities */
147 VLC_API void httpd_MsgAdd( httpd_message_t *, const char *psz_name, const char *psz_value, ... ) VLC_FORMAT( 3, 4 );
148 /* return "" if not found. The string is not allocated */
149 VLC_API const char * httpd_MsgGet( const httpd_message_t *, const char *psz_name );
151 #endif /* _VLC_HTTPD_H */