• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 /*
2      This file is part of libmicrohttpd
3      Copyright (C) 2006-2015 Christian Grothoff (and other contributing authors)
4 
5      This library is free software; you can redistribute it and/or
6      modify it under the terms of the GNU Lesser General Public
7      License as published by the Free Software Foundation; either
8      version 2.1 of the License, or (at your option) any later version.
9 
10      This library is distributed in the hope that it will be useful,
11      but WITHOUT ANY WARRANTY; without even the implied warranty of
12      MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
13      Lesser General Public License for more details.
14 
15      You should have received a copy of the GNU Lesser General Public
16      License along with this library; if not, write to the Free Software
17      Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301  USA
18 */
19 
20 /**
21  * @file microhttpd.h
22  * @brief public interface to libmicrohttpd
23  * @author Christian Grothoff
24  * @author Chris GauthierDickey
25  *
26  * All symbols defined in this header start with MHD.  MHD is a small
27  * HTTP daemon library.  As such, it does not have any API for logging
28  * errors (you can only enable or disable logging to stderr).  Also,
29  * it may not support all of the HTTP features directly, where
30  * applicable, portions of HTTP may have to be handled by clients of
31  * the library.
32  *
33  * The library is supposed to handle everything that it must handle
34  * (because the API would not allow clients to do this), such as basic
35  * connection management; however, detailed interpretations of headers
36  * -- such as range requests -- and HTTP methods are left to clients.
37  * The library does understand HEAD and will only send the headers of
38  * the response and not the body, even if the client supplied a body.
39  * The library also understands headers that control connection
40  * management (specifically, "Connection: close" and "Expect: 100
41  * continue" are understood and handled automatically).
42  *
43  * MHD understands POST data and is able to decode certain formats
44  * (at the moment only "application/x-www-form-urlencoded" and
45  * "mulitpart/formdata"). Unsupported encodings and large POST
46  * submissions may require the application to manually process
47  * the stream, which is provided to the main application (and thus can be
48  * processed, just not conveniently by MHD).
49  *
50  * The header file defines various constants used by the HTTP protocol.
51  * This does not mean that MHD actually interprets all of these
52  * values.  The provided constants are exported as a convenience
53  * for users of the library.  MHD does not verify that transmitted
54  * HTTP headers are part of the standard specification; users of the
55  * library are free to define their own extensions of the HTTP
56  * standard and use those with MHD.
57  *
58  * All functions are guaranteed to be completely reentrant and
59  * thread-safe (with the exception of #MHD_set_connection_value,
60  * which must only be used in a particular context).
61  *
62  * NEW: Before including "microhttpd.h" you should add the necessary
63  * includes to define the `uint64_t`, `size_t`, `fd_set`, `socklen_t`
64  * and `struct sockaddr` data types (which headers are needed may
65  * depend on your platform; for possible suggestions consult
66  * "platform.h" in the MHD distribution).  If you have done so, you
67  * should also have a line with "#define MHD_PLATFORM_H" which will
68  * prevent this header from trying (and, depending on your platform,
69  * failing) to include the right headers.
70  *
71  * @defgroup event event-loop control
72  * MHD API to start and stop the HTTP server and manage the event loop.
73  * @defgroup response generation of responses
74  * MHD API used to generate responses.
75  * @defgroup request handling of requests
76  * MHD API used to access information about requests.
77  * @defgroup authentication HTTP authentication
78  * MHD API related to basic and digest HTTP authentication.
79  * @defgroup logging logging
80  * MHD API to mange logging and error handling
81  * @defgroup specialized misc. specialized functions
82  * This group includes functions that do not fit into any particular
83  * category and that are rarely used.
84  */
85 
86 #ifndef MHD_MICROHTTPD_H
87 #define MHD_MICROHTTPD_H
88 
89 #ifdef __cplusplus
90 extern "C"
91 {
92 #if 0                           /* keep Emacsens' auto-indent happy */
93 }
94 #endif
95 #endif
96 
97 /* While we generally would like users to use a configure-driven
98    build process which detects which headers are present and
99    hence works on any platform, we use "standard" includes here
100    to build out-of-the-box for beginning users on common systems.
101 
102    Once you have a proper build system and go for more exotic
103    platforms, you should define MHD_PLATFORM_H in some header that
104    you always include *before* "microhttpd.h".  Then the following
105    "standard" includes won't be used (which might be a good
106    idea, especially on platforms where they do not exist). */
107 #ifndef MHD_PLATFORM_H
108 #include <stdarg.h>
109 #include <stdint.h>
110 #include <sys/types.h>
111 #if defined(_WIN32) && !defined(__CYGWIN__)
112 #include <ws2tcpip.h>
113 #if defined(_MSC_FULL_VER) && !defined (_SSIZE_T_DEFINED)
114 #define _SSIZE_T_DEFINED
115 typedef intptr_t ssize_t;
116 #endif // !_SSIZE_T_DEFINED */
117 #else
118 #include <unistd.h>
119 #include <sys/time.h>
120 #include <sys/socket.h>
121 #endif
122 #endif
123 
124 #if defined(__CYGWIN__) && !defined(_SYS_TYPES_FD_SET)
125 /* Do not define __USE_W32_SOCKETS under Cygwin! */
126 #error Cygwin with winsock fd_set is not supported
127 #endif
128 
129 /**
130  * Current version of the library.
131  * 0x01093001 = 1.9.30-1.
132  */
133 #define MHD_VERSION 0x00094200
134 
135 /**
136  * MHD-internal return code for "YES".
137  */
138 #define MHD_YES 1
139 
140 /**
141  * MHD-internal return code for "NO".
142  */
143 #define MHD_NO 0
144 
145 /**
146  * MHD digest auth internal code for an invalid nonce.
147  */
148 #define MHD_INVALID_NONCE -1
149 
150 /**
151  * Constant used to indicate unknown size (use when
152  * creating a response).
153  */
154 #ifdef UINT64_MAX
155 #define MHD_SIZE_UNKNOWN UINT64_MAX
156 #else
157 #define MHD_SIZE_UNKNOWN  ((uint64_t) -1LL)
158 #endif
159 
160 #ifdef SIZE_MAX
161 #define MHD_CONTENT_READER_END_OF_STREAM SIZE_MAX
162 #define MHD_CONTENT_READER_END_WITH_ERROR (SIZE_MAX - 1)
163 #else
164 #define MHD_CONTENT_READER_END_OF_STREAM ((size_t) -1LL)
165 #define MHD_CONTENT_READER_END_WITH_ERROR (((size_t) -1LL) - 1)
166 #endif
167 
168 #ifndef _MHD_EXTERN
169 #if defined(_WIN32) && defined(MHD_W32LIB)
170 #define _MHD_EXTERN extern
171 #elif defined (_WIN32) && defined(MHD_W32DLL)
172 /* Define MHD_W32DLL when using MHD as W32 .DLL to speed up linker a little */
173 #define _MHD_EXTERN __declspec(dllimport)
174 #else
175 #define _MHD_EXTERN extern
176 #endif
177 #endif
178 
179 #ifndef MHD_SOCKET_DEFINED
180 /**
181  * MHD_socket is type for socket FDs
182  */
183 #if !defined(_WIN32) || defined(_SYS_TYPES_FD_SET)
184 #define MHD_POSIX_SOCKETS 1
185 typedef int MHD_socket;
186 #define MHD_INVALID_SOCKET (-1)
187 #else /* !defined(_WIN32) || defined(_SYS_TYPES_FD_SET) */
188 #define MHD_WINSOCK_SOCKETS 1
189 #include <winsock2.h>
190 typedef SOCKET MHD_socket;
191 #define MHD_INVALID_SOCKET (INVALID_SOCKET)
192 #endif /* !defined(_WIN32) || defined(_SYS_TYPES_FD_SET) */
193 #define MHD_SOCKET_DEFINED 1
194 #endif /* MHD_SOCKET_DEFINED */
195 
196 /**
197  * Not all architectures and `printf()`'s support the `long long` type.
198  * This gives the ability to replace `long long` with just a `long`,
199  * standard `int` or a `short`.
200  */
201 #ifndef MHD_LONG_LONG
202 /**
203  * @deprecated use #MHD_UNSIGNED_LONG_LONG instead!
204  */
205 #define MHD_LONG_LONG long long
206 #define MHD_UNSIGNED_LONG_LONG unsigned long long
207 #endif
208 /**
209  * Format string for printing a variable of type #MHD_LONG_LONG.
210  * You should only redefine this if you also define #MHD_LONG_LONG.
211  */
212 #ifndef MHD_LONG_LONG_PRINTF
213 /**
214  * @deprecated use #MHD_UNSIGNED_LONG_LONG_PRINTF instead!
215  */
216 #define MHD_LONG_LONG_PRINTF "ll"
217 #define MHD_UNSIGNED_LONG_LONG_PRINTF "%llu"
218 #endif
219 
220 
221 /**
222  * @defgroup httpcode HTTP response codes.
223  * These are the status codes defined for HTTP responses.
224  * @{
225  */
226 #define MHD_HTTP_CONTINUE 100
227 #define MHD_HTTP_SWITCHING_PROTOCOLS 101
228 #define MHD_HTTP_PROCESSING 102
229 
230 #define MHD_HTTP_OK 200
231 #define MHD_HTTP_CREATED 201
232 #define MHD_HTTP_ACCEPTED 202
233 #define MHD_HTTP_NON_AUTHORITATIVE_INFORMATION 203
234 #define MHD_HTTP_NO_CONTENT 204
235 #define MHD_HTTP_RESET_CONTENT 205
236 #define MHD_HTTP_PARTIAL_CONTENT 206
237 #define MHD_HTTP_MULTI_STATUS 207
238 
239 #define MHD_HTTP_MULTIPLE_CHOICES 300
240 #define MHD_HTTP_MOVED_PERMANENTLY 301
241 #define MHD_HTTP_FOUND 302
242 #define MHD_HTTP_SEE_OTHER 303
243 #define MHD_HTTP_NOT_MODIFIED 304
244 #define MHD_HTTP_USE_PROXY 305
245 #define MHD_HTTP_SWITCH_PROXY 306
246 #define MHD_HTTP_TEMPORARY_REDIRECT 307
247 
248 #define MHD_HTTP_BAD_REQUEST 400
249 #define MHD_HTTP_UNAUTHORIZED 401
250 #define MHD_HTTP_PAYMENT_REQUIRED 402
251 #define MHD_HTTP_FORBIDDEN 403
252 #define MHD_HTTP_NOT_FOUND 404
253 #define MHD_HTTP_METHOD_NOT_ALLOWED 405
254 #define MHD_HTTP_NOT_ACCEPTABLE 406
255 /** @deprecated */
256 #define MHD_HTTP_METHOD_NOT_ACCEPTABLE 406
257 #define MHD_HTTP_PROXY_AUTHENTICATION_REQUIRED 407
258 #define MHD_HTTP_REQUEST_TIMEOUT 408
259 #define MHD_HTTP_CONFLICT 409
260 #define MHD_HTTP_GONE 410
261 #define MHD_HTTP_LENGTH_REQUIRED 411
262 #define MHD_HTTP_PRECONDITION_FAILED 412
263 #define MHD_HTTP_REQUEST_ENTITY_TOO_LARGE 413
264 #define MHD_HTTP_REQUEST_URI_TOO_LONG 414
265 #define MHD_HTTP_UNSUPPORTED_MEDIA_TYPE 415
266 #define MHD_HTTP_REQUESTED_RANGE_NOT_SATISFIABLE 416
267 #define MHD_HTTP_EXPECTATION_FAILED 417
268 #define MHD_HTTP_UNPROCESSABLE_ENTITY 422
269 #define MHD_HTTP_LOCKED 423
270 #define MHD_HTTP_FAILED_DEPENDENCY 424
271 #define MHD_HTTP_UNORDERED_COLLECTION 425
272 #define MHD_HTTP_UPGRADE_REQUIRED 426
273 #define MHD_HTTP_NO_RESPONSE 444
274 #define MHD_HTTP_RETRY_WITH 449
275 #define MHD_HTTP_BLOCKED_BY_WINDOWS_PARENTAL_CONTROLS 450
276 #define MHD_HTTP_UNAVAILABLE_FOR_LEGAL_REASONS 451
277 
278 #define MHD_HTTP_INTERNAL_SERVER_ERROR 500
279 #define MHD_HTTP_NOT_IMPLEMENTED 501
280 #define MHD_HTTP_BAD_GATEWAY 502
281 #define MHD_HTTP_SERVICE_UNAVAILABLE 503
282 #define MHD_HTTP_GATEWAY_TIMEOUT 504
283 #define MHD_HTTP_HTTP_VERSION_NOT_SUPPORTED 505
284 #define MHD_HTTP_VARIANT_ALSO_NEGOTIATES 506
285 #define MHD_HTTP_INSUFFICIENT_STORAGE 507
286 #define MHD_HTTP_BANDWIDTH_LIMIT_EXCEEDED 509
287 #define MHD_HTTP_NOT_EXTENDED 510
288 
289 /** @} */ /* end of group httpcode */
290 
291 /**
292  * Flag to be or-ed with MHD_HTTP status code for
293  * SHOUTcast.  This will cause the response to begin
294  * with the SHOUTcast "ICY" line instad of "HTTP".
295  * @ingroup specialized
296  */
297 #define MHD_ICY_FLAG ((uint32_t)(((uint32_t)1) << 31))
298 
299 /**
300  * @defgroup headers HTTP headers
301  * These are the standard headers found in HTTP requests and responses.
302  * @{
303  */
304 /* See also: http://www.w3.org/Protocols/rfc2616/rfc2616-sec14.html */
305 #define MHD_HTTP_HEADER_ACCEPT "Accept"
306 #define MHD_HTTP_HEADER_ACCEPT_CHARSET "Accept-Charset"
307 #define MHD_HTTP_HEADER_ACCEPT_ENCODING "Accept-Encoding"
308 #define MHD_HTTP_HEADER_ACCEPT_LANGUAGE "Accept-Language"
309 #define MHD_HTTP_HEADER_ACCEPT_RANGES "Accept-Ranges"
310 #define MHD_HTTP_HEADER_AGE "Age"
311 #define MHD_HTTP_HEADER_ALLOW "Allow"
312 #define MHD_HTTP_HEADER_AUTHORIZATION "Authorization"
313 #define MHD_HTTP_HEADER_CACHE_CONTROL "Cache-Control"
314 #define MHD_HTTP_HEADER_CONNECTION "Connection"
315 #define MHD_HTTP_HEADER_CONTENT_ENCODING "Content-Encoding"
316 #define MHD_HTTP_HEADER_CONTENT_LANGUAGE "Content-Language"
317 #define MHD_HTTP_HEADER_CONTENT_LENGTH "Content-Length"
318 #define MHD_HTTP_HEADER_CONTENT_LOCATION "Content-Location"
319 #define MHD_HTTP_HEADER_CONTENT_MD5 "Content-MD5"
320 #define MHD_HTTP_HEADER_CONTENT_RANGE "Content-Range"
321 #define MHD_HTTP_HEADER_CONTENT_TYPE "Content-Type"
322 #define MHD_HTTP_HEADER_COOKIE "Cookie"
323 #define MHD_HTTP_HEADER_DATE "Date"
324 #define MHD_HTTP_HEADER_ETAG "ETag"
325 #define MHD_HTTP_HEADER_EXPECT "Expect"
326 #define MHD_HTTP_HEADER_EXPIRES "Expires"
327 #define MHD_HTTP_HEADER_FROM "From"
328 #define MHD_HTTP_HEADER_HOST "Host"
329 #define MHD_HTTP_HEADER_IF_MATCH "If-Match"
330 #define MHD_HTTP_HEADER_IF_MODIFIED_SINCE "If-Modified-Since"
331 #define MHD_HTTP_HEADER_IF_NONE_MATCH "If-None-Match"
332 #define MHD_HTTP_HEADER_IF_RANGE "If-Range"
333 #define MHD_HTTP_HEADER_IF_UNMODIFIED_SINCE "If-Unmodified-Since"
334 #define MHD_HTTP_HEADER_LAST_MODIFIED "Last-Modified"
335 #define MHD_HTTP_HEADER_LOCATION "Location"
336 #define MHD_HTTP_HEADER_MAX_FORWARDS "Max-Forwards"
337 #define MHD_HTTP_HEADER_PRAGMA "Pragma"
338 #define MHD_HTTP_HEADER_PROXY_AUTHENTICATE "Proxy-Authenticate"
339 #define MHD_HTTP_HEADER_PROXY_AUTHORIZATION "Proxy-Authorization"
340 #define MHD_HTTP_HEADER_RANGE "Range"
341 /* This is not a typo, see HTTP spec */
342 #define MHD_HTTP_HEADER_REFERER "Referer"
343 #define MHD_HTTP_HEADER_RETRY_AFTER "Retry-After"
344 #define MHD_HTTP_HEADER_SERVER "Server"
345 #define MHD_HTTP_HEADER_SET_COOKIE "Set-Cookie"
346 #define MHD_HTTP_HEADER_SET_COOKIE2 "Set-Cookie2"
347 #define MHD_HTTP_HEADER_TE "TE"
348 #define MHD_HTTP_HEADER_TRAILER "Trailer"
349 #define MHD_HTTP_HEADER_TRANSFER_ENCODING "Transfer-Encoding"
350 #define MHD_HTTP_HEADER_UPGRADE "Upgrade"
351 #define MHD_HTTP_HEADER_USER_AGENT "User-Agent"
352 #define MHD_HTTP_HEADER_VARY "Vary"
353 #define MHD_HTTP_HEADER_VIA "Via"
354 #define MHD_HTTP_HEADER_WARNING "Warning"
355 #define MHD_HTTP_HEADER_WWW_AUTHENTICATE "WWW-Authenticate"
356 #define MHD_HTTP_HEADER_ACCESS_CONTROL_ALLOW_ORIGIN "Access-Control-Allow-Origin"
357 
358 /** @} */ /* end of group headers */
359 
360 /**
361  * @defgroup versions HTTP versions
362  * These strings should be used to match against the first line of the
363  * HTTP header.
364  * @{
365  */
366 #define MHD_HTTP_VERSION_1_0 "HTTP/1.0"
367 #define MHD_HTTP_VERSION_1_1 "HTTP/1.1"
368 
369 /** @} */ /* end of group versions */
370 
371 /**
372  * @defgroup methods HTTP methods
373  * Standard HTTP methods (as strings).
374  * @{
375  */
376 #define MHD_HTTP_METHOD_CONNECT "CONNECT"
377 #define MHD_HTTP_METHOD_DELETE "DELETE"
378 #define MHD_HTTP_METHOD_GET "GET"
379 #define MHD_HTTP_METHOD_HEAD "HEAD"
380 #define MHD_HTTP_METHOD_OPTIONS "OPTIONS"
381 #define MHD_HTTP_METHOD_POST "POST"
382 #define MHD_HTTP_METHOD_PUT "PUT"
383 #define MHD_HTTP_METHOD_PATCH "PATCH"
384 #define MHD_HTTP_METHOD_TRACE "TRACE"
385 
386 /** @} */ /* end of group methods */
387 
388 /**
389  * @defgroup postenc HTTP POST encodings
390  * See also: http://www.w3.org/TR/html4/interact/forms.html#h-17.13.4
391  * @{
392  */
393 #define MHD_HTTP_POST_ENCODING_FORM_URLENCODED "application/x-www-form-urlencoded"
394 #define MHD_HTTP_POST_ENCODING_MULTIPART_FORMDATA "multipart/form-data"
395 
396 /** @} */ /* end of group postenc */
397 
398 
399 /**
400  * @brief Handle for the daemon (listening on a socket for HTTP traffic).
401  * @ingroup event
402  */
403 struct MHD_Daemon;
404 
405 /**
406  * @brief Handle for a connection / HTTP request.
407  *
408  * With HTTP/1.1, multiple requests can be run over the same
409  * connection.  However, MHD will only show one request per TCP
410  * connection to the client at any given time.
411  * @ingroup request
412  */
413 struct MHD_Connection;
414 
415 /**
416  * @brief Handle for a response.
417  * @ingroup response
418  */
419 struct MHD_Response;
420 
421 /**
422  * @brief Handle for POST processing.
423  * @ingroup response
424  */
425 struct MHD_PostProcessor;
426 
427 
428 /**
429  * @brief Flags for the `struct MHD_Daemon`.
430  *
431  * Note that if neither #MHD_USE_THREAD_PER_CONNECTION nor
432  * #MHD_USE_SELECT_INTERNALLY is used, the client wants control over
433  * the process and will call the appropriate microhttpd callbacks.
434  *
435  * Starting the daemon may also fail if a particular option is not
436  * implemented or not supported on the target platform (i.e. no
437  * support for SSL, threads or IPv6).
438  */
439 enum MHD_FLAG
440 {
441   /**
442    * No options selected.
443    */
444   MHD_NO_FLAG = 0,
445 
446   /**
447    * Run in debug mode.  If this flag is used, the library should
448    * print error messages and warnings to `stderr`.
449    */
450   MHD_USE_DEBUG = 1,
451 
452   /**
453    * Run in HTTPS mode.
454    */
455   MHD_USE_SSL = 2,
456 
457   /**
458    * Run using one thread per connection.
459    */
460   MHD_USE_THREAD_PER_CONNECTION = 4,
461 
462   /**
463    * Run using an internal thread (or thread pool) doing `select()`.
464    */
465   MHD_USE_SELECT_INTERNALLY = 8,
466 
467   /**
468    * Run using the IPv6 protocol (otherwise, MHD will just support
469    * IPv4).  If you want MHD to support IPv4 and IPv6 using a single
470    * socket, pass #MHD_USE_DUAL_STACK, otherwise, if you only pass
471    * this option, MHD will try to bind to IPv6-only (resulting in
472    * no IPv4 support).
473    */
474   MHD_USE_IPv6 = 16,
475 
476   /**
477    * Be pedantic about the protocol (as opposed to as tolerant as
478    * possible).  Specifically, at the moment, this flag causes MHD to
479    * reject HTTP 1.1 connections without a "Host" header.  This is
480    * required by the standard, but of course in violation of the "be
481    * as liberal as possible in what you accept" norm.  It is
482    * recommended to turn this ON if you are testing clients against
483    * MHD, and OFF in production.
484    */
485   MHD_USE_PEDANTIC_CHECKS = 32,
486 
487   /**
488    * Use `poll()` instead of `select()`. This allows sockets with `fd >=
489    * FD_SETSIZE`.  This option is not compatible with using an
490    * 'external' `select()` mode (as there is no API to get the file
491    * descriptors for the external select from MHD) and must also not
492    * be used in combination with #MHD_USE_EPOLL_LINUX_ONLY.
493    */
494   MHD_USE_POLL = 64,
495 
496   /**
497    * Run using an internal thread (or thread pool) doing `poll()`.
498    */
499   MHD_USE_POLL_INTERNALLY = MHD_USE_SELECT_INTERNALLY | MHD_USE_POLL,
500 
501   /**
502    * Suppress (automatically) adding the 'Date:' header to HTTP responses.
503    * This option should ONLY be used on systems that do not have a clock
504    * and that DO provide other mechanisms for cache control.  See also
505    * RFC 2616, section 14.18 (exception 3).
506    */
507   MHD_SUPPRESS_DATE_NO_CLOCK = 128,
508 
509   /**
510    * Run without a listen socket.  This option only makes sense if
511    * #MHD_add_connection is to be used exclusively to connect HTTP
512    * clients to the HTTP server.  This option is incompatible with
513    * using a thread pool; if it is used, #MHD_OPTION_THREAD_POOL_SIZE
514    * is ignored.
515    */
516   MHD_USE_NO_LISTEN_SOCKET = 256,
517 
518   /**
519    * Use `epoll()` instead of `select()` or `poll()` for the event loop.
520    * This option is only available on Linux; using the option on
521    * non-Linux systems will cause #MHD_start_daemon to fail.
522    */
523   MHD_USE_EPOLL_LINUX_ONLY = 512,
524 
525   /**
526    * Run using an internal thread (or thread pool) doing `epoll()`.
527    * This option is only available on Linux; using the option on
528    * non-Linux systems will cause #MHD_start_daemon to fail.
529    */
530   MHD_USE_EPOLL_INTERNALLY_LINUX_ONLY = MHD_USE_SELECT_INTERNALLY | MHD_USE_EPOLL_LINUX_ONLY,
531 
532   /**
533    * Force MHD to use a signal pipe to notify the event loop (of
534    * threads) of our shutdown.  This is required if an appliction uses
535    * #MHD_USE_SELECT_INTERNALLY or #MHD_USE_THREAD_PER_CONNECTION and
536    * then performs #MHD_quiesce_daemon (which eliminates our ability
537    * to signal termination via the listen socket).  In these modes,
538    * #MHD_quiesce_daemon will fail if this option was not set.  Also,
539    * use of this option is automatic (as in, you do not even have to
540    * specify it), if #MHD_USE_NO_LISTEN_SOCKET is specified.  In
541    * "external" `select()` mode, this option is always simply ignored.
542    * MHD can be build for use a pair of sockets instead of a pipe.
543    * Pair of sockets is forced on W32.
544    *
545    * You must also use this option if you use internal select mode
546    * or a thread pool in conjunction with #MHD_add_connection.
547    */
548   MHD_USE_PIPE_FOR_SHUTDOWN = 1024,
549 
550   /**
551    * Use a single socket for IPv4 and IPv6.
552    */
553   MHD_USE_DUAL_STACK = MHD_USE_IPv6 | 2048,
554 
555   /**
556    * Enable `epoll()` turbo.  Disables certain calls to `shutdown()`
557    * and enables aggressive non-blocking optimisitc reads.
558    * Most effects only happen with #MHD_USE_EPOLL_LINUX_ONLY.
559    * Enalbed always on W32 as winsock does not properly behave
560    * with `shutdown()` and this then fixes potential problems.
561    */
562   MHD_USE_EPOLL_TURBO = 4096,
563 
564   /**
565    * Enable suspend/resume functions, which also implies setting up
566    * pipes to signal resume.
567    */
568   MHD_USE_SUSPEND_RESUME = 8192 | MHD_USE_PIPE_FOR_SHUTDOWN,
569 
570   /**
571    * Enable TCP_FASTOPEN option.  This option is only available on Linux with a
572    * kernel >= 3.6.  On other systems, using this option cases #MHD_start_daemon
573    * to fail.
574    */
575   MHD_USE_TCP_FASTOPEN = 16384
576 
577 };
578 
579 
580 /**
581  * Type of a callback function used for logging by MHD.
582  *
583  * @param cls closure
584  * @param fm format string (`printf()`-style)
585  * @param ap arguments to @a fm
586  * @ingroup logging
587  */
588 typedef void (*MHD_LogCallback)(void *cls, const char *fm, va_list ap);
589 
590 
591 /**
592  * @brief MHD options.
593  *
594  * Passed in the varargs portion of #MHD_start_daemon.
595  */
596 enum MHD_OPTION
597 {
598 
599   /**
600    * No more options / last option.  This is used
601    * to terminate the VARARGs list.
602    */
603   MHD_OPTION_END = 0,
604 
605   /**
606    * Maximum memory size per connection (followed by a `size_t`).
607    * Default is 32 kb (#MHD_POOL_SIZE_DEFAULT).
608    * Values above 128k are unlikely to result in much benefit, as half
609    * of the memory will be typically used for IO, and TCP buffers are
610    * unlikely to support window sizes above 64k on most systems.
611    */
612   MHD_OPTION_CONNECTION_MEMORY_LIMIT = 1,
613 
614   /**
615    * Maximum number of concurrent connections to
616    * accept (followed by an `unsigned int`).
617    */
618   MHD_OPTION_CONNECTION_LIMIT = 2,
619 
620   /**
621    * After how many seconds of inactivity should a
622    * connection automatically be timed out? (followed
623    * by an `unsigned int`; use zero for no timeout).
624    */
625   MHD_OPTION_CONNECTION_TIMEOUT = 3,
626 
627   /**
628    * Register a function that should be called whenever a request has
629    * been completed (this can be used for application-specific clean
630    * up).  Requests that have never been presented to the application
631    * (via #MHD_AccessHandlerCallback) will not result in
632    * notifications.
633    *
634    * This option should be followed by TWO pointers.  First a pointer
635    * to a function of type #MHD_RequestCompletedCallback and second a
636    * pointer to a closure to pass to the request completed callback.
637    * The second pointer maybe NULL.
638    */
639   MHD_OPTION_NOTIFY_COMPLETED = 4,
640 
641   /**
642    * Limit on the number of (concurrent) connections made to the
643    * server from the same IP address.  Can be used to prevent one
644    * IP from taking over all of the allowed connections.  If the
645    * same IP tries to establish more than the specified number of
646    * connections, they will be immediately rejected.  The option
647    * should be followed by an `unsigned int`.  The default is
648    * zero, which means no limit on the number of connections
649    * from the same IP address.
650    */
651   MHD_OPTION_PER_IP_CONNECTION_LIMIT = 5,
652 
653   /**
654    * Bind daemon to the supplied `struct sockaddr`. This option should
655    * be followed by a `struct sockaddr *`.  If #MHD_USE_IPv6 is
656    * specified, the `struct sockaddr*` should point to a `struct
657    * sockaddr_in6`, otherwise to a `struct sockaddr_in`.
658    */
659   MHD_OPTION_SOCK_ADDR = 6,
660 
661   /**
662    * Specify a function that should be called before parsing the URI from
663    * the client.  The specified callback function can be used for processing
664    * the URI (including the options) before it is parsed.  The URI after
665    * parsing will no longer contain the options, which maybe inconvenient for
666    * logging.  This option should be followed by two arguments, the first
667    * one must be of the form
668    *
669    *     void * my_logger(void *cls, const char *uri, struct MHD_Connection *con)
670    *
671    * where the return value will be passed as
672    * (`* con_cls`) in calls to the #MHD_AccessHandlerCallback
673    * when this request is processed later; returning a
674    * value of NULL has no special significance (however,
675    * note that if you return non-NULL, you can no longer
676    * rely on the first call to the access handler having
677    * `NULL == *con_cls` on entry;)
678    * "cls" will be set to the second argument following
679    * #MHD_OPTION_URI_LOG_CALLBACK.  Finally, uri will
680    * be the 0-terminated URI of the request.
681    *
682    * Note that during the time of this call, most of the connection's
683    * state is not initialized (as we have not yet parsed he headers).
684    * However, information about the connecting client (IP, socket)
685    * is available.
686    */
687   MHD_OPTION_URI_LOG_CALLBACK = 7,
688 
689   /**
690    * Memory pointer for the private key (key.pem) to be used by the
691    * HTTPS daemon.  This option should be followed by a
692    * `const char *` argument.
693    * This should be used in conjunction with #MHD_OPTION_HTTPS_MEM_CERT.
694    */
695   MHD_OPTION_HTTPS_MEM_KEY = 8,
696 
697   /**
698    * Memory pointer for the certificate (cert.pem) to be used by the
699    * HTTPS daemon.  This option should be followed by a
700    * `const char *` argument.
701    * This should be used in conjunction with #MHD_OPTION_HTTPS_MEM_KEY.
702    */
703   MHD_OPTION_HTTPS_MEM_CERT = 9,
704 
705   /**
706    * Daemon credentials type.
707    * Followed by an argument of type
708    * `gnutls_credentials_type_t`.
709    */
710   MHD_OPTION_HTTPS_CRED_TYPE = 10,
711 
712   /**
713    * Memory pointer to a `const char *` specifying the
714    * cipher algorithm (default: "NORMAL").
715    */
716   MHD_OPTION_HTTPS_PRIORITIES = 11,
717 
718   /**
719    * Pass a listen socket for MHD to use (systemd-style).  If this
720    * option is used, MHD will not open its own listen socket(s). The
721    * argument passed must be of type `int` and refer to an
722    * existing socket that has been bound to a port and is listening.
723    */
724   MHD_OPTION_LISTEN_SOCKET = 12,
725 
726   /**
727    * Use the given function for logging error messages.  This option
728    * must be followed by two arguments; the first must be a pointer to
729    * a function of type #MHD_LogCallback and the second a pointer
730    * `void *` which will be passed as the first argument to the log
731    * callback.
732    *
733    * Note that MHD will not generate any log messages
734    * if it was compiled without the "--enable-messages"
735    * flag being set.
736    */
737   MHD_OPTION_EXTERNAL_LOGGER = 13,
738 
739   /**
740    * Number (`unsigned int`) of threads in thread pool. Enable
741    * thread pooling by setting this value to to something
742    * greater than 1. Currently, thread model must be
743    * #MHD_USE_SELECT_INTERNALLY if thread pooling is enabled
744    * (#MHD_start_daemon returns NULL for an unsupported thread
745    * model).
746    */
747   MHD_OPTION_THREAD_POOL_SIZE = 14,
748 
749   /**
750    * Additional options given in an array of `struct MHD_OptionItem`.
751    * The array must be terminated with an entry `{MHD_OPTION_END, 0, NULL}`.
752    * An example for code using #MHD_OPTION_ARRAY is:
753    *
754    *     struct MHD_OptionItem ops[] = {
755    *       { MHD_OPTION_CONNECTION_LIMIT, 100, NULL },
756    *       { MHD_OPTION_CONNECTION_TIMEOUT, 10, NULL },
757    *       { MHD_OPTION_END, 0, NULL }
758    *     };
759    *     d = MHD_start_daemon (0, 8080, NULL, NULL, dh, NULL,
760    *                           MHD_OPTION_ARRAY, ops,
761    *                           MHD_OPTION_END);
762    *
763    * For options that expect a single pointer argument, the
764    * second member of the `struct MHD_OptionItem` is ignored.
765    * For options that expect two pointer arguments, the first
766    * argument must be cast to `intptr_t`.
767    */
768   MHD_OPTION_ARRAY = 15,
769 
770   /**
771    * Specify a function that should be called for unescaping escape
772    * sequences in URIs and URI arguments.  Note that this function
773    * will NOT be used by the `struct MHD_PostProcessor`.  If this
774    * option is not specified, the default method will be used which
775    * decodes escape sequences of the form "%HH".  This option should
776    * be followed by two arguments, the first one must be of the form
777    *
778    *     size_t my_unescaper(void *cls,
779    *                         struct MHD_Connection *c,
780    *                         char *s)
781    *
782    * where the return value must be "strlen(s)" and "s" should be
783    * updated.  Note that the unescape function must not lengthen "s"
784    * (the result must be shorter than the input and still be
785    * 0-terminated).  "cls" will be set to the second argument
786    * following #MHD_OPTION_UNESCAPE_CALLBACK.
787    */
788   MHD_OPTION_UNESCAPE_CALLBACK = 16,
789 
790   /**
791    * Memory pointer for the random values to be used by the Digest
792    * Auth module. This option should be followed by two arguments.
793    * First an integer of type  `size_t` which specifies the size
794    * of the buffer pointed to by the second argument in bytes.
795    * Note that the application must ensure that the buffer of the
796    * second argument remains allocated and unmodified while the
797    * deamon is running.
798    */
799   MHD_OPTION_DIGEST_AUTH_RANDOM = 17,
800 
801   /**
802    * Size of the internal array holding the map of the nonce and
803    * the nonce counter. This option should be followed by an `unsigend int`
804    * argument.
805    */
806   MHD_OPTION_NONCE_NC_SIZE = 18,
807 
808   /**
809    * Desired size of the stack for threads created by MHD. Followed
810    * by an argument of type `size_t`.  Use 0 for system default.
811    */
812   MHD_OPTION_THREAD_STACK_SIZE = 19,
813 
814   /**
815    * Memory pointer for the certificate (ca.pem) to be used by the
816    * HTTPS daemon for client authentification.
817    * This option should be followed by a `const char *` argument.
818    */
819   MHD_OPTION_HTTPS_MEM_TRUST = 20,
820 
821   /**
822    * Increment to use for growing the read buffer (followed by a
823    * `size_t`). Must fit within #MHD_OPTION_CONNECTION_MEMORY_LIMIT.
824    */
825   MHD_OPTION_CONNECTION_MEMORY_INCREMENT = 21,
826 
827   /**
828    * Use a callback to determine which X.509 certificate should be
829    * used for a given HTTPS connection.  This option should be
830    * followed by a argument of type `gnutls_certificate_retrieve_function2 *`.
831    * This option provides an
832    * alternative to #MHD_OPTION_HTTPS_MEM_KEY,
833    * #MHD_OPTION_HTTPS_MEM_CERT.  You must use this version if
834    * multiple domains are to be hosted at the same IP address using
835    * TLS's Server Name Indication (SNI) extension.  In this case,
836    * the callback is expected to select the correct certificate
837    * based on the SNI information provided.  The callback is expected
838    * to access the SNI data using `gnutls_server_name_get()`.
839    * Using this option requires GnuTLS 3.0 or higher.
840    */
841   MHD_OPTION_HTTPS_CERT_CALLBACK = 22,
842 
843   /**
844    * When using #MHD_USE_TCP_FASTOPEN, this option changes the default TCP
845    * fastopen queue length of 50.  Note that having a larger queue size can
846    * cause resource exhaustion attack as the TCP stack has to now allocate
847    * resources for the SYN packet along with its DATA.  This option should be
848    * followed by an `unsigned int` argument.
849    */
850   MHD_OPTION_TCP_FASTOPEN_QUEUE_SIZE = 23,
851 
852   /**
853    * Memory pointer for the Diffie-Hellman parameters (dh.pem) to be used by the
854    * HTTPS daemon for key exchange.
855    * This option must be followed by a `const char *` argument.
856    */
857   MHD_OPTION_HTTPS_MEM_DHPARAMS = 24,
858 
859   /**
860    * If present and set to true, allow reusing address:port socket
861    * (by using SO_REUSEPORT on most platform, or platform-specific ways).
862    * If present and set to false, disallow reusing address:port socket
863    * (does nothing on most plaform, but uses SO_EXCLUSIVEADDRUSE on Windows).
864    * This option must be followed by a `unsigned int` argument.
865    */
866   MHD_OPTION_LISTENING_ADDRESS_REUSE = 25,
867 
868   /**
869    * Memory pointer for a password that decrypts the private key (key.pem)
870    * to be used by the HTTPS daemon. This option should be followed by a
871    * `const char *` argument.
872    * This should be used in conjunction with #MHD_OPTION_HTTPS_MEM_KEY.
873    * @sa ::MHD_FEATURE_HTTPS_KEY_PASSWORD
874    */
875   MHD_OPTION_HTTPS_KEY_PASSWORD = 26,
876 
877   /**
878    * Register a function that should be called whenever a connection is
879    * started or closed.
880    *
881    * This option should be followed by TWO pointers.  First a pointer
882    * to a function of type #MHD_NotifyConnectionCallback and second a
883    * pointer to a closure to pass to the request completed callback.
884    * The second pointer maybe NULL.
885    */
886   MHD_OPTION_NOTIFY_CONNECTION = 27
887 
888 };
889 
890 
891 /**
892  * Entry in an #MHD_OPTION_ARRAY.
893  */
894 struct MHD_OptionItem
895 {
896   /**
897    * Which option is being given.  Use #MHD_OPTION_END
898    * to terminate the array.
899    */
900   enum MHD_OPTION option;
901 
902   /**
903    * Option value (for integer arguments, and for options requiring
904    * two pointer arguments); should be 0 for options that take no
905    * arguments or only a single pointer argument.
906    */
907   intptr_t value;
908 
909   /**
910    * Pointer option value (use NULL for options taking no arguments
911    * or only an integer option).
912    */
913   void *ptr_value;
914 
915 };
916 
917 
918 /**
919  * The `enum MHD_ValueKind` specifies the source of
920  * the key-value pairs in the HTTP protocol.
921  */
922 enum MHD_ValueKind
923 {
924 
925   /**
926    * Response header
927    */
928   MHD_RESPONSE_HEADER_KIND = 0,
929 
930   /**
931    * HTTP header.
932    */
933   MHD_HEADER_KIND = 1,
934 
935   /**
936    * Cookies.  Note that the original HTTP header containing
937    * the cookie(s) will still be available and intact.
938    */
939   MHD_COOKIE_KIND = 2,
940 
941   /**
942    * POST data.  This is available only if a content encoding
943    * supported by MHD is used (currently only URL encoding),
944    * and only if the posted content fits within the available
945    * memory pool.  Note that in that case, the upload data
946    * given to the #MHD_AccessHandlerCallback will be
947    * empty (since it has already been processed).
948    */
949   MHD_POSTDATA_KIND = 4,
950 
951   /**
952    * GET (URI) arguments.
953    */
954   MHD_GET_ARGUMENT_KIND = 8,
955 
956   /**
957    * HTTP footer (only for HTTP 1.1 chunked encodings).
958    */
959   MHD_FOOTER_KIND = 16
960 };
961 
962 
963 /**
964  * The `enum MHD_RequestTerminationCode` specifies reasons
965  * why a request has been terminated (or completed).
966  * @ingroup request
967  */
968 enum MHD_RequestTerminationCode
969 {
970 
971   /**
972    * We finished sending the response.
973    * @ingroup request
974    */
975   MHD_REQUEST_TERMINATED_COMPLETED_OK = 0,
976 
977   /**
978    * Error handling the connection (resources
979    * exhausted, other side closed connection,
980    * application error accepting request, etc.)
981    * @ingroup request
982    */
983   MHD_REQUEST_TERMINATED_WITH_ERROR = 1,
984 
985   /**
986    * No activity on the connection for the number
987    * of seconds specified using
988    * #MHD_OPTION_CONNECTION_TIMEOUT.
989    * @ingroup request
990    */
991   MHD_REQUEST_TERMINATED_TIMEOUT_REACHED = 2,
992 
993   /**
994    * We had to close the session since MHD was being
995    * shut down.
996    * @ingroup request
997    */
998   MHD_REQUEST_TERMINATED_DAEMON_SHUTDOWN = 3,
999 
1000   /**
1001    * We tried to read additional data, but the other side closed the
1002    * connection.  This error is similar to
1003    * #MHD_REQUEST_TERMINATED_WITH_ERROR, but specific to the case where
1004    * the connection died because the other side did not send expected
1005    * data.
1006    * @ingroup request
1007    */
1008   MHD_REQUEST_TERMINATED_READ_ERROR = 4,
1009 
1010   /**
1011    * The client terminated the connection by closing the socket
1012    * for writing (TCP half-closed); MHD aborted sending the
1013    * response according to RFC 2616, section 8.1.4.
1014    * @ingroup request
1015    */
1016   MHD_REQUEST_TERMINATED_CLIENT_ABORT = 5
1017 
1018 };
1019 
1020 
1021 /**
1022  * The `enum MHD_ConnectionNotificationCode` specifies types
1023  * of connection notifications.
1024  * @ingroup request
1025  */
1026 enum MHD_ConnectionNotificationCode
1027 {
1028 
1029   /**
1030    * A new connection has been started.
1031    * @ingroup request
1032    */
1033   MHD_CONNECTION_NOTIFY_STARTED = 0,
1034 
1035   /**
1036    * A connection is closed.
1037    * @ingroup request
1038    */
1039   MHD_CONNECTION_NOTIFY_CLOSED = 1
1040 
1041 };
1042 
1043 
1044 /**
1045  * Information about a connection.
1046  */
1047 union MHD_ConnectionInfo
1048 {
1049 
1050   /**
1051    * Cipher algorithm used, of type "enum gnutls_cipher_algorithm".
1052    */
1053   int /* enum gnutls_cipher_algorithm */ cipher_algorithm;
1054 
1055   /**
1056    * Protocol used, of type "enum gnutls_protocol".
1057    */
1058   int /* enum gnutls_protocol */ protocol;
1059 
1060   /**
1061    * Connect socket
1062    */
1063   MHD_socket connect_fd;
1064 
1065   /**
1066    * GNUtls session handle, of type "gnutls_session_t".
1067    */
1068   void * /* gnutls_session_t */ tls_session;
1069 
1070   /**
1071    * GNUtls client certificate handle, of type "gnutls_x509_crt_t".
1072    */
1073   void * /* gnutls_x509_crt_t */ client_cert;
1074 
1075   /**
1076    * Address information for the client.
1077    */
1078   struct sockaddr *client_addr;
1079 
1080   /**
1081    * Which daemon manages this connection (useful in case there are many
1082    * daemons running).
1083    */
1084   struct MHD_Daemon *daemon;
1085 
1086   /**
1087    * Socket-specific client context.  Points to the same address as
1088    * the "socket_context" of the #MHD_NotifyConnectionCallback.
1089    */
1090   void **socket_context;
1091 };
1092 
1093 
1094 /**
1095  * Values of this enum are used to specify what
1096  * information about a connection is desired.
1097  * @ingroup request
1098  */
1099 enum MHD_ConnectionInfoType
1100 {
1101   /**
1102    * What cipher algorithm is being used.
1103    * Takes no extra arguments.
1104    * @ingroup request
1105    */
1106   MHD_CONNECTION_INFO_CIPHER_ALGO,
1107 
1108   /**
1109    *
1110    * Takes no extra arguments.
1111    * @ingroup request
1112    */
1113   MHD_CONNECTION_INFO_PROTOCOL,
1114 
1115   /**
1116    * Obtain IP address of the client.  Takes no extra arguments.
1117    * Returns essentially a `struct sockaddr **` (since the API returns
1118    * a `union MHD_ConnectionInfo *` and that union contains a `struct
1119    * sockaddr *`).
1120    * @ingroup request
1121    */
1122   MHD_CONNECTION_INFO_CLIENT_ADDRESS,
1123 
1124   /**
1125    * Get the gnuTLS session handle.
1126    * @ingroup request
1127    */
1128   MHD_CONNECTION_INFO_GNUTLS_SESSION,
1129 
1130   /**
1131    * Get the gnuTLS client certificate handle.  Dysfunctional (never
1132    * implemented, deprecated).  Use #MHD_CONNECTION_INFO_GNUTLS_SESSION
1133    * to get the `gnutls_session_t` and then call
1134    * gnutls_certificate_get_peers().
1135    */
1136   MHD_CONNECTION_INFO_GNUTLS_CLIENT_CERT,
1137 
1138   /**
1139    * Get the `struct MHD_Daemon *` responsible for managing this connection.
1140    * @ingroup request
1141    */
1142   MHD_CONNECTION_INFO_DAEMON,
1143 
1144   /**
1145    * Request the file descriptor for the listening socket.
1146    * No extra arguments should be passed.
1147    * @ingroup request
1148    */
1149   MHD_CONNECTION_INFO_CONNECTION_FD,
1150 
1151   /**
1152    * Returns the client-specific pointer to a `void *` that was (possibly)
1153    * set during a #MHD_NotifyConnectionCallback when the socket was
1154    * first accepted.  Note that this is NOT the same as the "con_cls"
1155    * argument of the #MHD_AccessHandlerCallback.  The "con_cls" is
1156    * fresh for each HTTP request, while the "socket_context" is fresh
1157    * for each socket.
1158    */
1159   MHD_CONNECTION_INFO_SOCKET_CONTEXT
1160 
1161 };
1162 
1163 
1164 /**
1165  * Values of this enum are used to specify what
1166  * information about a deamon is desired.
1167  */
1168 enum MHD_DaemonInfoType
1169 {
1170   /**
1171    * No longer supported (will return NULL).
1172    */
1173   MHD_DAEMON_INFO_KEY_SIZE,
1174 
1175   /**
1176    * No longer supported (will return NULL).
1177    */
1178   MHD_DAEMON_INFO_MAC_KEY_SIZE,
1179 
1180   /**
1181    * Request the file descriptor for the listening socket.
1182    * No extra arguments should be passed.
1183    */
1184   MHD_DAEMON_INFO_LISTEN_FD,
1185 
1186   /**
1187    * Request the file descriptor for the external epoll.
1188    * No extra arguments should be passed.
1189    */
1190   MHD_DAEMON_INFO_EPOLL_FD_LINUX_ONLY,
1191 
1192   /**
1193    * Request the number of current connections handled by the daemon.
1194    * No extra arguments should be passed.
1195    */
1196   MHD_DAEMON_INFO_CURRENT_CONNECTIONS
1197 };
1198 
1199 
1200 /**
1201  * Callback for serious error condition. The default action is to print
1202  * an error message and `abort()`.
1203  *
1204  * @param cls user specified value
1205  * @param file where the error occured
1206  * @param line where the error occured
1207  * @param reason error detail, may be NULL
1208  * @ingroup logging
1209  */
1210 typedef void
1211 (*MHD_PanicCallback) (void *cls,
1212                       const char *file,
1213                       unsigned int line,
1214                       const char *reason);
1215 
1216 /**
1217  * Allow or deny a client to connect.
1218  *
1219  * @param cls closure
1220  * @param addr address information from the client
1221  * @param addrlen length of @a addr
1222  * @return #MHD_YES if connection is allowed, #MHD_NO if not
1223  */
1224 typedef int
1225 (*MHD_AcceptPolicyCallback) (void *cls,
1226                              const struct sockaddr *addr,
1227                              socklen_t addrlen);
1228 
1229 
1230 /**
1231  * A client has requested the given url using the given method
1232  * (#MHD_HTTP_METHOD_GET, #MHD_HTTP_METHOD_PUT,
1233  * #MHD_HTTP_METHOD_DELETE, #MHD_HTTP_METHOD_POST, etc).  The callback
1234  * must call MHD callbacks to provide content to give back to the
1235  * client and return an HTTP status code (i.e. #MHD_HTTP_OK,
1236  * #MHD_HTTP_NOT_FOUND, etc.).
1237  *
1238  * @param cls argument given together with the function
1239  *        pointer when the handler was registered with MHD
1240  * @param url the requested url
1241  * @param method the HTTP method used (#MHD_HTTP_METHOD_GET,
1242  *        #MHD_HTTP_METHOD_PUT, etc.)
1243  * @param version the HTTP version string (i.e.
1244  *        #MHD_HTTP_VERSION_1_1)
1245  * @param upload_data the data being uploaded (excluding HEADERS,
1246  *        for a POST that fits into memory and that is encoded
1247  *        with a supported encoding, the POST data will NOT be
1248  *        given in upload_data and is instead available as
1249  *        part of #MHD_get_connection_values; very large POST
1250  *        data *will* be made available incrementally in
1251  *        @a upload_data)
1252  * @param upload_data_size set initially to the size of the
1253  *        @a upload_data provided; the method must update this
1254  *        value to the number of bytes NOT processed;
1255  * @param con_cls pointer that the callback can set to some
1256  *        address and that will be preserved by MHD for future
1257  *        calls for this request; since the access handler may
1258  *        be called many times (i.e., for a PUT/POST operation
1259  *        with plenty of upload data) this allows the application
1260  *        to easily associate some request-specific state.
1261  *        If necessary, this state can be cleaned up in the
1262  *        global #MHD_RequestCompletedCallback (which
1263  *        can be set with the #MHD_OPTION_NOTIFY_COMPLETED).
1264  *        Initially, `*con_cls` will be NULL.
1265  * @return #MHD_YES if the connection was handled successfully,
1266  *         #MHD_NO if the socket must be closed due to a serios
1267  *         error while handling the request
1268  */
1269 typedef int
1270 (*MHD_AccessHandlerCallback) (void *cls,
1271                               struct MHD_Connection *connection,
1272                               const char *url,
1273                               const char *method,
1274                               const char *version,
1275                               const char *upload_data,
1276                               size_t *upload_data_size,
1277                               void **con_cls);
1278 
1279 
1280 /**
1281  * Signature of the callback used by MHD to notify the
1282  * application about completed requests.
1283  *
1284  * @param cls client-defined closure
1285  * @param connection connection handle
1286  * @param con_cls value as set by the last call to
1287  *        the #MHD_AccessHandlerCallback
1288  * @param toe reason for request termination
1289  * @see #MHD_OPTION_NOTIFY_COMPLETED
1290  * @ingroup request
1291  */
1292 typedef void
1293 (*MHD_RequestCompletedCallback) (void *cls,
1294                                  struct MHD_Connection *connection,
1295                                  void **con_cls,
1296                                  enum MHD_RequestTerminationCode toe);
1297 
1298 /**
1299  * Signature of the callback used by MHD to notify the
1300  * application about started/stopped connections
1301  *
1302  * @param cls client-defined closure
1303  * @param connection connection handle
1304  * @param socket_context socket-specific pointer where the
1305  *                       client can associate some state specific
1306  *                       to the TCP connection; note that this is
1307  *                       different from the "con_cls" which is per
1308  *                       HTTP request.  The client can initialize
1309  *                       during #MHD_CONNECTION_NOTIFY_STARTED and
1310  *                       cleanup during #MHD_CONNECTION_NOTIFY_CLOSED
1311  *                       and access in the meantime using
1312  *                       #MHD_CONNECTION_INFO_SOCKET_CONTEXT.
1313  * @param toe reason for connection notification
1314  * @see #MHD_OPTION_NOTIFY_CONNECTION
1315  * @ingroup request
1316  */
1317 typedef void
1318 (*MHD_NotifyConnectionCallback) (void *cls,
1319                                  struct MHD_Connection *connection,
1320                                  void **socket_context,
1321                                  enum MHD_ConnectionNotificationCode toe);
1322 
1323 
1324 /**
1325  * Iterator over key-value pairs.  This iterator
1326  * can be used to iterate over all of the cookies,
1327  * headers, or POST-data fields of a request, and
1328  * also to iterate over the headers that have been
1329  * added to a response.
1330  *
1331  * @param cls closure
1332  * @param kind kind of the header we are looking at
1333  * @param key key for the value, can be an empty string
1334  * @param value corresponding value, can be NULL
1335  * @return #MHD_YES to continue iterating,
1336  *         #MHD_NO to abort the iteration
1337  * @ingroup request
1338  */
1339 typedef int
1340 (*MHD_KeyValueIterator) (void *cls,
1341                          enum MHD_ValueKind kind,
1342                          const char *key,
1343                          const char *value);
1344 
1345 
1346 /**
1347  * Callback used by libmicrohttpd in order to obtain content.  The
1348  * callback is to copy at most @a max bytes of content into @a buf.  The
1349  * total number of bytes that has been placed into @a buf should be
1350  * returned.
1351  *
1352  * Note that returning zero will cause libmicrohttpd to try again.
1353  * Thus, returning zero should only be used in conjunction
1354  * with MHD_suspend_connection() to avoid busy waiting.
1355  *
1356  * @param cls extra argument to the callback
1357  * @param pos position in the datastream to access;
1358  *        note that if a `struct MHD_Response` object is re-used,
1359  *        it is possible for the same content reader to
1360  *        be queried multiple times for the same data;
1361  *        however, if a `struct MHD_Response` is not re-used,
1362  *        libmicrohttpd guarantees that "pos" will be
1363  *        the sum of all non-negative return values
1364  *        obtained from the content reader so far.
1365  * @param buf where to copy the data
1366  * @param max maximum number of bytes to copy to @a buf (size of @a buf)
1367  * @return number of bytes written to @a buf;
1368  *  0 is legal unless we are running in internal select mode (since
1369  *    this would cause busy-waiting); 0 in external select mode
1370  *    will cause this function to be called again once the external
1371  *    select calls MHD again;
1372  *  #MHD_CONTENT_READER_END_OF_STREAM (-1) for the regular
1373  *    end of transmission (with chunked encoding, MHD will then
1374  *    terminate the chunk and send any HTTP footers that might be
1375  *    present; without chunked encoding and given an unknown
1376  *    response size, MHD will simply close the connection; note
1377  *    that while returning #MHD_CONTENT_READER_END_OF_STREAM is not technically
1378  *    legal if a response size was specified, MHD accepts this
1379  *    and treats it just as #MHD_CONTENT_READER_END_WITH_ERROR;
1380  *  #MHD_CONTENT_READER_END_WITH_ERROR (-2) to indicate a server
1381  *    error generating the response; this will cause MHD to simply
1382  *    close the connection immediately.  If a response size was
1383  *    given or if chunked encoding is in use, this will indicate
1384  *    an error to the client.  Note, however, that if the client
1385  *    does not know a response size and chunked encoding is not in
1386  *    use, then clients will not be able to tell the difference between
1387  *    #MHD_CONTENT_READER_END_WITH_ERROR and #MHD_CONTENT_READER_END_OF_STREAM.
1388  *    This is not a limitation of MHD but rather of the HTTP protocol.
1389  */
1390 typedef ssize_t
1391 (*MHD_ContentReaderCallback) (void *cls,
1392                               uint64_t pos,
1393                               char *buf,
1394                               size_t max);
1395 
1396 
1397 /**
1398  * This method is called by libmicrohttpd if we
1399  * are done with a content reader.  It should
1400  * be used to free resources associated with the
1401  * content reader.
1402  *
1403  * @param cls closure
1404  * @ingroup response
1405  */
1406 typedef void
1407 (*MHD_ContentReaderFreeCallback) (void *cls);
1408 
1409 
1410 /**
1411  * Iterator over key-value pairs where the value
1412  * maybe made available in increments and/or may
1413  * not be zero-terminated.  Used for processing
1414  * POST data.
1415  *
1416  * @param cls user-specified closure
1417  * @param kind type of the value, always #MHD_POSTDATA_KIND when called from MHD
1418  * @param key 0-terminated key for the value
1419  * @param filename name of the uploaded file, NULL if not known
1420  * @param content_type mime-type of the data, NULL if not known
1421  * @param transfer_encoding encoding of the data, NULL if not known
1422  * @param data pointer to @a size bytes of data at the
1423  *              specified offset
1424  * @param off offset of data in the overall value
1425  * @param size number of bytes in @a data available
1426  * @return #MHD_YES to continue iterating,
1427  *         #MHD_NO to abort the iteration
1428  */
1429 typedef int
1430 (*MHD_PostDataIterator) (void *cls,
1431                          enum MHD_ValueKind kind,
1432                          const char *key,
1433                          const char *filename,
1434                          const char *content_type,
1435                          const char *transfer_encoding,
1436                          const char *data,
1437                          uint64_t off,
1438                          size_t size);
1439 
1440 /* **************** Daemon handling functions ***************** */
1441 
1442 /**
1443  * Start a webserver on the given port.
1444  *
1445  * @param flags combination of `enum MHD_FLAG` values
1446  * @param port port to bind to (in host byte order)
1447  * @param apc callback to call to check which clients
1448  *        will be allowed to connect; you can pass NULL
1449  *        in which case connections from any IP will be
1450  *        accepted
1451  * @param apc_cls extra argument to apc
1452  * @param dh handler called for all requests (repeatedly)
1453  * @param dh_cls extra argument to @a dh
1454  * @param ap list of options (type-value pairs,
1455  *        terminated with #MHD_OPTION_END).
1456  * @return NULL on error, handle to daemon on success
1457  * @ingroup event
1458  */
1459 _MHD_EXTERN struct MHD_Daemon *
1460 MHD_start_daemon_va (unsigned int flags,
1461 		     uint16_t port,
1462 		     MHD_AcceptPolicyCallback apc, void *apc_cls,
1463 		     MHD_AccessHandlerCallback dh, void *dh_cls,
1464 		     va_list ap);
1465 
1466 
1467 /**
1468  * Start a webserver on the given port.  Variadic version of
1469  * #MHD_start_daemon_va.
1470  *
1471  * @param flags combination of `enum MHD_FLAG` values
1472  * @param port port to bind to
1473  * @param apc callback to call to check which clients
1474  *        will be allowed to connect; you can pass NULL
1475  *        in which case connections from any IP will be
1476  *        accepted
1477  * @param apc_cls extra argument to apc
1478  * @param dh handler called for all requests (repeatedly)
1479  * @param dh_cls extra argument to @a dh
1480  * @return NULL on error, handle to daemon on success
1481  * @ingroup event
1482  */
1483 _MHD_EXTERN struct MHD_Daemon *
1484 MHD_start_daemon (unsigned int flags,
1485 		  uint16_t port,
1486 		  MHD_AcceptPolicyCallback apc, void *apc_cls,
1487 		  MHD_AccessHandlerCallback dh, void *dh_cls,
1488 		  ...);
1489 
1490 
1491 /**
1492  * Stop accepting connections from the listening socket.  Allows
1493  * clients to continue processing, but stops accepting new
1494  * connections.  Note that the caller is responsible for closing the
1495  * returned socket; however, if MHD is run using threads (anything but
1496  * external select mode), it must not be closed until AFTER
1497  * #MHD_stop_daemon has been called (as it is theoretically possible
1498  * that an existing thread is still using it).
1499  *
1500  * Note that some thread modes require the caller to have passed
1501  * #MHD_USE_PIPE_FOR_SHUTDOWN when using this API.  If this daemon is
1502  * in one of those modes and this option was not given to
1503  * #MHD_start_daemon, this function will return #MHD_INVALID_SOCKET.
1504  *
1505  * @param daemon daemon to stop accepting new connections for
1506  * @return old listen socket on success, #MHD_INVALID_SOCKET if
1507  *         the daemon was already not listening anymore
1508  * @ingroup specialized
1509  */
1510 _MHD_EXTERN MHD_socket
1511 MHD_quiesce_daemon (struct MHD_Daemon *daemon);
1512 
1513 
1514 /**
1515  * Shutdown an HTTP daemon.
1516  *
1517  * @param daemon daemon to stop
1518  * @ingroup event
1519  */
1520 _MHD_EXTERN void
1521 MHD_stop_daemon (struct MHD_Daemon *daemon);
1522 
1523 
1524 /**
1525  * Add another client connection to the set of connections managed by
1526  * MHD.  This API is usually not needed (since MHD will accept inbound
1527  * connections on the server socket).  Use this API in special cases,
1528  * for example if your HTTP server is behind NAT and needs to connect
1529  * out to the HTTP client, or if you are building a proxy.
1530  *
1531  * If you use this API in conjunction with a internal select or a
1532  * thread pool, you must set the option
1533  * #MHD_USE_PIPE_FOR_SHUTDOWN to ensure that the freshly added
1534  * connection is immediately processed by MHD.
1535  *
1536  * The given client socket will be managed (and closed!) by MHD after
1537  * this call and must no longer be used directly by the application
1538  * afterwards.
1539  *
1540  * Per-IP connection limits are ignored when using this API.
1541  *
1542  * @param daemon daemon that manages the connection
1543  * @param client_socket socket to manage (MHD will expect
1544  *        to receive an HTTP request from this socket next).
1545  * @param addr IP address of the client
1546  * @param addrlen number of bytes in @a addr
1547  * @return #MHD_YES on success, #MHD_NO if this daemon could
1548  *        not handle the connection (i.e. `malloc()` failed, etc).
1549  *        The socket will be closed in any case; `errno` is
1550  *        set to indicate further details about the error.
1551  * @ingroup specialized
1552  */
1553 _MHD_EXTERN int
1554 MHD_add_connection (struct MHD_Daemon *daemon,
1555 		    MHD_socket client_socket,
1556 		    const struct sockaddr *addr,
1557 		    socklen_t addrlen);
1558 
1559 
1560 /**
1561  * Obtain the `select()` sets for this daemon.
1562  * Daemon's FDs will be added to fd_sets. To get only
1563  * daemon FDs in fd_sets, call FD_ZERO for each fd_set
1564  * before calling this function. FD_SETSIZE is assumed
1565  * to be platform's default.
1566  *
1567  * @param daemon daemon to get sets from
1568  * @param read_fd_set read set
1569  * @param write_fd_set write set
1570  * @param except_fd_set except set
1571  * @param max_fd increased to largest FD added (if larger
1572  *               than existing value); can be NULL
1573  * @return #MHD_YES on success, #MHD_NO if this
1574  *         daemon was not started with the right
1575  *         options for this call or any FD didn't
1576  *         fit fd_set.
1577  * @ingroup event
1578  */
1579 _MHD_EXTERN int
1580 MHD_get_fdset (struct MHD_Daemon *daemon,
1581                fd_set *read_fd_set,
1582                fd_set *write_fd_set,
1583 	       fd_set *except_fd_set,
1584 	       MHD_socket *max_fd);
1585 
1586 
1587 /**
1588  * Obtain the `select()` sets for this daemon.
1589  * Daemon's FDs will be added to fd_sets. To get only
1590  * daemon FDs in fd_sets, call FD_ZERO for each fd_set
1591  * before calling this function. Passing custom FD_SETSIZE
1592  * as @a fd_setsize allow usage of larger/smaller than
1593  * platform's default fd_sets.
1594  *
1595  * @param daemon daemon to get sets from
1596  * @param read_fd_set read set
1597  * @param write_fd_set write set
1598  * @param except_fd_set except set
1599  * @param max_fd increased to largest FD added (if larger
1600  *               than existing value); can be NULL
1601  * @param fd_setsize value of FD_SETSIZE
1602  * @return #MHD_YES on success, #MHD_NO if this
1603  *         daemon was not started with the right
1604  *         options for this call or any FD didn't
1605  *         fit fd_set.
1606  * @ingroup event
1607  */
1608 _MHD_EXTERN int
1609 MHD_get_fdset2 (struct MHD_Daemon *daemon,
1610                fd_set *read_fd_set,
1611                fd_set *write_fd_set,
1612                fd_set *except_fd_set,
1613                MHD_socket *max_fd,
1614                unsigned int fd_setsize);
1615 
1616 
1617 /**
1618  * Obtain the `select()` sets for this daemon.
1619  * Daemon's FDs will be added to fd_sets. To get only
1620  * daemon FDs in fd_sets, call FD_ZERO for each fd_set
1621  * before calling this function. Size of fd_set is
1622  * determined by current value of FD_SETSIZE.
1623  *
1624  * @param daemon daemon to get sets from
1625  * @param read_fd_set read set
1626  * @param write_fd_set write set
1627  * @param except_fd_set except set
1628  * @param max_fd increased to largest FD added (if larger
1629  *               than existing value); can be NULL
1630  * @return #MHD_YES on success, #MHD_NO if this
1631  *         daemon was not started with the right
1632  *         options for this call or any FD didn't
1633  *         fit fd_set.
1634  * @ingroup event
1635  */
1636 #define MHD_get_fdset(daemon,read_fd_set,write_fd_set,except_fd_set,max_fd) \
1637   MHD_get_fdset2((daemon),(read_fd_set),(write_fd_set),(except_fd_set),(max_fd),FD_SETSIZE)
1638 
1639 
1640 /**
1641  * Obtain timeout value for `select()` for this daemon (only needed if
1642  * connection timeout is used).  The returned value is how many milliseconds
1643  * `select()` or `poll()` should at most block, not the timeout value set for
1644  * connections.  This function MUST NOT be called if MHD is running with
1645  * #MHD_USE_THREAD_PER_CONNECTION.
1646  *
1647  * @param daemon daemon to query for timeout
1648  * @param timeout set to the timeout (in milliseconds)
1649  * @return #MHD_YES on success, #MHD_NO if timeouts are
1650  *        not used (or no connections exist that would
1651  *        necessiate the use of a timeout right now).
1652  * @ingroup event
1653  */
1654 _MHD_EXTERN int
1655 MHD_get_timeout (struct MHD_Daemon *daemon,
1656 		 MHD_UNSIGNED_LONG_LONG *timeout);
1657 
1658 
1659 /**
1660  * Run webserver operations (without blocking unless in client
1661  * callbacks).  This method should be called by clients in combination
1662  * with #MHD_get_fdset if the client-controlled select method is used.
1663  *
1664  * This function is a convenience method, which is useful if the
1665  * fd_sets from #MHD_get_fdset were not directly passed to `select()`;
1666  * with this function, MHD will internally do the appropriate `select()`
1667  * call itself again.  While it is always safe to call #MHD_run (in
1668  * external select mode), you should call #MHD_run_from_select if
1669  * performance is important (as it saves an expensive call to
1670  * `select()`).
1671  *
1672  * @param daemon daemon to run
1673  * @return #MHD_YES on success, #MHD_NO if this
1674  *         daemon was not started with the right
1675  *         options for this call.
1676  * @ingroup event
1677  */
1678 _MHD_EXTERN int
1679 MHD_run (struct MHD_Daemon *daemon);
1680 
1681 
1682 /**
1683  * Run webserver operations. This method should be called by clients
1684  * in combination with #MHD_get_fdset if the client-controlled select
1685  * method is used.
1686  *
1687  * You can use this function instead of #MHD_run if you called
1688  * `select()` on the result from #MHD_get_fdset.  File descriptors in
1689  * the sets that are not controlled by MHD will be ignored.  Calling
1690  * this function instead of #MHD_run is more efficient as MHD will
1691  * not have to call `select()` again to determine which operations are
1692  * ready.
1693  *
1694  * @param daemon daemon to run select loop for
1695  * @param read_fd_set read set
1696  * @param write_fd_set write set
1697  * @param except_fd_set except set (not used, can be NULL)
1698  * @return #MHD_NO on serious errors, #MHD_YES on success
1699  * @ingroup event
1700  */
1701 _MHD_EXTERN int
1702 MHD_run_from_select (struct MHD_Daemon *daemon,
1703 		     const fd_set *read_fd_set,
1704 		     const fd_set *write_fd_set,
1705 		     const fd_set *except_fd_set);
1706 
1707 
1708 
1709 
1710 /* **************** Connection handling functions ***************** */
1711 
1712 /**
1713  * Get all of the headers from the request.
1714  *
1715  * @param connection connection to get values from
1716  * @param kind types of values to iterate over
1717  * @param iterator callback to call on each header;
1718  *        maybe NULL (then just count headers)
1719  * @param iterator_cls extra argument to @a iterator
1720  * @return number of entries iterated over
1721  * @ingroup request
1722  */
1723 _MHD_EXTERN int
1724 MHD_get_connection_values (struct MHD_Connection *connection,
1725                            enum MHD_ValueKind kind,
1726                            MHD_KeyValueIterator iterator, void *iterator_cls);
1727 
1728 
1729 /**
1730  * This function can be used to add an entry to the HTTP headers of a
1731  * connection (so that the #MHD_get_connection_values function will
1732  * return them -- and the `struct MHD_PostProcessor` will also see
1733  * them).  This maybe required in certain situations (see Mantis
1734  * #1399) where (broken) HTTP implementations fail to supply values
1735  * needed by the post processor (or other parts of the application).
1736  *
1737  * This function MUST only be called from within the
1738  * #MHD_AccessHandlerCallback (otherwise, access maybe improperly
1739  * synchronized).  Furthermore, the client must guarantee that the key
1740  * and value arguments are 0-terminated strings that are NOT freed
1741  * until the connection is closed.  (The easiest way to do this is by
1742  * passing only arguments to permanently allocated strings.).
1743  *
1744  * @param connection the connection for which a
1745  *  value should be set
1746  * @param kind kind of the value
1747  * @param key key for the value
1748  * @param value the value itself
1749  * @return #MHD_NO if the operation could not be
1750  *         performed due to insufficient memory;
1751  *         #MHD_YES on success
1752  * @ingroup request
1753  */
1754 _MHD_EXTERN int
1755 MHD_set_connection_value (struct MHD_Connection *connection,
1756                           enum MHD_ValueKind kind,
1757                           const char *key,
1758 			  const char *value);
1759 
1760 
1761 /**
1762  * Sets the global error handler to a different implementation.  @a cb
1763  * will only be called in the case of typically fatal, serious
1764  * internal consistency issues.  These issues should only arise in the
1765  * case of serious memory corruption or similar problems with the
1766  * architecture.  While @a cb is allowed to return and MHD will then
1767  * try to continue, this is never safe.
1768  *
1769  * The default implementation that is used if no panic function is set
1770  * simply prints an error message and calls `abort()`.  Alternative
1771  * implementations might call `exit()` or other similar functions.
1772  *
1773  * @param cb new error handler
1774  * @param cls passed to @a cb
1775  * @ingroup logging
1776  */
1777 _MHD_EXTERN void
1778 MHD_set_panic_func (MHD_PanicCallback cb, void *cls);
1779 
1780 
1781 /**
1782  * Process escape sequences ('%HH') Updates val in place; the
1783  * result should be UTF-8 encoded and cannot be larger than the input.
1784  * The result must also still be 0-terminated.
1785  *
1786  * @param val value to unescape (modified in the process)
1787  * @return length of the resulting val (`strlen(val)` may be
1788  *  shorter afterwards due to elimination of escape sequences)
1789  */
1790 _MHD_EXTERN size_t
1791 MHD_http_unescape (char *val);
1792 
1793 
1794 /**
1795  * Get a particular header value.  If multiple
1796  * values match the kind, return any one of them.
1797  *
1798  * @param connection connection to get values from
1799  * @param kind what kind of value are we looking for
1800  * @param key the header to look for, NULL to lookup 'trailing' value without a key
1801  * @return NULL if no such item was found
1802  * @ingroup request
1803  */
1804 _MHD_EXTERN const char *
1805 MHD_lookup_connection_value (struct MHD_Connection *connection,
1806 			     enum MHD_ValueKind kind,
1807 			     const char *key);
1808 
1809 
1810 /**
1811  * Queue a response to be transmitted to the client (as soon as
1812  * possible but after #MHD_AccessHandlerCallback returns).
1813  *
1814  * @param connection the connection identifying the client
1815  * @param status_code HTTP status code (i.e. #MHD_HTTP_OK)
1816  * @param response response to transmit
1817  * @return #MHD_NO on error (i.e. reply already sent),
1818  *         #MHD_YES on success or if message has been queued
1819  * @ingroup response
1820  */
1821 _MHD_EXTERN int
1822 MHD_queue_response (struct MHD_Connection *connection,
1823                     unsigned int status_code,
1824 		    struct MHD_Response *response);
1825 
1826 
1827 /**
1828  * Suspend handling of network data for a given connection.  This can
1829  * be used to dequeue a connection from MHD's event loop (external
1830  * select, internal select or thread pool; not applicable to
1831  * thread-per-connection!) for a while.
1832  *
1833  * If you use this API in conjunction with a internal select or a
1834  * thread pool, you must set the option #MHD_USE_PIPE_FOR_SHUTDOWN to
1835  * ensure that a resumed connection is immediately processed by MHD.
1836  *
1837  * Suspended connections continue to count against the total number of
1838  * connections allowed (per daemon, as well as per IP, if such limits
1839  * are set).  Suspended connections will NOT time out; timeouts will
1840  * restart when the connection handling is resumed.  While a
1841  * connection is suspended, MHD will not detect disconnects by the
1842  * client.
1843  *
1844  * The only safe time to suspend a connection is from the
1845  * #MHD_AccessHandlerCallback.
1846  *
1847  * Finally, it is an API violation to call #MHD_stop_daemon while
1848  * having suspended connections (this will at least create memory and
1849  * socket leaks or lead to undefined behavior).  You must explicitly
1850  * resume all connections before stopping the daemon.
1851  *
1852  * @param connection the connection to suspend
1853  */
1854 _MHD_EXTERN void
1855 MHD_suspend_connection (struct MHD_Connection *connection);
1856 
1857 
1858 /**
1859  * Resume handling of network data for suspended connection.  It is
1860  * safe to resume a suspended connection at any time.  Calling this
1861  * function on a connection that was not previously suspended will
1862  * result in undefined behavior.
1863  *
1864  * @param connection the connection to resume
1865  */
1866 _MHD_EXTERN void
1867 MHD_resume_connection (struct MHD_Connection *connection);
1868 
1869 
1870 /* **************** Response manipulation functions ***************** */
1871 
1872 
1873 /**
1874  * Flags for special handling of responses.
1875  */
1876 enum MHD_ResponseFlags
1877 {
1878   /**
1879    * Default: no special flags.
1880    */
1881   MHD_RF_NONE = 0,
1882 
1883   /**
1884    * Only respond in conservative HTTP 1.0-mode.   In particular,
1885    * do not (automatically) sent "Connection" headers and always
1886    * close the connection after generating the response.
1887    */
1888   MHD_RF_HTTP_VERSION_1_0_ONLY = 1
1889 
1890 };
1891 
1892 
1893 /**
1894  * MHD options (for future extensions).
1895  */
1896 enum MHD_ResponseOptions
1897 {
1898   /**
1899    * End of the list of options.
1900    */
1901   MHD_RO_END = 0
1902 };
1903 
1904 
1905 /**
1906  * Set special flags and options for a response.
1907  *
1908  * @param response the response to modify
1909  * @param flags to set for the response
1910  * @param ... #MHD_RO_END terminated list of options
1911  * @return #MHD_YES on success, #MHD_NO on error
1912  */
1913 _MHD_EXTERN int
1914 MHD_set_response_options (struct MHD_Response *response,
1915                           enum MHD_ResponseFlags flags,
1916                           ...);
1917 
1918 
1919 /**
1920  * Create a response object.  The response object can be extended with
1921  * header information and then be used any number of times.
1922  *
1923  * @param size size of the data portion of the response, #MHD_SIZE_UNKNOWN for unknown
1924  * @param block_size preferred block size for querying crc (advisory only,
1925  *                   MHD may still call @a crc using smaller chunks); this
1926  *                   is essentially the buffer size used for IO, clients
1927  *                   should pick a value that is appropriate for IO and
1928  *                   memory performance requirements
1929  * @param crc callback to use to obtain response data
1930  * @param crc_cls extra argument to @a crc
1931  * @param crfc callback to call to free @a crc_cls resources
1932  * @return NULL on error (i.e. invalid arguments, out of memory)
1933  * @ingroup response
1934  */
1935 _MHD_EXTERN struct MHD_Response *
1936 MHD_create_response_from_callback (uint64_t size,
1937 				   size_t block_size,
1938 				   MHD_ContentReaderCallback crc, void *crc_cls,
1939 				   MHD_ContentReaderFreeCallback crfc);
1940 
1941 
1942 /**
1943  * Create a response object.  The response object can be extended with
1944  * header information and then be used any number of times.
1945  *
1946  * @param size size of the @a data portion of the response
1947  * @param data the data itself
1948  * @param must_free libmicrohttpd should free data when done
1949  * @param must_copy libmicrohttpd must make a copy of @a data
1950  *        right away, the data maybe released anytime after
1951  *        this call returns
1952  * @return NULL on error (i.e. invalid arguments, out of memory)
1953  * @deprecated use #MHD_create_response_from_buffer instead
1954  * @ingroup response
1955  */
1956 _MHD_EXTERN struct MHD_Response *
1957 MHD_create_response_from_data (size_t size,
1958 			       void *data,
1959 			       int must_free,
1960 			       int must_copy);
1961 
1962 
1963 /**
1964  * Specification for how MHD should treat the memory buffer
1965  * given for the response.
1966  * @ingroup response
1967  */
1968 enum MHD_ResponseMemoryMode
1969 {
1970 
1971   /**
1972    * Buffer is a persistent (static/global) buffer that won't change
1973    * for at least the lifetime of the response, MHD should just use
1974    * it, not free it, not copy it, just keep an alias to it.
1975    * @ingroup response
1976    */
1977   MHD_RESPMEM_PERSISTENT,
1978 
1979   /**
1980    * Buffer is heap-allocated with `malloc()` (or equivalent) and
1981    * should be freed by MHD after processing the response has
1982    * concluded (response reference counter reaches zero).
1983    * @ingroup response
1984    */
1985   MHD_RESPMEM_MUST_FREE,
1986 
1987   /**
1988    * Buffer is in transient memory, but not on the heap (for example,
1989    * on the stack or non-`malloc()` allocated) and only valid during the
1990    * call to #MHD_create_response_from_buffer.  MHD must make its
1991    * own private copy of the data for processing.
1992    * @ingroup response
1993    */
1994   MHD_RESPMEM_MUST_COPY
1995 
1996 };
1997 
1998 
1999 /**
2000  * Create a response object.  The response object can be extended with
2001  * header information and then be used any number of times.
2002  *
2003  * @param size size of the data portion of the response
2004  * @param buffer size bytes containing the response's data portion
2005  * @param mode flags for buffer management
2006  * @return NULL on error (i.e. invalid arguments, out of memory)
2007  * @ingroup response
2008  */
2009 _MHD_EXTERN struct MHD_Response *
2010 MHD_create_response_from_buffer (size_t size,
2011 				 void *buffer,
2012 				 enum MHD_ResponseMemoryMode mode);
2013 
2014 
2015 /**
2016  * Create a response object.  The response object can be extended with
2017  * header information and then be used any number of times.
2018  *
2019  * @param size size of the data portion of the response
2020  * @param fd file descriptor referring to a file on disk with the
2021  *        data; will be closed when response is destroyed;
2022  *        fd should be in 'blocking' mode
2023  * @return NULL on error (i.e. invalid arguments, out of memory)
2024  * @ingroup response
2025  */
2026 _MHD_EXTERN struct MHD_Response *
2027 MHD_create_response_from_fd (size_t size,
2028 			     int fd);
2029 
2030 
2031 /**
2032  * Create a response object.  The response object can be extended with
2033  * header information and then be used any number of times.
2034  *
2035  * @param size size of the data portion of the response
2036  * @param fd file descriptor referring to a file on disk with the
2037  *        data; will be closed when response is destroyed;
2038  *        fd should be in 'blocking' mode
2039  * @param offset offset to start reading from in the file;
2040  *        Be careful! `off_t` may have been compiled to be a
2041  *        64-bit variable for MHD, in which case your application
2042  *        also has to be compiled using the same options! Read
2043  *        the MHD manual for more details.
2044  * @return NULL on error (i.e. invalid arguments, out of memory)
2045  * @ingroup response
2046  */
2047 _MHD_EXTERN struct MHD_Response *
2048 MHD_create_response_from_fd_at_offset (size_t size,
2049 				       int fd,
2050 				       off_t offset);
2051 
2052 
2053 #if 0
2054 /**
2055  * Enumeration for actions MHD should perform on the underlying socket
2056  * of the upgrade.  This API is not finalized, and in particular
2057  * the final set of actions is yet to be decided. This is just an
2058  * idea for what we might want.
2059  */
2060 enum MHD_UpgradeAction
2061 {
2062 
2063   /**
2064    * Close the socket, the application is done with it.
2065    *
2066    * Takes no extra arguments.
2067    *
2068    * NOTE: it is unclear if we want to have this in the
2069    * "final" API, this is all just ideas.
2070    */
2071   MHD_UPGRADE_ACTION_CLOSE = 0,
2072 
2073   /**
2074    * Uncork the TCP write buffer (that is, tell the OS to transmit all
2075    * bytes in the buffer now, and to not use TCP-CORKing).
2076    *
2077    * Takes no extra arguments.
2078    *
2079    * NOTE: it is unclear if we want to have this in the
2080    * "final" API, this is all just ideas.
2081    */
2082   MHD_UPGRADE_ACTION_CORK
2083 
2084 };
2085 
2086 
2087 /**
2088  * This connection-specific callback is provided by MHD to
2089  * applications (unusual) during the #MHD_UpgradeHandler.
2090  * It allows applications to perform 'special' actions on
2091  * the underlying socket from the upgrade.
2092  *
2093  * @param cls the closure (from `upgrade_action_cls`)
2094  * @param action which action should be performed
2095  * @param ... arguments to the action (depends on the action)
2096  * @return #MHD_NO on error, #MHD_YES on success
2097  */
2098 typedef int
2099 (*MHD_UpgradeActionCallback)(void *cls,
2100                              enum MHD_UpgradeAction action,
2101                              ...);
2102 
2103 /**
2104  * Function called after a protocol "upgrade" response was sent
2105  * successfully and the socket should now be controlled by some
2106  * protocol other than HTTP.
2107  *
2108  * Any data received on the socket will be made available in
2109  * 'data_in'.  The function should update 'data_in_size' to
2110  * reflect the number of bytes consumed from 'data_in' (the remaining
2111  * bytes will be made available in the next call to the handler).
2112  *
2113  * Any data that should be transmitted on the socket should be
2114  * stored in 'data_out'.  '*data_out_size' is initially set to
2115  * the available buffer space in 'data_out'.  It should be set to
2116  * the number of bytes stored in 'data_out' (which can be zero).
2117  *
2118  * The return value is a BITMASK that indicates how the function
2119  * intends to interact with the event loop.  It can request to be
2120  * notified for reading, writing, request to UNCORK the send buffer
2121  * (which MHD is allowed to ignore, if it is not possible to uncork on
2122  * the local platform), to wait for the 'external' select loop to
2123  * trigger another round.  It is also possible to specify "no events"
2124  * to terminate the connection; in this case, the
2125  * #MHD_RequestCompletedCallback will be called and all resources of
2126  * the connection will be released.
2127  *
2128  * Except when in 'thread-per-connection' mode, implementations
2129  * of this function should never block (as it will still be called
2130  * from within the main event loop).
2131  *
2132  * @param cls closure
2133  * @param connection original HTTP connection handle,
2134  *                   giving the function a last chance
2135  *                   to inspect the original HTTP request
2136  * @param sock socket to use for bi-directional communication
2137  *        with the client.  For HTTPS, this may not be a socket
2138  *        that is directly connected to the client and thus certain
2139  *        operations (TCP-specific setsockopt(), getsockopt(), etc.)
2140  *        may not work as expected (as the socket could be from a
2141  *        socketpair() or a TCP-loopback)
2142  * @param upgrade_action function that can be used to perform actions
2143  *        on the @a sock (like those that cannot be done explicitly).
2144  *        Applications must use this callback to perform the
2145  *        close() action on the @a sock.
2146  * @param upgrade_action_cls closure that must be passed to @a upgrade_action
2147  */
2148 typedef void
2149 (*MHD_UpgradeHandler)(void *cls,
2150                       struct MHD_Connection *connection,
2151                       MHD_SOCKET sock,
2152                       MHD_UpgradeActionCallback upgrade_action,
2153                       void *upgrade_action_cls);
2154 
2155 
2156 /**
2157  * Create a response object that can be used for 101 UPGRADE
2158  * responses, for example to implement WebSockets.  After sending the
2159  * response, control over the data stream is given to the callback (which
2160  * can then, for example, start some bi-directional communication).
2161  * If the response is queued for multiple connections, the callback
2162  * will be called for each connection.  The callback
2163  * will ONLY be called after the response header was successfully passed
2164  * to the OS; if there are communication errors before, the usual MHD
2165  * connection error handling code will be performed.
2166  *
2167  * Setting the correct HTTP code (i.e. MHD_HTTP_SWITCHING_PROTOCOLS)
2168  * and setting correct HTTP headers for the upgrade must be done
2169  * manually (this way, it is possible to implement most existing
2170  * WebSocket versions using this API; in fact, this API might be useful
2171  * for any protocol switch, not just WebSockets).  Note that
2172  * draft-ietf-hybi-thewebsocketprotocol-00 cannot be implemented this
2173  * way as the header "HTTP/1.1 101 WebSocket Protocol Handshake"
2174  * cannot be generated; instead, MHD will always produce "HTTP/1.1 101
2175  * Switching Protocols" (if the response code 101 is used).
2176  *
2177  * As usual, the response object can be extended with header
2178  * information and then be used any number of times (as long as the
2179  * header information is not connection-specific).
2180  *
2181  * @param upgrade_handler function to call with the 'upgraded' socket
2182  * @param upgrade_handler_cls closure for @a upgrade_handler
2183  * @return NULL on error (i.e. invalid arguments, out of memory)
2184  */
2185 struct MHD_Response *
2186 MHD_create_response_for_upgrade (MHD_UpgradeHandler upgrade_handler,
2187 				 void *upgrade_handler_cls);
2188 #endif
2189 
2190 /**
2191  * Destroy a response object and associated resources.  Note that
2192  * libmicrohttpd may keep some of the resources around if the response
2193  * is still in the queue for some clients, so the memory may not
2194  * necessarily be freed immediatley.
2195  *
2196  * @param response response to destroy
2197  * @ingroup response
2198  */
2199 _MHD_EXTERN void
2200 MHD_destroy_response (struct MHD_Response *response);
2201 
2202 
2203 /**
2204  * Add a header line to the response.
2205  *
2206  * @param response response to add a header to
2207  * @param header the header to add
2208  * @param content value to add
2209  * @return #MHD_NO on error (i.e. invalid header or content format),
2210  *         or out of memory
2211  * @ingroup response
2212  */
2213 _MHD_EXTERN int
2214 MHD_add_response_header (struct MHD_Response *response,
2215                          const char *header,
2216 			 const char *content);
2217 
2218 
2219 /**
2220  * Add a footer line to the response.
2221  *
2222  * @param response response to remove a header from
2223  * @param footer the footer to delete
2224  * @param content value to delete
2225  * @return #MHD_NO on error (i.e. invalid footer or content format).
2226  * @ingroup response
2227  */
2228 _MHD_EXTERN int
2229 MHD_add_response_footer (struct MHD_Response *response,
2230                          const char *footer,
2231 			 const char *content);
2232 
2233 
2234 /**
2235  * Delete a header (or footer) line from the response.
2236  *
2237  * @param response response to remove a header from
2238  * @param header the header to delete
2239  * @param content value to delete
2240  * @return #MHD_NO on error (no such header known)
2241  * @ingroup response
2242  */
2243 _MHD_EXTERN int
2244 MHD_del_response_header (struct MHD_Response *response,
2245                          const char *header,
2246 			 const char *content);
2247 
2248 
2249 /**
2250  * Get all of the headers (and footers) added to a response.
2251  *
2252  * @param response response to query
2253  * @param iterator callback to call on each header;
2254  *        maybe NULL (then just count headers)
2255  * @param iterator_cls extra argument to @a iterator
2256  * @return number of entries iterated over
2257  * @ingroup response
2258  */
2259 _MHD_EXTERN int
2260 MHD_get_response_headers (struct MHD_Response *response,
2261                           MHD_KeyValueIterator iterator, void *iterator_cls);
2262 
2263 
2264 /**
2265  * Get a particular header (or footer) from the response.
2266  *
2267  * @param response response to query
2268  * @param key which header to get
2269  * @return NULL if header does not exist
2270  * @ingroup response
2271  */
2272 _MHD_EXTERN const char *
2273 MHD_get_response_header (struct MHD_Response *response,
2274 			 const char *key);
2275 
2276 
2277 /* ********************** PostProcessor functions ********************** */
2278 
2279 /**
2280  * Create a `struct MHD_PostProcessor`.
2281  *
2282  * A `struct MHD_PostProcessor` can be used to (incrementally) parse
2283  * the data portion of a POST request.  Note that some buggy browsers
2284  * fail to set the encoding type.  If you want to support those, you
2285  * may have to call #MHD_set_connection_value with the proper encoding
2286  * type before creating a post processor (if no supported encoding
2287  * type is set, this function will fail).
2288  *
2289  * @param connection the connection on which the POST is
2290  *        happening (used to determine the POST format)
2291  * @param buffer_size maximum number of bytes to use for
2292  *        internal buffering (used only for the parsing,
2293  *        specifically the parsing of the keys).  A
2294  *        tiny value (256-1024) should be sufficient.
2295  *        Do NOT use a value smaller than 256.  For good
2296  *        performance, use 32 or 64k (i.e. 65536).
2297  * @param iter iterator to be called with the parsed data,
2298  *        Must NOT be NULL.
2299  * @param iter_cls first argument to @a iter
2300  * @return NULL on error (out of memory, unsupported encoding),
2301  *         otherwise a PP handle
2302  * @ingroup request
2303  */
2304 _MHD_EXTERN struct MHD_PostProcessor *
2305 MHD_create_post_processor (struct MHD_Connection *connection,
2306 			   size_t buffer_size,
2307 			   MHD_PostDataIterator iter, void *iter_cls);
2308 
2309 
2310 /**
2311  * Parse and process POST data.  Call this function when POST data is
2312  * available (usually during an #MHD_AccessHandlerCallback) with the
2313  * "upload_data" and "upload_data_size".  Whenever possible, this will
2314  * then cause calls to the #MHD_PostDataIterator.
2315  *
2316  * @param pp the post processor
2317  * @param post_data @a post_data_len bytes of POST data
2318  * @param post_data_len length of @a post_data
2319  * @return #MHD_YES on success, #MHD_NO on error
2320  *         (out-of-memory, iterator aborted, parse error)
2321  * @ingroup request
2322  */
2323 _MHD_EXTERN int
2324 MHD_post_process (struct MHD_PostProcessor *pp,
2325                   const char *post_data, size_t post_data_len);
2326 
2327 
2328 /**
2329  * Release PostProcessor resources.
2330  *
2331  * @param pp the PostProcessor to destroy
2332  * @return #MHD_YES if processing completed nicely,
2333  *         #MHD_NO if there were spurious characters / formatting
2334  *                problems; it is common to ignore the return
2335  *                value of this function
2336  * @ingroup request
2337  */
2338 _MHD_EXTERN int
2339 MHD_destroy_post_processor (struct MHD_PostProcessor *pp);
2340 
2341 
2342 /* ********************* Digest Authentication functions *************** */
2343 
2344 
2345 /**
2346  * Constant to indicate that the nonce of the provided
2347  * authentication code was wrong.
2348  * @ingroup authentication
2349  */
2350 #define MHD_INVALID_NONCE -1
2351 
2352 
2353 /**
2354  * Get the username from the authorization header sent by the client
2355  *
2356  * @param connection The MHD connection structure
2357  * @return NULL if no username could be found, a pointer
2358  * 			to the username if found
2359  * @ingroup authentication
2360  */
2361 _MHD_EXTERN char *
2362 MHD_digest_auth_get_username (struct MHD_Connection *connection);
2363 
2364 
2365 /**
2366  * Authenticates the authorization header sent by the client
2367  *
2368  * @param connection The MHD connection structure
2369  * @param realm The realm presented to the client
2370  * @param username The username needs to be authenticated
2371  * @param password The password used in the authentication
2372  * @param nonce_timeout The amount of time for a nonce to be
2373  * 			invalid in seconds
2374  * @return #MHD_YES if authenticated, #MHD_NO if not,
2375  * 			#MHD_INVALID_NONCE if nonce is invalid
2376  * @ingroup authentication
2377  */
2378 _MHD_EXTERN int
2379 MHD_digest_auth_check (struct MHD_Connection *connection,
2380 		       const char *realm,
2381 		       const char *username,
2382 		       const char *password,
2383 		       unsigned int nonce_timeout);
2384 
2385 
2386 /**
2387  * Queues a response to request authentication from the client
2388  *
2389  * @param connection The MHD connection structure
2390  * @param realm The realm presented to the client
2391  * @param opaque string to user for opaque value
2392  * @param response reply to send; should contain the "access denied"
2393  *        body; note that this function will set the "WWW Authenticate"
2394  *        header and that the caller should not do this
2395  * @param signal_stale #MHD_YES if the nonce is invalid to add
2396  * 			'stale=true' to the authentication header
2397  * @return #MHD_YES on success, #MHD_NO otherwise
2398  * @ingroup authentication
2399  */
2400 _MHD_EXTERN int
2401 MHD_queue_auth_fail_response (struct MHD_Connection *connection,
2402 			      const char *realm,
2403 			      const char *opaque,
2404 			      struct MHD_Response *response,
2405 			      int signal_stale);
2406 
2407 
2408 /**
2409  * Get the username and password from the basic authorization header sent by the client
2410  *
2411  * @param connection The MHD connection structure
2412  * @param password a pointer for the password
2413  * @return NULL if no username could be found, a pointer
2414  * 			to the username if found
2415  * @ingroup authentication
2416  */
2417 _MHD_EXTERN char *
2418 MHD_basic_auth_get_username_password (struct MHD_Connection *connection,
2419 				      char** password);
2420 
2421 
2422 /**
2423  * Queues a response to request basic authentication from the client
2424  * The given response object is expected to include the payload for
2425  * the response; the "WWW-Authenticate" header will be added and the
2426  * response queued with the 'UNAUTHORIZED' status code.
2427  *
2428  * @param connection The MHD connection structure
2429  * @param realm the realm presented to the client
2430  * @param response response object to modify and queue
2431  * @return #MHD_YES on success, #MHD_NO otherwise
2432  * @ingroup authentication
2433  */
2434 _MHD_EXTERN int
2435 MHD_queue_basic_auth_fail_response (struct MHD_Connection *connection,
2436 				    const char *realm,
2437 				    struct MHD_Response *response);
2438 
2439 /* ********************** generic query functions ********************** */
2440 
2441 
2442 /**
2443  * Obtain information about the given connection.
2444  *
2445  * @param connection what connection to get information about
2446  * @param info_type what information is desired?
2447  * @param ... depends on @a info_type
2448  * @return NULL if this information is not available
2449  *         (or if the @a info_type is unknown)
2450  * @ingroup specialized
2451  */
2452 _MHD_EXTERN const union MHD_ConnectionInfo *
2453 MHD_get_connection_info (struct MHD_Connection *connection,
2454 			 enum MHD_ConnectionInfoType info_type,
2455 			 ...);
2456 
2457 
2458 /**
2459  * MHD connection options.  Given to #MHD_set_connection_option to
2460  * set custom options for a particular connection.
2461  */
2462 enum MHD_CONNECTION_OPTION
2463 {
2464 
2465   /**
2466    * Set a custom timeout for the given connection.  Specified
2467    * as the number of seconds, given as an `unsigned int`.  Use
2468    * zero for no timeout.
2469    */
2470   MHD_CONNECTION_OPTION_TIMEOUT
2471 
2472 };
2473 
2474 
2475 /**
2476  * Set a custom option for the given connection, overriding defaults.
2477  *
2478  * @param connection connection to modify
2479  * @param option option to set
2480  * @param ... arguments to the option, depending on the option type
2481  * @return #MHD_YES on success, #MHD_NO if setting the option failed
2482  * @ingroup specialized
2483  */
2484 _MHD_EXTERN int
2485 MHD_set_connection_option (struct MHD_Connection *connection,
2486 			   enum MHD_CONNECTION_OPTION option,
2487 			   ...);
2488 
2489 
2490 /**
2491  * Information about an MHD daemon.
2492  */
2493 union MHD_DaemonInfo
2494 {
2495   /**
2496    * Size of the key, no longer supported.
2497    * @deprecated
2498    */
2499   size_t key_size;
2500 
2501   /**
2502    * Size of the mac key, no longer supported.
2503    * @deprecated
2504    */
2505   size_t mac_key_size;
2506 
2507   /**
2508    * Listen socket file descriptor, for #MHD_DAEMON_INFO_EPOLL_FD_LINUX_ONLY
2509    * and #MHD_DAEMON_INFO_LISTEN_FD.
2510    */
2511   MHD_socket listen_fd;
2512 
2513   /**
2514    * Number of active connections, for #MHD_DAEMON_INFO_CURRENT_CONNECTIONS.
2515    */
2516   unsigned int num_connections;
2517 };
2518 
2519 
2520 /**
2521  * Obtain information about the given daemon
2522  * (not fully implemented!).
2523  *
2524  * @param daemon what daemon to get information about
2525  * @param info_type what information is desired?
2526  * @param ... depends on @a info_type
2527  * @return NULL if this information is not available
2528  *         (or if the @a info_type is unknown)
2529  * @ingroup specialized
2530  */
2531 _MHD_EXTERN const union MHD_DaemonInfo *
2532 MHD_get_daemon_info (struct MHD_Daemon *daemon,
2533 		     enum MHD_DaemonInfoType info_type,
2534 		     ...);
2535 
2536 
2537 /**
2538  * Obtain the version of this library
2539  *
2540  * @return static version string, e.g. "0.9.9"
2541  * @ingroup specialized
2542  */
2543 _MHD_EXTERN const char*
2544 MHD_get_version (void);
2545 
2546 
2547 /**
2548  * Types of information about MHD features,
2549  * used by #MHD_is_feature_supported().
2550  */
2551 enum MHD_FEATURE
2552 {
2553   /**
2554    * Get whether messages are supported. If supported then in debug
2555    * mode messages can be printed to stderr or to external logger.
2556    */
2557   MHD_FEATURE_MESSGES = 1,
2558 
2559   /**
2560    * Get whether HTTPS is supported.  If supported then flag
2561    * #MHD_USE_SSL and options #MHD_OPTION_HTTPS_MEM_KEY,
2562    * #MHD_OPTION_HTTPS_MEM_CERT, #MHD_OPTION_HTTPS_MEM_TRUST,
2563    * #MHD_OPTION_HTTPS_MEM_DHPARAMS, #MHD_OPTION_HTTPS_CRED_TYPE,
2564    * #MHD_OPTION_HTTPS_PRIORITIES can be used.
2565    */
2566   MHD_FEATURE_SSL = 2,
2567 
2568   /**
2569    * Get whether option #MHD_OPTION_HTTPS_CERT_CALLBACK is
2570    * supported.
2571    */
2572   MHD_FEATURE_HTTPS_CERT_CALLBACK = 3,
2573 
2574   /**
2575    * Get whether IPv6 is supported. If supported then flag
2576    * #MHD_USE_IPv6 can be used.
2577    */
2578   MHD_FEATURE_IPv6 = 4,
2579 
2580   /**
2581    * Get whether IPv6 without IPv4 is supported. If not supported
2582    * then IPv4 is always enabled in IPv6 sockets and
2583    * flag #MHD_USE_DUAL_STACK if always used when #MHD_USE_IPv6 is
2584    * specified.
2585    */
2586   MHD_FEATURE_IPv6_ONLY = 5,
2587 
2588   /**
2589    * Get whether `poll()` is supported. If supported then flag
2590    * #MHD_USE_POLL can be used.
2591    */
2592   MHD_FEATURE_POLL = 6,
2593 
2594   /**
2595    * Get whether `epoll()` is supported. If supported then Flags
2596    * #MHD_USE_EPOLL_LINUX_ONLY and
2597    * #MHD_USE_EPOLL_INTERNALLY_LINUX_ONLY can be used.
2598    */
2599   MHD_FEATURE_EPOLL = 7,
2600 
2601   /**
2602    * Get whether shutdown on listen socket to signal other
2603    * threads is supported. If not supported flag
2604    * #MHD_USE_PIPE_FOR_SHUTDOWN is automatically forced.
2605    */
2606   MHD_FEATURE_SHUTDOWN_LISTEN_SOCKET = 8,
2607 
2608   /**
2609    * Get whether socketpair is used internally instead of pipe to
2610    * signal other threads.
2611    */
2612   MHD_FEATURE_SOCKETPAIR = 9,
2613 
2614   /**
2615    * Get whether TCP Fast Open is supported. If supported then
2616    * flag #MHD_USE_TCP_FASTOPEN and option
2617    * #MHD_OPTION_TCP_FASTOPEN_QUEUE_SIZE can be used.
2618    */
2619   MHD_FEATURE_TCP_FASTOPEN = 10,
2620 
2621   /**
2622    * Get whether HTTP Basic authorization is supported. If supported
2623    * then functions #MHD_basic_auth_get_username_password and
2624    * #MHD_queue_basic_auth_fail_response can be used.
2625    */
2626   MHD_FEATURE_BASIC_AUTH = 11,
2627 
2628   /**
2629    * Get whether HTTP Digest authorization is supported. If
2630    * supported then options #MHD_OPTION_DIGEST_AUTH_RANDOM,
2631    * #MHD_OPTION_NONCE_NC_SIZE and
2632    * #MHD_digest_auth_check() can be used.
2633    */
2634   MHD_FEATURE_DIGEST_AUTH = 12,
2635 
2636   /**
2637    * Get whether postprocessor is supported. If supported then
2638    * functions #MHD_create_post_processor(), #MHD_post_process() and
2639    * #MHD_destroy_post_processor() can
2640    * be used.
2641    */
2642   MHD_FEATURE_POSTPROCESSOR = 13,
2643 
2644   /**
2645   * Get whether password encrypted private key for HTTPS daemon is
2646   * supported. If supported then option
2647   * ::MHD_OPTION_HTTPS_KEY_PASSWORD can be used.
2648   */
2649   MHD_FEATURE_HTTPS_KEY_PASSWORD = 14
2650 };
2651 
2652 
2653 /**
2654  * Get information about supported MHD features.
2655  * Indicate that MHD was compiled with or without support for
2656  * particular feature. Some features require additional support
2657  * by kernel. Kernel support is not checked by this function.
2658  *
2659  * @param feature type of requested information
2660  * @return #MHD_YES if feature is supported by MHD, #MHD_NO if
2661  * feature is not supported or feature is unknown.
2662  * @ingroup specialized
2663  */
2664 _MHD_EXTERN int
2665 MHD_is_feature_supported(enum MHD_FEATURE feature);
2666 
2667 
2668 #if 0                           /* keep Emacsens' auto-indent happy */
2669 {
2670 #endif
2671 #ifdef __cplusplus
2672 }
2673 #endif
2674 
2675 #endif
2676