Home | History | Annotate | Line # | Download | only in httpd
bozohttpd.h revision 1.7
      1  1.7  joerg /*	$NetBSD: bozohttpd.h,v 1.7 2009/02/09 17:06:11 joerg Exp $	*/
      2  1.3    tls 
      3  1.5    mrg /*	$eterna: bozohttpd.h,v 1.18 2008/03/03 03:36:11 mrg Exp $	*/
      4  1.1    tls 
      5  1.1    tls /*
      6  1.5    mrg  * Copyright (c) 1997-2008 Matthew R. Green
      7  1.1    tls  * All rights reserved.
      8  1.1    tls  *
      9  1.1    tls  * Redistribution and use in source and binary forms, with or without
     10  1.1    tls  * modification, are permitted provided that the following conditions
     11  1.1    tls  * are met:
     12  1.1    tls  * 1. Redistributions of source code must retain the above copyright
     13  1.1    tls  *    notice, this list of conditions and the following disclaimer.
     14  1.1    tls  * 2. Redistributions in binary form must reproduce the above copyright
     15  1.1    tls  *    notice, this list of conditions and the following disclaimer and
     16  1.1    tls  *    dedication in the documentation and/or other materials provided
     17  1.1    tls  *    with the distribution.
     18  1.1    tls  * 3. The name of the author may not be used to endorse or promote products
     19  1.1    tls  *    derived from this software without specific prior written permission.
     20  1.1    tls  *
     21  1.1    tls  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
     22  1.1    tls  * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
     23  1.1    tls  * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
     24  1.1    tls  * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
     25  1.1    tls  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
     26  1.1    tls  * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
     27  1.1    tls  * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
     28  1.1    tls  * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
     29  1.1    tls  * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
     30  1.1    tls  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
     31  1.1    tls  * SUCH DAMAGE.
     32  1.1    tls  *
     33  1.1    tls  */
     34  1.2    tls #include <sys/queue.h>
     35  1.1    tls #include <sys/stat.h>
     36  1.5    mrg 
     37  1.1    tls #include <stdio.h>
     38  1.1    tls 
     39  1.1    tls /* headers */
     40  1.1    tls struct headers {
     41  1.4    rtr 	/*const*/ char *h_header;
     42  1.1    tls 	/*const*/ char *h_value;	/* this gets free()'ed etc at times */
     43  1.1    tls 	SIMPLEQ_ENTRY(headers)	h_next;
     44  1.1    tls };
     45  1.1    tls 
     46  1.1    tls /* http_req */
     47  1.1    tls typedef struct {
     48  1.1    tls 	int	hr_method;
     49  1.1    tls #define	HTTP_GET	0x01
     50  1.1    tls #define HTTP_POST	0x02
     51  1.1    tls #define HTTP_HEAD	0x03
     52  1.1    tls #define HTTP_OPTIONS	0x04	/* not supported */
     53  1.1    tls #define HTTP_PUT	0x05	/* not supported */
     54  1.1    tls #define HTTP_DELETE	0x06	/* not supported */
     55  1.1    tls #define HTTP_TRACE	0x07	/* not supported */
     56  1.1    tls #define HTTP_CONNECT	0x08	/* not supported */
     57  1.1    tls 	const char *hr_methodstr;
     58  1.6    tls 	char	   *hr_file;
     59  1.6    tls         char       *hr_query;
     60  1.1    tls 	const char *hr_proto;
     61  1.1    tls 	const char *hr_content_type;
     62  1.1    tls 	const char *hr_content_length;
     63  1.1    tls 	const char *hr_allow;
     64  1.1    tls 	const char *hr_host;		/* HTTP/1.1 Host: */
     65  1.1    tls 	const char *hr_referrer;
     66  1.5    mrg 	const char *hr_range;
     67  1.7  joerg 	const char *hr_if_modified_since;
     68  1.5    mrg 	int         hr_have_range;
     69  1.5    mrg 	off_t       hr_first_byte_pos;
     70  1.5    mrg 	off_t       hr_last_byte_pos;
     71  1.1    tls 	const char *hr_remotehost;
     72  1.1    tls 	const char *hr_remoteaddr;
     73  1.1    tls 	const char *hr_serverport;
     74  1.1    tls #ifdef DO_HTPASSWD
     75  1.1    tls 	const char *hr_authrealm;
     76  1.1    tls 	const char *hr_authuser;
     77  1.1    tls 	const char *hr_authpass;
     78  1.1    tls #endif
     79  1.1    tls 	SIMPLEQ_HEAD(, headers)	hr_headers;
     80  1.1    tls 	int	hr_nheaders;
     81  1.1    tls } http_req;
     82  1.1    tls 
     83  1.1    tls struct content_map {
     84  1.1    tls 	const char *name;	/* postfix of file */
     85  1.1    tls 	const char *type;	/* matching content-type */
     86  1.1    tls 	const char *encoding;	/* matching content-encoding */
     87  1.1    tls 	const char *encoding11;	/* matching content-encoding (HTTP/1.1) */
     88  1.1    tls 	const char *cgihandler;	/* optional CGI handler */
     89  1.1    tls };
     90  1.1    tls 
     91  1.1    tls #define WRSZ	(64 * 1024)
     92  1.1    tls 
     93  1.1    tls /* debug flags */
     94  1.1    tls #define DEBUG_NORMAL	1
     95  1.1    tls #define DEBUG_FAT	2
     96  1.1    tls #define DEBUG_OBESE	3
     97  1.1    tls #define DEBUG_EXPLODING	4
     98  1.1    tls 
     99  1.1    tls #define	strornull(x)	((x) ? (x) : "<null>")
    100  1.1    tls 
    101  1.1    tls extern	int	dflag;
    102  1.1    tls extern	const char *index_html;
    103  1.1    tls extern	const char *server_software;
    104  1.1    tls extern	char	*myname;
    105  1.1    tls 
    106  1.1    tls #ifdef DEBUG
    107  1.1    tls void	debug__(int, const char *, ...)
    108  1.1    tls 			__attribute__((__format__(__printf__, 2, 3)));
    109  1.1    tls #define debug(x)	debug__ x
    110  1.1    tls #else
    111  1.1    tls #define	debug(x)
    112  1.1    tls #endif /* DEBUG */
    113  1.1    tls 
    114  1.1    tls void	warning(const char *, ...)
    115  1.1    tls 		__attribute__((__format__(__printf__, 1, 2)));
    116  1.1    tls void	error(int, const char *, ...)
    117  1.1    tls 		__attribute__((__format__(__printf__, 2, 3)));
    118  1.5    mrg void	http_error(int, http_req *, const char *)
    119  1.5    mrg 		__attribute__((__noreturn__));
    120  1.1    tls 
    121  1.1    tls void	check_special_files(http_req *, const char *);
    122  1.1    tls char	*http_date(void);
    123  1.1    tls void	print_header(http_req *, struct stat *, const char *, const char *);
    124  1.1    tls 
    125  1.5    mrg char	*bozodgetln(int, ssize_t *, ssize_t	(*)(int, void *, size_t));
    126  1.5    mrg char	*bozostrnsep(char **, const char *, ssize_t *);
    127  1.1    tls 
    128  1.1    tls void	*bozomalloc(size_t);
    129  1.1    tls void	*bozorealloc(void *, size_t);
    130  1.1    tls char	*bozostrdup(const char *);
    131  1.1    tls 
    132  1.1    tls extern	const char *Iflag;
    133  1.1    tls extern	int	Iflag_set;
    134  1.1    tls extern	int	bflag, fflag;
    135  1.1    tls extern	char	*slashdir;
    136  1.1    tls extern	const char http_09[];
    137  1.1    tls extern	const char http_10[];
    138  1.1    tls extern	const char http_11[];
    139  1.1    tls extern	const char text_plain[];
    140  1.1    tls 
    141  1.1    tls /* bozotic io */
    142  1.1    tls extern	int	(*bozoprintf)(const char *, ...);
    143  1.1    tls extern	ssize_t	(*bozoread)(int, void *, size_t);
    144  1.1    tls extern	ssize_t	(*bozowrite)(int, const void *, size_t);
    145  1.1    tls extern	int	(*bozoflush)(FILE *);
    146  1.1    tls 
    147  1.1    tls 
    148  1.1    tls /* ssl-bozo.c */
    149  1.1    tls #ifndef NO_SSL_SUPPORT
    150  1.1    tls extern	void	ssl_set_opts(char *, char *);
    151  1.1    tls extern	void	ssl_init(void);
    152  1.1    tls extern	void	ssl_accept(void);
    153  1.1    tls extern	void	ssl_destroy(void);
    154  1.1    tls #else
    155  1.1    tls #define ssl_set_opts(x, y)	/* nothing */
    156  1.1    tls #define ssl_init()		/* nothing */
    157  1.1    tls #define ssl_accept()		/* nothing */
    158  1.1    tls #define ssl_destroy()		/* nothing */
    159  1.1    tls #endif
    160  1.1    tls 
    161  1.1    tls 
    162  1.1    tls /* auth-bozo.c */
    163  1.1    tls #ifdef DO_HTPASSWD
    164  1.1    tls extern	void	auth_check(http_req *, const char *);
    165  1.1    tls extern	int	auth_check_headers(http_req *, char *, char *, ssize_t);
    166  1.1    tls extern	void	auth_check_special_files(http_req *, const char *);
    167  1.1    tls extern	void	auth_check_401(http_req *, int);
    168  1.1    tls extern	void	auth_cgi_setenv(http_req *, char ***);
    169  1.1    tls extern	int	auth_cgi_count(http_req *);
    170  1.1    tls #else
    171  1.1    tls #define		auth_check(x, y)		/* nothing */
    172  1.1    tls #define		auth_check_headers(x, y, z, a)	0
    173  1.1    tls #define		auth_check_special_files(x, y)	/* nothing */
    174  1.1    tls #define		auth_check_401(x, y)		/* nothing */
    175  1.1    tls #define		auth_cgi_setenv(x, y)		/* nothing */
    176  1.1    tls #define		auth_cgi_count(x)		0
    177  1.1    tls #endif /* DO_HTPASSWD */
    178  1.1    tls 
    179  1.1    tls 
    180  1.1    tls /* cgi-bozo.c */
    181  1.1    tls #ifndef NO_CGIBIN_SUPPORT
    182  1.1    tls void	set_cgibin(char *);
    183  1.1    tls void	spsetenv(const char *env, const char *val, char **envp);
    184  1.1    tls void	process_cgi(http_req *);
    185  1.1    tls void	add_content_map_cgi(char *, char *);
    186  1.1    tls #else
    187  1.1    tls #define	process_cgi(r)				/* nothing */
    188  1.1    tls #endif /* NO_CGIBIN_SUPPORT */
    189  1.1    tls 
    190  1.1    tls 
    191  1.1    tls /* daemon-bozo.c */
    192  1.1    tls extern	const char *Iflag;
    193  1.1    tls extern	int	Iflag_set;
    194  1.1    tls #ifndef NO_DAEMON_MODE
    195  1.1    tls extern	char	*iflag;
    196  1.1    tls 
    197  1.1    tls void	daemon_init(void);
    198  1.1    tls void	daemon_fork(void);
    199  1.1    tls #else
    200  1.1    tls #define daemon_init()				/* nothing */
    201  1.1    tls #define daemon_fork()				/* nothing */
    202  1.1    tls #endif /* NO_DAEMON_MODE */
    203  1.1    tls 
    204  1.1    tls 
    205  1.1    tls /* tilde-luzah-bozo.c */
    206  1.1    tls #ifndef NO_USER_SUPPORT
    207  1.1    tls extern	int	uflag;
    208  1.1    tls extern	const char *public_html;
    209  1.1    tls 
    210  1.1    tls char *	user_transform(http_req *, int *);
    211  1.1    tls #endif /* NO_USER_SUPPORT */
    212  1.1    tls 
    213  1.1    tls 
    214  1.1    tls /* dir-index-bozo.c */
    215  1.1    tls #ifndef NO_DIRINDEX_SUPPORT
    216  1.1    tls extern	int	Xflag;
    217  1.1    tls extern	int	Hflag;
    218  1.1    tls int	directory_index(http_req *, const char *, int);
    219  1.1    tls #else
    220  1.1    tls #define directory_index(a, b, c)		0
    221  1.1    tls #endif /* NO_DIRINDEX_SUPPORT */
    222  1.1    tls 
    223  1.1    tls 
    224  1.1    tls /* content-bozo.c */
    225  1.1    tls const char *content_type(http_req *, const char *);
    226  1.1    tls const char *content_encoding(http_req *, const char *);
    227  1.1    tls struct content_map *match_content_map(const char *, int);
    228  1.1    tls struct content_map *get_content_map(const char *);
    229  1.1    tls #ifndef NO_DYNAMIC_CONTENT
    230  1.1    tls void	add_content_map_mime(char *, char *, char *, char *);
    231  1.1    tls #endif
    232