Sat, 22 Jun 2013 13:08:36 +0200
some fixes
1 | 1 | /* |
2 | * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS HEADER. | |
3 | * | |
4 | * Copyright 2008 Sun Microsystems, Inc. All rights reserved. | |
5 | * | |
6 | * THE BSD LICENSE | |
7 | * | |
8 | * Redistribution and use in source and binary forms, with or without | |
9 | * modification, are permitted provided that the following conditions are met: | |
10 | * | |
11 | * Redistributions of source code must retain the above copyright notice, this | |
12 | * list of conditions and the following disclaimer. | |
13 | * Redistributions in binary form must reproduce the above copyright notice, | |
14 | * this list of conditions and the following disclaimer in the documentation | |
15 | * and/or other materials provided with the distribution. | |
16 | * | |
17 | * Neither the name of the nor the names of its contributors may be | |
18 | * used to endorse or promote products derived from this software without | |
19 | * specific prior written permission. | |
20 | * | |
21 | * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | |
22 | * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | |
23 | * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | |
24 | * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER | |
25 | * OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, | |
26 | * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, | |
27 | * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; | |
28 | * OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, | |
29 | * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR | |
30 | * OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF | |
31 | * ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | |
32 | */ | |
33 | ||
34 | #ifndef PUBLIC_NSAPI_H | |
35 | #define PUBLIC_NSAPI_H | |
36 | ||
37 | /* | |
38 | * File: nsapi.h | |
39 | * | |
40 | * Description: | |
41 | * | |
42 | * This file defines an interface for extending the server with | |
43 | * in-process plug-ins. | |
44 | */ | |
45 | ||
46 | #ifdef __cplusplus | |
47 | extern "C" { | |
48 | #endif | |
49 | ||
50 | /* NSAPI version defined by this header file */ | |
51 | #define NSAPI_VERSION 303 | |
52 | ||
53 | /* Define USE_NSAPI_VERSION to use a specific NSAPI version at compile time */ | |
54 | #ifdef USE_NSAPI_VERSION | |
55 | #if USE_NSAPI_VERSION < 300 || USE_NSAPI_VERSION > NSAPI_VERSION | |
56 | #error This header file does not support the requested NSAPI version | |
57 | #else | |
58 | #undef NSAPI_VERSION | |
59 | #define NSAPI_VERSION USE_NSAPI_VERSION | |
60 | #endif | |
61 | #endif | |
62 | ||
63 | /* --- Begin native platform configuration definitions --- */ | |
64 | ||
65 | #if !defined(XP_WIN32) && !defined(XP_UNIX) | |
66 | #if defined(WIN32) || defined(_WIN32) || defined(__WIN32__) | |
67 | #define XP_WIN32 | |
68 | #else | |
69 | #define XP_UNIX | |
70 | #endif | |
71 | #endif | |
72 | ||
73 | #ifdef XP_UNIX | |
74 | #define NSAPI_PUBLIC | |
75 | #define ZERO(ptr, len) memset(ptr, 0, len) | |
76 | #ifdef AIX | |
77 | #define TCPLEN_T size_t | |
78 | #endif | |
79 | #ifdef HPUX | |
80 | #define TCPLEN_T int | |
81 | #endif | |
82 | #ifndef TCPLEN_T | |
83 | #define TCPLEN_T socklen_t | |
84 | #endif | |
85 | #endif /* XP_UNIX */ | |
86 | ||
87 | #ifdef XP_WIN32 | |
88 | #define NSAPI_PUBLIC __declspec(dllexport) | |
89 | struct iovec { | |
90 | char *iov_base; | |
91 | unsigned iov_len; | |
92 | }; | |
93 | #ifndef S_ISDIR | |
94 | #define S_ISDIR(mode) ((mode & S_IFMT) == S_IFDIR) | |
95 | #endif | |
96 | #ifndef S_ISREG | |
97 | #define S_ISREG(mode) ((mode & S_IFMT) == S_IFREG) | |
98 | #endif | |
99 | #ifndef S_ISLNK | |
100 | #define S_ISLNK(x) (0) | |
101 | #endif | |
102 | #define caddr_t PCHAR | |
103 | #define NEED_STRCASECMP | |
104 | #define NEED_STRNCASECMP | |
105 | #define ZERO(ptr, len) ZeroMemory(ptr, len) | |
106 | #define TCPLEN_T int | |
107 | #endif /* XP_WIN32 */ | |
108 | ||
109 | /* --- End native platform configuration definitions --- */ | |
110 | ||
111 | /* --- Begin miscellaneous definitions --- */ | |
112 | ||
113 | /* Used in some places as a length limit on error messages */ | |
114 | #define MAGNUS_ERROR_LEN 1024 | |
115 | ||
116 | /* Carriage return and line feed */ | |
117 | #define CR 13 | |
118 | #define LF 10 | |
119 | #ifdef XP_WIN32 | |
120 | #define ENDLINE "\r\n" | |
121 | #else | |
122 | #define ENDLINE "\n" | |
123 | #endif | |
124 | ||
125 | /* mime.types file identification line */ | |
126 | #define NCC_MT_MAGIC "#--Netscape Communications Corporation MIME Information" | |
127 | #define NCC_MT_MAGIC_LEN 55 | |
128 | ||
129 | /* The character which separates extensions with cinfo_find */ | |
130 | #define CINFO_SEPARATOR '.' | |
131 | ||
132 | /* The maximum length of a line in a mime.types file */ | |
133 | #define CINFO_MAX_LEN 1024 | |
134 | ||
135 | /* The maximum length of an error message */ | |
136 | #define MAX_ERROR_LEN 4096 | |
137 | ||
138 | /* | |
139 | * A warning is a minor mishap, such as a 404 being issued. | |
140 | */ | |
141 | #define LOG_WARN 0 | |
142 | ||
143 | /* | |
144 | * A misconfig is when there is a syntax error or permission violation in | |
145 | * a config file. | |
146 | */ | |
147 | #define LOG_MISCONFIG 1 | |
148 | ||
149 | /* | |
150 | * Security warnings are issued when authentication fails, or a host is | |
151 | * given a 403 return code. | |
152 | */ | |
153 | #define LOG_SECURITY 2 | |
154 | ||
155 | /* | |
156 | * A failure is when a request could not be fulfilled due to an internal | |
157 | * problem, such as a CGI script exiting prematurely, or a filesystem | |
158 | * permissions problem. | |
159 | */ | |
160 | #define LOG_FAILURE 3 | |
161 | ||
162 | /* | |
163 | * A catastrophe is a fatal server error such as running out of | |
164 | * memory or processes, or a system call failing, or even a server crash. | |
165 | * The server child cannot recover from a catastrophe. | |
166 | */ | |
167 | #define LOG_CATASTROPHE 4 | |
168 | ||
169 | /* | |
170 | * Informational message, of no concern. | |
171 | */ | |
172 | #define LOG_INFORM 5 | |
173 | ||
174 | /* | |
175 | * Internal diagnostic message. | |
176 | */ | |
177 | #define LOG_VERBOSE 6 | |
178 | ||
179 | /* | |
180 | * The time format to use in the error log | |
181 | */ | |
182 | #define ERR_TIMEFMT "[%d/%b/%Y:%H:%M:%S]" | |
183 | ||
184 | ||
185 | /* The fd you will get if you are reporting errors to SYSLOG */ | |
186 | #define ERRORS_TO_SYSLOG NULL | |
187 | ||
188 | /* Return codes from file I/O routines */ | |
189 | #define IO_OKAY 1 | |
190 | #define IO_ERROR -1 | |
191 | #define IO_EOF 0 | |
192 | #define NETBUF_EOF -1 | |
193 | #define NETBUF_ERROR -2 | |
194 | #define NETBUF_FULL -3 | |
195 | ||
196 | /* The disk page size on this machine. */ | |
197 | #define FILE_BUFFERSIZE 4096 | |
198 | ||
199 | #ifdef XP_UNIX | |
200 | ||
201 | #define FILE_PATHSEP '/' | |
202 | #define FILE_PARENT "../" | |
203 | ||
204 | #elif defined(XP_WIN32) | |
205 | ||
206 | #define FILE_PATHSEP '/' | |
207 | #define FILE_PARENT "..\\" | |
208 | ||
209 | #endif /* XP_WIN32 */ | |
210 | ||
211 | #define NET_INFINITE_TIMEOUT 0 | |
212 | #define NET_ZERO_TIMEOUT -1 | |
213 | ||
214 | #ifdef USE_REGEX | |
215 | /* WILDPAT uses regular expressions */ | |
216 | #define WILDPAT_VALID(exp) regexp_valid(exp) | |
217 | #define WILDPAT_MATCH(str, exp) regexp_match(str, exp) | |
218 | #define WILDPAT_CMP(str, exp) regexp_cmp(str, exp) | |
219 | #define WILDPAT_CASECMP(str, exp) regexp_casecmp(str, exp) | |
220 | #define WILDPAT_USES_REGEXP 1 | |
221 | #else | |
222 | /* WILDPAT uses shell expressions */ | |
223 | #define WILDPAT_VALID(exp) shexp_valid(exp) | |
224 | #define WILDPAT_MATCH(str, exp) shexp_match(str, exp) | |
225 | #define WILDPAT_CMP(str, exp) shexp_cmp(str, exp) | |
226 | #define WILDPAT_CASECMP(str, exp) shexp_casecmp(str, exp) | |
227 | #define WILDPAT_USES_SHEXP 1 | |
228 | #endif | |
229 | ||
230 | /* Define return codes from WILDPAT_VALID */ | |
231 | #define NON_WILDPAT -1 /* exp is ordinary string */ | |
232 | #define INVALID_WILDPAT -2 /* exp is an invalid pattern */ | |
233 | #define VALID_WILDPAT 1 /* exp is a valid pattern */ | |
234 | ||
235 | /* Define return codes from regexp_valid and shexp_valid */ | |
236 | #define NON_SXP NON_WILDPAT /* exp is an ordinary string */ | |
237 | #define INVALID_SXP INVALID_WILDPAT /* exp is an invalid shell exp */ | |
238 | #define VALID_SXP VALID_WILDPAT /* exp is a valid shell exp */ | |
239 | ||
240 | #define NON_REGEXP NON_SXP | |
241 | #define INVALID_REGEXP INVALID_SXP | |
242 | #define VALID_REGEXP VALID_SXP | |
243 | ||
244 | #define SYSTHREAD_DEFAULT_PRIORITY 16 | |
245 | ||
246 | /* The longest line in the configuration file */ | |
247 | #define CONF_MAXLEN 16384 | |
248 | ||
249 | #define HTTP_DATE_LEN 30 | |
250 | #define HTTP_DATE_FMT "%a, %d %b %Y %T GMT" | |
251 | ||
252 | /* HTTP status codes */ | |
253 | #define PROTOCOL_CONTINUE 100 | |
254 | #define PROTOCOL_SWITCHING 101 | |
255 | #define PROTOCOL_OK 200 | |
256 | #define PROTOCOL_CREATED 201 | |
257 | #define PROTOCOL_ACCEPTED 202 | |
258 | #define PROTOCOL_NONAUTHORITATIVE 203 | |
259 | #define PROTOCOL_NO_RESPONSE 204 | |
260 | #define PROTOCOL_NO_CONTENT 204 | |
261 | #define PROTOCOL_RESET_CONTENT 205 | |
262 | #define PROTOCOL_PARTIAL_CONTENT 206 | |
263 | #define PROTOCOL_MULTI_STATUS 207 | |
264 | #define PROTOCOL_MULTIPLE_CHOICES 300 | |
265 | #define PROTOCOL_MOVED_PERMANENTLY 301 | |
266 | #define PROTOCOL_REDIRECT 302 | |
267 | #define PROTOCOL_SEE_OTHER 303 | |
268 | #define PROTOCOL_NOT_MODIFIED 304 | |
269 | #define PROTOCOL_USE_PROXY 305 | |
270 | #define PROTOCOL_TEMPORARY_REDIRECT 307 | |
271 | #define PROTOCOL_BAD_REQUEST 400 | |
272 | #define PROTOCOL_UNAUTHORIZED 401 | |
273 | #define PROTOCOL_PAYMENT_REQUIRED 402 | |
274 | #define PROTOCOL_FORBIDDEN 403 | |
275 | #define PROTOCOL_NOT_FOUND 404 | |
276 | #define PROTOCOL_METHOD_NOT_ALLOWED 405 | |
277 | #define PROTOCOL_NOT_ACCEPTABLE 406 | |
278 | #define PROTOCOL_PROXY_UNAUTHORIZED 407 | |
279 | #define PROTOCOL_REQUEST_TIMEOUT 408 | |
280 | #define PROTOCOL_CONFLICT 409 | |
281 | #define PROTOCOL_GONE 410 | |
282 | #define PROTOCOL_LENGTH_REQUIRED 411 | |
283 | #define PROTOCOL_PRECONDITION_FAIL 412 | |
284 | #define PROTOCOL_ENTITY_TOO_LARGE 413 | |
285 | #define PROTOCOL_URI_TOO_LARGE 414 | |
286 | #define PROTOCOL_UNSUPPORTED_MEDIA_TYPE 415 | |
287 | #define PROTOCOL_REQUESTED_RANGE_NOT_SATISFIABLE 416 | |
288 | #define PROTOCOL_EXPECTATION_FAILED 417 | |
289 | #define PROTOCOL_LOCKED 423 | |
290 | #define PROTOCOL_FAILED_DEPENDENCY 424 | |
291 | #define PROTOCOL_SERVER_ERROR 500 | |
292 | #define PROTOCOL_NOT_IMPLEMENTED 501 | |
293 | #define PROTOCOL_BAD_GATEWAY 502 | |
294 | #define PROTOCOL_SERVICE_UNAVAILABLE 503 | |
295 | #define PROTOCOL_GATEWAY_TIMEOUT 504 | |
296 | #define PROTOCOL_VERSION_NOT_SUPPORTED 505 | |
297 | #define PROTOCOL_INSUFFICIENT_STORAGE 507 | |
298 | ||
299 | #define PROTOCOL_VERSION_HTTP09 9 | |
300 | #define PROTOCOL_VERSION_HTTP10 100 | |
301 | #define PROTOCOL_VERSION_HTTP11 101 | |
302 | #define CURRENT_PROTOCOL_VERSION PROTOCOL_VERSION_HTTP11 | |
303 | ||
304 | /* Definitions for HTTP over SSL */ | |
305 | #define HTTPS_PORT 443 | |
306 | #define HTTPS_URL "https" | |
307 | ||
308 | /* Definitions for HTTP over TCP */ | |
309 | #define HTTP_PORT 80 | |
310 | #define HTTP_URL "http" | |
311 | ||
312 | ||
313 | #define REQ_MAX_LINE 4096 | |
314 | ||
315 | /* | |
316 | * The REQ_ return codes. These codes are used to determine what the server | |
317 | * should do after a particular module completes its task. | |
318 | * | |
319 | * Func type functions return these as do many internal functions. | |
320 | */ | |
321 | ||
322 | /* The function performed its task, proceed with the request */ | |
323 | #define REQ_PROCEED 0 | |
324 | /* The entire request should be aborted: An error occurred */ | |
325 | #define REQ_ABORTED -1 | |
326 | /* The function performed no task, but proceed anyway */ | |
327 | #define REQ_NOACTION -2 | |
328 | /* Tear down the session and exit */ | |
329 | #define REQ_EXIT -3 | |
330 | /* Restart the entire request-response process */ | |
331 | #define REQ_RESTART -4 | |
332 | /* Too busy to execute this now */ | |
333 | #define REQ_TOOBUSY -5 | |
334 | ||
3
137197831306
minimal request handling
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
1
diff
changeset
|
335 | |
137197831306
minimal request handling
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
1
diff
changeset
|
336 | /**** NSAPI extensions ****/ |
137197831306
minimal request handling
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
1
diff
changeset
|
337 | |
137197831306
minimal request handling
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
1
diff
changeset
|
338 | /* The function is still in progress (async extension) */ |
137197831306
minimal request handling
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
1
diff
changeset
|
339 | #define REQ_PROCESSING -8 |
137197831306
minimal request handling
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
1
diff
changeset
|
340 | |
137197831306
minimal request handling
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
1
diff
changeset
|
341 | /**** END NSAPI extensions ****/ |
137197831306
minimal request handling
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
1
diff
changeset
|
342 | |
6
ce8fecc9847d
improved request processing
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
3
diff
changeset
|
343 | |
1 | 344 | /* --- End miscellaneous definitions --- */ |
345 | ||
346 | /* --- Begin native platform includes --- */ | |
347 | ||
348 | #ifdef XP_UNIX | |
349 | #include <unistd.h> | |
350 | #include <sys/file.h> | |
6
ce8fecc9847d
improved request processing
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
3
diff
changeset
|
351 | #include <alloca.h> /* new */ |
29
e8619defde14
added event handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
23
diff
changeset
|
352 | #include <pthread.h> |
1 | 353 | #ifndef HPUX |
354 | #include <sys/select.h> | |
355 | #endif | |
356 | #include <sys/socket.h> | |
357 | #include <sys/time.h> | |
358 | #include <sys/types.h> | |
359 | #include <sys/uio.h> | |
360 | #include <fcntl.h> | |
361 | #include <dirent.h> | |
362 | #include <pwd.h> | |
363 | #include <netinet/in.h> | |
364 | #endif /* XP_UNIX */ | |
365 | ||
366 | #ifdef XP_WIN32 | |
367 | #include <wtypes.h> | |
368 | #include <winbase.h> | |
369 | #include <direct.h> | |
370 | #include <winsock.h> | |
371 | #endif /* XP_WIN32 */ | |
372 | ||
373 | #include <sys/stat.h> | |
374 | #include <ctype.h> | |
375 | #include <stdio.h> | |
376 | #include <stdarg.h> | |
377 | #include <stdlib.h> | |
378 | #include <string.h> | |
379 | #include <errno.h> | |
380 | #include <time.h> | |
381 | ||
382 | /* --- End native platform includes --- */ | |
383 | ||
384 | /* --- Begin type definitions --- */ | |
385 | ||
386 | /* NOTE: both SYS_FILE and SYS_NETFD are actually NSPR PRFileDesc * and can */ | |
387 | /* be used with NSPR API calls (after casting them to PRFileDesc *) */ | |
388 | ||
54 | 389 | // NOTE: no they are not NSPR PRFileDesc* |
390 | // they are VFSFile* | |
391 | // TODO: fix NOTE | |
392 | ||
393 | ||
1 | 394 | #ifndef SYS_FILE_T |
54 | 395 | typedef struct VFSFile *SYS_FILE; |
1 | 396 | #define SYS_FILE_T void * |
397 | #endif /* !SYS_FILE_T */ | |
398 | ||
54 | 399 | #define SYS_ERROR_FD ((SYS_FILE)-1) // TODO: fix |
1 | 400 | |
401 | #ifndef SYS_NETFD_T | |
402 | typedef void *SYS_NETFD; | |
403 | #define SYS_NETFD_T void * | |
404 | #endif /* !SYS_NETFD_T */ | |
405 | ||
406 | /* Error value for a SYS_NETFD */ | |
407 | #ifndef SYS_NET_ERRORFD | |
408 | #define SYS_NET_ERRORFD ((SYS_NETFD)-1) | |
409 | #endif /* !SYS_NET_ERRORFD */ | |
410 | ||
411 | /* | |
412 | * These structures were originally defined in nsapi.h, but those definitions | |
413 | * were removed in iPlanet Web Server 4.0. The contents of these structures | |
414 | * are now private to the server implementation and must not be accessed | |
415 | * directly. Instead, use the objset_*, object_*, directive_table_*, and | |
416 | * directive_* accessor functions. | |
417 | */ | |
418 | typedef struct directive directive; | |
419 | typedef struct dtable dtable; | |
420 | typedef struct httpd_object httpd_object; | |
421 | typedef struct httpd_objset httpd_objset; | |
422 | ||
423 | /* | |
424 | * Type: filebuffer, filebuf_t | |
425 | * | |
426 | * Description: | |
427 | * | |
428 | * This structure is used to represent a buffered file. On some | |
429 | * systems the file may be memory-mapped. A filebuffer is created | |
430 | * by filebuf_open(), and destroyed by filebuf_close(). | |
431 | * | |
432 | * Notes: | |
433 | * | |
434 | * Direct access to the members of this structure, not using | |
435 | * macros defined here, is discouraged. | |
436 | * | |
437 | * The filebuf alias that used to be defined for this type was | |
438 | * found to conflict with a C++ class of the same name, so it | |
439 | * has been renamed to filebuf_t. | |
440 | */ | |
441 | typedef struct filebuffer filebuffer; | |
442 | ||
443 | /* Version of filebuffer when memory-mapped files are supported */ | |
444 | struct filebuffer { | |
445 | SYS_FILE fd; | |
446 | #ifdef XP_WIN32 | |
447 | HANDLE fdmap; | |
448 | #endif | |
449 | caddr_t fp; | |
450 | int len; | |
451 | ||
452 | unsigned char *inbuf; | |
453 | int cursize; | |
454 | ||
455 | int pos; | |
456 | const char *errmsg; | |
457 | }; | |
458 | ||
459 | /* Return next character or IO_EOF */ | |
460 | #define filebuf_getc(b) ((b)->pos == (b)->len ? IO_EOF : (int)((b)->fp)[(b)->pos++]) | |
461 | ||
462 | #define filebuf_iseof(b) ((b)->pos == (b)->len) | |
463 | ||
464 | /* C++ streamio defines a filebuf class. */ | |
465 | typedef filebuffer filebuf_t; | |
466 | ||
467 | #ifdef XP_WIN32 | |
468 | /* Use a filebuffer to read data from a pipe */ | |
469 | #define pipebuf_getc(b) \ | |
470 | ((b)->pos != (b)->cursize ? (int)((b)->inbuf[(b)->pos++]) : pipebuf_next(b,1)) | |
471 | #endif /* XP_WIN32 */ | |
472 | ||
473 | /* | |
474 | * Type: netbuf | |
475 | * | |
476 | * Description: | |
477 | * | |
478 | * This structure is used to represent a buffered network socket. | |
479 | * It is created by netbuf_open(), and destroyed by netbuf_close(). | |
480 | * | |
481 | * Notes: | |
482 | * | |
483 | * Direct access to the members of this structure, not using | |
484 | * macros defined here, is discouraged. | |
485 | * | |
486 | * The inbuf field used to be (unsigned char *), but is now | |
487 | * simply (char *). The value returned by the netbuf_getc() | |
488 | * macro is (int). | |
489 | */ | |
490 | typedef struct netbuf netbuf; | |
491 | struct netbuf { | |
492 | SYS_NETFD sd; | |
493 | ||
494 | int pos, cursize, maxsize, rdtimeout; | |
495 | #ifdef XP_WIN32 | |
496 | CHAR address[64]; | |
497 | #endif /* XP_WIN32 */ | |
498 | unsigned char *inbuf; | |
499 | char *errmsg; | |
500 | #ifndef XP_WIN32 | |
501 | char address[64]; | |
502 | #endif /* !XP_WIN32 */ | |
503 | }; | |
504 | ||
505 | /* | |
506 | * netbuf_getc gets a character from the given network buffer and returns | |
507 | * it (as an integer). | |
508 | * | |
509 | * It will return (int) IO_ERROR for an error and (int) IO_EOF for | |
510 | * an error condition or EOF respectively. | |
511 | */ | |
512 | #define netbuf_getc(b) \ | |
513 | ((b)->pos != (b)->cursize ? (int)((b)->inbuf[(b)->pos++]) : netbuf_next(b,1)) | |
514 | ||
515 | /* | |
516 | * buffer_error returns the last error that occurred with buffer. Don't use | |
517 | * this unless you know an error occurred. Independent of network/file type. | |
518 | */ | |
519 | #define buffer_error(b) ((b)->errmsg) | |
520 | ||
521 | /* | |
522 | * Type: sendfiledata | |
523 | * | |
524 | * Description: | |
525 | * | |
526 | * This structure is used to pass arguments to the net_sendfile() | |
527 | * function. offset and len may be set to 0 to transmit a file in its | |
528 | * entirety. | |
529 | */ | |
530 | typedef struct sendfiledata sendfiledata; | |
531 | struct sendfiledata { | |
532 | SYS_FILE fd; /* file to send */ | |
533 | size_t offset; /* offset in file to start sending from */ | |
534 | size_t len; /* number of bytes to send from file */ | |
535 | const void *header; /* data to send before file */ | |
536 | int hlen; /* number of bytes to send before file */ | |
537 | const void *trailer; /* data to send after file */ | |
538 | int tlen; /* number of bytes to send after file */ | |
539 | }; | |
540 | ||
541 | /* | |
542 | * Type: NSAPIIOVec | |
543 | * | |
544 | * Description: | |
545 | * | |
546 | * This structure is used to pass arguments to the net_writev() | |
547 | * and FilterWritevFunc() functions. | |
548 | */ | |
65
14722c5f8856
added chunked transfer encoding
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
64
diff
changeset
|
549 | typedef struct iovec NSAPIIOVec; |
14722c5f8856
added chunked transfer encoding
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
64
diff
changeset
|
550 | |
14722c5f8856
added chunked transfer encoding
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
64
diff
changeset
|
551 | /* |
14722c5f8856
added chunked transfer encoding
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
64
diff
changeset
|
552 | //ifdef _LP64 |
1 | 553 | typedef struct NSAPIIOVec NSAPIIOVec; |
554 | struct NSAPIIOVec { | |
555 | char *iov_base; | |
556 | int iov_len; | |
557 | }; | |
65
14722c5f8856
added chunked transfer encoding
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
64
diff
changeset
|
558 | //else |
1 | 559 | typedef struct iovec NSAPIIOVec; |
65
14722c5f8856
added chunked transfer encoding
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
64
diff
changeset
|
560 | //endif |
14722c5f8856
added chunked transfer encoding
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
64
diff
changeset
|
561 | */ |
1 | 562 | |
563 | ||
564 | /* | |
565 | * Type: cinfo | |
566 | * | |
567 | * Description: | |
568 | * | |
569 | * This is a structure that captures the information in the name/value | |
570 | * pairs on one line of a mime.types file. A cinfo structure is | |
571 | * stored in the memory-resident database, indexed by each of the | |
572 | * file extensions specified in the "exts" name/value pair. It | |
573 | * defines various attributes of resources with names containing | |
574 | * the specified file extensions. | |
575 | * | |
576 | * Notes: | |
577 | * | |
578 | * Pointers to cinfo structures returned by this API may or may not | |
579 | * need to freed by the caller. See the individual function | |
580 | * descriptions. | |
581 | * | |
582 | * The strings referenced by the fields of cinfo structures returned | |
583 | * by this API should be considered read-only, and do not need to be | |
584 | * freed by the caller, even when the cinfo structure does. | |
585 | */ | |
586 | typedef struct cinfo cinfo; | |
587 | struct cinfo { | |
588 | char *type; | |
589 | char *encoding; | |
590 | char *language; | |
591 | }; | |
592 | ||
593 | ||
594 | typedef void* CONDVAR; | |
595 | typedef void *COUNTING_SEMAPHORE; | |
596 | typedef void* CRITICAL; | |
597 | ||
598 | #ifdef XP_UNIX | |
599 | typedef DIR* SYS_DIR; | |
600 | typedef struct dirent SYS_DIRENT; | |
601 | #endif /* XP_UNIX */ | |
602 | ||
603 | #ifdef XP_WIN32 | |
604 | ||
605 | typedef struct dirent_s dirent_s; | |
606 | struct dirent_s { | |
607 | char *d_name; | |
608 | }; | |
609 | ||
610 | typedef struct dir_s dir_s; | |
611 | struct dir_s { | |
612 | HANDLE dp; | |
613 | WIN32_FIND_DATA fdata; | |
614 | dirent_s de; | |
615 | }; | |
616 | ||
617 | typedef dir_s* SYS_DIR; | |
618 | typedef dirent_s SYS_DIRENT; | |
619 | ||
620 | #endif /* XP_WIN32 */ | |
621 | ||
622 | typedef struct pb_param pb_param; | |
623 | struct pb_param { | |
624 | char *name,*value; | |
625 | }; | |
626 | ||
627 | typedef struct pb_entry pb_entry; | |
628 | struct pb_entry { | |
629 | pb_param *param; | |
630 | struct pb_entry *next; | |
631 | }; | |
632 | ||
633 | typedef struct pblock pblock; | |
634 | struct pblock { | |
635 | int hsize; | |
636 | struct pb_entry **ht; | |
637 | }; | |
638 | ||
639 | #ifndef POOL_HANDLE_T | |
640 | #define POOL_HANDLE_T | |
641 | typedef void *pool_handle_t; | |
642 | #endif | |
643 | ||
644 | #ifndef SEMAPHORE_T | |
645 | typedef void *SEMAPHORE; | |
646 | #define SEMAPHORE_T void * | |
647 | #endif /* !SEMAPHORE_T */ | |
648 | ||
649 | #define SESSION_HASHSIZE 5 | |
650 | ||
651 | typedef struct PListStruct_s PListStruct_s; | |
652 | typedef struct ACLListHandle ACLListHandle; | |
54 | 653 | typedef struct VFS VFS; |
654 | typedef struct VFSContext VFSContext; | |
1 | 655 | |
656 | #ifndef PR_AF_INET | |
657 | typedef union PRNetAddr PRNetAddr; | |
658 | #endif | |
659 | ||
660 | typedef struct Session Session; | |
661 | typedef struct Request Request; | |
662 | struct Session { | |
663 | pblock *client; /* client-specific information */ | |
664 | ||
665 | SYS_NETFD csd; /* client file descriptor */ | |
666 | netbuf *inbuf; /* input buffer */ | |
667 | int csd_open; | |
668 | ||
669 | struct in_addr iaddr; | |
670 | ||
671 | pool_handle_t *pool; | |
672 | ||
673 | void *clauth; /* v2 ACL client authentication information */ | |
674 | struct Session *next; | |
675 | int fill; | |
676 | struct sockaddr_in local_addr; /* local addr for this session */ | |
677 | ||
678 | PListStruct_s *subject; | |
679 | int ssl; /* 0 = SSL OFF, 1 = SSL ON */ | |
680 | int clientauth; /* 0 = client auth OFF, 1 = client auth ON */ | |
681 | ||
682 | PRNetAddr *pr_client_addr; | |
683 | PRNetAddr *pr_local_addr; | |
684 | }; | |
685 | ||
686 | /* | |
687 | * FuncPtr is a pointer to an NSAPI SAF function | |
688 | */ | |
689 | ||
690 | #ifdef XP_UNIX | |
691 | typedef int Func(pblock *, Session *, Request *); | |
692 | #else /* XP_WIN32 */ | |
693 | typedef int _cdecl Func(pblock *, Session *, Request *); | |
694 | #endif /* XP_WIN32 */ | |
695 | ||
696 | typedef Func *FuncPtr; | |
697 | ||
698 | /* | |
699 | * FuncStruct is a structure used in the static declaration of the | |
700 | * functions. This static declaration is parsed into a hash table at | |
701 | * startup. | |
702 | */ | |
703 | ||
704 | typedef struct FuncStruct FuncStruct; | |
705 | ||
706 | struct FuncStruct { | |
707 | const char * name; | |
708 | FuncPtr func; | |
709 | struct FuncStruct *next; | |
710 | unsigned flags; | |
711 | unsigned poolID; | |
712 | unsigned pool_resolved; | |
713 | }; | |
714 | ||
19
d680536f8c2f
Added configuration manager
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
14
diff
changeset
|
715 | ////// new |
d680536f8c2f
Added configuration manager
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
14
diff
changeset
|
716 | |
d680536f8c2f
Added configuration manager
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
14
diff
changeset
|
717 | typedef struct _http_listener HttpListener; |
d680536f8c2f
Added configuration manager
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
14
diff
changeset
|
718 | |
d680536f8c2f
Added configuration manager
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
14
diff
changeset
|
719 | ////// |
1 | 720 | /* |
721 | * VSInitFunc, VSDestroyFunc, VSDirectiveInitFunc and VSDirectiveDestroyFunc | |
722 | */ | |
723 | typedef struct VirtualServer VirtualServer; | |
724 | typedef int VSInitFunc(VirtualServer *incoming, const VirtualServer *current); | |
725 | typedef void VSDestroyFunc(VirtualServer *outgoing); | |
726 | typedef VSInitFunc *VSInitFuncPtr; | |
727 | typedef VSDestroyFunc *VSDestroyFuncPtr; | |
728 | typedef int VSDirectiveInitFunc(const directive *dir, VirtualServer *incoming, const VirtualServer *current); | |
729 | typedef void VSDirectiveDestroyFunc(const directive *dir, VirtualServer *outgoing); | |
730 | typedef VSDirectiveInitFunc *VSDirectiveInitFuncPtr; | |
731 | typedef VSDirectiveDestroyFunc *VSDirectiveDestroyFuncPtr; | |
732 | ||
733 | /* | |
734 | * Filter is an opaque filter identifier | |
735 | */ | |
736 | typedef struct Filter Filter; | |
737 | ||
738 | /* | |
739 | * FilterContext stores context associated with a particular filter layer | |
740 | */ | |
741 | ||
742 | typedef struct FilterContext FilterContext; | |
743 | ||
744 | struct FilterContext { | |
745 | pool_handle_t *pool; /* pool context was allocated from */ | |
746 | Session *sn; /* session being processed */ | |
747 | Request *rq; /* request being processed */ | |
748 | void *data; /* filter-defined private data */ | |
749 | }; | |
750 | ||
751 | /* | |
752 | * FilterLayer represents one layer of a filter stack | |
753 | */ | |
754 | ||
755 | typedef struct FilterLayer FilterLayer; | |
756 | ||
757 | struct FilterLayer { | |
758 | Filter *filter; /* the filter at this layer in the filter stack */ | |
759 | FilterContext *context; /* context for the filter */ | |
760 | SYS_NETFD lower; /* access to the next filter layer in the stack */ | |
761 | }; | |
762 | ||
763 | /* | |
764 | * Function prototypes for filter methods | |
765 | */ | |
21
627b09ee74e4
New configuration loader
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
19
diff
changeset
|
766 | |
627b09ee74e4
New configuration loader
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
19
diff
changeset
|
767 | /* |
627b09ee74e4
New configuration loader
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
19
diff
changeset
|
768 | * TODO: modified: added * bevor Filter...Func |
627b09ee74e4
New configuration loader
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
19
diff
changeset
|
769 | */ |
627b09ee74e4
New configuration loader
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
19
diff
changeset
|
770 | typedef int (*FilterInsertFunc)(FilterLayer *layer, pblock *pb); |
627b09ee74e4
New configuration loader
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
19
diff
changeset
|
771 | typedef void (*FilterRemoveFunc)(FilterLayer *layer); |
627b09ee74e4
New configuration loader
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
19
diff
changeset
|
772 | typedef int (*FilterFlushFunc)(FilterLayer *layer); |
627b09ee74e4
New configuration loader
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
19
diff
changeset
|
773 | typedef int (*FilterReadFunc)(FilterLayer *layer, void *buf, int amount, int timeout); |
627b09ee74e4
New configuration loader
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
19
diff
changeset
|
774 | typedef int (*FilterWriteFunc)(FilterLayer *layer, const void *buf, int amount); |
627b09ee74e4
New configuration loader
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
19
diff
changeset
|
775 | typedef int (*FilterWritevFunc)(FilterLayer *layer, const NSAPIIOVec *iov, int iov_size); |
627b09ee74e4
New configuration loader
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
19
diff
changeset
|
776 | typedef int (*FilterSendfileFunc)(FilterLayer *layer, sendfiledata *sfd); |
1 | 777 | |
778 | /* | |
779 | * FilterMethods is passed to filter_create() to declare the filter methods for | |
780 | * a new filter. Each instance of the FilterMethods structure should be | |
781 | * initialized using the FILTER_METHODS_INITIALIZER macro. | |
782 | */ | |
783 | ||
784 | typedef struct FilterMethods FilterMethods; | |
785 | ||
786 | struct FilterMethods { | |
787 | size_t size; | |
788 | #if NSAPI_VERSION >= 302 | |
789 | FilterInsertFunc *insert; | |
790 | FilterRemoveFunc *remove; | |
791 | FilterFlushFunc *flush; | |
792 | FilterReadFunc *read; | |
793 | FilterWriteFunc *write; | |
794 | FilterWritevFunc *writev; | |
795 | FilterSendfileFunc *sendfile; | |
796 | #else | |
797 | void *reserved1; | |
798 | void *reserved2; | |
799 | void *reserved3; | |
800 | void *reserved4; | |
801 | void *reserved5; | |
802 | void *reserved6; | |
803 | void *reserved7; | |
804 | #endif /* NSAPI_VERSION >= 302 */ | |
805 | }; | |
806 | ||
807 | #define FILTER_METHODS_INITIALIZER \ | |
808 | { \ | |
809 | sizeof(FilterMethods), \ | |
810 | NULL, /* insert */ \ | |
811 | NULL, /* remove */ \ | |
812 | NULL, /* flush */ \ | |
813 | NULL, /* read */ \ | |
814 | NULL, /* write */ \ | |
815 | NULL, /* writev */ \ | |
816 | NULL /* sendfile */ \ | |
817 | } | |
818 | ||
819 | /* | |
820 | * Filter order definitions for filter_create() | |
821 | */ | |
822 | #define FILTER_CONTENT_GENERATION 0xf0000 | |
823 | #define FILTER_CONTENT_TRANSLATION_HIGH 0xa0000 | |
824 | #define FILTER_CONTENT_TRANSLATION 0x90000 | |
825 | #define FILTER_CONTENT_TRANSLATION_LOW 0x80000 | |
826 | #define FILTER_CONTENT_CODING 0x50000 | |
827 | #define FILTER_TRANSFER_CODING 0x40000 | |
828 | #define FILTER_MESSAGE_CODING 0x30000 | |
829 | #define FILTER_TRANSPORT_CODING 0x20000 | |
830 | #define FILTER_NETWORK 0x10000 | |
831 | ||
832 | typedef struct shmem_s shmem_s; | |
833 | struct shmem_s { | |
834 | void *data; /* the data */ | |
835 | #ifdef XP_WIN32 | |
836 | HANDLE fdmap; | |
837 | #endif /* XP_WIN32 */ | |
838 | int size; /* the maximum length of the data */ | |
839 | ||
840 | char *name; /* internal use: filename to unlink if exposed */ | |
841 | SYS_FILE fd; /* internal use: file descriptor for region */ | |
842 | }; | |
843 | ||
844 | /* Define a handle for a thread */ | |
29
e8619defde14
added event handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
23
diff
changeset
|
845 | //typedef void* SYS_THREAD; |
e8619defde14
added event handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
23
diff
changeset
|
846 | typedef pthread_t SYS_THREAD; |
1 | 847 | |
848 | /* Define an error value for the thread handle */ | |
849 | #define SYS_THREAD_ERROR NULL | |
850 | ||
851 | ||
852 | typedef struct conf_global_vars_s conf_global_vars_s; | |
853 | struct conf_global_vars_s { | |
854 | ||
855 | /* What port we listen to */ | |
856 | int Vport; /* OBSOLETE */ | |
9
30e51941a673
Added mod_jk dependencies
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
8
diff
changeset
|
857 | #define server_portnum 80 |
1 | 858 | |
859 | /* What address to bind to */ | |
860 | char *Vaddr; /* OBSOLETE */ | |
861 | ||
862 | /* User to run as */ | |
863 | struct passwd *Vuserpw; | |
864 | ||
865 | /* Directory to chroot to */ | |
866 | char *Vchr; | |
867 | ||
868 | /* Where to log our pid to */ | |
869 | char *Vpidfn; | |
870 | ||
871 | #define pool_max conf_getglobals()->Vpool_max | |
872 | int Vpool_max; | |
873 | #define pool_min conf_getglobals()->Vpool_min | |
874 | int Vpool_min; /* OBSOLETE */ | |
875 | #define pool_life conf_getglobals()->Vpool_life | |
876 | int Vpool_life; /* OBSOLETE */ | |
877 | ||
878 | /* For multiprocess UNIX servers, the maximum threads per process */ | |
879 | #define pool_maxthreads conf_getglobals()->Vpool_maxthreads | |
880 | int Vpool_maxthreads; | |
881 | ||
882 | #define pool_minthreads conf_getglobals()->Vpool_minthreads | |
883 | int Vpool_minthreads; /* OBSOLETE */ | |
884 | ||
885 | char *Vsecure_keyfn; /* OBSOLETE */ | |
886 | char *Vsecure_certfn; /* OBSOLETE */ | |
887 | ||
9
30e51941a673
Added mod_jk dependencies
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
8
diff
changeset
|
888 | #define security_active 0 |
1 | 889 | int Vsecurity_active; |
890 | int Vssl3_active; /* OBSOLETE */ | |
891 | int Vssl2_active; /* OBSOLETE */ | |
892 | int Vsecure_auth; /* OBSOLETE */ | |
893 | int Vsecurity_session_timeout; | |
894 | long Vssl3_session_timeout; | |
895 | ||
896 | /* The server's hostname as should be reported in self-ref URLs */ | |
47
ce9790523346
server can change uid
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
29
diff
changeset
|
897 | #define server_hostname "x4" // TODO: fix |
1 | 898 | char *Vserver_hostname; |
899 | ||
900 | /* The main object from which all are derived */ | |
901 | #define root_object conf_getglobals()->Vroot_object | |
902 | char *Vroot_object; | |
903 | ||
904 | /* The object set the administrator has asked us to load */ | |
905 | #define std_os conf_getglobals()->Vstd_os | |
906 | httpd_objset *Vstd_os; | |
907 | ||
908 | /* The root of ACL data structures */ | |
909 | void *Vacl_root; | |
910 | ||
911 | /* The main error log, where all errors are logged */ | |
912 | char *Vmaster_error_log; | |
913 | ||
914 | /* The server root directory (contains instance subdirectories) */ | |
915 | #define server_root conf_getglobals()->Vserver_root | |
916 | char *Vserver_root; | |
917 | ||
918 | /* This server's id */ | |
919 | #define server_id conf_getglobals()->Vserver_id | |
920 | char *Vserver_id; | |
921 | ||
922 | /* Admin server users file */ | |
923 | char *Vadmin_users; | |
924 | ||
925 | /* The installation directory (contains bin and lib subdirectories) */ | |
926 | char *Vnetsite_root; | |
927 | ||
928 | /* Digest authentication stale nonce timeout value */ | |
929 | int digest_stale_timeout; | |
930 | ||
931 | int single_accept; /* OBSOLETE */ | |
932 | int num_keep_alives; /* OBSOLETE */ | |
933 | int log_verbose; /* OBSOLETE */ | |
934 | int mmap_flags; /* OBSOLETE */ | |
935 | int mmap_prots; /* OBSOLETE */ | |
936 | int unused1; | |
937 | int unused2; | |
938 | ||
939 | /* Begin Enterprise 3.0 fields */ | |
940 | int accept_language; /* turn accept-language on/off */ | |
941 | ||
942 | char *mtahost; | |
943 | char *nntphost; /* OBSOLETE */ | |
944 | ||
945 | /* The root of ACL data structures */ | |
946 | void *Vacl_root_30; | |
947 | ||
948 | char *agentFilePath; /* OBSOLETE */ | |
949 | ||
950 | int Allowed; /* OBSOLETE */ | |
951 | ||
952 | pblock *genericGlobals; /* OBSOLETE */ | |
953 | ||
954 | char *agentsACLFile; /* OBSOLETE */ | |
955 | ||
956 | int wait_for_cgi; /* OBSOLETE */ | |
957 | int cgiwatch_timeout; /* OBSOLETE */ | |
958 | int started_by_watchdog; | |
959 | int restarted_by_watchdog; | |
960 | int old_accel_cache_enabled; /* OBSOLETE */ | |
961 | int Vssl_cache_entries; | |
962 | int blocking_listen_socket; /* OBSOLETE */ | |
963 | pblock **initfns; | |
964 | char *vs_config_file; /* OBSOLETE */ | |
965 | }; | |
966 | ||
967 | /* Type used for Request rq_attr bit flags */ | |
968 | #ifdef AIX | |
969 | #define RQATTR unsigned | |
970 | #else | |
971 | #define RQATTR unsigned long | |
972 | #endif | |
973 | ||
974 | struct Request { | |
975 | /* Server working variables */ | |
976 | pblock *vars; | |
977 | ||
978 | /* The method, URI, and protocol revision of this request */ | |
979 | pblock *reqpb; | |
980 | /* Protocol specific headers */ | |
981 | int loadhdrs; | |
982 | pblock *headers; | |
983 | ||
984 | /* Server's response headers */ | |
985 | int senthdrs; | |
986 | pblock *srvhdrs; | |
987 | ||
988 | /* The object set constructed to fulfill this request */ | |
989 | httpd_objset *os; | |
990 | /* Array of objects that were created from .nsconfig files */ | |
991 | httpd_objset *tmpos; | |
992 | ||
993 | /* The stat last returned by request_stat_path */ | |
994 | char *statpath; | |
995 | char *staterr; | |
996 | struct stat *finfo; | |
997 | ||
998 | /* access control state */ | |
999 | int aclstate; /* ACL decision state */ | |
1000 | int acldirno; /* deciding ACL directive number */ | |
1001 | char *aclname; /* name of deciding ACL */ | |
1002 | pblock *aclpb; /* OBSOLETE */ | |
1003 | /* 3.0 ACL list pointer */ | |
1004 | ACLListHandle *acllist; | |
52
aced2245fb1c
new pathcheck saf and code cleanup
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
47
diff
changeset
|
1005 | uint32_t aclreqaccess; /* new - required access rights */ |
54 | 1006 | |
1007 | VFS *vfs; /* new - virtual file system */ | |
59
ab25c0a231d0
some fixes and new public APIs
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
58
diff
changeset
|
1008 | |
ab25c0a231d0
some fixes and new public APIs
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
58
diff
changeset
|
1009 | void *davCollection; |
1 | 1010 | |
1011 | int request_is_cacheable; /* */ | |
1012 | int directive_is_cacheable; /* set by SAFs with no external side effects that make decisions based solely on URI and path */ | |
1013 | ||
1014 | char *cached_headers; /* OBSOLETE */ | |
1015 | int cached_headers_len; /* OBSOLETE */ | |
1016 | char *unused; | |
1017 | ||
1018 | /* HTTP/1.1 features */ | |
1019 | #define REQ_TIME(x) (x)->req_start | |
1020 | time_t req_start; /* time request arrived - used for selecting weak or strong cache validation */ | |
1021 | short protv_num; /* protocol version number */ | |
1022 | short method_num; /* method number */ | |
1023 | struct rq_attr { | |
1024 | RQATTR abs_uri:1; /* set if absolute URI was used */ | |
1025 | RQATTR chunked:1; /* chunked transfer-coding */ | |
1026 | RQATTR keep_alive:1; /* connection keep-alive */ | |
1027 | RQATTR pipelined:1; /* request packet is pipelined */ | |
1028 | RQATTR internal_req:1; /* this was an internal request */ | |
1029 | RQATTR perm_req:1; /* don't FREE() this request */ | |
1030 | RQATTR header_file_present:1; /* OBSOLETE */ | |
1031 | RQATTR footer_file_present:1; /* OBSOLETE */ | |
1032 | RQATTR jvm_attached:1; /* OBSOLETE */ | |
1033 | RQATTR req_restarted:1; /* request was restarted */ | |
1034 | RQATTR jvm_request_locked:1; /* used for first-request serialization on some platforms */ | |
1035 | RQATTR default_type_set:1; /* set if default types were set using set-default-type objecttype function */ | |
1036 | RQATTR is_web_app:1; /* OBSOLETE */ | |
1037 | RQATTR ssl_unclean_shutdown:1; /* set if browser requires unclean SSL shutdown */ | |
1038 | RQATTR vary_accept_language:1; /* set if request was restarted based on an accept-language header */ | |
1039 | RQATTR reserved:17; /* if you add a flag, make sure to subtract from this */ | |
1040 | } rq_attr; | |
1041 | char *hostname; /* hostname used to access server (always non-NULL) */ | |
1042 | int allowed; /* OBSOLETE */ | |
1043 | int byterange; /* OBSOLETE */ | |
1044 | short status_num; /* HTTP status code */ | |
1045 | ||
1046 | int staterrno; /* used for rqstat */ | |
1047 | Request *orig_rq; /* original Request - used for internal redirects */ | |
1048 | }; | |
1049 | ||
1050 | /* Request attribute macros */ | |
1051 | #define ABS_URI(x) (x)->rq_attr.abs_uri | |
1052 | #define CHUNKED(x) (x)->rq_attr.chunked | |
1053 | #define KEEP_ALIVE(x) (x)->rq_attr.keep_alive | |
1054 | #define PIPELINED(x) (x)->rq_attr.pipelined | |
1055 | #define INTERNAL_REQUEST(x) (x)->rq_attr.internal_req | |
1056 | #define RESTARTED_REQUEST(x) (x)->rq_attr.req_restarted | |
1057 | #define PERM_REQUEST(x) (x)->rq_attr.perm_req | |
1058 | #define JVM_REQUEST_LOCKED(x) (x)->rq_attr.jvm_request_locked | |
1059 | #define SSL_UNCLEAN_SHUTDOWN(x) (x)->rq_attr.ssl_unclean_shutdown | |
1060 | #define VARY_ACCEPT_LANGUAGE(x) (x)->rq_attr.vary_accept_language | |
1061 | ||
1062 | /* Define methods for HTTP/1.1 */ | |
1063 | #define METHOD_HEAD 0 | |
1064 | #define METHOD_GET 1 | |
1065 | #define METHOD_PUT 2 | |
1066 | #define METHOD_POST 3 | |
1067 | #define METHOD_DELETE 4 | |
1068 | #define METHOD_TRACE 5 | |
1069 | #define METHOD_OPTIONS 6 | |
1070 | /* The following methods are Netscape method extensions */ | |
1071 | #define METHOD_MOVE 7 | |
1072 | #define METHOD_INDEX 8 | |
1073 | #define METHOD_MKDIR 9 | |
1074 | #define METHOD_RMDIR 10 | |
1075 | #define METHOD_COPY 11 | |
1076 | #define METHOD_MAX 12 /* Number of methods available on this server */ | |
1077 | ||
1078 | #define ISMGET(r) ((r)->method_num == METHOD_GET) | |
1079 | #define ISMHEAD(r) ((r)->method_num == METHOD_HEAD) | |
1080 | #define ISMPUT(r) ((r)->method_num == METHOD_PUT) | |
1081 | #define ISMPOST(r) ((r)->method_num == METHOD_POST) | |
1082 | #define ISMDELETE(r) ((r)->method_num == METHOD_DELETE) | |
1083 | #define ISMMOVE(r) ((r)->method_num == METHOD_MOVE) | |
1084 | #define ISMINDEX(r) ((r)->method_num == METHOD_INDEX) | |
1085 | #define ISMMKDIR(r) ((r)->method_num == METHOD_MKDIR) | |
1086 | #define ISMRMDIR(r) ((r)->method_num == METHOD_RMDIR) | |
1087 | #define ISMCOPY(r) ((r)->method_num == METHOD_COPY) | |
1088 | #define ISMTRACE(r) ((r)->method_num == METHOD_TRACE) | |
1089 | #define ISMOPTIONS(r) ((r)->method_num == METHOD_OPTIONS) | |
1090 | ||
1091 | ||
59
ab25c0a231d0
some fixes and new public APIs
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
58
diff
changeset
|
1092 | // new type |
ab25c0a231d0
some fixes and new public APIs
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
58
diff
changeset
|
1093 | typedef struct _thread_pool threadpool_t; |
ab25c0a231d0
some fixes and new public APIs
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
58
diff
changeset
|
1094 | typedef struct _threadpool_job threadpool_job; |
ab25c0a231d0
some fixes and new public APIs
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
58
diff
changeset
|
1095 | typedef void*(*job_callback_f)(void *data); |
ab25c0a231d0
some fixes and new public APIs
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
58
diff
changeset
|
1096 | |
1 | 1097 | /* --- End type definitions --- */ |
1098 | ||
1099 | /* --- Begin dispatch vector table definition --- */ | |
1100 | /* --- End dispatch vector table definition --- */ | |
1101 | ||
1102 | /* --- Begin API macro definitions --- */ | |
1103 | ||
1104 | #ifndef INTNSAPI | |
1105 | ||
1106 | #if NSAPI_VERSION >= 301 | |
1107 | ||
1108 | /* | |
1109 | * In Sun ONE Web Server 6.1 and higher, http_parse_request("", NULL, NULL) | |
1110 | * returns the NSAPI version. In previous releases, it returns -1. | |
1111 | */ | |
68
f5102a892ed4
some fixes for mod_jk
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
67
diff
changeset
|
1112 | //define __NSAPI_RUNTIME_VERSION \ |
f5102a892ed4
some fixes for mod_jk
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
67
diff
changeset
|
1113 | // ((*__nsapi30_table->f_http_parse_request)("", NULL, NULL)) |
f5102a892ed4
some fixes for mod_jk
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
67
diff
changeset
|
1114 | |
f5102a892ed4
some fixes for mod_jk
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
67
diff
changeset
|
1115 | // new: |
f5102a892ed4
some fixes for mod_jk
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
67
diff
changeset
|
1116 | #define __NSAPI_RUNTIME_VERSION nsapi_runtime_version() |
1 | 1117 | |
1118 | /* | |
1119 | * NSAPI_RUNTIME_VERSION returns the NSAPI version the server implements. The | |
1120 | * returned NSAPI version number is reliable only in iPlanet Web Server 6.0, | |
1121 | * Netscape Enterprise Server 6.0, and Sun ONE Web Server 6.0 and higher. | |
1122 | */ | |
68
f5102a892ed4
some fixes for mod_jk
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
67
diff
changeset
|
1123 | //define NSAPI_RUNTIME_VERSION \ |
f5102a892ed4
some fixes for mod_jk
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
67
diff
changeset
|
1124 | // (__NSAPI_RUNTIME_VERSION > 0 ? __NSAPI_RUNTIME_VERSION : 301) |
f5102a892ed4
some fixes for mod_jk
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
67
diff
changeset
|
1125 | |
f5102a892ed4
some fixes for mod_jk
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
67
diff
changeset
|
1126 | // new: |
f5102a892ed4
some fixes for mod_jk
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
67
diff
changeset
|
1127 | #define NSAPI_RUNTIME_VERSION nsapi_runtime_version() |
1 | 1128 | |
1129 | #endif /* NSAPI_VERSION >= 301 */ | |
1130 | ||
68
f5102a892ed4
some fixes for mod_jk
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
67
diff
changeset
|
1131 | //define system_version (*__nsapi30_table->f_system_version) |
f5102a892ed4
some fixes for mod_jk
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
67
diff
changeset
|
1132 | // new: |
f5102a892ed4
some fixes for mod_jk
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
67
diff
changeset
|
1133 | NSAPI_PUBLIC char* system_version(); |
1 | 1134 | |
1135 | /* | |
1136 | * Depending on the system, memory allocated via these macros may come from | |
1137 | * an arena. If these functions are called from within an Init function, they | |
1138 | * will be allocated from permanent storage. Otherwise, they will be freed | |
1139 | * when the current request is finished. | |
1140 | */ | |
1141 | ||
1142 | ||
1143 | ||
1144 | #endif /* !INTNSAPI */ | |
1145 | ||
1146 | #ifdef XP_UNIX | |
1147 | #define dir_open opendir | |
1148 | #define dir_read readdir | |
1149 | #define dir_close closedir | |
1150 | #define dir_create(path) mkdir(path, 0755) | |
1151 | #define dir_remove rmdir | |
1152 | #define system_chdir chdir | |
1153 | #define file_unix2local(path,p2) strcpy(p2,path) | |
1154 | #endif /* XP_UNIX */ | |
1155 | ||
1156 | #ifdef XP_WIN32 | |
1157 | #define dir_create _mkdir | |
1158 | #define dir_remove _rmdir | |
1159 | #define system_chdir SetCurrentDirectory | |
1160 | #endif /* XP_WIN32 */ | |
1161 | ||
1162 | /* | |
1163 | * Thread-safe variants of localtime and gmtime | |
1164 | */ | |
1165 | #define system_localtime(curtime, ret) util_localtime(curtime, ret) | |
1166 | #define system_gmtime(curtime, ret) util_gmtime(curtime, ret) | |
1167 | ||
1168 | /* | |
1169 | * pblock_find finds the entry with the given name in pblock pb. | |
1170 | * | |
1171 | * If it is successful, it returns the param block. If not, it returns NULL. | |
1172 | */ | |
1173 | #define pblock_find(name, pb) (pblock_fr(name,pb,0)) | |
1174 | ||
1175 | /* | |
1176 | * pblock_remove behaves exactly like pblock_find, but removes the given | |
1177 | * entry from pb. | |
1178 | */ | |
1179 | #define pblock_remove(name, pb) (pblock_fr(name,pb,1)) | |
1180 | ||
1181 | /* | |
1182 | * session_dns returns the DNS hostname of the client of this session, | |
1183 | * and inserts it into the client pblock. Returns NULL if unavailable. | |
1184 | */ | |
1185 | #define session_dns(sn) session_dns_lookup(sn, 0) | |
1186 | ||
1187 | /* | |
1188 | * session_maxdns looks up a hostname from an IP address, and then verifies | |
1189 | * that the host is really who they claim to be. | |
1190 | */ | |
1191 | #define session_maxdns(sn) session_dns_lookup(sn, 1) | |
1192 | ||
9
30e51941a673
Added mod_jk dependencies
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
8
diff
changeset
|
1193 | |
30e51941a673
Added mod_jk dependencies
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
8
diff
changeset
|
1194 | /* nsapi functions */ |
30e51941a673
Added mod_jk dependencies
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
8
diff
changeset
|
1195 | |
47
ce9790523346
server can change uid
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
29
diff
changeset
|
1196 | NSAPI_PUBLIC conf_global_vars_s* conf_getglobals(); |
ce9790523346
server can change uid
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
29
diff
changeset
|
1197 | |
61
c858850f3d3a
improved configuration reloading
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
59
diff
changeset
|
1198 | /* |
c858850f3d3a
improved configuration reloading
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
59
diff
changeset
|
1199 | * Query the VirtualServer* associated with a given Request*. |
c858850f3d3a
improved configuration reloading
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
59
diff
changeset
|
1200 | */ |
c858850f3d3a
improved configuration reloading
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
59
diff
changeset
|
1201 | const VirtualServer* request_get_vs(Request *rq); |
c858850f3d3a
improved configuration reloading
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
59
diff
changeset
|
1202 | #define request_get_vs request_get_vs |
c858850f3d3a
improved configuration reloading
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
59
diff
changeset
|
1203 | |
c858850f3d3a
improved configuration reloading
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
59
diff
changeset
|
1204 | |
9
30e51941a673
Added mod_jk dependencies
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
8
diff
changeset
|
1205 | ssize_t net_write(SYS_NETFD fd, void *buf, size_t nbytes); |
64
c7f5b062e622
added net_writev
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
63
diff
changeset
|
1206 | ssize_t net_writev(SYS_NETFD fd, struct iovec *iovec, int iovcnt); |
9
30e51941a673
Added mod_jk dependencies
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
8
diff
changeset
|
1207 | |
64
c7f5b062e622
added net_writev
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
63
diff
changeset
|
1208 | // NSAPI extension |
23
a2c8fc23c90e
Added basic authentication
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
21
diff
changeset
|
1209 | ssize_t net_printf(SYS_NETFD fd, char *format, ...); |
a2c8fc23c90e
Added basic authentication
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
21
diff
changeset
|
1210 | |
a2c8fc23c90e
Added basic authentication
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
21
diff
changeset
|
1211 | |
9
30e51941a673
Added mod_jk dependencies
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
8
diff
changeset
|
1212 | NSAPI_PUBLIC pb_param *INTparam_create(const char *name, const char *value); |
30e51941a673
Added mod_jk dependencies
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
8
diff
changeset
|
1213 | |
30e51941a673
Added mod_jk dependencies
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
8
diff
changeset
|
1214 | NSAPI_PUBLIC int INTparam_free(pb_param *pp); |
30e51941a673
Added mod_jk dependencies
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
8
diff
changeset
|
1215 | |
30e51941a673
Added mod_jk dependencies
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
8
diff
changeset
|
1216 | NSAPI_PUBLIC pblock *INTpblock_create(int n); |
30e51941a673
Added mod_jk dependencies
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
8
diff
changeset
|
1217 | |
30e51941a673
Added mod_jk dependencies
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
8
diff
changeset
|
1218 | NSAPI_PUBLIC void INTpblock_free(pblock *pb); |
30e51941a673
Added mod_jk dependencies
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
8
diff
changeset
|
1219 | |
30e51941a673
Added mod_jk dependencies
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
8
diff
changeset
|
1220 | NSAPI_PUBLIC char *INTpblock_findval(const char *name, const pblock *pb); |
30e51941a673
Added mod_jk dependencies
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
8
diff
changeset
|
1221 | |
30e51941a673
Added mod_jk dependencies
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
8
diff
changeset
|
1222 | NSAPI_PUBLIC pb_param *INTpblock_nvinsert(const char *name, const char *value, pblock *pb); |
30e51941a673
Added mod_jk dependencies
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
8
diff
changeset
|
1223 | |
30e51941a673
Added mod_jk dependencies
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
8
diff
changeset
|
1224 | NSAPI_PUBLIC pb_param *pblock_nvlinsert(const char *name, int namelen, const char *value, int valuelen, pblock *pb); |
30e51941a673
Added mod_jk dependencies
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
8
diff
changeset
|
1225 | |
30e51941a673
Added mod_jk dependencies
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
8
diff
changeset
|
1226 | NSAPI_PUBLIC pb_param *INTpblock_nninsert(const char *name, int value, pblock *pb); |
30e51941a673
Added mod_jk dependencies
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
8
diff
changeset
|
1227 | |
30e51941a673
Added mod_jk dependencies
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
8
diff
changeset
|
1228 | NSAPI_PUBLIC void INTpblock_pinsert(pb_param *pp, pblock *pb); |
30e51941a673
Added mod_jk dependencies
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
8
diff
changeset
|
1229 | |
30e51941a673
Added mod_jk dependencies
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
8
diff
changeset
|
1230 | NSAPI_PUBLIC int INTpblock_str2pblock(const char *str, pblock *pb); |
30e51941a673
Added mod_jk dependencies
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
8
diff
changeset
|
1231 | |
30e51941a673
Added mod_jk dependencies
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
8
diff
changeset
|
1232 | NSAPI_PUBLIC char *INTpblock_pblock2str(const pblock *pb, char *str); |
30e51941a673
Added mod_jk dependencies
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
8
diff
changeset
|
1233 | |
30e51941a673
Added mod_jk dependencies
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
8
diff
changeset
|
1234 | NSAPI_PUBLIC int INTpblock_copy(const pblock *src, pblock *dst); |
30e51941a673
Added mod_jk dependencies
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
8
diff
changeset
|
1235 | |
30e51941a673
Added mod_jk dependencies
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
8
diff
changeset
|
1236 | NSAPI_PUBLIC pblock *INTpblock_dup(const pblock *src); |
30e51941a673
Added mod_jk dependencies
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
8
diff
changeset
|
1237 | |
30e51941a673
Added mod_jk dependencies
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
8
diff
changeset
|
1238 | NSAPI_PUBLIC char **INTpblock_pb2env(const pblock *pb, char **env); |
30e51941a673
Added mod_jk dependencies
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
8
diff
changeset
|
1239 | |
30e51941a673
Added mod_jk dependencies
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
8
diff
changeset
|
1240 | NSAPI_PUBLIC void pblock_nvreplace (const char *name, const char *value, pblock *pb); |
30e51941a673
Added mod_jk dependencies
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
8
diff
changeset
|
1241 | |
30e51941a673
Added mod_jk dependencies
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
8
diff
changeset
|
1242 | NSAPI_PUBLIC pb_param *pblock_param_create(pblock *pb, const char *name, const char *value); |
30e51941a673
Added mod_jk dependencies
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
8
diff
changeset
|
1243 | |
30e51941a673
Added mod_jk dependencies
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
8
diff
changeset
|
1244 | NSAPI_PUBLIC pblock *pblock_create_pool(pool_handle_t *pool_handle, int n); |
30e51941a673
Added mod_jk dependencies
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
8
diff
changeset
|
1245 | |
30e51941a673
Added mod_jk dependencies
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
8
diff
changeset
|
1246 | NSAPI_PUBLIC pb_param *INTpblock_fr(const char *name, pblock *pb, int remove); |
30e51941a673
Added mod_jk dependencies
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
8
diff
changeset
|
1247 | |
30e51941a673
Added mod_jk dependencies
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
8
diff
changeset
|
1248 | NSAPI_PUBLIC char *INTpblock_replace(const char *name,char * new_value,pblock *pb); |
30e51941a673
Added mod_jk dependencies
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
8
diff
changeset
|
1249 | |
30e51941a673
Added mod_jk dependencies
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
8
diff
changeset
|
1250 | NSAPI_PUBLIC int INTpblock_str2pblock_lowercasename(const char *str, pblock *pb); |
30e51941a673
Added mod_jk dependencies
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
8
diff
changeset
|
1251 | |
30e51941a673
Added mod_jk dependencies
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
8
diff
changeset
|
1252 | //NSAPI_PUBLIC pb_param *pblock_removeone(pblock *pb); |
30e51941a673
Added mod_jk dependencies
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
8
diff
changeset
|
1253 | |
30e51941a673
Added mod_jk dependencies
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
8
diff
changeset
|
1254 | //NSAPI_PUBLIC const pb_key *pblock_key(const char *name); |
30e51941a673
Added mod_jk dependencies
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
8
diff
changeset
|
1255 | |
30e51941a673
Added mod_jk dependencies
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
8
diff
changeset
|
1256 | //NSAPI_PUBLIC pb_param *pblock_key_param_create(pblock *pb, const pb_key *key, const char *value, int valuelen); |
30e51941a673
Added mod_jk dependencies
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
8
diff
changeset
|
1257 | |
30e51941a673
Added mod_jk dependencies
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
8
diff
changeset
|
1258 | //NSAPI_PUBLIC char *pblock_findkeyval(const pb_key *key, const pblock *pb); |
30e51941a673
Added mod_jk dependencies
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
8
diff
changeset
|
1259 | |
30e51941a673
Added mod_jk dependencies
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
8
diff
changeset
|
1260 | //NSAPI_PUBLIC pb_param *pblock_findkey(const pb_key *key, const pblock *pb); |
30e51941a673
Added mod_jk dependencies
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
8
diff
changeset
|
1261 | |
30e51941a673
Added mod_jk dependencies
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
8
diff
changeset
|
1262 | //NSAPI_PUBLIC pb_param *pblock_removekey(const pb_key *key, pblock *pb); |
30e51941a673
Added mod_jk dependencies
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
8
diff
changeset
|
1263 | |
30e51941a673
Added mod_jk dependencies
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
8
diff
changeset
|
1264 | //NSAPI_PUBLIC pb_param *pblock_kvinsert(const pb_key *key, const char *value, int valuelen, pblock *pb); |
30e51941a673
Added mod_jk dependencies
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
8
diff
changeset
|
1265 | |
30e51941a673
Added mod_jk dependencies
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
8
diff
changeset
|
1266 | //NSAPI_PUBLIC void pblock_kpinsert(const pb_key *key, pb_param *pp, pblock *pb); |
30e51941a673
Added mod_jk dependencies
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
8
diff
changeset
|
1267 | |
30e51941a673
Added mod_jk dependencies
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
8
diff
changeset
|
1268 | //NSAPI_PUBLIC void pblock_kvreplace(const pb_key *key, const char *value, int valuelen, pblock *pb); |
30e51941a673
Added mod_jk dependencies
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
8
diff
changeset
|
1269 | |
30e51941a673
Added mod_jk dependencies
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
8
diff
changeset
|
1270 | //NSAPI_PUBLIC pb_param *pblock_kninsert(const pb_key *key, int value, pblock *pb); |
30e51941a673
Added mod_jk dependencies
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
8
diff
changeset
|
1271 | |
30e51941a673
Added mod_jk dependencies
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
8
diff
changeset
|
1272 | //NSAPI_PUBLIC pb_param *pblock_kllinsert(const pb_key *key, PRInt64 value, pblock *pb); |
30e51941a673
Added mod_jk dependencies
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
8
diff
changeset
|
1273 | |
65
14722c5f8856
added chunked transfer encoding
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
64
diff
changeset
|
1274 | #define pblock_remove(name, pb) (pblock_fr(name,pb,1)) |
14722c5f8856
added chunked transfer encoding
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
64
diff
changeset
|
1275 | |
9
30e51941a673
Added mod_jk dependencies
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
8
diff
changeset
|
1276 | #define param_create INTparam_create |
30e51941a673
Added mod_jk dependencies
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
8
diff
changeset
|
1277 | #define param_free INTparam_free |
30e51941a673
Added mod_jk dependencies
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
8
diff
changeset
|
1278 | #define pblock_create INTpblock_create |
30e51941a673
Added mod_jk dependencies
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
8
diff
changeset
|
1279 | #define pblock_free INTpblock_free |
30e51941a673
Added mod_jk dependencies
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
8
diff
changeset
|
1280 | #define pblock_findval INTpblock_findval |
30e51941a673
Added mod_jk dependencies
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
8
diff
changeset
|
1281 | #define pblock_nvinsert INTpblock_nvinsert |
30e51941a673
Added mod_jk dependencies
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
8
diff
changeset
|
1282 | #define pblock_nninsert INTpblock_nninsert |
30e51941a673
Added mod_jk dependencies
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
8
diff
changeset
|
1283 | #define pblock_pinsert INTpblock_pinsert |
30e51941a673
Added mod_jk dependencies
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
8
diff
changeset
|
1284 | #define pblock_str2pblock INTpblock_str2pblock |
30e51941a673
Added mod_jk dependencies
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
8
diff
changeset
|
1285 | #define pblock_pblock2str INTpblock_pblock2str |
30e51941a673
Added mod_jk dependencies
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
8
diff
changeset
|
1286 | #define pblock_copy INTpblock_copy |
30e51941a673
Added mod_jk dependencies
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
8
diff
changeset
|
1287 | #define pblock_dup INTpblock_dup |
30e51941a673
Added mod_jk dependencies
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
8
diff
changeset
|
1288 | #define pblock_pb2env INTpblock_pb2env |
30e51941a673
Added mod_jk dependencies
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
8
diff
changeset
|
1289 | #define pblock_fr INTpblock_fr |
30e51941a673
Added mod_jk dependencies
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
8
diff
changeset
|
1290 | #define pblock_replace INTpblock_replace |
30e51941a673
Added mod_jk dependencies
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
8
diff
changeset
|
1291 | |
59
ab25c0a231d0
some fixes and new public APIs
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
58
diff
changeset
|
1292 | |
ab25c0a231d0
some fixes and new public APIs
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
58
diff
changeset
|
1293 | // pool |
ab25c0a231d0
some fixes and new public APIs
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
58
diff
changeset
|
1294 | NSAPI_PUBLIC pool_handle_t *INTpool_create(void); |
ab25c0a231d0
some fixes and new public APIs
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
58
diff
changeset
|
1295 | |
ab25c0a231d0
some fixes and new public APIs
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
58
diff
changeset
|
1296 | NSAPI_PUBLIC void *INTpool_mark(pool_handle_t *pool_handle); |
ab25c0a231d0
some fixes and new public APIs
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
58
diff
changeset
|
1297 | |
ab25c0a231d0
some fixes and new public APIs
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
58
diff
changeset
|
1298 | NSAPI_PUBLIC void INTpool_recycle(pool_handle_t *pool_handle, void *mark); |
ab25c0a231d0
some fixes and new public APIs
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
58
diff
changeset
|
1299 | |
ab25c0a231d0
some fixes and new public APIs
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
58
diff
changeset
|
1300 | NSAPI_PUBLIC void INTpool_destroy(pool_handle_t *pool_handle); |
ab25c0a231d0
some fixes and new public APIs
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
58
diff
changeset
|
1301 | |
ab25c0a231d0
some fixes and new public APIs
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
58
diff
changeset
|
1302 | NSAPI_PUBLIC int INTpool_enabled(void); |
ab25c0a231d0
some fixes and new public APIs
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
58
diff
changeset
|
1303 | |
ab25c0a231d0
some fixes and new public APIs
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
58
diff
changeset
|
1304 | NSAPI_PUBLIC void *INTpool_malloc(pool_handle_t *pool_handle, size_t size ); |
ab25c0a231d0
some fixes and new public APIs
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
58
diff
changeset
|
1305 | |
ab25c0a231d0
some fixes and new public APIs
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
58
diff
changeset
|
1306 | NSAPI_PUBLIC void INTpool_free(pool_handle_t *pool_handle, void *ptr ); |
ab25c0a231d0
some fixes and new public APIs
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
58
diff
changeset
|
1307 | |
ab25c0a231d0
some fixes and new public APIs
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
58
diff
changeset
|
1308 | NSAPI_PUBLIC |
ab25c0a231d0
some fixes and new public APIs
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
58
diff
changeset
|
1309 | void *INTpool_calloc(pool_handle_t *pool_handle, size_t nelem, size_t elsize); |
ab25c0a231d0
some fixes and new public APIs
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
58
diff
changeset
|
1310 | |
ab25c0a231d0
some fixes and new public APIs
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
58
diff
changeset
|
1311 | NSAPI_PUBLIC |
ab25c0a231d0
some fixes and new public APIs
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
58
diff
changeset
|
1312 | void *INTpool_realloc(pool_handle_t *pool_handle, void *ptr, size_t size ); |
ab25c0a231d0
some fixes and new public APIs
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
58
diff
changeset
|
1313 | |
ab25c0a231d0
some fixes and new public APIs
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
58
diff
changeset
|
1314 | NSAPI_PUBLIC |
ab25c0a231d0
some fixes and new public APIs
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
58
diff
changeset
|
1315 | char *INTpool_strdup(pool_handle_t *pool_handle, const char *orig_str ); |
ab25c0a231d0
some fixes and new public APIs
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
58
diff
changeset
|
1316 | |
ab25c0a231d0
some fixes and new public APIs
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
58
diff
changeset
|
1317 | #define pool_create INTpool_create |
ab25c0a231d0
some fixes and new public APIs
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
58
diff
changeset
|
1318 | #define pool_mark INTpool_mark |
ab25c0a231d0
some fixes and new public APIs
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
58
diff
changeset
|
1319 | #define pool_recycle INTpool_recycle |
ab25c0a231d0
some fixes and new public APIs
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
58
diff
changeset
|
1320 | #define pool_destroy INTpool_destroy |
ab25c0a231d0
some fixes and new public APIs
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
58
diff
changeset
|
1321 | #define pool_enabled INTpool_enabled |
ab25c0a231d0
some fixes and new public APIs
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
58
diff
changeset
|
1322 | #define pool_malloc INTpool_malloc |
ab25c0a231d0
some fixes and new public APIs
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
58
diff
changeset
|
1323 | #define pool_free INTpool_free |
ab25c0a231d0
some fixes and new public APIs
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
58
diff
changeset
|
1324 | #define pool_calloc INTpool_calloc |
ab25c0a231d0
some fixes and new public APIs
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
58
diff
changeset
|
1325 | #define pool_realloc INTpool_realloc |
ab25c0a231d0
some fixes and new public APIs
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
58
diff
changeset
|
1326 | #define pool_strdup INTpool_strdup |
ab25c0a231d0
some fixes and new public APIs
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
58
diff
changeset
|
1327 | |
23
a2c8fc23c90e
Added basic authentication
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
21
diff
changeset
|
1328 | // func util functions |
a2c8fc23c90e
Added basic authentication
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
21
diff
changeset
|
1329 | FuncStruct* func_resolve(pblock *pb, Session *sn, Request *rq); |
a2c8fc23c90e
Added basic authentication
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
21
diff
changeset
|
1330 | int func_exec (pblock *pb, Session *sn, Request *rq); |
a2c8fc23c90e
Added basic authentication
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
21
diff
changeset
|
1331 | |
9
30e51941a673
Added mod_jk dependencies
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
8
diff
changeset
|
1332 | |
30e51941a673
Added mod_jk dependencies
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
8
diff
changeset
|
1333 | |
30e51941a673
Added mod_jk dependencies
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
8
diff
changeset
|
1334 | void protocol_status(Session *sn, Request *rq, int n, const char *m); |
30e51941a673
Added mod_jk dependencies
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
8
diff
changeset
|
1335 | |
30e51941a673
Added mod_jk dependencies
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
8
diff
changeset
|
1336 | int http_start_response(Session *sn, Request *rq); |
1 | 1337 | #define protocol_start_response http_start_response |
9
30e51941a673
Added mod_jk dependencies
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
8
diff
changeset
|
1338 | int request_header(char *name, char **value, Session *sn, Request *rq); |
30e51941a673
Added mod_jk dependencies
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
8
diff
changeset
|
1339 | |
30e51941a673
Added mod_jk dependencies
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
8
diff
changeset
|
1340 | typedef void (*thrstartfunc)(void *); |
30e51941a673
Added mod_jk dependencies
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
8
diff
changeset
|
1341 | SYS_THREAD INTsysthread_start(int prio, int stksz, thrstartfunc fn, void *arg); |
30e51941a673
Added mod_jk dependencies
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
8
diff
changeset
|
1342 | NSAPI_PUBLIC void INTsysthread_sleep(int milliseconds); |
30e51941a673
Added mod_jk dependencies
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
8
diff
changeset
|
1343 | |
30e51941a673
Added mod_jk dependencies
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
8
diff
changeset
|
1344 | #define systhread_start INTsysthread_start |
30e51941a673
Added mod_jk dependencies
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
8
diff
changeset
|
1345 | #define systhread_sleep INTsysthread_sleep |
30e51941a673
Added mod_jk dependencies
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
8
diff
changeset
|
1346 | |
1 | 1347 | |
9
30e51941a673
Added mod_jk dependencies
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
8
diff
changeset
|
1348 | void webserver_atrestart(void (*fn)(void *), void *data); |
30e51941a673
Added mod_jk dependencies
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
8
diff
changeset
|
1349 | #define magnus_atrestart webserver_atrestart |
30e51941a673
Added mod_jk dependencies
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
8
diff
changeset
|
1350 | |
30e51941a673
Added mod_jk dependencies
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
8
diff
changeset
|
1351 | |
30e51941a673
Added mod_jk dependencies
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
8
diff
changeset
|
1352 | NSAPI_PUBLIC int INTshexp_match(const char *str, const char *exp); |
30e51941a673
Added mod_jk dependencies
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
8
diff
changeset
|
1353 | #define shexp_match INTshexp_match |
30e51941a673
Added mod_jk dependencies
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
8
diff
changeset
|
1354 | |
30e51941a673
Added mod_jk dependencies
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
8
diff
changeset
|
1355 | |
30e51941a673
Added mod_jk dependencies
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
8
diff
changeset
|
1356 | |
30e51941a673
Added mod_jk dependencies
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
8
diff
changeset
|
1357 | NSAPI_PUBLIC char *session_dns_lookup(Session *s, int verify); |
30e51941a673
Added mod_jk dependencies
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
8
diff
changeset
|
1358 | |
1 | 1359 | |
8
f4d56bf9de40
Added request body reader
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
6
diff
changeset
|
1360 | |
f4d56bf9de40
Added request body reader
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
6
diff
changeset
|
1361 | /* netbuf functions */ |
f4d56bf9de40
Added request body reader
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
6
diff
changeset
|
1362 | NSAPI_PUBLIC netbuf *netbuf_open(SYS_NETFD sd, int sz); |
f4d56bf9de40
Added request body reader
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
6
diff
changeset
|
1363 | |
f4d56bf9de40
Added request body reader
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
6
diff
changeset
|
1364 | NSAPI_PUBLIC void netbuf_close(netbuf *buf); |
f4d56bf9de40
Added request body reader
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
6
diff
changeset
|
1365 | |
f4d56bf9de40
Added request body reader
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
6
diff
changeset
|
1366 | NSAPI_PUBLIC unsigned char * netbuf_replace(netbuf *buf, |
f4d56bf9de40
Added request body reader
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
6
diff
changeset
|
1367 | unsigned char *inbuf, int pos, int cursize, int maxsize); |
f4d56bf9de40
Added request body reader
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
6
diff
changeset
|
1368 | |
f4d56bf9de40
Added request body reader
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
6
diff
changeset
|
1369 | NSAPI_PUBLIC int netbuf_next(netbuf *buf, int advance); |
f4d56bf9de40
Added request body reader
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
6
diff
changeset
|
1370 | |
f4d56bf9de40
Added request body reader
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
6
diff
changeset
|
1371 | NSAPI_PUBLIC int netbuf_getbytes(netbuf *buf, char *buffer, int size); |
f4d56bf9de40
Added request body reader
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
6
diff
changeset
|
1372 | |
f4d56bf9de40
Added request body reader
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
6
diff
changeset
|
1373 | NSAPI_PUBLIC int netbuf_grab(netbuf *buf, int sz); |
f4d56bf9de40
Added request body reader
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
6
diff
changeset
|
1374 | |
21
627b09ee74e4
New configuration loader
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
19
diff
changeset
|
1375 | #define netbuf_open netbuf_open |
627b09ee74e4
New configuration loader
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
19
diff
changeset
|
1376 | #define netbuf_close netbuf_close |
627b09ee74e4
New configuration loader
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
19
diff
changeset
|
1377 | #define netbuf_replace netbuf_replace |
627b09ee74e4
New configuration loader
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
19
diff
changeset
|
1378 | #define netbuf_next netbuf_next |
627b09ee74e4
New configuration loader
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
19
diff
changeset
|
1379 | #define netbuf_getbytes netbuf_getbytes |
627b09ee74e4
New configuration loader
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
19
diff
changeset
|
1380 | #define netbuf_grab netbuf_grab |
627b09ee74e4
New configuration loader
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
19
diff
changeset
|
1381 | |
58
66c22e54aa90
webdav uses the vfs api
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
56
diff
changeset
|
1382 | /* file */ |
66c22e54aa90
webdav uses the vfs api
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
56
diff
changeset
|
1383 | NSAPI_PUBLIC int system_fread(SYS_FILE fd, void *buf, int nbyte); |
66c22e54aa90
webdav uses the vfs api
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
56
diff
changeset
|
1384 | NSAPI_PUBLIC int system_fwrite(SYS_FILE fd, const void *buf, int nbyte); |
66
74babc0082b7
added authentication cache
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
65
diff
changeset
|
1385 | NSAPI_PUBLIC off_t system_lseek(SYS_FILE fd, off_t offset, int whence); |
58
66c22e54aa90
webdav uses the vfs api
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
56
diff
changeset
|
1386 | NSAPI_PUBLIC int system_fclose(SYS_FILE fd); |
66c22e54aa90
webdav uses the vfs api
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
56
diff
changeset
|
1387 | |
67
50505dc3f8a6
dynamic thread pool
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
66
diff
changeset
|
1388 | /* new macro and function definitions begin */ |
50505dc3f8a6
dynamic thread pool
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
66
diff
changeset
|
1389 | |
63
66442f81f823
supports file system ACLs on Solaris
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
61
diff
changeset
|
1390 | NSAPI_PUBLIC int util_errno2status(int errno_value); // new |
56
c6cf20b09043
added vfs_mkdir and vfs_unlink
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
54
diff
changeset
|
1391 | #define util_errno2status util_errno2status |
21
627b09ee74e4
New configuration loader
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
19
diff
changeset
|
1392 | |
627b09ee74e4
New configuration loader
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
19
diff
changeset
|
1393 | |
59
ab25c0a231d0
some fixes and new public APIs
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
58
diff
changeset
|
1394 | // threadpool |
67
50505dc3f8a6
dynamic thread pool
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
66
diff
changeset
|
1395 | threadpool_t* threadpool_new(int min, int max); |
59
ab25c0a231d0
some fixes and new public APIs
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
58
diff
changeset
|
1396 | void* threadpool_func(void *data); |
ab25c0a231d0
some fixes and new public APIs
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
58
diff
changeset
|
1397 | threadpool_job* threadpool_get_job(threadpool_t *pool); |
ab25c0a231d0
some fixes and new public APIs
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
58
diff
changeset
|
1398 | void threadpool_run(threadpool_t *pool, job_callback_f func, void *data); |
ab25c0a231d0
some fixes and new public APIs
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
58
diff
changeset
|
1399 | |
8
f4d56bf9de40
Added request body reader
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
6
diff
changeset
|
1400 | /* end new macro and function definitions */ |
f4d56bf9de40
Added request body reader
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
6
diff
changeset
|
1401 | |
1 | 1402 | #define SYS_STDERR STDERR_FILENO |
1403 | ||
1404 | #ifdef XP_WIN32 | |
1405 | ||
1406 | typedef HANDLE pid_t; | |
1407 | ||
1408 | #define ERROR_PIPE \ | |
1409 | (ERROR_BROKEN_PIPE | ERROR_BAD_PIPE | \ | |
1410 | ERROR_PIPE_BUSY | ERROR_PIPE_LISTENING | ERROR_PIPE_NOT_CONNECTED) | |
1411 | #define CONVERT_TO_PRINTABLE_FORMAT(Filename) \ | |
1412 | { \ | |
1413 | register char *s; \ | |
1414 | if (Filename) \ | |
1415 | for (s = Filename; *s; s++) \ | |
1416 | if ( *s == '\\') \ | |
1417 | *s = '/'; \ | |
1418 | } | |
1419 | #define CONVERT_TO_NATIVE_FS(Filename) \ | |
1420 | { \ | |
1421 | register char *s; \ | |
1422 | if (Filename) \ | |
1423 | for (s = Filename; *s; s++) \ | |
1424 | if ( *s == '/') \ | |
1425 | *s = '\\'; \ | |
1426 | } | |
1427 | ||
1428 | #ifdef INTNSAPI | |
1429 | NSAPI_PUBLIC extern nsapi_dispatch_t *__nsapi30_table; | |
1430 | #if NSAPI_VERSION >= 302 | |
1431 | NSAPI_PUBLIC extern nsapi302_dispatch_t *__nsapi302_table; | |
1432 | #endif /* NSAPI_VERSION >= 302 */ | |
1433 | #if NSAPI_VERSION >= 303 | |
1434 | NSAPI_PUBLIC extern nsapi303_dispatch_t *__nsapi303_table; | |
1435 | #endif /* NSAPI_VERSION >= 303 */ | |
1436 | #else | |
1437 | __declspec(dllimport) nsapi_dispatch_t *__nsapi30_table; | |
1438 | #if NSAPI_VERSION >= 302 | |
1439 | __declspec(dllimport) nsapi302_dispatch_t *__nsapi302_table; | |
1440 | #endif /* NSAPI_VERSION >= 302 */ | |
1441 | #if NSAPI_VERSION >= 303 | |
1442 | __declspec(dllimport) nsapi303_dispatch_t *__nsapi303_table; | |
1443 | #endif /* NSAPI_VERSION >= 303 */ | |
1444 | #endif /* INTNSAPI */ | |
1445 | ||
1446 | #else /* !XP_WIN32 */ | |
1447 | ||
1448 | ||
1449 | #endif /* XP_WIN32 */ | |
1450 | ||
1451 | #ifdef __cplusplus | |
1452 | } | |
1453 | #endif | |
1454 | ||
1455 | #endif /* !PUBLIC_NSAPI_H */ |