vlc_httpd.h

Go to the documentation of this file.
00001 /*****************************************************************************
00002  * vlc_httpd.h: builtin HTTP/RTSP server.
00003  *****************************************************************************
00004  * Copyright (C) 2004-2006 VLC authors and VideoLAN
00005  * $Id: 6100dd00b2f1a1c957224c5d0af0791ace64551a $
00006  *
00007  * Authors: Laurent Aimar <fenrir@via.ecp.fr>
00008  *
00009  * This program is free software; you can redistribute it and/or modify it
00010  * under the terms of the GNU Lesser General Public License as published by
00011  * the Free Software Foundation; either version 2.1 of the License, or
00012  * (at your option) any later version.
00013  *
00014  * This program is distributed in the hope that it will be useful,
00015  * but WITHOUT ANY WARRANTY; without even the implied warranty of
00016  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
00017  * GNU Lesser General Public License for more details.
00018  *
00019  * You should have received a copy of the GNU Lesser General Public License
00020  * along with this program; if not, write to the Free Software Foundation,
00021  * Inc., 51 Franklin Street, Fifth Floor, Boston MA 02110-1301, USA.
00022  *****************************************************************************/
00023 
00024 #ifndef VLC_HTTPD_H
00025 #define VLC_HTTPD_H 1
00026 
00027 /**
00028  * \file
00029  * HTTP/RTSP server API.
00030  */
00031 
00032 enum
00033 {
00034     HTTPD_MSG_NONE,
00035 
00036     /* answer */
00037     HTTPD_MSG_ANSWER,
00038 
00039     /* http request */
00040     HTTPD_MSG_GET,
00041     HTTPD_MSG_HEAD,
00042     HTTPD_MSG_POST,
00043 
00044     /* rtsp request */
00045     HTTPD_MSG_OPTIONS,
00046     HTTPD_MSG_DESCRIBE,
00047     HTTPD_MSG_SETUP,
00048     HTTPD_MSG_PLAY,
00049     HTTPD_MSG_PAUSE,
00050     HTTPD_MSG_GETPARAMETER,
00051     HTTPD_MSG_TEARDOWN,
00052 
00053     /* just to track the count of MSG */
00054     HTTPD_MSG_MAX
00055 };
00056 
00057 enum
00058 {
00059     HTTPD_PROTO_NONE,
00060     HTTPD_PROTO_HTTP,  /* HTTP/1.x */
00061     HTTPD_PROTO_RTSP,  /* RTSP/1.x */
00062     HTTPD_PROTO_HTTP0, /* HTTP/0.x */
00063 };
00064 
00065 typedef struct httpd_host_t   httpd_host_t;
00066 typedef struct httpd_client_t httpd_client_t;
00067 /* create a new host */
00068 VLC_API httpd_host_t *vlc_http_HostNew( vlc_object_t * ) VLC_USED;
00069 VLC_API httpd_host_t *vlc_https_HostNew( vlc_object_t * ) VLC_USED;
00070 VLC_API httpd_host_t *vlc_rtsp_HostNew( vlc_object_t * ) VLC_USED;
00071 /* delete a host */
00072 VLC_API void httpd_HostDelete( httpd_host_t * );
00073 
00074 typedef struct httpd_message_t
00075 {
00076     httpd_client_t *cl; /* NULL if not throught a connection e vlc internal */
00077 
00078     uint8_t i_type;
00079     uint8_t i_proto;
00080     uint8_t i_version;
00081 
00082     /* for an answer */
00083     int     i_status;
00084 
00085     /* for a query */
00086     char    *psz_url;
00087     /* FIXME find a clean way to handle GET(psz_args)
00088        and POST(body) through the same code */
00089     uint8_t *psz_args;
00090 
00091     /* options */
00092     int     i_name;
00093     char    **name;
00094     int     i_value;
00095     char    **value;
00096 
00097     /* body */
00098     int64_t i_body_offset;
00099     int     i_body;
00100     uint8_t *p_body;
00101 
00102 } httpd_message_t;
00103 
00104 typedef struct httpd_url_t      httpd_url_t;
00105 typedef struct httpd_callback_sys_t httpd_callback_sys_t;
00106 typedef int    (*httpd_callback_t)( httpd_callback_sys_t *, httpd_client_t *, httpd_message_t *answer, const httpd_message_t *query );
00107 /* register a new url */
00108 VLC_API httpd_url_t * httpd_UrlNew( httpd_host_t *, const char *psz_url, const char *psz_user, const char *psz_password ) VLC_USED;
00109 /* register callback on a url */
00110 VLC_API int httpd_UrlCatch( httpd_url_t *, int i_msg, httpd_callback_t, httpd_callback_sys_t * );
00111 /* delete a url */
00112 VLC_API void httpd_UrlDelete( httpd_url_t * );
00113 
00114 VLC_API char* httpd_ClientIP( const httpd_client_t *cl, char *, int * );
00115 VLC_API char* httpd_ServerIP( const httpd_client_t *cl, char *, int * );
00116 
00117 /* High level */
00118 
00119 typedef struct httpd_file_t     httpd_file_t;
00120 typedef struct httpd_file_sys_t httpd_file_sys_t;
00121 typedef int (*httpd_file_callback_t)( httpd_file_sys_t *, httpd_file_t *, uint8_t *psz_request, uint8_t **pp_data, int *pi_data );
00122 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;
00123 VLC_API httpd_file_sys_t * httpd_FileDelete( httpd_file_t * );
00124 
00125 
00126 typedef struct httpd_handler_t  httpd_handler_t;
00127 typedef struct httpd_handler_sys_t httpd_handler_sys_t;
00128 typedef int (*httpd_handler_callback_t)( httpd_handler_sys_t *, 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 );
00129 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, httpd_handler_sys_t * ) VLC_USED;
00130 VLC_API httpd_handler_sys_t * httpd_HandlerDelete( httpd_handler_t * );
00131 
00132 typedef struct httpd_redirect_t httpd_redirect_t;
00133 VLC_API httpd_redirect_t * httpd_RedirectNew( httpd_host_t *, const char *psz_url_dst, const char *psz_url_src ) VLC_USED;
00134 VLC_API void httpd_RedirectDelete( httpd_redirect_t * );
00135 
00136 
00137 typedef struct httpd_stream_t httpd_stream_t;
00138 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;
00139 VLC_API void httpd_StreamDelete( httpd_stream_t * );
00140 VLC_API int httpd_StreamHeader( httpd_stream_t *, uint8_t *p_data, int i_data );
00141 VLC_API int httpd_StreamSend( httpd_stream_t *, uint8_t *p_data, int i_data );
00142 
00143 
00144 /* Msg functions facilities */
00145 VLC_API void httpd_MsgAdd( httpd_message_t *, const char *psz_name, const char *psz_value, ... ) VLC_FORMAT( 3, 4 );
00146 /* return "" if not found. The string is not allocated */
00147 VLC_API const char * httpd_MsgGet( const httpd_message_t *, const char *psz_name );
00148 
00149 #endif /* _VLC_HTTPD_H */
 All Data Structures Files Functions Variables Typedefs Enumerations Enumerator Defines