libmicrohttpd.texi 122 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846184718481849185018511852185318541855185618571858185918601861186218631864186518661867186818691870187118721873187418751876187718781879188018811882188318841885188618871888188918901891189218931894189518961897189818991900190119021903190419051906190719081909191019111912191319141915191619171918191919201921192219231924192519261927192819291930193119321933193419351936193719381939194019411942194319441945194619471948194919501951195219531954195519561957195819591960196119621963196419651966196719681969197019711972197319741975197619771978197919801981198219831984198519861987198819891990199119921993199419951996199719981999200020012002200320042005200620072008200920102011201220132014201520162017201820192020202120222023202420252026202720282029203020312032203320342035203620372038203920402041204220432044204520462047204820492050205120522053205420552056205720582059206020612062206320642065206620672068206920702071207220732074207520762077207820792080208120822083208420852086208720882089209020912092209320942095209620972098209921002101210221032104210521062107210821092110211121122113211421152116211721182119212021212122212321242125212621272128212921302131213221332134213521362137213821392140214121422143214421452146214721482149215021512152215321542155215621572158215921602161216221632164216521662167216821692170217121722173217421752176217721782179218021812182218321842185218621872188218921902191219221932194219521962197219821992200220122022203220422052206220722082209221022112212221322142215221622172218221922202221222222232224222522262227222822292230223122322233223422352236223722382239224022412242224322442245224622472248224922502251225222532254225522562257225822592260226122622263226422652266226722682269227022712272227322742275227622772278227922802281228222832284228522862287228822892290229122922293229422952296229722982299230023012302230323042305230623072308230923102311231223132314231523162317231823192320232123222323232423252326232723282329233023312332233323342335233623372338233923402341234223432344234523462347234823492350235123522353235423552356235723582359236023612362236323642365236623672368236923702371237223732374237523762377237823792380238123822383238423852386238723882389239023912392239323942395239623972398239924002401240224032404240524062407240824092410241124122413241424152416241724182419242024212422242324242425242624272428242924302431243224332434243524362437243824392440244124422443244424452446244724482449245024512452245324542455245624572458245924602461246224632464246524662467246824692470247124722473247424752476247724782479248024812482248324842485248624872488248924902491249224932494249524962497249824992500250125022503250425052506250725082509251025112512251325142515251625172518251925202521252225232524252525262527252825292530253125322533253425352536253725382539254025412542254325442545254625472548254925502551255225532554255525562557255825592560256125622563256425652566256725682569257025712572257325742575257625772578257925802581258225832584258525862587258825892590259125922593259425952596259725982599260026012602260326042605260626072608260926102611261226132614261526162617261826192620262126222623262426252626262726282629263026312632263326342635263626372638263926402641264226432644264526462647264826492650265126522653265426552656265726582659266026612662266326642665266626672668266926702671267226732674267526762677267826792680268126822683268426852686268726882689269026912692269326942695269626972698269927002701270227032704270527062707270827092710271127122713271427152716271727182719272027212722272327242725272627272728272927302731273227332734273527362737273827392740274127422743274427452746274727482749275027512752275327542755275627572758275927602761276227632764276527662767276827692770277127722773277427752776277727782779278027812782278327842785278627872788278927902791279227932794279527962797279827992800280128022803280428052806280728082809281028112812281328142815281628172818281928202821282228232824282528262827282828292830283128322833283428352836283728382839284028412842284328442845284628472848284928502851285228532854285528562857285828592860286128622863286428652866286728682869287028712872287328742875287628772878287928802881288228832884288528862887288828892890289128922893289428952896289728982899290029012902290329042905290629072908290929102911291229132914291529162917291829192920292129222923292429252926292729282929293029312932293329342935293629372938293929402941294229432944294529462947294829492950295129522953295429552956295729582959296029612962296329642965296629672968296929702971297229732974297529762977297829792980298129822983298429852986298729882989299029912992299329942995299629972998299930003001300230033004300530063007300830093010301130123013301430153016301730183019302030213022302330243025302630273028302930303031303230333034303530363037303830393040304130423043304430453046304730483049305030513052305330543055305630573058305930603061306230633064306530663067306830693070307130723073307430753076307730783079308030813082308330843085308630873088308930903091309230933094309530963097309830993100310131023103310431053106310731083109311031113112311331143115311631173118311931203121312231233124312531263127312831293130313131323133313431353136313731383139314031413142314331443145314631473148314931503151315231533154315531563157315831593160316131623163316431653166316731683169317031713172317331743175317631773178317931803181318231833184318531863187318831893190319131923193319431953196319731983199320032013202320332043205320632073208320932103211321232133214321532163217321832193220322132223223322432253226322732283229323032313232323332343235323632373238323932403241324232433244324532463247324832493250325132523253325432553256325732583259326032613262326332643265326632673268326932703271327232733274327532763277327832793280328132823283328432853286328732883289329032913292329332943295329632973298329933003301330233033304330533063307330833093310
  1. \input texinfo
  2. @setfilename libmicrohttpd.info
  3. @documentencoding UTF-8
  4. @include version.texi
  5. @settitle The GNU libmicrohttpd Reference Manual
  6. @c Unify all the indices into concept index.
  7. @syncodeindex vr cp
  8. @syncodeindex ky cp
  9. @syncodeindex pg cp
  10. @copying
  11. This manual is for GNU libmicrohttpd
  12. (version @value{VERSION}, @value{UPDATED}), a library for embedding
  13. an HTTP(S) server into C applications.
  14. Copyright @copyright{} 2007--2019 Christian Grothoff
  15. @quotation
  16. Permission is granted to copy, distribute and/or modify this document
  17. under the terms of the GNU Free Documentation License, Version 1.3
  18. or any later version published by the Free Software Foundation;
  19. with no Invariant Sections, no Front-Cover Texts, and no Back-Cover
  20. Texts. A copy of the license is included in the section entitled "GNU
  21. Free Documentation License".
  22. @end quotation
  23. @end copying
  24. @dircategory Software libraries
  25. @direntry
  26. * libmicrohttpd: (libmicrohttpd). Embedded HTTP server library.
  27. @end direntry
  28. @c
  29. @c Titlepage
  30. @c
  31. @titlepage
  32. @title The GNU libmicrohttpd Reference Manual
  33. @subtitle Version @value{VERSION}
  34. @subtitle @value{UPDATED}
  35. @author Marco Maggi (@email{marco.maggi-ipsu@@poste.it})
  36. @author Christian Grothoff (@email{christian@@grothoff.org})
  37. @page
  38. @vskip 0pt plus 1filll
  39. @insertcopying
  40. @end titlepage
  41. @summarycontents
  42. @contents
  43. @c ------------------------------------------------------------
  44. @ifnottex
  45. @node Top
  46. @top The GNU libmicrohttpd Library
  47. @insertcopying
  48. @end ifnottex
  49. @menu
  50. * microhttpd-intro:: Introduction.
  51. * microhttpd-const:: Constants.
  52. * microhttpd-struct:: Structures type definition.
  53. * microhttpd-cb:: Callback functions definition.
  54. * microhttpd-init:: Starting and stopping the server.
  55. * microhttpd-inspect:: Implementing external @code{select}.
  56. * microhttpd-requests:: Handling requests.
  57. * microhttpd-responses:: Building responses to requests.
  58. * microhttpd-flow:: Flow control.
  59. * microhttpd-dauth:: Utilizing Authentication.
  60. * microhttpd-post:: Adding a @code{POST} processor.
  61. * microhttpd-info:: Obtaining and modifying status information.
  62. * microhttpd-util:: Utilities.
  63. Appendices
  64. * GNU-LGPL:: The GNU Lesser General Public License says how you
  65. can copy and share almost all of `libmicrohttpd'.
  66. * GNU GPL with eCos Extension:: The GNU General Public License with eCos extension says how you
  67. can copy and share some parts of `libmicrohttpd'.
  68. * GNU-FDL:: The GNU Free Documentation License says how you
  69. can copy and share the documentation of `libmicrohttpd'.
  70. Indices
  71. * Concept Index:: Index of concepts and programs.
  72. * Function and Data Index:: Index of functions, variables and data types.
  73. * Type Index:: Index of data types.
  74. @end menu
  75. @c ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
  76. @c ------------------------------------------------------------
  77. @node microhttpd-intro
  78. @chapter Introduction
  79. @noindent
  80. All symbols defined in the public API start with @code{MHD_}. MHD
  81. is a small HTTP daemon library. As such, it does not have any API
  82. for logging errors (you can only enable or disable logging to stderr).
  83. Also, it may not support all of the HTTP features directly, where
  84. applicable, portions of HTTP may have to be handled by clients of the
  85. library.
  86. The library is supposed to handle everything that it must handle
  87. (because the API would not allow clients to do this), such as basic
  88. connection management. However, detailed interpretations of headers,
  89. such as range requests, are left to the main application. In
  90. particular, if an application developer wants to support range
  91. requests, he needs to explicitly indicate support in responses and
  92. also explicitly parse the range header and generate a response (for
  93. example, using the @code{MHD_create_response_from_fd_at_offset} call
  94. to serve ranges from a file). MHD does understands headers that
  95. control connection management (specifically, @code{Connection: close}
  96. and @code{Expect: 100 continue} are understood and handled
  97. automatically). @code{Connection: upgrade} is supported by passing
  98. control over the socket (or something that behaves like the real
  99. socket in the case of TLS) to the application (after sending the
  100. desired HTTP response header).
  101. MHD largely ignores the semantics of the different HTTP methods,
  102. so clients are left to handle those. One exception is that MHD does
  103. understand @code{HEAD} and will only send the headers of the response
  104. and not the body, even if the client supplied a body. (In fact,
  105. clients do need to construct a response with the correct length, even
  106. for @code{HEAD} request.)
  107. MHD understands @code{POST} data and is able to decode certain
  108. formats (at the moment only @code{application/x-www-form-urlencoded}
  109. and @code{multipart/form-data}) using the post processor API. The
  110. data stream of a POST is also provided directly to the main
  111. application, so unsupported encodings could still be processed, just
  112. not conveniently by MHD.
  113. The header file defines various constants used by the HTTP protocol.
  114. This does not mean that MHD actually interprets all of these values.
  115. The provided constants are exported as a convenience for users of the
  116. library. MHD does not verify that transmitted HTTP headers are
  117. part of the standard specification; users of the library are free to
  118. define their own extensions of the HTTP standard and use those with
  119. MHD.
  120. All functions are guaranteed to be completely reentrant and
  121. thread-safe. MHD checks for allocation failures and tries to
  122. recover gracefully (for example, by closing the connection).
  123. Additionally, clients can specify resource limits on the overall
  124. number of connections, number of connections per IP address and memory
  125. used per connection to avoid resource exhaustion.
  126. @section Scope
  127. MHD is currently used in a wide range of implementations.
  128. Examples based on reports we've received from developers include:
  129. @itemize
  130. @item Embedded HTTP server on a cortex M3 (128 KB code space)
  131. @item Large-scale multimedia server (reportedly serving at the
  132. simulator limit of 7.5 GB/s)
  133. @item Administrative console (via HTTP/HTTPS) for network appliances
  134. @c If you have other interesting examples, please let us know
  135. @end itemize
  136. @section Thread modes and event loops
  137. @cindex poll
  138. @cindex epoll
  139. @cindex select
  140. MHD supports four basic thread modes and up to three event loop
  141. styles.
  142. The four basic thread modes are external sockets polling (MHD creates
  143. no threads, event loop is fully managed by the application), internal
  144. polling (MHD creates one thread for all connections), polling in
  145. thread pool (MHD creates a thread pool which is used to process all
  146. connections) and thread-per-connection (MHD creates one thread for
  147. listen sockets and then one thread per accepted connection).
  148. These thread modes are then combined with the evet loop styles
  149. (polling function type). MHD support select, poll and epoll. select
  150. is available on all platforms, epoll and poll may not be available on
  151. some platforms. Note that it is possible to combine MHD using epoll
  152. with an external select-based event loop.
  153. The default (if no other option is passed) is ``external select''.
  154. The highest performance can typically be obtained with a thread pool
  155. using @code{epoll}. Apache Benchmark (ab) was used to compare the
  156. performance of @code{select} and @code{epoll} when using a thread pool
  157. and a large number of connections. @ref{fig:performance} shows the
  158. resulting plot from the @code{benchmark.c} example, which measures the
  159. latency between an incoming request and the completion of the
  160. transmission of the response. In this setting, the @code{epoll}
  161. thread pool with four threads was able to handle more than 45,000
  162. connections per second on loopback (with Apache Benchmark running
  163. three processes on the same machine).
  164. @cindex performance
  165. @float Figure,fig:performance
  166. @image{libmicrohttpd_performance_data,400pt,300pt,Data,.png}
  167. @caption{Performance measurements for select vs. epoll (with thread-pool).}
  168. @end float
  169. Not all combinations of thread modes and event loop styles are
  170. supported. This is partially to keep the API simple, and partially
  171. because some combinations simply make no sense as others are strictly
  172. superior. Note that the choice of style depends first of all on the
  173. application logic, and then on the performance requirements.
  174. Applications that perform a blocking operation while handling a
  175. request within the callbacks from MHD must use a thread per
  176. connection. This is typically rather costly. Applications that do
  177. not support threads or that must run on embedded devices without
  178. thread-support must use the external mode. Using @code{epoll} is only
  179. supported on some platform, thus portable applications must at least
  180. have a fallback option available. @ref{tbl:supported} lists the sane
  181. combinations.
  182. @float Table,tbl:supported
  183. @multitable {@b{thread-per-connection}} {@b{select}} {@b{poll}} {@b{epoll}}
  184. @item @tab @b{select} @tab @b{poll} @tab @b{epoll}
  185. @item @b{external} @tab yes @tab no @tab yes
  186. @item @b{internal} @tab yes @tab yes @tab yes
  187. @item @b{thread pool} @tab yes @tab yes @tab yes
  188. @item @b{thread-per-connection} @tab yes @tab yes @tab no
  189. @end multitable
  190. @caption{Supported combinations of event styles and thread modes.}
  191. @end float
  192. @section Compiling GNU libmicrohttpd
  193. @cindex compilation
  194. @cindex embedded systems
  195. @cindex portability
  196. MHD uses the standard GNU system where the usual build process
  197. involves running
  198. @verbatim
  199. $ ./configure
  200. $ make
  201. $ make install
  202. @end verbatim
  203. MHD supports various options to be given to configure to tailor the
  204. binary to a specific situation. Note that some of these options will
  205. remove portions of the MHD code that are required for
  206. binary-compatibility. They should only be used on embedded systems
  207. with tight resource constraints and no concerns about library
  208. versioning. Standard distributions including MHD are expected to
  209. always ship with all features enabled, otherwise unexpected
  210. incompatibilities can arise!
  211. Here is a list of MHD-specific options that can be given to configure
  212. (canonical configure options such as ``--prefix'' are also supported, for a
  213. full list of options run ``./configure --help''):
  214. @table @code
  215. @item ``--disable-curl''
  216. disable running testcases using libcurl
  217. @item ``--disable-largefile''
  218. disable support for 64-bit files
  219. @item ``--disable-messages''
  220. disable logging of error messages (smaller binary size, not so much fun for debugging)
  221. @item ``--disable-https''
  222. disable HTTPS support, even if GNUtls is found; this option must be used if eCOS license is desired as an option (in all cases the resulting binary falls under a GNU LGPL-only license)
  223. @item ``--disable-postprocessor''
  224. do not include the post processor API (results in binary incompatibility)
  225. @item ``--disable-dauth''
  226. do not include the authentication APIs (results in binary incompatibility)
  227. @item ``--disable-httpupgrade''
  228. do not build code for HTTP ``Upgrade'' (smaller binary size, binary incompatible library)
  229. @item ``--disable-epoll''
  230. do not include epoll support, even if it supported (minimally smaller binary size, good for portability testing)
  231. @item ``--enable-coverage''
  232. set flags for analysis of code-coverage with gcc/gcov (results in slow, large binaries)
  233. @item ``--with-threads=posix,w32,none,auto''
  234. sets threading library to use. With use ``none'' to not support threads. In this case, MHD will only support the ``external'' threading modes and not perform any locking of data structures! Use @code{MHD_is_feature_supported(MHD_FEATURE_THREADS)} to test if threads are available. Default is ``auto''.
  235. @item ``--with-gcrypt=PATH''
  236. specifies path to libgcrypt installation
  237. @item ``--with-gnutls=PATH''
  238. specifies path to libgnutls installation
  239. @end table
  240. @section Validity of pointers
  241. MHD will give applications access to its internal data structures
  242. via pointers via arguments and return values from its API. This
  243. creates the question as to how long those pointers are assured to
  244. stay valid.
  245. Most MHD data structures are associated with the connection of an
  246. HTTP client. Thus, pointers associated with a connection are
  247. typically valid until the connection is finished, at which point
  248. MHD will call the @code{MHD_RequestCompletedCallback} if one is
  249. registered. Applications that have such a callback registered
  250. may assume that keys and values from the
  251. @code{MHD_KeyValueIterator}, return values from
  252. @code{MHD_lookup_connection_value} and the @code{url},
  253. @code{method} and @code{version} arguments to the
  254. @code{MHD_AccessHandlerCallback} will remain valid until the
  255. respective @code{MHD_RequestCompletedCallback} is invoked.
  256. In contrast, the @code{upload_data} argument of
  257. @code{MHD_RequestCompletedCallback} as well as all pointers
  258. from the @code{MHD_PostDataIterator} are only valid for the
  259. duration of the callback.
  260. Pointers returned from @code{MHD_get_response_header} are
  261. valid as long as the response itself is valid.
  262. @section Including the microhttpd.h header
  263. @cindex portability
  264. @cindex microhttpd.h
  265. Ideally, before including "microhttpd.h" you should add the necessary
  266. includes to define the @code{uint64_t}, @code{size_t}, @code{fd_set},
  267. @code{socklen_t} and @code{struct sockaddr} data types. Which
  268. specific headers are needed may depend on your platform and your build
  269. system might include some tests to provide you with the necessary
  270. conditional operations. For possible suggestions consult
  271. @code{platform.h} and @code{configure.ac} in the MHD distribution.
  272. Once you have ensured that you manually (!) included the right headers
  273. for your platform before "microhttpd.h", you should also add a line
  274. with @code{#define MHD_PLATFORM_H} which will prevent the
  275. "microhttpd.h" header from trying (and, depending on your platform,
  276. failing) to include the right headers.
  277. If you do not define MHD_PLATFORM_H, the "microhttpd.h" header will
  278. automatically include headers needed on GNU/Linux systems (possibly
  279. causing problems when porting to other platforms).
  280. @section SIGPIPE
  281. @cindex signals
  282. MHD does not install a signal handler for SIGPIPE. On platforms where
  283. this is possible (such as GNU/Linux), it disables SIGPIPE for its I/O
  284. operations (by passing MSG_NOSIGNAL or similar). On other platforms,
  285. SIGPIPE signals may be generated from network operations by MHD and
  286. will cause the process to die unless the developer explicitly installs
  287. a signal handler for SIGPIPE.
  288. Hence portable code using MHD must install a SIGPIPE handler or
  289. explicitly block the SIGPIPE signal. MHD does not do so in order to
  290. avoid messing with other parts of the application that may need to
  291. handle SIGPIPE in a particular way. You can make your application
  292. handle SIGPIPE by calling the following function in @code{main}:
  293. @verbatim
  294. static void
  295. catcher (int sig)
  296. {
  297. }
  298. static void
  299. ignore_sigpipe ()
  300. {
  301. struct sigaction oldsig;
  302. struct sigaction sig;
  303. sig.sa_handler = &catcher;
  304. sigemptyset (&sig.sa_mask);
  305. #ifdef SA_INTERRUPT
  306. sig.sa_flags = SA_INTERRUPT; /* SunOS */
  307. #else
  308. sig.sa_flags = SA_RESTART;
  309. #endif
  310. if (0 != sigaction (SIGPIPE, &sig, &oldsig))
  311. fprintf (stderr,
  312. "Failed to install SIGPIPE handler: %s\n", strerror (errno));
  313. }
  314. @end verbatim
  315. @section MHD_UNSIGNED_LONG_LONG
  316. @cindex long long
  317. @cindex MHD_LONG_LONG
  318. @cindex IAR
  319. @cindex ARM
  320. @cindex cortex m3
  321. @cindex embedded systems
  322. Some platforms do not support @code{long long}. Hence MHD defines a
  323. macro @code{MHD_UNSIGNED LONG_LONG} which will default to
  324. @code{unsigned long long}. For standard desktop operating systems,
  325. this is all you need to know.
  326. However, if your platform does not support @code{unsigned long long},
  327. you should change "platform.h" to define @code{MHD_LONG_LONG} and
  328. @code{MHD_UNSIGNED_LONG_LONG} to an appropriate alternative type and
  329. also define @code{MHD_LONG_LONG_PRINTF} and
  330. @code{MHD_UNSIGNED_LONG_LONG_PRINTF} to the corresponding format
  331. string for printing such a data type. Note that the ``signed''
  332. versions are deprecated. Also, for historical reasons,
  333. @code{MHD_LONG_LONG_PRINTF} is without the percent sign, whereas
  334. @code{MHD_UNSIGNED_LONG_LONG_PRINTF} is with the percent sign. Newly
  335. written code should only use the unsigned versions. However, you need
  336. to define both in "platform.h" if you need to change the definition
  337. for the specific platform.
  338. @section Portability to W32
  339. libmicrohttpd in general ported well to W32. Most libmicrohttpd features
  340. are supported. W32 do not support some functions, like epoll and
  341. corresponding MHD features are not available on W32.
  342. @section Portability to z/OS
  343. To compile MHD on z/OS, extract the archive and run
  344. @verbatim
  345. iconv -f UTF-8 -t IBM-1047 contrib/ascebc > /tmp/ascebc.sh
  346. chmod +x /tmp/ascebc.sh
  347. for n in `find * -type f`
  348. do
  349. /tmp/ascebc.sh $n
  350. done
  351. @end verbatim
  352. to convert all source files to EBCDIC. Note that you must run
  353. @code{configure} from the directory where the configure script is
  354. located. Otherwise, configure will fail to find the
  355. @code{contrib/xcc} script (which is a wrapper around the z/OS c89
  356. compiler).
  357. @c ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
  358. @c ------------------------------------------------------------
  359. @node microhttpd-const
  360. @chapter Constants
  361. @deftp {Enumeration} MHD_FLAG
  362. Options for the MHD daemon.
  363. Note that MHD will run automatically in background thread(s) only if
  364. @code{MHD_USE_INTERNAL_POLLING_THREAD} is used. Otherwise caller
  365. (application) must use @code{MHD_run} or @code{MHD_run_from_select} to
  366. have MHD processed network connections and data.
  367. Starting the daemon may also fail if a particular option is not
  368. implemented or not supported on the target platform (i.e. no support
  369. for @acronym{TLS}, threads or IPv6). TLS support generally depends on
  370. options given during MHD compilation.
  371. @table @code
  372. @item MHD_NO_FLAG
  373. No options selected.
  374. @item MHD_USE_ERROR_LOG
  375. If this flag is used, the library should print error messages and
  376. warnings to stderr (or to custom error printer if it's specified by
  377. options). Note that for this run-time option to have any effect, MHD
  378. needs to be compiled with messages enabled. This is done by default
  379. except you ran configure with the @code{--disable-messages} flag set.
  380. @item MHD_USE_DEBUG
  381. @cindex debugging
  382. Currently the same as @code{MHD_USE_ERROR_LOG}.
  383. @item MHD_USE_TLS
  384. @cindex TLS
  385. @cindex SSL
  386. Run in HTTPS-mode. If you specify @code{MHD_USE_TLS} and MHD was
  387. compiled without SSL support, @code{MHD_start_daemon} will return
  388. NULL.
  389. @item MHD_USE_THREAD_PER_CONNECTION
  390. Run using one thread per connection.
  391. @item MHD_USE_INTERNAL_POLLING_THREAD
  392. Run using an internal thread doing @code{SELECT}.
  393. @item MHD_USE_IPv6
  394. @cindex IPv6
  395. Run using the IPv6 protocol (otherwise, MHD will just support IPv4).
  396. If you specify @code{MHD_USE_IPV6} and the local platform does not
  397. support it, @code{MHD_start_daemon} will return NULL.
  398. If you want MHD to support IPv4 and IPv6 using a single socket, pass
  399. MHD_USE_DUAL_STACK, otherwise, if you only pass this option, MHD will
  400. try to bind to IPv6-only (resulting in no IPv4 support).
  401. @item MHD_USE_DUAL_STACK
  402. @cindex IPv6
  403. Use a single socket for IPv4 and IPv6. Note that this will mean
  404. that IPv4 addresses are returned by MHD in the IPv6-mapped format
  405. (the 'struct sockaddr_in6' format will be used for IPv4 and IPv6).
  406. @item MHD_USE_PEDANTIC_CHECKS
  407. @cindex deprecated
  408. Deprecated (use @code{MHD_OPTION_STRICT_FOR_CLIENT}).
  409. Be pedantic about the protocol.
  410. Specifically, at the moment, this flag causes MHD to reject HTTP
  411. 1.1 connections without a @code{Host} header. This is required by the
  412. standard, but of course in violation of the ``be as liberal as possible
  413. in what you accept'' norm. It is recommended to turn this @strong{ON}
  414. if you are testing clients against MHD, and @strong{OFF} in
  415. production.
  416. @item MHD_USE_POLL
  417. @cindex FD_SETSIZE
  418. @cindex poll
  419. @cindex select
  420. Use @code{poll()} instead of @code{select()}. This allows sockets with
  421. descriptors @code{>= FD_SETSIZE}. This option currently only works in
  422. conjunction with @code{MHD_USE_INTERNAL_POLLING_THREAD} (at this point).
  423. If you specify @code{MHD_USE_POLL} and the local platform does not
  424. support it, @code{MHD_start_daemon} will return NULL.
  425. @item MHD_USE_EPOLL
  426. @cindex FD_SETSIZE
  427. @cindex epoll
  428. @cindex select
  429. Use @code{epoll()} instead of @code{poll()} or @code{select()}. This
  430. allows sockets with descriptors @code{>= FD_SETSIZE}. This option is
  431. only available on some systems and does not work in conjunction with
  432. @code{MHD_USE_THREAD_PER_CONNECTION} (at this point). If you specify
  433. @code{MHD_USE_EPOLL} and the local platform does not support it,
  434. @code{MHD_start_daemon} will return NULL. Using @code{epoll()}
  435. instead of @code{select()} or @code{poll()} can in some situations
  436. result in significantly higher performance as the system call has
  437. fundamentally lower complexity (O(1) for @code{epoll()} vs. O(n) for
  438. @code{select()}/@code{poll()} where n is the number of open
  439. connections).
  440. @item MHD_USE_TURBO
  441. @cindex performance
  442. Enable optimizations to aggressively improve performance.
  443. Currently, the optimizations this option enables are based on
  444. opportunistic reads and writes. Bascially, MHD will simply try to
  445. read or write or accept on a socket before checking that the socket is
  446. ready for IO using the event loop mechanism. As the sockets are
  447. non-blocking, this may fail (at a loss of performance), but generally
  448. MHD does this in situations where the operation is likely to succeed,
  449. in which case performance is improved. Setting the flag should generally
  450. be safe (even though the code is slightly more experimental). You may
  451. want to benchmark your application to see if this makes any difference
  452. for you.
  453. @item MHD_USE_SUPPRESS_DATE_NO_CLOCK
  454. @cindex date
  455. @cindex clock
  456. @cindex embedded systems
  457. Suppress (automatically) adding the 'Date:' header to HTTP responses.
  458. This option should ONLY be used on systems that do not have a clock
  459. and that DO provide other mechanisms for cache control. See also
  460. RFC 2616, section 14.18 (exception 3).
  461. @item MHD_USE_NO_LISTEN_SOCKET
  462. @cindex listen
  463. @cindex proxy
  464. @cindex embedded systems
  465. Run the HTTP server without any listen socket. This option only makes
  466. sense if @code{MHD_add_connection} is going to be used exclusively to
  467. connect HTTP clients to the HTTP server. This option is incompatible
  468. with using a thread pool; if it is used,
  469. @code{MHD_OPTION_THREAD_POOL_SIZE} is ignored.
  470. @item MHD_USE_ITC
  471. @cindex quiesce
  472. Force MHD to use a signal inter-thread communication channel to notify
  473. the event loop (of threads) of our shutdown and other events. This is
  474. required if an application uses @code{MHD_USE_INTERNAL_POLLING_THREAD}
  475. and then performs @code{MHD_quiesce_daemon} (which eliminates our
  476. ability to signal termination via the listen socket). In these modes,
  477. @code{MHD_quiesce_daemon} will fail if this option was not set. Also,
  478. use of this option is automatic (as in, you do not even have to
  479. specify it), if @code{MHD_USE_NO_LISTEN_SOCKET} is specified. In
  480. "external" select mode, this option is always simply ignored.
  481. Using this option also guarantees that MHD will not call
  482. @code{shutdown()} on the listen socket, which means a parent
  483. process can continue to use the socket.
  484. @item MHD_ALLOW_SUSPEND_RESUME
  485. Enables using @code{MHD_suspend_connection} and
  486. @code{MHD_resume_connection}, as performing these calls requires some
  487. additional inter-thred communication channels to be created, and code
  488. not using these calls should not pay the cost.
  489. @item MHD_USE_TCP_FASTOPEN
  490. @cindex listen
  491. Enable TCP_FASTOPEN on the listen socket. TCP_FASTOPEN is currently
  492. supported on Linux >= 3.6. On other systems using this option with
  493. cause @code{MHD_start_daemon} to fail.
  494. @item MHD_ALLOW_UPGRADE
  495. @cindex upgrade
  496. This option must be set if you want to upgrade connections
  497. (via ``101 Switching Protocols'' responses). This requires MHD to
  498. allocate additional resources, and hence we require this
  499. special flag so we only use the resources that are really needed.
  500. @item MHD_USE_AUTO
  501. Automatically select best event loop style (polling function)
  502. depending on requested mode by other MHD flags and functions available
  503. on platform. If application doesn't have requirements for any
  504. specific polling function, it's recommended to use this flag. This
  505. flag is very convenient for multiplatform applications.
  506. @item MHD_USE_POST_HANDSHAKE_AUTH_SUPPORT
  507. Tell the TLS library to support post handshake client authentication.
  508. Only useful in combination with @code{MHD_USE_TLS}.
  509. This option will only work if the underyling TLS library
  510. supports it (i.e. GnuTLS after 3.6.3). If the TLS library
  511. does not support it, MHD may ignore the option and proceed
  512. without supporting this features.
  513. @item MHD_USE_INSECURE_TLS_EARLY_DATA
  514. Tell the TLS library to support TLS v1.3 early data (0-RTT) with the
  515. resulting security drawbacks. Only enable this if you really know what
  516. you are doing. MHD currently does NOT enforce that this only affects
  517. GET requests! You have been warned.
  518. This option will only work if the underyling TLS library
  519. supports it (i.e. GnuTLS after 3.6.3). If the TLS library
  520. does not support it, MHD may ignore the option and proceed
  521. without supporting this features.
  522. @end table
  523. @end deftp
  524. @deftp {Enumeration} MHD_OPTION
  525. MHD options. Passed in the varargs portion of
  526. @code{MHD_start_daemon()}.
  527. @table @code
  528. @item MHD_OPTION_END
  529. No more options / last option. This is used to terminate the VARARGs
  530. list.
  531. @item MHD_OPTION_CONNECTION_MEMORY_LIMIT
  532. @cindex memory, limiting memory utilization
  533. Maximum memory size per connection (followed by a @code{size_t}). The
  534. default is 32 kB (32*1024 bytes) as defined by the internal constant
  535. @code{MHD_POOL_SIZE_DEFAULT}. Values above 128k are unlikely to
  536. result in much benefit, as half of the memory will be typically used
  537. for IO, and TCP buffers are unlikely to support window sizes above 64k
  538. on most systems.
  539. @item MHD_OPTION_CONNECTION_MEMORY_INCREMENT
  540. @cindex memory
  541. Increment to use for growing the read buffer (followed by a
  542. @code{size_t}). The default is 1024 (bytes). Increasing this value
  543. will make MHD use memory for reading more aggressively, which can
  544. reduce the number of @code{recvfrom} calls but may increase the number
  545. of @code{sendto} calls. The given value must fit within
  546. MHD_OPTION_CONNECTION_MEMORY_LIMIT.
  547. @item MHD_OPTION_CONNECTION_LIMIT
  548. @cindex connection, limiting number of connections
  549. Maximum number of concurrent connections to accept (followed by an
  550. @code{unsigned int}). The default is @code{FD_SETSIZE - 4} (the
  551. maximum number of file descriptors supported by @code{select} minus
  552. four for @code{stdin}, @code{stdout}, @code{stderr} and the server
  553. socket). In other words, the default is as large as possible.
  554. If the connection limit is reached, MHD's behavior depends a bit on
  555. other options. If @code{MHD_USE_ITC} was given, MHD
  556. will stop accepting connections on the listen socket. This will cause
  557. the operating system to queue connections (up to the @code{listen()}
  558. limit) above the connection limit. Those connections will be held
  559. until MHD is done processing at least one of the active connections.
  560. If @code{MHD_USE_ITC} is not set, then MHD will continue
  561. to @code{accept()} and immediately @code{close()} these connections.
  562. Note that if you set a low connection limit, you can easily get into
  563. trouble with browsers doing request pipelining. For example, if your
  564. connection limit is ``1'', a browser may open a first connection to
  565. access your ``index.html'' file, keep it open but use a second
  566. connection to retrieve CSS files, images and the like. In fact, modern
  567. browsers are typically by default configured for up to 15 parallel
  568. connections to a single server. If this happens, MHD will refuse to
  569. even accept the second connection until the first connection is
  570. closed --- which does not happen until timeout. As a result, the
  571. browser will fail to render the page and seem to hang. If you expect
  572. your server to operate close to the connection limit, you should
  573. first consider using a lower timeout value and also possibly add
  574. a ``Connection: close'' header to your response to ensure that
  575. request pipelining is not used and connections are closed immediately
  576. after the request has completed:
  577. @example
  578. MHD_add_response_header (response,
  579. MHD_HTTP_HEADER_CONNECTION,
  580. "close");
  581. @end example
  582. @item MHD_OPTION_CONNECTION_TIMEOUT
  583. @cindex timeout
  584. After how many seconds of inactivity should a connection automatically
  585. be timed out? (followed by an @code{unsigned int}; use zero for no
  586. timeout). The default is zero (no timeout).
  587. @item MHD_OPTION_NOTIFY_COMPLETED
  588. Register a function that should be called whenever a request has been
  589. completed (this can be used for application-specific clean up).
  590. Requests that have never been presented to the application (via
  591. @code{MHD_AccessHandlerCallback()}) will not result in
  592. notifications.
  593. This option should be followed by @strong{TWO} pointers. First a
  594. pointer to a function of type @code{MHD_RequestCompletedCallback()}
  595. and second a pointer to a closure to pass to the request completed
  596. callback. The second pointer maybe @code{NULL}.
  597. @item MHD_OPTION_NOTIFY_CONNECTION
  598. Register a function that should be called when the TCP connection to a
  599. client is opened or closed. Note that
  600. @code{MHD_OPTION_NOTIFY_COMPLETED} and the @code{con_cls} argument to
  601. the @code{MHD_AccessHandlerCallback} are per HTTP request (and there
  602. can be multiple HTTP requests per TCP connection). The registered
  603. callback is called twice per TCP connection, with
  604. @code{MHD_CONNECTION_NOTIFY_STARTED} and
  605. @code{MHD_CONNECTION_NOTIFY_CLOSED} respectively. An additional
  606. argument can be used to store TCP connection specific information,
  607. which can be retrieved using @code{MHD_CONNECTION_INFO_SOCKET_CONTEXT}
  608. during the lifetime of the TCP connection. The respective location is
  609. not the same as the HTTP-request-specific @code{con_cls} from the
  610. @code{MHD_AccessHandlerCallback}.
  611. This option should be followed by @strong{TWO} pointers. First a
  612. pointer to a function of type @code{MHD_NotifyConnectionCallback()}
  613. and second a pointer to a closure to pass to the request completed
  614. callback. The second pointer maybe @code{NULL}.
  615. @item MHD_OPTION_PER_IP_CONNECTION_LIMIT
  616. Limit on the number of (concurrent) connections made to the
  617. server from the same IP address. Can be used to prevent one
  618. IP from taking over all of the allowed connections. If the
  619. same IP tries to establish more than the specified number of
  620. connections, they will be immediately rejected. The option
  621. should be followed by an @code{unsigned int}. The default is
  622. zero, which means no limit on the number of connections
  623. from the same IP address.
  624. @item MHD_OPTION_LISTEN_BACKLOG_SIZE
  625. Set the size of the @code{listen()} back log queue of the TCP socket.
  626. Takes an @code{unsigned int} as the argument. Default is the
  627. platform-specific value of @code{SOMAXCONN}.
  628. @item MHD_OPTION_STRICT_FOR_CLIENT
  629. Specify how strict we should enforce the HTTP protocol.
  630. Takes an @code{int} as the argument. Default is zero.
  631. If set to 1, MHD will be strict about the protocol. Specifically, at
  632. the moment, this flag uses MHD to reject HTTP 1.1 connections without
  633. a "Host" header. This is required by the standard, but of course in
  634. violation of the "be as liberal as possible in what you accept" norm.
  635. It is recommended to set this to 1 if you are testing clients against
  636. MHD, and 0 in production.
  637. If set to -1 MHD will be permissive about the protocol, allowing
  638. slight deviations that are technically not allowed by the
  639. RFC. Specifically, at the moment, this flag causes MHD to allow spaces
  640. in header field names. This is disallowed by the standard.
  641. It is not recommended to set it to -1 on publicly available servers as
  642. it may potentially lower level of protection.
  643. @item MHD_OPTION_SOCK_ADDR
  644. @cindex bind, restricting bind
  645. Bind daemon to the supplied socket address. This option should be followed by a
  646. @code{struct sockaddr *}. If @code{MHD_USE_IPv6} is specified,
  647. the @code{struct sockaddr*} should point to a @code{struct sockaddr_in6},
  648. otherwise to a @code{struct sockaddr_in}. If this option is not specified,
  649. the daemon will listen to incoming connections from anywhere. If you use this
  650. option, the 'port' argument from @code{MHD_start_daemon} is ignored and the port
  651. from the given @code{struct sockaddr *} will be used instead.
  652. @item MHD_OPTION_URI_LOG_CALLBACK
  653. @cindex debugging
  654. @cindex logging
  655. @cindex query string
  656. Specify a function that should be called before parsing the URI from
  657. the client. The specified callback function can be used for processing
  658. the URI (including the options) before it is parsed. The URI after
  659. parsing will no longer contain the options, which maybe inconvenient for
  660. logging. This option should be followed by two arguments, the first
  661. one must be of the form
  662. @example
  663. void * my_logger(void * cls, const char * uri, struct MHD_Connection *con)
  664. @end example
  665. where the return value will be passed as
  666. @code{*con_cls} in calls to the @code{MHD_AccessHandlerCallback}
  667. when this request is processed later; returning a
  668. value of @code{NULL} has no special significance; (however,
  669. note that if you return non-@code{NULL}, you can no longer
  670. rely on the first call to the access handler having
  671. @code{NULL == *con_cls} on entry)
  672. @code{cls} will be set to the second argument following
  673. MHD_OPTION_URI_LOG_CALLBACK. Finally, @code{uri} will
  674. be the 0-terminated URI of the request.
  675. Note that during the time of this call, most of the connection's state
  676. is not initialized (as we have not yet parsed he headers). However,
  677. information about the connecting client (IP, socket) is available.
  678. @item MHD_OPTION_HTTPS_MEM_KEY
  679. @cindex SSL
  680. @cindex TLS
  681. Memory pointer to the private key to be used by the
  682. HTTPS daemon. This option should be followed by an
  683. "const char*" argument.
  684. This should be used in conjunction with 'MHD_OPTION_HTTPS_MEM_CERT'.
  685. @item MHD_OPTION_HTTPS_KEY_PASSWORD
  686. @cindex SSL
  687. @cindex TLS
  688. Memory pointer to the password that decrypts the
  689. private key to be used by the HTTPS daemon.
  690. This option should be followed by an
  691. "const char*" argument.
  692. This should be used in conjunction with 'MHD_OPTION_HTTPS_MEM_KEY'.
  693. The password (or passphrase) is only used immediately during
  694. @code{MHD_start_daemon()}. Thus, the application may want to
  695. erase it from memory afterwards for additional security.
  696. @item MHD_OPTION_HTTPS_MEM_CERT
  697. @cindex SSL
  698. @cindex TLS
  699. Memory pointer to the certificate to be used by the
  700. HTTPS daemon. This option should be followed by an
  701. "const char*" argument.
  702. This should be used in conjunction with 'MHD_OPTION_HTTPS_MEM_KEY'.
  703. @item MHD_OPTION_HTTPS_MEM_TRUST
  704. @cindex SSL
  705. @cindex TLS
  706. Memory pointer to the CA certificate to be used by the
  707. HTTPS daemon to authenticate and trust clients certificates.
  708. This option should be followed by an "const char*" argument.
  709. The presence of this option activates the request of certificate
  710. to the client. The request to the client is marked optional, and
  711. it is the responsibility of the server to check the presence
  712. of the certificate if needed.
  713. Note that most browsers will only present a client certificate
  714. only if they have one matching the specified CA, not sending
  715. any certificate otherwise.
  716. @item MHD_OPTION_HTTPS_CRED_TYPE
  717. @cindex SSL
  718. @cindex TLS
  719. Daemon credentials type. Either certificate or anonymous,
  720. this option should be followed by one of the values listed in
  721. "enum gnutls_credentials_type_t".
  722. @item MHD_OPTION_HTTPS_PRIORITIES
  723. @cindex SSL
  724. @cindex TLS
  725. @cindex cipher
  726. SSL/TLS protocol version and ciphers.
  727. This option must be followed by an "const char *" argument
  728. specifying the SSL/TLS protocol versions and ciphers that
  729. are acceptable for the application. The string is passed
  730. unchanged to gnutls_priority_init. If this option is not
  731. specified, ``NORMAL'' is used.
  732. @item MHD_OPTION_HTTPS_CERT_CALLBACK
  733. @cindex SSL
  734. @cindex TLS
  735. @cindex SNI
  736. Use a callback to determine which X.509 certificate should be used for
  737. a given HTTPS connection. This option should be followed by a
  738. argument of type "gnutls_certificate_retrieve_function2 *". This
  739. option provides an alternative to MHD_OPTION_HTTPS_MEM_KEY and
  740. MHD_OPTION_HTTPS_MEM_CERT. You must use this version if multiple
  741. domains are to be hosted at the same IP address using TLS's Server
  742. Name Indication (SNI) extension. In this case, the callback is
  743. expected to select the correct certificate based on the SNI
  744. information provided. The callback is expected to access the SNI data
  745. using gnutls_server_name_get(). Using this option requires GnuTLS 3.0
  746. or higher.
  747. @item MHD_OPTION_HTTPS_CERT_CALLBACK2
  748. @cindex SSL
  749. @cindex TLS
  750. @cindex SNI
  751. @cindex OCSP
  752. Use a callback to determine which X.509 certificate should be
  753. used for a given HTTPS connection. This option should be
  754. followed by a argument of type `gnutls_certificate_retrieve_function3 *`.
  755. This option provides an
  756. alternative/extension to #MHD_OPTION_HTTPS_CERT_CALLBACK.
  757. You must use this version if you want to use OCSP stapling.
  758. Using this option requires GnuTLS 3.6.3 or higher.
  759. @item MHD_OPTION_GNUTLS_PSK_CRED_HANDLER
  760. @cindex SSL
  761. @cindex TLS
  762. @cindex PSK
  763. Use pre-shared key for TLS credentials.
  764. Pass a pointer to callback of type
  765. @code{MHD_PskServerCredentialsCallback} and a closure.
  766. The function will be called to
  767. retrieve the shared key for a given username.
  768. @item MHD_OPTION_DIGEST_AUTH_RANDOM
  769. @cindex digest auth
  770. @cindex random
  771. Digest Authentication nonce's seed.
  772. This option should be followed by two arguments. First an integer of
  773. type "size_t" which specifies the size of the buffer pointed to by the
  774. second argument in bytes. Note that the application must ensure that
  775. the buffer of the second argument remains allocated and unmodified
  776. while the daemon is running. For security, you SHOULD provide a fresh
  777. random nonce when using MHD with Digest Authentication.
  778. @item MHD_OPTION_NONCE_NC_SIZE
  779. @cindex digest auth
  780. @cindex replay attack
  781. Size of an array of nonce and nonce counter map. This option must be
  782. followed by an "unsigned int" argument that have the size (number of
  783. elements) of a map of a nonce and a nonce-counter. If this option
  784. is not specified, a default value of 4 will be used (which might be
  785. too small for servers handling many requests). If you do not use
  786. digest authentication at all, you can specify a value of zero to
  787. save some memory.
  788. You should calculate the value of NC_SIZE based on the number of
  789. connections per second multiplied by your expected session duration
  790. plus a factor of about two for hash table collisions. For example, if
  791. you expect 100 digest-authenticated connections per second and the
  792. average user to stay on your site for 5 minutes, then you likely need
  793. a value of about 60000. On the other hand, if you can only expect
  794. only 10 digest-authenticated connections per second, tolerate browsers
  795. getting a fresh nonce for each request and expect a HTTP request
  796. latency of 250 ms, then a value of about 5 should be fine.
  797. @item MHD_OPTION_LISTEN_SOCKET
  798. @cindex systemd
  799. Listen socket to use. Pass a listen socket for MHD to use
  800. (systemd-style). If this option is used, MHD will not open its own
  801. listen socket(s). The argument passed must be of type "int" and refer
  802. to an existing socket that has been bound to a port and is listening.
  803. @item MHD_OPTION_EXTERNAL_LOGGER
  804. @cindex logging
  805. Use the given function for logging error messages.
  806. This option must be followed by two arguments; the
  807. first must be a pointer to a function
  808. of type 'void fun(void * arg, const char * fmt, va_list ap)'
  809. and the second a pointer of type 'void*' which will
  810. be passed as the "arg" argument to "fun".
  811. Note that MHD will not generate any log messages without
  812. the MHD_USE_ERROR_LOG flag set and if MHD was compiled
  813. with the "--disable-messages" flag.
  814. @item MHD_OPTION_THREAD_POOL_SIZE
  815. @cindex performance
  816. Number (unsigned int) of threads in thread pool. Enable
  817. thread pooling by setting this value to to something
  818. greater than 1. Currently, thread mode must be
  819. MHD_USE_INTERNAL_POLLING_THREAD if thread pooling is enabled
  820. (@code{MHD_start_daemon} returns @code{NULL} for an unsupported thread
  821. mode).
  822. @item MHD_OPTION_ARRAY
  823. @cindex options
  824. @cindex foreign-function interface
  825. This option can be used for initializing MHD using options from an
  826. array. A common use for this is writing an FFI for MHD. The actual
  827. options given are in an array of 'struct MHD_OptionItem', so this
  828. option requires a single argument of type 'struct MHD_OptionItem'.
  829. The array must be terminated with an entry @code{MHD_OPTION_END}.
  830. An example for code using MHD_OPTION_ARRAY is:
  831. @example
  832. struct MHD_OptionItem ops[] = @{
  833. @{ MHD_OPTION_CONNECTION_LIMIT, 100, NULL @},
  834. @{ MHD_OPTION_CONNECTION_TIMEOUT, 10, NULL @},
  835. @{ MHD_OPTION_END, 0, NULL @}
  836. @};
  837. d = MHD_start_daemon(0, 8080, NULL, NULL, dh, NULL,
  838. MHD_OPTION_ARRAY, ops,
  839. MHD_OPTION_END);
  840. @end example
  841. For options that expect a single pointer argument, the
  842. second member of the @code{struct MHD_OptionItem} is ignored.
  843. For options that expect two pointer arguments, the first
  844. argument must be cast to @code{intptr_t}.
  845. @item MHD_OPTION_UNESCAPE_CALLBACK
  846. @cindex internationalization
  847. @cindex escaping
  848. Specify a function that should be called for unescaping escape
  849. sequences in URIs and URI arguments. Note that this function will NOT
  850. be used by the MHD_PostProcessor. If this option is not specified,
  851. the default method will be used which decodes escape sequences of the
  852. form "%HH". This option should be followed by two arguments, the
  853. first one must be of the form
  854. @example
  855. size_t my_unescaper(void * cls, struct MHD_Connection *c, char *s)
  856. @end example
  857. where the return value must be @code{strlen(s)} and @code{s} should be
  858. updated. Note that the unescape function must not lengthen @code{s}
  859. (the result must be shorter than the input and still be 0-terminated).
  860. @code{cls} will be set to the second argument following
  861. MHD_OPTION_UNESCAPE_CALLBACK.
  862. @item MHD_OPTION_THREAD_STACK_SIZE
  863. @cindex stack
  864. @cindex thread
  865. @cindex pthread
  866. @cindex embedded systems
  867. Maximum stack size for threads created by MHD. This option must be
  868. followed by a @code{size_t}). Not specifying this option or using
  869. a value of zero means using the system default (which is likely to
  870. differ based on your platform).
  871. @item MHD_OPTION_TCP_FASTQUEUE_QUEUE_SIZE
  872. @cindex listen
  873. When the flag @code{MHD_USE_TCP_FASTOPEN} is used, this option sets the
  874. connection handshake queue size for the TCP FASTOPEN connections. Note
  875. that a TCP FASTOPEN connection handshake occupies more resources than a
  876. TCP handshake as the SYN packets also contain DATA which is kept in the
  877. associate state until handshake is completed. If this option is not
  878. given the queue size is set to a default value of 10. This option must
  879. be followed by a @code{unsigned int}.
  880. @item MHD_OPTION_HTTPS_MEM_DHPARAMS
  881. @cindex TLS
  882. @cindex SSL
  883. @cindex DH
  884. Memory pointer for the Diffie-Hellman parameters (dh.pem) to be used
  885. by the HTTPS daemon for key exchange. This option must be followed by
  886. a @code{const char *} argument. The argument would be a zero-terminated
  887. string with a PEM encoded PKCS3 DH parameters structure suitable
  888. for passing to @code{gnutls_dh_parms_import_pkcs3}.
  889. @item MHD_OPTION_LISTENING_ADDRESS_REUSE
  890. @cindex bind, restricting bind
  891. @cindex reusing listening address
  892. This option must be followed by a @code{unsigned int} argument.
  893. If this option is present and true (nonzero) parameter is given, allow reusing
  894. the address:port of the listening socket (using @code{SO_REUSEPORT} on most
  895. platforms, and @code{SO_REUSEADDR} on Windows). If a false (zero) parameter is
  896. given, disallow reusing the the address:port of the listening socket (this
  897. usually requires no special action, but @code{SO_EXCLUSIVEADDRUSE} is needed on
  898. Windows). If this option is not present @code{SO_REUSEADDR} is used on all
  899. platforms except Windows so reusing of address:port is disallowed.
  900. @end table
  901. @end deftp
  902. @deftp {C Struct} MHD_OptionItem
  903. Entry in an MHD_OPTION_ARRAY. See the @code{MHD_OPTION_ARRAY} option
  904. argument for its use.
  905. The @code{option} member is used to specify which option is specified
  906. in the array. The other members specify the respective argument.
  907. Note that for options taking only a single pointer, the
  908. @code{ptr_value} member should be set. For options taking two pointer
  909. arguments, the first pointer must be cast to @code{intptr_t} and both
  910. the @code{value} and the @code{ptr_value} members should be used to
  911. pass the two pointers.
  912. @end deftp
  913. @deftp {Enumeration} MHD_ValueKind
  914. The @code{MHD_ValueKind} specifies the source of the key-value pairs in
  915. the HTTP protocol.
  916. @table @code
  917. @item MHD_HEADER_KIND
  918. HTTP header.
  919. @item MHD_COOKIE_KIND
  920. @cindex cookie
  921. Cookies. Note that the original HTTP header containing the cookie(s)
  922. will still be available and intact.
  923. @item MHD_POSTDATA_KIND
  924. @cindex POST method
  925. @code{POST} data. This is available only if a content encoding
  926. supported by MHD is used (currently only @acronym{URL} encoding), and
  927. only if the posted content fits within the available memory pool. Note
  928. that in that case, the upload data given to the
  929. @code{MHD_AccessHandlerCallback()} will be empty (since it has
  930. already been processed).
  931. @item MHD_GET_ARGUMENT_KIND
  932. @code{GET} (URI) arguments.
  933. @item MHD_FOOTER_KIND
  934. HTTP footer (only for http 1.1 chunked encodings).
  935. @end table
  936. @end deftp
  937. @deftp {Enumeration} MHD_RequestTerminationCode
  938. The @code{MHD_RequestTerminationCode} specifies reasons why a request
  939. has been terminated (or completed).
  940. @table @code
  941. @item MHD_REQUEST_TERMINATED_COMPLETED_OK
  942. We finished sending the response.
  943. @item MHD_REQUEST_TERMINATED_WITH_ERROR
  944. Error handling the connection (resources exhausted, other side closed
  945. connection, application error accepting request, etc.)
  946. @item MHD_REQUEST_TERMINATED_TIMEOUT_REACHED
  947. No activity on the connection for the number of seconds specified using
  948. @code{MHD_OPTION_CONNECTION_TIMEOUT}.
  949. @item MHD_REQUEST_TERMINATED_DAEMON_SHUTDOWN
  950. We had to close the session since MHD was being shut down.
  951. @end table
  952. @end deftp
  953. @deftp {Enumeration} MHD_ResponseMemoryMode
  954. The @code{MHD_ResponeMemoryMode} specifies how MHD should treat
  955. the memory buffer given for the response in
  956. @code{MHD_create_response_from_buffer}.
  957. @table @code
  958. @item MHD_RESPMEM_PERSISTENT
  959. Buffer is a persistent (static/global) buffer that won't change
  960. for at least the lifetime of the response, MHD should just use
  961. it, not free it, not copy it, just keep an alias to it.
  962. @item MHD_RESPMEM_MUST_FREE
  963. Buffer is heap-allocated with @code{malloc} (or equivalent) and
  964. should be freed by MHD after processing the response has
  965. concluded (response reference counter reaches zero).
  966. @item MHD_RESPMEM_MUST_COPY
  967. Buffer is in transient memory, but not on the heap (for example,
  968. on the stack or non-malloc allocated) and only valid during the
  969. call to @code{MHD_create_response_from_buffer}. MHD must make its
  970. own private copy of the data for processing.
  971. @end table
  972. @end deftp
  973. @deftp {Enumeration} MHD_ResponseFlags
  974. Response-specific flags. Passed as an argument to
  975. @code{MHD_set_response_options()}.
  976. @table @code
  977. @item MHD_RF_NONE
  978. No special handling.
  979. @item MHD_RF_HTTP_VERSION_1_0_ONLY
  980. Only respond in conservative HTTP 1.0-mode. In particular,
  981. do not (automatically) sent "Connection" headers and always
  982. close the connection after generating the response.
  983. By default, MHD will respond using the same HTTP version which
  984. was set in the request. You can also set the
  985. @code{MHD_RF_HTTP_VERSION_1_0_RESPONSE} flag to force version 1.0
  986. in the response.
  987. @item MHD_RF_HTTP_VERSION_1_0_RESPONSE
  988. Only respond in HTTP 1.0-mode. Contrary to the
  989. @code{MHD_RF_HTTP_VERSION_1_0_ONLY} flag, the response's HTTP version will
  990. always be set to 1.0 and ``Connection'' headers are still supported.
  991. You can even combine this option with MHD_RF_HTTP_VERSION_1_0_ONLY to
  992. change the response's HTTP version while maintaining strict compliance
  993. with HTTP 1.0 regarding connection management.
  994. This solution is not perfect as this flag is set on the response which
  995. is created after header processing. So MHD will behave as a HTTP 1.1
  996. server until the response is queued. It means that an invalid HTTP 1.1
  997. request will fail even if the response is sent with HTTP 1.0 and the
  998. request would be valid if interpreted with this version. For example,
  999. this request will fail in strict mode:
  1000. @verbatim
  1001. GET / HTTP/1.1
  1002. @end verbatim
  1003. as the ``Host'' header is missing and is mandatory in HTTP 1.1, but it
  1004. should succeed when interpreted with HTTP 1.0.
  1005. @end table
  1006. @end deftp
  1007. @deftp {Enumeration} MHD_ResponseOptions
  1008. Response-specific options. Passed in the varargs portion of
  1009. @code{MHD_set_response_options()}.
  1010. @table @code
  1011. @item MHD_RO_END
  1012. No more options / last option. This is used to terminate the VARARGs
  1013. list.
  1014. @end table
  1015. @end deftp
  1016. @c ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
  1017. @c ------------------------------------------------------------
  1018. @node microhttpd-struct
  1019. @chapter Structures type definition
  1020. @deftp {C Struct} MHD_Daemon
  1021. Handle for the daemon (listening on a socket for HTTP traffic).
  1022. @end deftp
  1023. @deftp {C Struct} MHD_Connection
  1024. Handle for a connection / HTTP request. With HTTP/1.1, multiple
  1025. requests can be run over the same connection. However, MHD will only
  1026. show one request per TCP connection to the client at any given time.
  1027. @end deftp
  1028. @deftp {C Struct} MHD_Response
  1029. Handle for a response.
  1030. @end deftp
  1031. @deftp {C Struct} MHD_PostProcessor
  1032. @cindex POST method
  1033. Handle for @code{POST} processing.
  1034. @end deftp
  1035. @deftp {C Union} MHD_ConnectionInfo
  1036. Information about a connection.
  1037. @end deftp
  1038. @deftp {C Union} MHD_DaemonInfo
  1039. Information about an MHD daemon.
  1040. @end deftp
  1041. @c ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
  1042. @c ------------------------------------------------------------
  1043. @node microhttpd-cb
  1044. @chapter Callback functions definition
  1045. @deftypefn {Function Pointer} int {*MHD_AcceptPolicyCallback} (void *cls, const struct sockaddr * addr, socklen_t addrlen)
  1046. Invoked in the context of a connection to allow or deny a client to
  1047. connect. This callback return @code{MHD_YES} if connection is allowed,
  1048. @code{MHD_NO} if not.
  1049. @table @var
  1050. @item cls
  1051. custom value selected at callback registration time;
  1052. @item addr
  1053. address information from the client;
  1054. @item addrlen
  1055. length of the address information.
  1056. @end table
  1057. @end deftypefn
  1058. @deftypefn {Function Pointer} int {*MHD_AccessHandlerCallback} (void *cls, struct MHD_Connection * connection, const char *url, const char *method, const char *version, const char *upload_data, size_t *upload_data_size, void **con_cls)
  1059. Invoked in the context of a connection to answer a request from the
  1060. client. This callback must call MHD functions (example: the
  1061. @code{MHD_Response} ones) to provide content to give back to the client
  1062. and return an HTTP status code (i.e. @code{200} for OK, @code{404},
  1063. etc.).
  1064. @ref{microhttpd-post}, for details on how to code this callback.
  1065. Must return @code{MHD_YES} if the connection was handled successfully,
  1066. @code{MHD_NO} if the socket must be closed due to a serious error while
  1067. handling the request
  1068. @table @var
  1069. @item cls
  1070. custom value selected at callback registration time;
  1071. @item url
  1072. the URL requested by the client;
  1073. @item method
  1074. the HTTP method used by the client (@code{GET}, @code{PUT},
  1075. @code{DELETE}, @code{POST}, etc.);
  1076. @item version
  1077. the HTTP version string (i.e. @code{HTTP/1.1});
  1078. @item upload_data
  1079. the data being uploaded (excluding headers):
  1080. @cindex POST method
  1081. @cindex PUT method
  1082. @code{POST} data @strong{will} be made available
  1083. incrementally in @var{upload_data}; even if @code{POST}
  1084. data is available, the first time the callback is
  1085. invoked there won't be upload data, as this is done
  1086. just after MHD parses the headers. If supported by
  1087. the client and the HTTP version, the application can
  1088. at this point queue an error response to possibly
  1089. avoid the upload entirely. If no response is generated,
  1090. MHD will (if required) automatically send a 100 CONTINUE
  1091. reply to the client.
  1092. Afterwards, POST data will be passed to the callback
  1093. to be processed incrementally by the application. The
  1094. application may return @code{MHD_NO} to forcefully
  1095. terminate the TCP connection without generating a
  1096. proper HTTP response. Once all of the upload data has
  1097. been provided to the application, the application
  1098. will be called again with 0 bytes of upload data.
  1099. At this point, a response should be queued to complete
  1100. the handling of the request.
  1101. @item upload_data_size
  1102. set initially to the size of the @var{upload_data} provided; this
  1103. callback must update this value to the number of bytes @strong{NOT}
  1104. processed; unless external select is used, the callback maybe
  1105. required to process at least some data. If the callback fails to
  1106. process data in multi-threaded or internal-select mode and if the
  1107. read-buffer is already at the maximum size that MHD is willing to
  1108. use for reading (about half of the maximum amount of memory allowed
  1109. for the connection), then MHD will abort handling the connection
  1110. and return an internal server error to the client. In order to
  1111. avoid this, clients must be able to process upload data incrementally
  1112. and reduce the value of @code{upload_data_size}.
  1113. @item con_cls
  1114. reference to a pointer, initially set to @code{NULL}, that this callback can
  1115. set to some address and that will be preserved by MHD for future
  1116. calls for this request;
  1117. since the access handler may be called many times (i.e., for a
  1118. @code{PUT}/@code{POST} operation with plenty of upload data) this allows
  1119. the application to easily associate some request-specific state;
  1120. if necessary, this state can be cleaned up in the global
  1121. @code{MHD_RequestCompletedCallback} (which can be set with the
  1122. @code{MHD_OPTION_NOTIFY_COMPLETED}).
  1123. @end table
  1124. @end deftypefn
  1125. @deftypefn {Function Pointer} void {*MHD_RequestCompletedCallback} (void *cls, struct MHD_Connectionconnection, void **con_cls, enum MHD_RequestTerminationCode toe)
  1126. Signature of the callback used by MHD to notify the application about
  1127. completed requests.
  1128. @table @var
  1129. @item cls
  1130. custom value selected at callback registration time;
  1131. @item connection
  1132. connection handle;
  1133. @item con_cls
  1134. value as set by the last call to the
  1135. @code{MHD_AccessHandlerCallback};
  1136. @item toe
  1137. reason for request termination see @code{MHD_OPTION_NOTIFY_COMPLETED}.
  1138. @end table
  1139. @end deftypefn
  1140. @deftypefn {Function Pointer} int {*MHD_KeyValueIterator} (void *cls, enum MHD_ValueKind kind, const char *key, const char *value, size_t value_size)
  1141. Iterator over key-value pairs. This iterator can be used to iterate
  1142. over all of the cookies, headers, or @code{POST}-data fields of a
  1143. request, and also to iterate over the headers that have been added to a
  1144. response.
  1145. @table @var
  1146. @item cls
  1147. custom value specified when iteration was triggered;
  1148. @item kind
  1149. kind of the header we are looking at
  1150. @item key
  1151. key for the value, can be an empty string
  1152. @item value
  1153. value corresponding value, can be NULL
  1154. @item value_size
  1155. number of bytes in @code{value}. This argument was introduced in
  1156. @code{MHD_VERSION} 0x00096301 to allow applications to use binary
  1157. zeros in values. Applications using this argument must ensure that
  1158. they are using a sufficiently recent version of MHD, i.e. by testing
  1159. @code{MHD_get_version()} for values above or equal to 0.9.64.
  1160. Applications that do not need zeros in values and that want to compile
  1161. without warnings against newer versions of MHD should not declare this
  1162. argument and cast the function pointer argument to
  1163. @code{MHD_KeyValueIterator}.
  1164. @end table
  1165. Return @code{MHD_YES} to continue iterating, @code{MHD_NO} to abort the
  1166. iteration.
  1167. @end deftypefn
  1168. @deftypefn {Function Pointer} int {*MHD_ContentReaderCallback} (void *cls, uint64_t pos, char *buf, size_t max)
  1169. Callback used by MHD in order to obtain content. The callback has to
  1170. copy at most @var{max} bytes of content into @var{buf}. The total
  1171. number of bytes that has been placed into @var{buf} should be returned.
  1172. Note that returning zero will cause MHD to try again.
  1173. Thus, returning zero should only be used in conjunction
  1174. with @code{MHD_suspend_connection()} to avoid busy waiting.
  1175. While usually the callback simply returns the number of bytes written
  1176. into @var{buf}, there are two special return value:
  1177. @code{MHD_CONTENT_READER_END_OF_STREAM} (-1) should be returned
  1178. for the regular end of transmission (with chunked encoding, MHD will then
  1179. terminate the chunk and send any HTTP footers that might be
  1180. present; without chunked encoding and given an unknown
  1181. response size, MHD will simply close the connection; note
  1182. that while returning @code{MHD_CONTENT_READER_END_OF_STREAM} is not technically
  1183. legal if a response size was specified, MHD accepts this
  1184. and treats it just as @code{MHD_CONTENT_READER_END_WITH_ERROR}.
  1185. @code{MHD_CONTENT_READER_END_WITH_ERROR} (-2) is used to indicate a server
  1186. error generating the response; this will cause MHD to simply
  1187. close the connection immediately. If a response size was
  1188. given or if chunked encoding is in use, this will indicate
  1189. an error to the client. Note, however, that if the client
  1190. does not know a response size and chunked encoding is not in
  1191. use, then clients will not be able to tell the difference between
  1192. @code{MHD_CONTENT_READER_END_WITH_ERROR} and
  1193. @code{MHD_CONTENT_READER_END_OF_STREAM}.
  1194. This is not a limitation of MHD but rather of the HTTP protocol.
  1195. @table @var
  1196. @item cls
  1197. custom value selected at callback registration time;
  1198. @item pos
  1199. position in the datastream to access; note that if an
  1200. @code{MHD_Response} object is re-used, it is possible for the same
  1201. content reader to be queried multiple times for the same data; however,
  1202. if an @code{MHD_Response} is not re-used, MHD guarantees that
  1203. @var{pos} will be the sum of all non-negative return values obtained
  1204. from the content reader so far.
  1205. @end table
  1206. Return @code{-1} on error (MHD will no longer try to read content and
  1207. instead close the connection with the client).
  1208. @end deftypefn
  1209. @deftypefn {Function Pointer} void {*MHD_ContentReaderFreeCallback} (void *cls)
  1210. This method is called by MHD if we are done with a content reader.
  1211. It should be used to free resources associated with the content reader.
  1212. @end deftypefn
  1213. @deftypefn {Function Pointer} int {*MHD_PostDataIterator} (void *cls, enum MHD_ValueKind kind, const char *key, const char *filename, const char *content_type, const char *transfer_encoding, const char *data, uint64_t off, size_t size)
  1214. Iterator over key-value pairs where the value maybe made available in
  1215. increments and/or may not be zero-terminated. Used for processing
  1216. @code{POST} data.
  1217. @table @var
  1218. @item cls
  1219. custom value selected at callback registration time;
  1220. @item kind
  1221. type of the value;
  1222. @item key
  1223. zero-terminated key for the value;
  1224. @item filename
  1225. name of the uploaded file, @code{NULL} if not known;
  1226. @item content_type
  1227. mime-type of the data, @code{NULL} if not known;
  1228. @item transfer_encoding
  1229. encoding of the data, @code{NULL} if not known;
  1230. @item data
  1231. pointer to size bytes of data at the specified offset;
  1232. @item off
  1233. offset of data in the overall value;
  1234. @item size
  1235. number of bytes in data available.
  1236. @end table
  1237. Return @code{MHD_YES} to continue iterating, @code{MHD_NO} to abort the
  1238. iteration.
  1239. @end deftypefn
  1240. @c ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
  1241. @c ------------------------------------------------------------
  1242. @node microhttpd-init
  1243. @chapter Starting and stopping the server
  1244. @deftypefun {void} MHD_set_panic_func (MHD_PanicCallback cb, void *cls)
  1245. Set a handler for fatal errors.
  1246. @table @var
  1247. @item cb
  1248. function to call if MHD encounters a fatal internal error. If no handler was set explicitly, MHD will call @code{abort}.
  1249. @item cls
  1250. closure argument for cb; the other arguments are the name of the source file, line number and a string describing the nature of the fatal error (which can be @code{NULL})
  1251. @end table
  1252. @end deftypefun
  1253. @deftypefun {struct MHD_Daemon *} MHD_start_daemon (unsigned int flags, unsigned short port, MHD_AcceptPolicyCallback apc, void *apc_cls, MHD_AccessHandlerCallback dh, void *dh_cls, ...)
  1254. Start a webserver on the given port.
  1255. @table @var
  1256. @item flags
  1257. OR-ed combination of @code{MHD_FLAG} values;
  1258. @item port
  1259. port to bind to;
  1260. @item apc
  1261. callback to call to check which clients will be allowed to connect; you
  1262. can pass @code{NULL} in which case connections from any @acronym{IP} will be
  1263. accepted;
  1264. @item apc_cls
  1265. extra argument to @var{apc};
  1266. @item dh
  1267. default handler for all URIs;
  1268. @item dh_cls
  1269. extra argument to @var{dh}.
  1270. @end table
  1271. Additional arguments are a list of options (type-value pairs,
  1272. terminated with @code{MHD_OPTION_END}). It is mandatory to use
  1273. @code{MHD_OPTION_END} as last argument, even when there are no
  1274. additional arguments.
  1275. Return @code{NULL} on error, handle to daemon on success.
  1276. @end deftypefun
  1277. @deftypefun int MHD_quiesce_daemon (struct MHD_Daemon *daemon)
  1278. @cindex quiesce
  1279. Stop accepting connections from the listening socket. Allows clients
  1280. to continue processing, but stops accepting new connections. Note
  1281. that the caller is responsible for closing the returned socket;
  1282. however, if MHD is run using threads (anything but external select
  1283. mode), it must not be closed until AFTER @code{MHD_stop_daemon} has
  1284. been called (as it is theoretically possible that an existing thread
  1285. is still using it).
  1286. This function is useful in the special case that a listen socket
  1287. is to be migrated to another process (i.e. a newer version of the
  1288. HTTP server) while existing connections should continue to be
  1289. processed until they are finished.
  1290. Return @code{-1} on error (daemon not listening), the handle to the
  1291. listen socket otherwise.
  1292. @end deftypefun
  1293. @deftypefun void MHD_stop_daemon (struct MHD_Daemon *daemon)
  1294. Shutdown an HTTP daemon.
  1295. @end deftypefun
  1296. @deftypefun int MHD_run (struct MHD_Daemon *daemon)
  1297. Run webserver operations (without blocking unless in client callbacks).
  1298. This method should be called by clients in combination with
  1299. @code{MHD_get_fdset()} if the client-controlled @code{select}-method is used.
  1300. @cindex select
  1301. @cindex poll
  1302. This function will work for external @code{poll} and @code{select} mode.
  1303. However, if using external @code{select} mode, you may want to
  1304. instead use @code{MHD_run_from_select}, as it is more efficient.
  1305. @table @var
  1306. @item daemon
  1307. daemon to process connections of
  1308. @end table
  1309. Return @code{MHD_YES} on success, @code{MHD_NO} if this daemon was not
  1310. started with the right options for this call.
  1311. @end deftypefun
  1312. @deftypefun int MHD_run_from_select (struct MHD_Daemon *daemon, const fd_set *read_fd_set, const fd_set *write_fd_set, const fd_set *except_fd_set)
  1313. Run webserver operations given sets of ready socket handles.
  1314. @cindex select
  1315. This method should be called by clients in combination with
  1316. @code{MHD_get_fdset} if the client-controlled (external)
  1317. select method is used.
  1318. You can use this function instead of @code{MHD_run} if you called
  1319. @code{select} on the result from @code{MHD_get_fdset}. File descriptors in
  1320. the sets that are not controlled by MHD will be ignored. Calling
  1321. this function instead of @code{MHD_run} is more efficient as MHD will
  1322. not have to call @code{select} again to determine which operations are
  1323. ready.
  1324. @table @var
  1325. @item daemon
  1326. daemon to process connections of
  1327. @item read_fd_set
  1328. set of descriptors that must be ready for reading without blocking
  1329. @item write_fd_set
  1330. set of descriptors that must be ready for writing without blocking
  1331. @item except_fd_set
  1332. ignored, can be NULL
  1333. @end table
  1334. Return @code{MHD_YES} on success, @code{MHD_NO} on serious internal
  1335. errors.
  1336. @end deftypefun
  1337. @deftypefun void MHD_add_connection (struct MHD_Daemon *daemon, int client_socket, const struct sockaddr *addr, socklen_t addrlen)
  1338. Add another client connection to the set of connections
  1339. managed by MHD. This API is usually not needed (since
  1340. MHD will accept inbound connections on the server socket).
  1341. Use this API in special cases, for example if your HTTP
  1342. server is behind NAT and needs to connect out to the
  1343. HTTP client, or if you are building a proxy.
  1344. If you use this API in conjunction with a internal select or a thread
  1345. pool, you must set the option @code{MHD_USE_ITC} to
  1346. ensure that the freshly added connection is immediately processed by
  1347. MHD.
  1348. The given client socket will be managed (and closed!) by MHD after
  1349. this call and must no longer be used directly by the application
  1350. afterwards.
  1351. @table @var
  1352. @item daemon
  1353. daemon that manages the connection
  1354. @item client_socket
  1355. socket to manage (MHD will expect to receive an HTTP request from this socket next).
  1356. @item addr
  1357. IP address of the client
  1358. @item addrlen
  1359. number of bytes in addr
  1360. @end table
  1361. This function will return @code{MHD_YES} on success,
  1362. @code{MHD_NO} if this daemon could
  1363. not handle the connection (i.e. malloc failed, etc).
  1364. The socket will be closed in any case; 'errno' is set
  1365. to indicate further details about the error.
  1366. @end deftypefun
  1367. @c ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
  1368. @c -----------------------------------------------------------
  1369. @node microhttpd-inspect
  1370. @chapter Implementing external @code{select}
  1371. @deftypefun int MHD_get_fdset (struct MHD_Daemon *daemon, fd_set * read_fd_set, fd_set * write_fd_set, fd_set * except_fd_set, int *max_fd)
  1372. Obtain the @code{select()} sets for this daemon. The daemon's socket
  1373. is added to @var{read_fd_set}. The list of currently existent
  1374. connections is scanned and their file descriptors added to the correct
  1375. set.
  1376. When calling this function, FD_SETSIZE is assumed to be platform's
  1377. default. If you changed FD_SETSIZE for your application,
  1378. you should use @code{MHD_get_fdset2()} instead.
  1379. This function should only be called in when MHD is configured to use
  1380. external select with @code{select()} or with @code{epoll()}. In
  1381. the latter case, it will only add the single @code{epoll()} file
  1382. descriptor used by MHD to the sets.
  1383. After the call completed successfully: the variable referenced by
  1384. @var{max_fd} references the file descriptor with highest integer
  1385. identifier. The variable must be set to zero before invoking this
  1386. function.
  1387. Return @code{MHD_YES} on success, @code{MHD_NO} if: the arguments are
  1388. invalid (example: @code{NULL} pointers); this daemon was not started with
  1389. the right options for this call.
  1390. @end deftypefun
  1391. @deftypefun int MHD_get_fdset2 (struct MHD_Daemon *daemon, fd_set * read_fd_set, fd_set * write_fd_set, fd_set * except_fd_set, int *max_fd, unsigned int fd_setsize)
  1392. Like @code{MHD_get_fdset()}, except that you can manually specify the value of FD_SETSIZE used by your application.
  1393. @end deftypefun
  1394. @deftypefun int MHD_get_timeout (struct MHD_Daemon *daemon, unsigned long long *timeout)
  1395. @cindex timeout
  1396. Obtain timeout value for select for this daemon (only needed if
  1397. connection timeout is used). The returned value is how many
  1398. milliseconds @code{select} should at most block, not the timeout value
  1399. set for connections. This function must not be called if the
  1400. @code{MHD_USE_THREAD_PER_CONNECTION} mode is in use (since then it is
  1401. not meaningful to ask for a timeout, after all, there is concurrenct
  1402. activity). The function must also not be called by user-code if
  1403. @code{MHD_USE_INTERNAL_POLLING_THREAD} is in use. In the latter case, the
  1404. behavior is undefined.
  1405. @table @var
  1406. @item daemon
  1407. which daemon to obtain the timeout from.
  1408. @item timeout
  1409. will be set to the timeout (in milliseconds).
  1410. @end table
  1411. Return @code{MHD_YES} on success, @code{MHD_NO} if timeouts are not used
  1412. (or no connections exist that would necessiate the use of a timeout
  1413. right now).
  1414. @end deftypefun
  1415. @c ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
  1416. @c -----------------------------------------------------------
  1417. @node microhttpd-requests
  1418. @chapter Handling requests
  1419. @deftypefun int MHD_get_connection_values (struct MHD_Connection *connection, enum MHD_ValueKind kind, MHD_KeyValueIterator iterator, void *iterator_cls)
  1420. Get all the headers matching @var{kind} from the request. The @var{kind}
  1421. argument can be a bitmask, ORing the various header kinds that are
  1422. requested.
  1423. The @var{iterator} callback is invoked once for each header, with
  1424. @var{iterator_cls} as first argument. After version 0.9.19, the
  1425. headers are iterated in the same order as they were received from
  1426. the network; previous versions iterated over the headers in reverse
  1427. order.
  1428. @code{MHD_get_connection_values} returns the number of entries
  1429. iterated over; this can be less than the number of headers if, while
  1430. iterating, @var{iterator} returns @code{MHD_NO}.
  1431. @var{iterator} can be @code{NULL}: in this case this function just counts
  1432. and returns the number of headers.
  1433. In the case of @code{MHD_GET_ARGUMENT_KIND}, the @var{value} argument
  1434. will be @code{NULL} if the URL contained a key without an equals operator.
  1435. For example, for a HTTP request to the URL ``http://foo/bar?key'', the
  1436. @var{value} argument is @code{NULL}; in contrast, a HTTP request to the URL
  1437. ``http://foo/bar?key='', the @var{value} argument is the empty string.
  1438. The normal case is that the URL contains ``http://foo/bar?key=value''
  1439. in which case @var{value} would be the string ``value'' and @var{key}
  1440. would contain the string ``key''.
  1441. @end deftypefun
  1442. @deftypefun int MHD_set_connection_value (struct MHD_Connection *connection, enum MHD_ValueKind kind, const char *key, const char *value)
  1443. This function can be used to append an entry to
  1444. the list of HTTP headers of a connection (so that the
  1445. @code{MHD_get_connection_values function} will return
  1446. them -- and the MHD PostProcessor will also
  1447. see them). This maybe required in certain
  1448. situations (see Mantis #1399) where (broken)
  1449. HTTP implementations fail to supply values needed
  1450. by the post processor (or other parts of the
  1451. application).
  1452. This function MUST only be called from within
  1453. the MHD_AccessHandlerCallback (otherwise, access
  1454. maybe improperly synchronized). Furthermore,
  1455. the client must guarantee that the key and
  1456. value arguments are 0-terminated strings that
  1457. are NOT freed until the connection is closed.
  1458. (The easiest way to do this is by passing only
  1459. arguments to permanently allocated strings.).
  1460. @var{connection} is the connection for which
  1461. the entry for @var{key} of the given @var{kind}
  1462. should be set to the given @var{value}.
  1463. The function returns @code{MHD_NO} if the operation
  1464. could not be performed due to insufficient memory
  1465. and @code{MHD_YES} on success.
  1466. @end deftypefun
  1467. @deftypefun {const char *} MHD_lookup_connection_value (struct MHD_Connection *connection, enum MHD_ValueKind kind, const char *key)
  1468. Get a particular header value. If multiple values match the
  1469. @var{kind}, return one of them (the ``first'', whatever that means).
  1470. @var{key} must reference a zero-terminated ASCII-coded string
  1471. representing the header to look for: it is compared against the
  1472. headers using @code{strcasecmp()}, so case is ignored. A value of
  1473. @code{NULL} for @var{key} can be used to lookup 'trailing' values without a
  1474. key, for example if a URI is of the form
  1475. ``http://example.com/?trailer'', a @var{key} of @code{NULL} can be used to
  1476. access ``tailer" The function returns @code{NULL} if no matching item
  1477. was found.
  1478. @end deftypefun
  1479. @c ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
  1480. @c ------------------------------------------------------------
  1481. @node microhttpd-responses
  1482. @chapter Building responses to requests
  1483. @noindent
  1484. Response objects handling by MHD is asynchronous with respect to the
  1485. application execution flow. Instances of the @code{MHD_Response}
  1486. structure are not associated to a daemon and neither to a client
  1487. connection: they are managed with reference counting.
  1488. In the simplest case: we allocate a new @code{MHD_Response} structure
  1489. for each response, we use it once and finally we destroy it.
  1490. MHD allows more efficient resources usages.
  1491. Example: we allocate a new @code{MHD_Response} structure for each
  1492. response @strong{kind}, we use it every time we have to give that
  1493. response and we finally destroy it only when the daemon shuts down.
  1494. @menu
  1495. * microhttpd-response enqueue:: Enqueuing a response.
  1496. * microhttpd-response create:: Creating a response object.
  1497. * microhttpd-response headers:: Adding headers to a response.
  1498. * microhttpd-response options:: Setting response options.
  1499. * microhttpd-response inspect:: Inspecting a response object.
  1500. * microhttpd-response upgrade:: Creating a response for protocol upgrades.
  1501. @end menu
  1502. @c ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
  1503. @c ------------------------------------------------------------
  1504. @node microhttpd-response enqueue
  1505. @section Enqueuing a response
  1506. @deftypefun int MHD_queue_response (struct MHD_Connection *connection, unsigned int status_code, struct MHD_Response *response)
  1507. Queue a response to be transmitted to the client as soon as possible
  1508. but only after MHD_AccessHandlerCallback returns. This function
  1509. checks that it is legal to queue a response at this time for the
  1510. given connection. It also increments the internal reference
  1511. counter for the response object (the counter will be decremented
  1512. automatically once the response has been transmitted).
  1513. @table @var
  1514. @item connection
  1515. the connection identifying the client;
  1516. @item status_code
  1517. HTTP status code (i.e. @code{200} for OK);
  1518. @item response
  1519. response to transmit.
  1520. @end table
  1521. Return @code{MHD_YES} on success or if message has been queued. Return
  1522. @code{MHD_NO}: if arguments are invalid (example: @code{NULL} pointer); on
  1523. error (i.e. reply already sent).
  1524. @end deftypefun
  1525. @deftypefun void MHD_destroy_response (struct MHD_Response *response)
  1526. Destroy a response object and associated resources (decrement the
  1527. reference counter). Note that MHD may keep some of the resources
  1528. around if the response is still in the queue for some clients, so the
  1529. memory may not necessarily be freed immediately.
  1530. @end deftypefun
  1531. An explanation of reference counting@footnote{Note to readers acquainted
  1532. to the Tcl API: reference counting on @code{MHD_Connection}
  1533. structures is handled in the same way as Tcl handles @code{Tcl_Obj}
  1534. structures through @code{Tcl_IncrRefCount()} and
  1535. @code{Tcl_DecrRefCount()}.}:
  1536. @enumerate
  1537. @item
  1538. a @code{MHD_Response} object is allocated:
  1539. @example
  1540. struct MHD_Response * response = MHD_create_response_from_buffer(...);
  1541. /* here: reference counter = 1 */
  1542. @end example
  1543. @item
  1544. the @code{MHD_Response} object is enqueued in a @code{MHD_Connection}:
  1545. @example
  1546. MHD_queue_response(connection, , response);
  1547. /* here: reference counter = 2 */
  1548. @end example
  1549. @item
  1550. the creator of the response object discharges responsibility for it:
  1551. @example
  1552. MHD_destroy_response(response);
  1553. /* here: reference counter = 1 */
  1554. @end example
  1555. @item
  1556. the daemon handles the connection sending the response's data to the
  1557. client then decrements the reference counter by calling
  1558. @code{MHD_destroy_response()}: the counter's value drops to zero and
  1559. the @code{MHD_Response} object is released.
  1560. @end enumerate
  1561. @c ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
  1562. @c ------------------------------------------------------------
  1563. @node microhttpd-response create
  1564. @section Creating a response object
  1565. @deftypefun {struct MHD_Response *} MHD_create_response_from_callback (uint64_t size, size_t block_size, MHD_ContentReaderCallback crc, void *crc_cls, MHD_ContentReaderFreeCallback crfc)
  1566. Create a response object. The response object can be extended with
  1567. header information and then it can be used any number of times.
  1568. @table @var
  1569. @item size
  1570. size of the data portion of the response, @code{-1} for unknown;
  1571. @item block_size
  1572. preferred block size for querying @var{crc} (advisory only, MHD may
  1573. still call @var{crc} using smaller chunks); this is essentially the
  1574. buffer size used for @acronym{IO}, clients should pick a value that is
  1575. appropriate for @acronym{IO} and memory performance requirements;
  1576. @item crc
  1577. callback to use to obtain response data;
  1578. @item crc_cls
  1579. extra argument to @var{crc};
  1580. @item crfc
  1581. callback to call to free @var{crc_cls} resources.
  1582. @end table
  1583. Return @code{NULL} on error (i.e. invalid arguments, out of memory).
  1584. @end deftypefun
  1585. @deftypefun {struct MHD_Response *} MHD_create_response_from_fd (uint64_t size, int fd)
  1586. Create a response object. The response object can be extended with
  1587. header information and then it can be used any number of times.
  1588. @table @var
  1589. @item size
  1590. size of the data portion of the response (should be smaller or equal to the
  1591. size of the file)
  1592. @item fd
  1593. file descriptor referring to a file on disk with the data; will be
  1594. closed when response is destroyed; note that 'fd' must be an actual
  1595. file descriptor (not a pipe or socket) since MHD might use 'sendfile'
  1596. or 'seek' on it. The descriptor should be in blocking-IO mode.
  1597. @end table
  1598. Return @code{NULL} on error (i.e. invalid arguments, out of memory).
  1599. @end deftypefun
  1600. @deftypefun {struct MHD_Response *} MHD_create_response_from_fd_at_offset (size_t size, int fd, off_t offset)
  1601. Create a response object. The response object can be extended with
  1602. header information and then it can be used any number of times.
  1603. Note that you need to be a bit careful about @code{off_t} when
  1604. writing this code. Depending on your platform, MHD is likely
  1605. to have been compiled with support for 64-bit files. When you
  1606. compile your own application, you must make sure that @code{off_t}
  1607. is also a 64-bit value. If not, your compiler may pass a 32-bit
  1608. value as @code{off_t}, which will result in 32-bits of garbage.
  1609. If you use the autotools, use the @code{AC_SYS_LARGEFILE} autoconf
  1610. macro and make sure to include the generated @file{config.h} file
  1611. before @file{microhttpd.h} to avoid problems. If you do not have a
  1612. build system and only want to run on a GNU/Linux system, you could
  1613. also use
  1614. @verbatim
  1615. #define _FILE_OFFSET_BITS 64
  1616. #include <sys/types.h>
  1617. #include <sys/stat.h>
  1618. #include <fcntl.h>
  1619. #include <microhttpd.h>
  1620. @end verbatim
  1621. to ensure 64-bit @code{off_t}. Note that if your operating system
  1622. does not support 64-bit files, MHD will be compiled with a 32-bit
  1623. @code{off_t} (in which case the above would be wrong).
  1624. @table @var
  1625. @item size
  1626. size of the data portion of the response (number of bytes to transmit from the
  1627. file starting at offset).
  1628. @item fd
  1629. file descriptor referring to a file on disk with the data; will be
  1630. closed when response is destroyed; note that 'fd' must be an actual
  1631. file descriptor (not a pipe or socket) since MHD might use 'sendfile'
  1632. or 'seek' on it. The descriptor should be in blocking-IO mode.
  1633. @item offset
  1634. offset to start reading from in the file
  1635. @end table
  1636. Return @code{NULL} on error (i.e. invalid arguments, out of memory).
  1637. @end deftypefun
  1638. @deftypefun {struct MHD_Response *} MHD_create_response_from_buffer (size_t size, void *data, enum MHD_ResponseMemoryMode mode)
  1639. Create a response object. The response object can be extended with
  1640. header information and then it can be used any number of times.
  1641. @table @var
  1642. @item size
  1643. size of the data portion of the response;
  1644. @item buffer
  1645. the data itself;
  1646. @item mode
  1647. memory management options for buffer; use
  1648. MHD_RESPMEM_PERSISTENT if the buffer is static/global memory,
  1649. use MHD_RESPMEM_MUST_FREE if the buffer is heap-allocated and
  1650. should be freed by MHD and MHD_RESPMEM_MUST_COPY if the
  1651. buffer is in transient memory (i.e. on the stack) and must
  1652. be copied by MHD;
  1653. @end table
  1654. Return @code{NULL} on error (i.e. invalid arguments, out of memory).
  1655. @end deftypefun
  1656. @deftypefun {struct MHD_Response *} MHD_create_response_from_buffer_with_free_callback (size_t size, void *data, MHD_ContentReaderFreeCallback crfc)
  1657. Create a response object. The buffer at the end must be free'd
  1658. by calling the @var{crfc} function.
  1659. @table @var
  1660. @item size
  1661. size of the data portion of the response;
  1662. @item buffer
  1663. the data itself;
  1664. @item crfc
  1665. function to call at the end to free memory allocated at @var{buffer}.
  1666. @end table
  1667. Return @code{NULL} on error (i.e. invalid arguments, out of memory).
  1668. @end deftypefun
  1669. @deftypefun {struct MHD_Response *} MHD_create_response_from_data (size_t size, void *data, int must_free, int must_copy)
  1670. Create a response object. The response object can be extended with
  1671. header information and then it can be used any number of times.
  1672. This function is deprecated, use @code{MHD_create_response_from_buffer} instead.
  1673. @table @var
  1674. @item size
  1675. size of the data portion of the response;
  1676. @item data
  1677. the data itself;
  1678. @item must_free
  1679. if true: MHD should free data when done;
  1680. @item must_copy
  1681. if true: MHD allocates a block of memory and use it to make a copy of
  1682. @var{data} embedded in the returned @code{MHD_Response} structure;
  1683. handling of the embedded memory is responsibility of MHD; @var{data}
  1684. can be released anytime after this call returns.
  1685. @end table
  1686. Return @code{NULL} on error (i.e. invalid arguments, out of memory).
  1687. @end deftypefun
  1688. Example: create a response from a statically allocated string:
  1689. @example
  1690. const char * data = "<html><body><p>Error!</p></body></html>";
  1691. struct MHD_Connection * connection = ...;
  1692. struct MHD_Response * response;
  1693. response = MHD_create_response_from_buffer (strlen(data), data,
  1694. MHD_RESPMEM_PERSISTENT);
  1695. MHD_queue_response(connection, 404, response);
  1696. MHD_destroy_response(response);
  1697. @end example
  1698. @c ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
  1699. @c ------------------------------------------------------------
  1700. @node microhttpd-response headers
  1701. @section Adding headers to a response
  1702. @deftypefun int MHD_add_response_header (struct MHD_Response *response, const char *header, const char *content)
  1703. Add a header line to the response. The strings referenced by
  1704. @var{header} and @var{content} must be zero-terminated and they are
  1705. duplicated into memory blocks embedded in @var{response}.
  1706. Notice that the strings must not hold newlines, carriage returns or tab
  1707. chars.
  1708. MHD_add_response_header() prevents applications from setting a
  1709. ``Transfer-Encoding'' header to values other than ``identity'' or
  1710. ``chunked'' as other transfer encodings are not supported by MHD. Note
  1711. that usually MHD will pick the transfer encoding correctly
  1712. automatically, but applications can use the header to force a
  1713. particular behavior.
  1714. MHD_add_response_header() also prevents applications from setting a
  1715. ``Content-Length'' header. MHD will automatically set a correct
  1716. ``Content-Length'' header if it is possible and allowed.
  1717. Return @code{MHD_NO} on error (i.e. invalid header or content format or
  1718. memory allocation error).
  1719. @end deftypefun
  1720. @deftypefun int MHD_add_response_footer (struct MHD_Response *response, const char *footer, const char *content)
  1721. Add a footer line to the response. The strings referenced by
  1722. @var{footer} and @var{content} must be zero-terminated and they are
  1723. duplicated into memory blocks embedded in @var{response}.
  1724. Notice that the strings must not hold newlines, carriage returns or tab
  1725. chars. You can add response footers at any time before signalling the
  1726. end of the response to MHD (not just before calling 'MHD_queue_response').
  1727. Footers are useful for adding cryptographic checksums to the reply or to
  1728. signal errors encountered during data generation. This call was introduced
  1729. in MHD 0.9.3.
  1730. Return @code{MHD_NO} on error (i.e. invalid header or content format or
  1731. memory allocation error).
  1732. @end deftypefun
  1733. @deftypefun int MHD_del_response_header (struct MHD_Response *response, const char *header, const char *content)
  1734. Delete a header (or footer) line from the response. Return @code{MHD_NO} on error
  1735. (arguments are invalid or no such header known).
  1736. @end deftypefun
  1737. @c ------------------------------------------------------------
  1738. @node microhttpd-response options
  1739. @section Setting response options
  1740. @deftypefun int MHD_set_response_options (struct MHD_Response *response, enum MHD_ResponseFlags flags, ...)
  1741. Set special flags and options for a response.
  1742. Calling this functions sets the given flags and options for the response.
  1743. @table @var
  1744. @item response
  1745. which response should be modified;
  1746. @item flags
  1747. flags to set for the response;
  1748. @end table
  1749. Additional arguments are a list of options (type-value pairs,
  1750. terminated with @code{MHD_RO_END}). It is mandatory to use
  1751. @code{MHD_RO_END} as last argument, even when there are no
  1752. additional arguments.
  1753. Return @code{MHD_NO} on error, @code{MHD_YES} on success.
  1754. @end deftypefun
  1755. @c ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
  1756. @c ------------------------------------------------------------
  1757. @node microhttpd-response inspect
  1758. @section Inspecting a response object
  1759. @deftypefun int MHD_get_response_headers (struct MHD_Response *response, MHD_KeyValueIterator iterator, void *iterator_cls)
  1760. Get all of the headers added to a response.
  1761. Invoke the @var{iterator} callback for each header in the response,
  1762. using @var{iterator_cls} as first argument. Return number of entries
  1763. iterated over. @var{iterator} can be @code{NULL}: in this case the function
  1764. just counts headers.
  1765. @var{iterator} should not modify the its key and value arguments, unless
  1766. we know what we are doing.
  1767. @end deftypefun
  1768. @deftypefun {const char *} MHD_get_response_header (struct MHD_Response *response, const char *key)
  1769. Find and return a pointer to the value of a particular header from the
  1770. response. @var{key} must reference a zero-terminated string
  1771. representing the header to look for. The search is case sensitive.
  1772. Return @code{NULL} if header does not exist or @var{key} is @code{NULL}.
  1773. We should not modify the value, unless we know what we are doing.
  1774. @end deftypefun
  1775. @c ------------------------------------------------------------
  1776. @node microhttpd-response upgrade
  1777. @section Creating a response for protocol upgrades
  1778. @cindex WebSockets
  1779. @cindex Upgrade
  1780. @cindex HTTP2
  1781. @cindex RFC2817
  1782. With RFC 2817 a mechanism to switch protocols within HTTP was
  1783. introduced. Here, a client sends a request with a ``Connection:
  1784. Upgrade'' header. The server responds with a ``101 Switching
  1785. Protocols'' response header, after which the two parties begin to
  1786. speak a different (non-HTTP) protocol over the TCP connection.
  1787. This mechanism is used for upgrading HTTP 1.1 connections to HTTP2 or
  1788. HTTPS, as well as for implementing WebSockets. Which protocol
  1789. upgrade is performed is negotiated between server and client in
  1790. additional headers, in particular the ``Upgrade'' header.
  1791. MHD supports switching protocols using this mechanism only if the
  1792. @code{MHD_ALLOW_SUSPEND_RESUME} flag has been set when starting
  1793. the daemon. If this flag has been set, applications can upgrade
  1794. a connection by queueing a response (using the
  1795. @code{MHD_HTTP_SWITCHING_PROTOCOLS} status code) which must
  1796. have been created with the following function:
  1797. @deftypefun int MHD_create_response_for_upgrade (MHD_UpgradeHandler upgrade_handler, void *upgrade_handler_cls)
  1798. Create a response suitable for switching protocols. Returns @code{MHD_YES} on success. @code{upgrade_handler} must not be @code{NULL}.
  1799. When creating this type of response, the ``Connection: Upgrade''
  1800. header will be set automatically for you. MHD requires that you
  1801. additionally set an ``Upgrade:'' header. The ``Upgrade'' header
  1802. must simply exist, the specific value is completely up to the
  1803. application.
  1804. @end deftypefun
  1805. The @code{upgrade_handler} argument to the above has the following type:
  1806. @deftypefn {Function Pointer} void {*MHD_UpgradeHandler} (void *cls, struct MHD_Connection *connection, const char *extra_in, size_t extra_in_size, MHD_socket sock, struct MHD_UpgradeResponseHandle *urh)
  1807. This function will be called once MHD has transmitted the header of the response to the connection that is being upgraded. At this point, the application is expected to take over the socket @code{sock} and speak the non-HTTP protocol to which the connection was upgraded. MHD will no longer use the socket; this includes handling timeouts. The application must call @code{MHD_upgrade_action} with an upgrade action of @code{MHD_UPGRADE_ACTION_CLOSE} when it is done processing the connection to close the socket. The application must not call @code{MHD_stop_daemon} on the respective daemon as long as it is still handling the connection. The arguments given to the @code{upgrade_handler} have the following meaning:
  1808. @table @var
  1809. @item cls
  1810. matches the @code{upgrade_handler_cls} that was given to @code{MHD_create_response_for_upgrade}
  1811. @item connection
  1812. identifies the connection that is being upgraded;
  1813. @item con_cls
  1814. last value left in `*con_cls` in the `MHD_AccessHandlerCallback`
  1815. @item extra_in
  1816. buffer of bytes MHD read ``by accident'' from the socket already. This can happen if the client eagerly transmits more than just the HTTP request. The application should treat these as if it had read them from the socket.
  1817. @item extra_in_size
  1818. number of bytes in @code{extra_in}
  1819. @item sock
  1820. the socket which the application can now use directly for some bi-directional communication with the client. The application can henceforth use @code{recv()} and @code{send()} or @code{read()} and @code{write()} system calls on the socket. However, @code{ioctl()} and @code{setsockopt()} functions will not work as expected when using HTTPS. Such operations may be supported in the future via @code{MHD_upgrade_action}. Most importantly, the application must never call @code{close()} on this socket. Closing the socket must be done using @code{MHD_upgrade_action}. However, while close is forbidden, the application may call @code{shutdown()} on the socket.
  1821. @item urh
  1822. argument for calls to @code{MHD_upgrade_action}. Applications must eventually use this function to perform the @code{close()} action on the socket.
  1823. @end table
  1824. @end deftypefn
  1825. @deftypefun int MHD_upgrade_action (struct MHD_UpgradeResponseHandle *urh, enum MHD_UpgradeAction action, ...)
  1826. Perform special operations related to upgraded connections.
  1827. @table @var
  1828. @item urh
  1829. identifies the upgraded connection to perform an action on
  1830. @item action
  1831. specifies the action to perform; further arguments to the function depend on the specifics of the action.
  1832. @end table
  1833. @end deftypefun
  1834. @deftp {Enumeration} MHD_UpgradeAction
  1835. Set of actions to be performed on upgraded connections. Passed as an argument to
  1836. @code{MHD_upgrade_action()}.
  1837. @table @code
  1838. @item MHD_UPGRADE_ACTION_CLOSE
  1839. Closes the connection. Must be called once the application is done with the client. Takes no additional arguments.
  1840. @item MHD_UPGRADE_ACTION_CORK_ON
  1841. Enable corking on the underlying socket.
  1842. @item MHD_UPGRADE_ACTION_CORK_OFF
  1843. Disable corking on the underlying socket.
  1844. @end table
  1845. @end deftp
  1846. @c ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
  1847. @c ------------------------------------------------------------
  1848. @node microhttpd-flow
  1849. @chapter Flow control.
  1850. @noindent
  1851. Sometimes it may be possible that clients upload data faster
  1852. than an application can process it, or that an application
  1853. needs an extended period of time to generate a response.
  1854. If @code{MHD_USE_THREAD_PER_CONNECTION} is used, applications
  1855. can simply deal with this by performing their logic within the
  1856. thread and thus effectively blocking connection processing
  1857. by MHD. In all other modes, blocking logic must not be
  1858. placed within the callbacks invoked by MHD as this would also
  1859. block processing of other requests, as a single thread may be
  1860. responsible for tens of thousands of connections.
  1861. Instead, applications using thread modes other than
  1862. @code{MHD_USE_THREAD_PER_CONNECTION} should use the
  1863. following functions to perform flow control.
  1864. @deftypefun int MHD_suspend_connection (struct MHD_Connection *connection)
  1865. Suspend handling of network data for a given connection. This can
  1866. be used to dequeue a connection from MHD's event loop (external
  1867. select, internal select or thread pool; not applicable to
  1868. thread-per-connection!) for a while.
  1869. If you use this API in conjunction with a internal select or a
  1870. thread pool, you must set the option @code{MHD_ALLOW_SUSPEND_RESUME} to
  1871. ensure that a resumed connection is immediately processed by MHD.
  1872. Suspended connections continue to count against the total number of
  1873. connections allowed (per daemon, as well as per IP, if such limits
  1874. are set). Suspended connections will NOT time out; timeouts will
  1875. restart when the connection handling is resumed. While a
  1876. connection is suspended, MHD will not detect disconnects by the
  1877. client.
  1878. The only safe time to suspend a connection is from the
  1879. @code{MHD_AccessHandlerCallback} or from the respective
  1880. @code{MHD_ContentReaderCallback} (but in this case the
  1881. response object must not be shared among multiple
  1882. connections).
  1883. Finally, it is an API violation to call @code{MHD_stop_daemon} while
  1884. having suspended connections (this will at least create memory and
  1885. socket leaks or lead to undefined behavior). You must explicitly
  1886. resume all connections before stopping the daemon.
  1887. @table @var
  1888. @item connection
  1889. the connection to suspend
  1890. @end table
  1891. @end deftypefun
  1892. @deftypefun int MHD_resume_connection (struct MHD_Connection *connection)
  1893. Resume handling of network data for suspended connection. It is safe
  1894. to resume a suspended connection at any time. Calling this function
  1895. on a connection that was not previously suspended will result in
  1896. undefined behavior.
  1897. If you are using this function in ``external'' select mode, you must
  1898. make sure to run @code{MHD_run} afterwards (before again calling
  1899. @code{MHD_get_fdset}), as otherwise the change may not be reflected in
  1900. the set returned by @code{MHD_get_fdset} and you may end up with a
  1901. connection that is stuck until the next network activity.
  1902. You can check whether a connection is currently suspended using
  1903. @code{MHD_get_connection_info} by querying for
  1904. @code{MHD_CONNECTION_INFO_CONNECTION_SUSPENDED}.
  1905. @table @var
  1906. @item connection
  1907. the connection to resume
  1908. @end table
  1909. @end deftypefun
  1910. @c ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
  1911. @c ------------------------------------------------------------
  1912. @node microhttpd-dauth
  1913. @chapter Utilizing Authentication
  1914. @noindent
  1915. MHD support three types of client authentication.
  1916. Basic authentication uses a simple authentication method based
  1917. on BASE64 algorithm. Username and password are exchanged in clear
  1918. between the client and the server, so this method must only be used
  1919. for non-sensitive content or when the session is protected with https.
  1920. When using basic authentication MHD will have access to the clear
  1921. password, possibly allowing to create a chained authentication
  1922. toward an external authentication server.
  1923. Digest authentication uses a one-way authentication method based
  1924. on MD5 hash algorithm. Only the hash will transit over the network,
  1925. hence protecting the user password. The nonce will prevent replay
  1926. attacks. This method is appropriate for general use, especially
  1927. when https is not used to encrypt the session.
  1928. Client certificate authentication uses a X.509 certificate from
  1929. the client. This is the strongest authentication mechanism but it
  1930. requires the use of HTTPS. Client certificate authentication can
  1931. be used simultaneously with Basic or Digest Authentication in order
  1932. to provide a two levels authentication (like for instance separate
  1933. machine and user authentication). A code example for using
  1934. client certificates is presented in the MHD tutorial.
  1935. @menu
  1936. * microhttpd-dauth basic:: Using Basic Authentication.
  1937. * microhttpd-dauth digest:: Using Digest Authentication.
  1938. @end menu
  1939. @c ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
  1940. @c ------------------------------------------------------------
  1941. @node microhttpd-dauth basic
  1942. @section Using Basic Authentication
  1943. @deftypefun {void} MHD_free (void *ptr)
  1944. Free the memory given at @code{ptr}. Used to free data structures allocated by MHD. Calls @code{free(ptr)}.
  1945. @end deftypefun
  1946. @deftypefun {char *} MHD_basic_auth_get_username_password (struct MHD_Connection *connection, char** password)
  1947. Get the username and password from the basic authorization header sent by the client.
  1948. Return @code{NULL} if no username could be found, a pointer to the username if found.
  1949. If returned value is not @code{NULL}, the value must be @code{MHD_free()}'ed.
  1950. @var{password} reference a buffer to store the password. It can be @code{NULL}.
  1951. If returned value is not @code{NULL}, the value must be @code{MHD_free()}'ed.
  1952. @end deftypefun
  1953. @deftypefun {int} MHD_queue_basic_auth_fail_response (struct MHD_Connection *connection, const char *realm, struct MHD_Response *response)
  1954. Queues a response to request basic authentication from the client.
  1955. Return @code{MHD_YES} if successful, otherwise @code{MHD_NO}.
  1956. @var{realm} must reference to a zero-terminated string representing the realm.
  1957. @var{response} a response structure to specify what shall be presented to the
  1958. client with a 401 HTTP status.
  1959. @end deftypefun
  1960. @c ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
  1961. @c ------------------------------------------------------------
  1962. @node microhttpd-dauth digest
  1963. @section Using Digest Authentication
  1964. MHD supports MD5 (deprecated by IETF) and SHA-256 hash algorithms
  1965. for digest authentication. The @code{MHD_DigestAuthAlgorithm} enumeration
  1966. is used to specify which algorithm should be used.
  1967. @deftp {Enumeration} MHD_DigestAuthAlgorithm
  1968. Which digest algorithm should be used. Must be used consistently.
  1969. @table @code
  1970. @item MHD_DIGEST_ALG_AUTO
  1971. Have MHD pick an algorithm currently considered secure. For now defaults to SHA-256.
  1972. @item MHD_DIGEST_ALG_MD5
  1973. Force use of (deprecated, ancient, insecure) MD5.
  1974. @item MHD_DIGEST_ALG_SHA256
  1975. Force use of SHA-256.
  1976. @end table
  1977. @end deftp
  1978. @deftypefun {char *} MHD_digest_auth_get_username (struct MHD_Connection *connection)
  1979. Find and return a pointer to the username value from the request header.
  1980. Return @code{NULL} if the value is not found or header does not exist.
  1981. If returned value is not @code{NULL}, the value must be @code{MHD_free()}'ed.
  1982. @end deftypefun
  1983. @deftypefun int MHD_digest_auth_check2 (struct MHD_Connection *connection, const char *realm, const char *username, const char *password, unsigned int nonce_timeout, enum MHD_DigestAuthAlgorithm algo)
  1984. Checks if the provided values in the WWW-Authenticate header are valid
  1985. and sound according to RFC2716. If valid return @code{MHD_YES}, otherwise return @code{MHD_NO}.
  1986. @var{realm} must reference to a zero-terminated string representing the realm.
  1987. @var{username} must reference to a zero-terminated string representing the username,
  1988. it is usually the returned value from MHD_digest_auth_get_username.
  1989. @var{password} must reference to a zero-terminated string representing the password,
  1990. most probably it will be the result of a lookup of the username against a local database.
  1991. @var{nonce_timeout} is the amount of time in seconds for a nonce to be invalid.
  1992. Most of the time it is sound to specify 300 seconds as its values.
  1993. @var{algo} which digest algorithm should we use.
  1994. @end deftypefun
  1995. @deftypefun int MHD_digest_auth_check (struct MHD_Connection *connection, const char *realm, const char *username, const char *password, unsigned int nonce_timeout)
  1996. Checks if the provided values in the WWW-Authenticate header are valid
  1997. and sound according to RFC2716. If valid return @code{MHD_YES}, otherwise return @code{MHD_NO}.
  1998. Deprecated, use @code{MHD_digest_auth_check2} instead.
  1999. @var{realm} must reference to a zero-terminated string representing the realm.
  2000. @var{username} must reference to a zero-terminated string representing the username,
  2001. it is usually the returned value from MHD_digest_auth_get_username.
  2002. @var{password} must reference to a zero-terminated string representing the password,
  2003. most probably it will be the result of a lookup of the username against a local database.
  2004. @var{nonce_timeout} is the amount of time in seconds for a nonce to be invalid.
  2005. Most of the time it is sound to specify 300 seconds as its values.
  2006. @end deftypefun
  2007. @deftypefun int MHD_digest_auth_check_digest2 (struct MHD_Connection *connection, const char *realm, const char *username, const uint8_t *digest, unsigned int nonce_timeout, enum MHD_DigestAuthAlgorithm algo)
  2008. Checks if the provided values in the WWW-Authenticate header are valid
  2009. and sound according to RFC2716. If valid return @code{MHD_YES}, otherwise return @code{MHD_NO}.
  2010. @var{realm} must reference to a zero-terminated string representing the realm.
  2011. @var{username} must reference to a zero-terminated string representing the username,
  2012. it is usually the returned value from MHD_digest_auth_get_username.
  2013. @var{digest} pointer to the binary MD5 sum for the precalculated hash value ``userame:realm:password''. The size must match the selected @var{algo}!
  2014. @var{nonce_timeout} is the amount of time in seconds for a nonce to be invalid.
  2015. Most of the time it is sound to specify 300 seconds as its values.
  2016. @var{algo} digest authentication algorithm to use.
  2017. @end deftypefun
  2018. @deftypefun int MHD_digest_auth_check_digest (struct MHD_Connection *connection, const char *realm, const char *username, const unsigned char digest[MHD_MD5_DIGEST_SIZE], unsigned int nonce_timeout)
  2019. Checks if the provided values in the WWW-Authenticate header are valid
  2020. and sound according to RFC2716. If valid return @code{MHD_YES}, otherwise return @code{MHD_NO}.
  2021. Deprecated, use @code{MHD_digest_auth_check_digest2} instead.
  2022. @var{realm} must reference to a zero-terminated string representing the realm.
  2023. @var{username} must reference to a zero-terminated string representing the username,
  2024. it is usually the returned value from MHD_digest_auth_get_username.
  2025. @var{digest} pointer to the binary MD5 sum for the precalculated hash value ``userame:realm:password'' of @code{MHD_MD5_DIGEST_SIZE} bytes.
  2026. @var{nonce_timeout} is the amount of time in seconds for a nonce to be invalid.
  2027. Most of the time it is sound to specify 300 seconds as its values.
  2028. @end deftypefun
  2029. @deftypefun int MHD_queue_auth_fail_response2 (struct MHD_Connection *connection, const char *realm, const char *opaque, struct MHD_Response *response, int signal_stale, enum MHD_DigestAuthAlgorithm algo)
  2030. Queues a response to request authentication from the client,
  2031. return @code{MHD_YES} if successful, otherwise @code{MHD_NO}.
  2032. @var{realm} must reference to a zero-terminated string representing the realm.
  2033. @var{opaque} must reference to a zero-terminated string representing a value
  2034. that gets passed to the client and expected to be passed again to the server
  2035. as-is. This value can be a hexadecimal or base64 string.
  2036. @var{response} a response structure to specify what shall be presented to the
  2037. client with a 401 HTTP status.
  2038. @var{signal_stale} a value that signals "stale=true" in the response header to
  2039. indicate the invalidity of the nonce and no need to ask for authentication
  2040. parameters and only a new nonce gets generated. @code{MHD_YES} to generate a new
  2041. nonce, @code{MHD_NO} to ask for authentication parameters.
  2042. @var{algo} which digest algorithm should we use. The same algorithm
  2043. must then be selected when checking digests received from clients!
  2044. @end deftypefun
  2045. @deftypefun int MHD_queue_auth_fail_response (struct MHD_Connection *connection, const char *realm, const char *opaque, struct MHD_Response *response, int signal_stale)
  2046. Queues a response to request authentication from the client,
  2047. return @code{MHD_YES} if successful, otherwise @code{MHD_NO}.
  2048. @var{realm} must reference to a zero-terminated string representing the realm.
  2049. @var{opaque} must reference to a zero-terminated string representing a value
  2050. that gets passed to the client and expected to be passed again to the server
  2051. as-is. This value can be a hexadecimal or base64 string.
  2052. @var{response} a response structure to specify what shall be presented to the
  2053. client with a 401 HTTP status.
  2054. @var{signal_stale} a value that signals "stale=true" in the response header to
  2055. indicate the invalidity of the nonce and no need to ask for authentication
  2056. parameters and only a new nonce gets generated. @code{MHD_YES} to generate a new
  2057. nonce, @code{MHD_NO} to ask for authentication parameters.
  2058. @end deftypefun
  2059. Example: handling digest authentication requests and responses.
  2060. @example
  2061. #define PAGE "<html><head><title>libmicrohttpd demo</title></head><body>Access granted</body></html>"
  2062. #define DENIED "<html><head><title>libmicrohttpd demo</title></head><body>Access denied</body></html>"
  2063. #define OPAQUE "11733b200778ce33060f31c9af70a870ba96ddd4"
  2064. static int
  2065. ahc_echo (void *cls,
  2066. struct MHD_Connection *connection,
  2067. const char *url,
  2068. const char *method,
  2069. const char *version,
  2070. const char *upload_data, size_t *upload_data_size, void **ptr)
  2071. @{
  2072. struct MHD_Response *response;
  2073. char *username;
  2074. const char *password = "testpass";
  2075. const char *realm = "test@@example.com";
  2076. int ret;
  2077. username = MHD_digest_auth_get_username (connection);
  2078. if (username == NULL)
  2079. @{
  2080. response = MHD_create_response_from_buffer(strlen (DENIED),
  2081. DENIED,
  2082. MHD_RESPMEM_PERSISTENT);
  2083. ret = MHD_queue_auth_fail_response2 (connection,
  2084. realm,
  2085. OPAQUE,
  2086. response,
  2087. MHD_NO,
  2088. MHD_DIGEST_ALG_SHA256);
  2089. MHD_destroy_response(response);
  2090. return ret;
  2091. @}
  2092. ret = MHD_digest_auth_check2 (connection,
  2093. realm,
  2094. username,
  2095. password,
  2096. 300,
  2097. MHD_DIGEST_ALG_SHA256);
  2098. free(username);
  2099. if ( (ret == MHD_INVALID_NONCE) ||
  2100. (ret == MHD_NO) )
  2101. @{
  2102. response = MHD_create_response_from_buffer(strlen (DENIED),
  2103. DENIED,
  2104. MHD_RESPMEM_PERSISTENT);
  2105. if (NULL == response)
  2106. return MHD_NO;
  2107. ret = MHD_queue_auth_fail_response2 (connection,
  2108. realm,
  2109. OPAQUE,
  2110. response,
  2111. (ret == MHD_INVALID_NONCE) ? MHD_YES : MHD_NO,
  2112. MHD_DIGEST_ALG_SHA256);
  2113. MHD_destroy_response(response);
  2114. return ret;
  2115. @}
  2116. response = MHD_create_response_from_buffer (strlen(PAGE),
  2117. PAGE,
  2118. MHD_RESPMEM_PERSISTENT);
  2119. ret = MHD_queue_response (connection,
  2120. MHD_HTTP_OK,
  2121. response);
  2122. MHD_destroy_response(response);
  2123. return ret;
  2124. @}
  2125. @end example
  2126. @c ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
  2127. @c ------------------------------------------------------------
  2128. @node microhttpd-post
  2129. @chapter Adding a @code{POST} processor
  2130. @cindex POST method
  2131. @menu
  2132. * microhttpd-post api:: Programming interface for the
  2133. @code{POST} processor.
  2134. @end menu
  2135. @noindent
  2136. MHD provides the post processor API to make it easier for applications to
  2137. parse the data of a client's @code{POST} request: the
  2138. @code{MHD_AccessHandlerCallback} will be invoked multiple times to
  2139. process data as it arrives; at each invocation a new chunk of data must
  2140. be processed. The arguments @var{upload_data} and @var{upload_data_size}
  2141. are used to reference the chunk of data.
  2142. When @code{MHD_AccessHandlerCallback} is invoked for a new connection:
  2143. its @code{*@var{con_cls}} argument is set to @code{NULL}. When @code{POST}
  2144. data comes in the upload buffer it is @strong{mandatory} to use the
  2145. @var{con_cls} to store a reference to per-connection data. The fact
  2146. that the pointer was initially @code{NULL} can be used to detect that
  2147. this is a new request.
  2148. One method to detect that a new connection was established is
  2149. to set @code{*con_cls} to an unused integer:
  2150. @example
  2151. int
  2152. access_handler (void *cls,
  2153. struct MHD_Connection * connection,
  2154. const char *url,
  2155. const char *method, const char *version,
  2156. const char *upload_data, size_t *upload_data_size,
  2157. void **con_cls)
  2158. @{
  2159. static int old_connection_marker;
  2160. int new_connection = (NULL == *con_cls);
  2161. if (new_connection)
  2162. @{
  2163. /* new connection with POST */
  2164. *con_cls = &old_connection_marker;
  2165. @}
  2166. ...
  2167. @}
  2168. @end example
  2169. @noindent
  2170. In contrast to the previous example, for @code{POST} requests in particular,
  2171. it is more common to use the value of @code{*con_cls} to keep track of
  2172. actual state used during processing, such as the post processor (or a
  2173. struct containing a post processor):
  2174. @example
  2175. int
  2176. access_handler (void *cls,
  2177. struct MHD_Connection * connection,
  2178. const char *url,
  2179. const char *method, const char *version,
  2180. const char *upload_data, size_t *upload_data_size,
  2181. void **con_cls)
  2182. @{
  2183. struct MHD_PostProcessor * pp = *con_cls;
  2184. if (pp == NULL)
  2185. @{
  2186. pp = MHD_create_post_processor(connection, ...);
  2187. *con_cls = pp;
  2188. return MHD_YES;
  2189. @}
  2190. if (*upload_data_size)
  2191. @{
  2192. MHD_post_process(pp, upload_data, *upload_data_size);
  2193. *upload_data_size = 0;
  2194. return MHD_YES;
  2195. @}
  2196. else
  2197. @{
  2198. MHD_destroy_post_processor(pp);
  2199. return MHD_queue_response(...);
  2200. @}
  2201. @}
  2202. @end example
  2203. Note that the callback from @code{MHD_OPTION_NOTIFY_COMPLETED}
  2204. should be used to destroy the post processor. This cannot be
  2205. done inside of the access handler since the connection may not
  2206. always terminate normally.
  2207. @c ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
  2208. @c ------------------------------------------------------------
  2209. @node microhttpd-post api
  2210. @section Programming interface for the @code{POST} processor
  2211. @cindex POST method
  2212. @deftypefun {struct MHD_PostProcessor *} MHD_create_post_processor (struct MHD_Connection *connection, size_t buffer_size, MHD_PostDataIterator iterator, void *iterator_cls)
  2213. Create a PostProcessor. A PostProcessor can be used to (incrementally)
  2214. parse the data portion of a @code{POST} request.
  2215. @table @var
  2216. @item connection
  2217. the connection on which the @code{POST} is happening (used to determine
  2218. the @code{POST} format);
  2219. @item buffer_size
  2220. maximum number of bytes to use for internal buffering (used only for the
  2221. parsing, specifically the parsing of the keys). A tiny value (256-1024)
  2222. should be sufficient; do @strong{NOT} use a value smaller than 256;
  2223. for good performance, use 32k or 64k (i.e. 65536).
  2224. @item iterator
  2225. iterator to be called with the parsed data; must @strong{NOT} be
  2226. @code{NULL};
  2227. @item iterator_cls
  2228. custom value to be used as first argument to @var{iterator}.
  2229. @end table
  2230. Return @code{NULL} on error (out of memory, unsupported encoding), otherwise
  2231. a PP handle.
  2232. @end deftypefun
  2233. @deftypefun int MHD_post_process (struct MHD_PostProcessor *pp, const char *post_data, size_t post_data_len)
  2234. Parse and process @code{POST} data. Call this function when @code{POST}
  2235. data is available (usually during an @code{MHD_AccessHandlerCallback})
  2236. with the @var{upload_data} and @var{upload_data_size}. Whenever
  2237. possible, this will then cause calls to the
  2238. @code{MHD_IncrementalKeyValueIterator}.
  2239. @table @var
  2240. @item pp
  2241. the post processor;
  2242. @item post_data
  2243. @var{post_data_len} bytes of @code{POST} data;
  2244. @item post_data_len
  2245. length of @var{post_data}.
  2246. @end table
  2247. Return @code{MHD_YES} on success, @code{MHD_NO} on error
  2248. (out-of-memory, iterator aborted, parse error).
  2249. @end deftypefun
  2250. @deftypefun int MHD_destroy_post_processor (struct MHD_PostProcessor *pp)
  2251. Release PostProcessor resources. After this function is being called,
  2252. the PostProcessor is guaranteed to no longer call its iterator. There
  2253. is no special call to the iterator to indicate the end of the post processing
  2254. stream. After destroying the PostProcessor, the programmer should
  2255. perform any necessary work to complete the processing of the iterator.
  2256. Return @code{MHD_YES} if processing completed nicely, @code{MHD_NO}
  2257. if there were spurious characters or formatting problems with
  2258. the post request. It is common to ignore the return value
  2259. of this function.
  2260. @end deftypefun
  2261. @c ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
  2262. @c ------------------------------------------------------------
  2263. @node microhttpd-info
  2264. @chapter Obtaining and modifying status information.
  2265. @menu
  2266. * microhttpd-info daemon:: State information about an MHD daemon
  2267. * microhttpd-info conn:: State information about a connection
  2268. * microhttpd-option conn:: Modify per-connection options
  2269. @end menu
  2270. @c ------------------------------------------------------------
  2271. @node microhttpd-info daemon
  2272. @section Obtaining state information about an MHD daemon
  2273. @deftypefun {const union MHD_DaemonInfo *} MHD_get_daemon_info (struct MHD_Daemon *daemon, enum MHD_DaemonInfoType infoType, ...)
  2274. Obtain information about the given daemon. This function
  2275. is currently not fully implemented.
  2276. @table @var
  2277. @item daemon
  2278. the daemon about which information is desired;
  2279. @item infoType
  2280. type of information that is desired
  2281. @item ...
  2282. additional arguments about the desired information (depending on
  2283. infoType)
  2284. @end table
  2285. Returns a union with the respective member (depending on
  2286. infoType) set to the desired information), or @code{NULL}
  2287. in case the desired information is not available or
  2288. applicable.
  2289. @end deftypefun
  2290. @deftp {Enumeration} MHD_DaemonInfoType
  2291. Values of this enum are used to specify what
  2292. information about a daemon is desired.
  2293. @table @code
  2294. @item MHD_DAEMON_INFO_KEY_SIZE
  2295. Request information about the key size for a particular cipher
  2296. algorithm. The cipher algorithm should be passed as an extra argument
  2297. (of type 'enum MHD_GNUTLS_CipherAlgorithm'). No longer supported,
  2298. using this value will cause @code{MHD_get_daemon_info} to return NULL.
  2299. @item MHD_DAEMON_INFO_MAC_KEY_SIZE
  2300. Request information about the key size for a particular cipher
  2301. algorithm. The cipher algorithm should be passed as an extra argument
  2302. (of type 'enum MHD_GNUTLS_HashAlgorithm'). No longer supported,
  2303. using this value will cause @code{MHD_get_daemon_info} to return NULL.
  2304. @item MHD_DAEMON_INFO_LISTEN_FD
  2305. @cindex listen
  2306. Request the file-descriptor number that MHD is using to listen to the
  2307. server socket. This can be useful if no port
  2308. was specified and a client needs to learn what port
  2309. is actually being used by MHD.
  2310. No extra arguments should be passed.
  2311. @item MHD_DAEMON_INFO_EPOLL_FD
  2312. @cindex epoll
  2313. Request the file-descriptor number that MHD is using for epoll. If
  2314. the build is not supporting epoll, NULL is returned; if we are using a
  2315. thread pool or this daemon was not started with
  2316. @code{MHD_USE_EPOLL}, (a pointer to) -1 is returned. If we are
  2317. using @code{MHD_USE_INTERNAL_POLLING_THREAD} or are in 'external' select mode, the
  2318. internal epoll FD is returned. This function must be used in external
  2319. select mode with epoll to obtain the FD to call epoll on. No extra
  2320. arguments should be passed.
  2321. @item MHD_DAEMON_INFO_CURRENT_CONNECTIONS
  2322. @cindex connection, limiting number of connections
  2323. Request the number of current connections handled by the daemon. No
  2324. extra arguments should be passed and a pointer to a @code{union
  2325. MHD_DaemonInfo} value is returned, with the @code{num_connections}
  2326. member of type @code{unsigned int} set to the number of active
  2327. connections.
  2328. Note that in multi-threaded or internal-select mode, the real number of current
  2329. connections may already be different when @code{MHD_get_daemon_info} returns.
  2330. The number of current connections can be used (even in multi-threaded and
  2331. internal-select mode) after @code{MHD_quiesce_daemon} to detect whether all
  2332. connections have been handled.
  2333. @end table
  2334. @end deftp
  2335. @c ------------------------------------------------------------
  2336. @node microhttpd-info conn
  2337. @section Obtaining state information about a connection
  2338. @deftypefun {const union MHD_ConnectionInfo *} MHD_get_connection_info (struct MHD_Connection *connection, enum MHD_ConnectionInfoType infoType, ...)
  2339. Obtain information about the given connection.
  2340. @table @var
  2341. @item connection
  2342. the connection about which information is desired;
  2343. @item infoType
  2344. type of information that is desired
  2345. @item ...
  2346. additional arguments about the desired information (depending on
  2347. infoType)
  2348. @end table
  2349. Returns a union with the respective member (depending on
  2350. infoType) set to the desired information), or @code{NULL}
  2351. in case the desired information is not available or
  2352. applicable.
  2353. @end deftypefun
  2354. @deftp {Enumeration} MHD_ConnectionInfoType
  2355. Values of this enum are used to specify what information about a
  2356. connection is desired.
  2357. @table @code
  2358. @item MHD_CONNECTION_INFO_CIPHER_ALGO
  2359. What cipher algorithm is being used (HTTPS connections only).
  2360. @code{NULL} is returned for non-HTTPS connections.
  2361. Takes no extra arguments.
  2362. @item MHD_CONNECTION_INFO_PROTOCOL,
  2363. Allows finding out the TLS/SSL protocol used
  2364. (HTTPS connections only).
  2365. @code{NULL} is returned for non-HTTPS connections.
  2366. Takes no extra arguments.
  2367. @item MHD_CONNECTION_INFO_CLIENT_ADDRESS
  2368. Returns information about the address of the client. Returns
  2369. essentially a @code{struct sockaddr **} (since the API returns
  2370. a @code{union MHD_ConnectionInfo *} and that union contains
  2371. a @code{struct sockaddr *}).
  2372. Takes no extra arguments.
  2373. @item MHD_CONNECTION_INFO_GNUTLS_SESSION,
  2374. Takes no extra arguments. Allows access to the underlying GNUtls session,
  2375. including access to the underlying GNUtls client certificate
  2376. (HTTPS connections only). Takes no extra arguments.
  2377. @code{NULL} is returned for non-HTTPS connections.
  2378. Takes no extra arguments.
  2379. @item MHD_CONNECTION_INFO_GNUTLS_CLIENT_CERT,
  2380. Dysfunctional (never implemented, deprecated). Use
  2381. MHD_CONNECTION_INFO_GNUTLS_SESSION to get the @code{gnutls_session_t}
  2382. and then call @code{gnutls_certificate_get_peers()}.
  2383. @item MHD_CONNECTION_INFO_DAEMON
  2384. Returns information about @code{struct MHD_Daemon} which manages
  2385. this connection.
  2386. Takes no extra arguments.
  2387. @item MHD_CONNECTION_INFO_CONNECTION_FD
  2388. Returns the file descriptor (usually a TCP socket) associated with
  2389. this connection (in the ``connect-fd'' member of the returned struct).
  2390. Note that manipulating the descriptor directly can have problematic
  2391. consequences (as in, break HTTP). Applications might use this access
  2392. to manipulate TCP options, for example to set the ``TCP-NODELAY''
  2393. option for COMET-like applications. Note that MHD will set TCP-CORK
  2394. after sending the HTTP header and clear it after finishing the footers
  2395. automatically (if the platform supports it). As the connection
  2396. callbacks are invoked in between, those might be used to set different
  2397. values for TCP-CORK and TCP-NODELAY in the meantime.
  2398. Takes no extra arguments.
  2399. @item MHD_CONNECTION_INFO_CONNECTION_SUSPENDED
  2400. Returns pointer to an integer that is @code{MHD_YES} if the connection
  2401. is currently suspended (and thus can be safely resumed) and
  2402. @code{MHD_NO} otherwise.
  2403. Takes no extra arguments.
  2404. @item MHD_CONNECTION_INFO_SOCKET_CONTEXT
  2405. Returns the client-specific pointer to a @code{void *} that was
  2406. (possibly) set during a @code{MHD_NotifyConnectionCallback} when the
  2407. socket was first accepted. Note that this is NOT the same as the
  2408. @code{con_cls} argument of the @code{MHD_AccessHandlerCallback}. The
  2409. @code{con_cls} is fresh for each HTTP request, while the
  2410. @code{socket_context} is fresh for each socket.
  2411. Takes no extra arguments.
  2412. @item MHD_CONNECTION_INFO_CONNECTION_TIMEOUT
  2413. Returns pointer to an @code{unsigned int} that is the current timeout
  2414. used for the connection (in seconds, 0 for no timeout). Note that
  2415. while suspended connections will not timeout, the timeout value
  2416. returned for suspended connections will be the timeout that the
  2417. connection will use after it is resumed, and thus might not be zero.
  2418. Takes no extra arguments.
  2419. @item MHD_CONNECTION_INFO_REQUEST_HEADER_SIZE
  2420. @cindex performance
  2421. Returns pointer to an @code{size_t} that represents the size of the
  2422. HTTP header received from the client. Only valid after the first callback
  2423. to the access handler.
  2424. Takes no extra arguments.
  2425. @end table
  2426. @end deftp
  2427. @c ------------------------------------------------------------
  2428. @node microhttpd-option conn
  2429. @section Setting custom options for an individual connection
  2430. @cindex timeout
  2431. @deftypefun {int} MHD_set_connection_option (struct MHD_Connection *daemon, enum MHD_CONNECTION_OPTION option, ...)
  2432. Set a custom option for the given connection.
  2433. @table @var
  2434. @item connection
  2435. the connection for which an option should be set or modified;
  2436. @item option
  2437. option to set
  2438. @item ...
  2439. additional arguments for the option (depending on option)
  2440. @end table
  2441. Returns @code{MHD_YES} on success, @code{MHD_NO} for errors
  2442. (i.e. option argument invalid or option unknown).
  2443. @end deftypefun
  2444. @deftp {Enumeration} MHD_CONNECTION_OPTION
  2445. Values of this enum are used to specify which option for a
  2446. connection should be changed.
  2447. @table @code
  2448. @item MHD_CONNECTION_OPTION_TIMEOUT
  2449. Set a custom timeout for the given connection. Specified
  2450. as the number of seconds, given as an @code{unsigned int}. Use
  2451. zero for no timeout.
  2452. @end table
  2453. @end deftp
  2454. @c ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
  2455. @c ------------------------------------------------------------
  2456. @node microhttpd-util
  2457. @chapter Utility functions.
  2458. @menu
  2459. * microhttpd-util feature:: Test supported MHD features
  2460. * microhttpd-util unescape:: Unescape strings
  2461. @end menu
  2462. @c ------------------------------------------------------------
  2463. @node microhttpd-util feature
  2464. @section Testing for supported MHD features
  2465. @deftp {Enumeration} MHD_FEATURE
  2466. Values of this enum are used to specify what
  2467. information about a daemon is desired.
  2468. @table @code
  2469. @item MHD_FEATURE_MESSAGES
  2470. Get whether messages are supported. If supported then in debug
  2471. mode messages can be printed to stderr or to external logger.
  2472. @item MHD_FEATURE_SSL
  2473. Get whether HTTPS is supported. If supported then flag
  2474. MHD_USE_SSL and options MHD_OPTION_HTTPS_MEM_KEY,
  2475. MHD_OPTION_HTTPS_MEM_CERT, MHD_OPTION_HTTPS_MEM_TRUST,
  2476. MHD_OPTION_HTTPS_MEM_DHPARAMS, MHD_OPTION_HTTPS_CRED_TYPE,
  2477. MHD_OPTION_HTTPS_PRIORITIES can be used.
  2478. @item MHD_FEATURE_HTTPS_CERT_CALLBACK
  2479. Get whether option #MHD_OPTION_HTTPS_CERT_CALLBACK is
  2480. supported.
  2481. @item MHD_FEATURE_IPv6
  2482. Get whether IPv6 is supported. If supported then flag
  2483. MHD_USE_IPv6 can be used.
  2484. @item MHD_FEATURE_IPv6_ONLY
  2485. Get whether IPv6 without IPv4 is supported. If not supported
  2486. then IPv4 is always enabled in IPv6 sockets and
  2487. flag MHD_USE_DUAL_STACK if always used when MHD_USE_IPv6 is
  2488. specified.
  2489. @item MHD_FEATURE_POLL
  2490. Get whether @code{poll()} is supported. If supported then flag
  2491. MHD_USE_POLL can be used.
  2492. @item MHD_FEATURE_EPOLL
  2493. Get whether @code{epoll()} is supported. If supported then Flags
  2494. MHD_USE_EPOLL and
  2495. MHD_USE_EPOLL_INTERNAL_THREAD can be used.
  2496. @item MHD_FEATURE_SHUTDOWN_LISTEN_SOCKET
  2497. Get whether shutdown on listen socket to signal other
  2498. threads is supported. If not supported flag
  2499. MHD_USE_ITC is automatically forced.
  2500. @item MHD_FEATURE_SOCKETPAIR
  2501. Get whether a @code{socketpair()} is used internally instead of
  2502. a @code{pipe()} to signal other threads.
  2503. @item MHD_FEATURE_TCP_FASTOPEN
  2504. Get whether TCP Fast Open is supported. If supported then
  2505. flag MHD_USE_TCP_FASTOPEN and option
  2506. MHD_OPTION_TCP_FASTOPEN_QUEUE_SIZE can be used.
  2507. @item MHD_FEATURE_BASIC_AUTH
  2508. Get whether HTTP Basic authorization is supported. If supported
  2509. then functions @code{MHD_basic_auth_get_username_password()} and
  2510. @code{MHD_queue_basic_auth_fail_response()} can be used.
  2511. @item MHD_FEATURE_DIGEST_AUTH
  2512. Get whether HTTP Digest authorization is supported. If
  2513. supported then options MHD_OPTION_DIGEST_AUTH_RANDOM,
  2514. MHD_OPTION_NONCE_NC_SIZE and functions @code{MHD_digest_auth_check()},
  2515. can be used.
  2516. @item MHD_FEATURE_POSTPROCESSOR
  2517. Get whether postprocessor is supported. If supported then
  2518. functions @code{MHD_create_post_processor()},
  2519. @code{MHD_post_process()}, @code{MHD_destroy_post_processor()}
  2520. can be used.
  2521. @item MHD_FEATURE_SENDFILE
  2522. Get whether @code{sendfile()} is supported.
  2523. @end table
  2524. @end deftp
  2525. @deftypefun {int} MHD_is_feature_supported (enum MHD_FEATURE feature)
  2526. Get information about supported MHD features. Indicate that MHD was
  2527. compiled with or without support for particular feature. Some features
  2528. require additional support by the kernel. However, kernel support is not
  2529. checked by this function.
  2530. @table @var
  2531. @item feature
  2532. type of requested information
  2533. @end table
  2534. Returns @code{MHD_YES} if the feature is supported,
  2535. and @code{MHD_NO} if not.
  2536. @end deftypefun
  2537. @c ------------------------------------------------------------
  2538. @node microhttpd-util unescape
  2539. @section Unescape strings
  2540. @deftypefun {size_t} MHD_http_unescape (char *val)
  2541. Process escape sequences ('%HH') Updates val in place; the result
  2542. should be UTF-8 encoded and cannot be larger than the input. The
  2543. result must also still be 0-terminated.
  2544. @table @var
  2545. @item val
  2546. value to unescape (modified in the process), must be
  2547. a 0-terminated UTF-8 string.
  2548. @end table
  2549. Returns length of the resulting val (@code{strlen(val)} may be
  2550. shorter afterwards due to elimination of escape sequences).
  2551. @end deftypefun
  2552. @c ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
  2553. @c **********************************************************
  2554. @c ******************* Appendices *************************
  2555. @c **********************************************************
  2556. @node GNU-LGPL
  2557. @unnumbered GNU-LGPL
  2558. @cindex license
  2559. @include lgpl.texi
  2560. @node GNU GPL with eCos Extension
  2561. @unnumbered GNU GPL with eCos Extension
  2562. @cindex license
  2563. @include ecos.texi
  2564. @node GNU-FDL
  2565. @unnumbered GNU-FDL
  2566. @cindex license
  2567. @include fdl-1.3.texi
  2568. @node Concept Index
  2569. @unnumbered Concept Index
  2570. @printindex cp
  2571. @node Function and Data Index
  2572. @unnumbered Function and Data Index
  2573. @printindex fn
  2574. @node Type Index
  2575. @unnumbered Type Index
  2576. @printindex tp
  2577. @bye