1 #ifndef PARSERS_H_INCLUDED
2 #define PARSERS_H_INCLUDED
3 #define PARSERS_H_VERSION "$Id: parsers.h,v 1.42 2008/04/17 14:40:49 fabiankeil Exp $"
4 /*********************************************************************
6 * File : $Source: /cvsroot/ijbswa/current/parsers.h,v $
8 * Purpose : Declares functions to parse/crunch headers and pages.
9 * Functions declared include:
10 * `add_to_iob', `client_cookie_adder', `client_from',
11 * `client_referrer', `client_send_cookie', `client_ua',
12 * `client_uagent', `client_x_forwarded',
13 * `client_x_forwarded_adder', `client_xtra_adder',
14 * `content_type', `crumble', `destroy_list', `enlist',
15 * `flush_socket', `free_http_request', `get_header',
16 * `list_to_text', `parse_http_request', `sed',
17 * and `server_set_cookie'.
19 * Copyright : Written by and Copyright (C) 2001 the SourceForge
20 * Privoxy team. http://www.privoxy.org/
22 * Based on the Internet Junkbuster originally written
23 * by and Copyright (C) 1997 Anonymous Coders and
24 * Junkbusters Corporation. http://www.junkbusters.com
26 * This program is free software; you can redistribute it
27 * and/or modify it under the terms of the GNU General
28 * Public License as published by the Free Software
29 * Foundation; either version 2 of the License, or (at
30 * your option) any later version.
32 * This program is distributed in the hope that it will
33 * be useful, but WITHOUT ANY WARRANTY; without even the
34 * implied warranty of MERCHANTABILITY or FITNESS FOR A
35 * PARTICULAR PURPOSE. See the GNU General Public
36 * License for more details.
38 * The GNU General Public License should be included with
39 * this file. If not, you can view it at
40 * http://www.gnu.org/copyleft/gpl.html
41 * or write to the Free Software Foundation, Inc., 59
42 * Temple Place - Suite 330, Boston, MA 02111-1307, USA.
46 * Revision 1.42 2008/04/17 14:40:49 fabiankeil
47 * Provide get_http_time() with the buffer size so it doesn't
48 * have to blindly assume that the buffer is big enough.
50 * Revision 1.41 2008/04/16 16:38:21 fabiankeil
51 * Don't pass the whole csp structure to flush_socket()
52 * when it only needs a file descriptor and a buffer.
54 * Revision 1.40 2007/08/11 14:47:26 fabiankeil
55 * Remove the prototypes for functions that are only
56 * used in parsers.c and thus should be static.
58 * Revision 1.39 2007/06/01 16:31:55 fabiankeil
59 * Change sed() to return a jb_err in preparation for forward-override{}.
61 * Revision 1.38 2007/03/25 14:27:11 fabiankeil
62 * Let parse_header_time() return a jb_err code
63 * instead of a pointer that can only be used to
64 * check for NULL anyway.
66 * Revision 1.37 2007/03/20 15:22:17 fabiankeil
67 * - Remove filter_client_header() and filter_client_header(),
68 * filter_header() now checks the shiny new
69 * CSP_FLAG_CLIENT_HEADER_PARSING_DONE flag instead.
71 * Revision 1.36 2007/03/05 13:25:32 fabiankeil
72 * - Cosmetical changes for LOG_LEVEL_RE_FILTER messages.
73 * - Handle "Cookie:" and "Connection:" headers a bit smarter
74 * (don't crunch them just to recreate them later on).
75 * - Add another non-standard time format for the cookie
76 * expiration date detection.
77 * - Fix a valgrind warning.
79 * Revision 1.35 2007/01/01 19:36:37 fabiankeil
80 * Integrate a modified version of Wil Mahan's
81 * zlib patch (PR #895531).
83 * Revision 1.34 2006/12/29 19:08:22 fabiankeil
84 * Reverted parts of my last commit
85 * to keep error handling working.
87 * Revision 1.33 2006/12/29 18:04:40 fabiankeil
88 * Fixed gcc43 conversion warnings.
90 * Revision 1.32 2006/12/06 19:14:23 fabiankeil
91 * Added prototype for get_destination_from_headers().
93 * Revision 1.31 2006/08/17 17:15:10 fabiankeil
94 * - Back to timegm() using GnuPG's replacement if necessary.
95 * Using mktime() and localtime() could add a on hour offset if
96 * the randomize factor was big enough to lead to a summer/wintertime
99 * - Removed now-useless Privoxy 3.0.3 compatibility glue.
101 * - Moved randomization code into pick_from_range().
103 * - Changed parse_header_time definition.
104 * time_t isn't guaranteed to be signed and
105 * if it isn't, -1 isn't available as error code.
106 * Changed some variable types in client_if_modified_since()
107 * because of the same reason.
109 * Revision 1.30 2006/08/14 08:25:19 fabiankeil
110 * Split filter-headers{} into filter-client-headers{}
111 * and filter-server-headers{}.
112 * Added parse_header_time() to share some code.
113 * Replaced timegm() with mktime().
115 * Revision 1.29 2006/08/03 02:46:41 david__schmidt
116 * Incorporate Fabian Keil's patch work:
\rhttp://www.fabiankeil.de/sourcecode/privoxy/
118 * Revision 1.28 2006/07/18 14:48:47 david__schmidt
119 * Reorganizing the repository: swapping out what was HEAD (the old 3.1 branch)
120 * with what was really the latest development (the v_3_0_branch branch)
122 * Revision 1.26.2.1 2002/09/25 14:52:46 oes
123 * Added basic support for OPTIONS and TRACE HTTP methods:
124 * - New parser function client_max_forwards which decrements
125 * the Max-Forwards HTTP header field of OPTIONS and TRACE
126 * requests by one before forwarding
127 * - New parser function client_host which extracts the host
128 * and port information from the HTTP header field if the
129 * request URI was not absolute
130 * - Don't crumble and re-add the Host: header, but only generate
131 * and append if missing
133 * Revision 1.26 2002/05/08 15:59:53 oes
134 * Changed add_to_iob signature (now returns jb_err)
136 * Revision 1.25 2002/03/26 22:29:55 swa
137 * we have a new homepage!
139 * Revision 1.24 2002/03/24 13:25:43 swa
140 * name change related issues
142 * Revision 1.23 2002/03/13 00:27:05 jongfoster
145 * Revision 1.22 2002/03/09 20:03:52 jongfoster
146 * - Making various functions return int rather than size_t.
147 * (Undoing a recent change). Since size_t is unsigned on
148 * Windows, functions like read_socket that return -1 on
149 * error cannot return a size_t.
151 * THIS WAS A MAJOR BUG - it caused frequent, unpredictable
152 * crashes, and also frequently caused JB to jump to 100%
153 * CPU and stay there. (Because it thought it had just
154 * read ((unsigned)-1) == 4Gb of data...)
156 * - The signature of write_socket has changed, it now simply
157 * returns success=0/failure=nonzero.
159 * - Trying to get rid of a few warnings --with-debug on
160 * Windows, I've introduced a new type "jb_socket". This is
161 * used for the socket file descriptors. On Windows, this
162 * is SOCKET (a typedef for unsigned). Everywhere else, it's
163 * an int. The error value can't be -1 any more, so it's
164 * now JB_INVALID_SOCKET (which is -1 on UNIX, and in
165 * Windows it maps to the #define INVALID_SOCKET.)
167 * - The signature of bind_port has changed.
169 * Revision 1.21 2002/03/07 03:46:17 oes
170 * Fixed compiler warnings
172 * Revision 1.20 2002/02/20 23:15:13 jongfoster
173 * Parsing functions now handle out-of-memory gracefully by returning
176 * Revision 1.19 2002/01/17 21:03:47 jongfoster
177 * Moving all our URL and URL pattern parsing code to urlmatch.c.
179 * Revision 1.18 2001/10/26 17:40:23 oes
180 * Introduced get_header_value()
181 * Removed client_accept()
183 * Revision 1.17 2001/10/13 12:47:32 joergs
184 * Removed client_host, added client_host_adder
186 * Revision 1.16 2001/10/07 18:50:16 oes
187 * Added server_content_encoding, renamed server_transfer_encoding
189 * Revision 1.15 2001/10/07 18:01:55 oes
190 * Changed server_http11 to server_http
192 * Revision 1.14 2001/10/07 15:45:48 oes
193 * added client_accept_encoding, client_te, client_accept_encoding_adder
195 * renamed content_type and content_length
197 * fixed client_host and strclean prototypes
199 * Revision 1.13 2001/09/29 12:56:03 joergs
200 * IJB now changes HTTP/1.1 to HTTP/1.0 in requests and answers.
202 * Revision 1.12 2001/09/13 23:05:50 jongfoster
203 * Changing the string paramater to the header parsers a "const".
205 * Revision 1.11 2001/07/31 14:46:53 oes
206 * Added prototype for connection_close_adder
208 * Revision 1.10 2001/07/30 22:08:36 jongfoster
209 * Tidying up #defines:
210 * - All feature #defines are now of the form FEATURE_xxx
211 * - Permanently turned off WIN_GUI_EDIT
212 * - Permanently turned on WEBDAV and SPLIT_PROXY_ARGS
214 * Revision 1.9 2001/07/29 18:43:08 jongfoster
215 * Changing #ifdef _FILENAME_H to FILENAME_H_INCLUDED, to conform to
218 * Revision 1.8 2001/07/13 14:01:54 oes
219 * Removed all #ifdef PCRS
221 * Revision 1.7 2001/06/29 13:32:14 oes
222 * Removed logentry from cancelled commit
224 * Revision 1.6 2001/06/03 19:12:38 oes
225 * deleted const struct interceptors
227 * Revision 1.5 2001/05/31 21:30:33 jongfoster
228 * Removed list code - it's now in list.[ch]
229 * Renamed "permission" to "action", and changed many features
230 * to use the actions file rather than the global config.
232 * Revision 1.4 2001/05/27 13:19:06 oes
233 * Patched Joergs solution for the content-length in.
235 * Revision 1.3 2001/05/26 13:39:32 jongfoster
236 * Only crunches Content-Length header if applying RE filtering.
237 * Without this fix, Microsoft Windows Update wouldn't work.
239 * Revision 1.2 2001/05/20 01:21:20 jongfoster
240 * Version 2.9.4 checkin.
241 * - Merged popupfile and cookiefile, and added control over PCRS
242 * filtering, in new "permissionsfile".
243 * - Implemented LOG_LEVEL_FATAL, so that if there is a configuration
244 * file error you now get a message box (in the Win32 GUI) rather
245 * than the program exiting with no explanation.
246 * - Made killpopup use the PCRS MIME-type checking and HTTP-header
248 * - Removed tabs from "config"
249 * - Moved duplicated url parsing code in "loaders.c" to a new funcition.
250 * - Bumped up version number.
252 * Revision 1.1.1.1 2001/05/15 13:59:01 oes
253 * Initial import of version 2.9.3 source tree
256 *********************************************************************/
265 extern const struct parsers client_patterns[];
266 extern const struct parsers server_patterns[];
267 extern const struct parsers server_patterns_light[];
269 extern const add_header_func_ptr add_client_headers[];
270 extern const add_header_func_ptr add_server_headers[];
272 extern int flush_socket(jb_socket fd, struct iob *iob);
273 extern jb_err add_to_iob(struct client_state *csp, char *buf, int n);
274 extern jb_err decompress_iob(struct client_state *csp);
275 extern char *get_header(struct iob *iob);
276 extern char *get_header_value(const struct list *header_list, const char *header_name);
277 extern jb_err sed(const struct parsers pats[], const add_header_func_ptr more_headers[], struct client_state *csp);
278 extern void get_http_time(int time_offset, char *buf, size_t buffer_size);
279 extern jb_err get_destination_from_headers(const struct list *headers, struct http_request *http);
281 #ifdef FEATURE_FORCE_LOAD
282 extern int strclean(const char *string, const char *substring);
283 #endif /* def FEATURE_FORCE_LOAD */
285 /* Revision control strings from this header and associated .c file */
286 extern const char parsers_rcs[];
287 extern const char parsers_h_rcs[];
295 #endif /* ndef PARSERS_H_INCLUDED */