1httpd(3)                   Erlang Module Definition                   httpd(3)
2
3
4

NAME

6       httpd -
7           HTTP server API
8
9

DESCRIPTION

11       An  implementation  of  an HTTP 1.1 compliant web server, as defined in
12       RFC 2616. Provides web server start options, administrative  functions,
13       and an Erlang callback API.
14

DATA TYPES

16       Type definitions that are used more than once in this module:
17
18       boolean() = true | false
19
20       string() = list of ASCII characters
21
22       path() = string() representing a file or a directory path
23
24        ip_address() = {N1,N2,N3,N4} % IPv4 | {K1,K2,K3,K4,K5,K6,K7,K8} % IPv6
25
26       hostname() = string() representing a host, for example, "foo.bar.com"
27
28       property() = atom()
29

ERLANG HTTP SERVER SERVICE START/STOP

31       A  web server can be configured to start when starting the Inets appli‐
32       cation, or dynamically in runtime by calling the Inets application  API
33       inets:start(httpd,  ServiceConfig) or inets:start(httpd, ServiceConfig,
34       How), see inets(3). The configuration options, also called  properties,
35       are as follows:
36
37       File Properties
38
39       When  the  web server is started at application start time, the proper‐
40       ties are to be fetched from a configuration file that can consist of  a
41       regular Erlang property list, that is, [{Option, Value}], where  Option
42       = property()  and Value = term(), followed by a full stop. If  the  web
43       server is started dynamically at runtime, a file can still be specified
44       but also the complete property list.
45
46         {proplist_file, path()}:
47           If this property is defined, Inets expects to find all other  prop‐
48           erties  defined  in this file. The file must include all properties
49           listed under mandatory properties.
50
51   Note:
52       Note support for  legacy  configuration  file  with  Apache  syntax  is
53       dropped in OTP-23.
54
55
56       Mandatory Properties
57
58         {port, integer()} :
59           The  port  that  the HTTP server listen to. If zero is specified as
60           port,  an  arbitrary  available  port  is   picked   and   function
61           httpd:info/2 can be used to determine which port was picked.
62
63         {server_name, string()}:
64           The name of your server, normally a fully qualified domain name.
65
66         {server_root, path()}:
67           Defines  the  home directory of the server, where log files, and so
68           on, can be stored. Relative paths specified in other properties re‐
69           fer to this directory.
70
71         {document_root, path()}:
72           Defines  the  top directory for the documents that are available on
73           the HTTP server.
74
75       Communication Properties
76
77         {bind_address, ip_address() | hostname() | any}:
78           Default is any
79
80         {profile, atom()}:
81           Used together with bind_address and port  to  uniquely  identify  a
82           HTTP server. This can be useful in a virtualized environment, where
83           there can be more that one server that has  the  same  bind_address
84           and  port.  If  this  property is not explicitly set, it is assumed
85           that the bind_address and port uniquely identifies the HTTP server.
86
87         {socket_type, ip_comm | {ip_comm, Config::proplist()} |  {essl,  Con‐
88         fig::proplist()}}:
89           For  ip_comm  configuration options, see gen_tcp:listen/2, some op‐
90           tions that are used internally by httpd cannot be set.
91
92           For SSL configuration options, see ssl:listen/2.
93
94           Default is ip_comm.
95
96         {ipfamily, inet | inet6}:
97           Default is inet, legacy option inet6fb4 no longer makes  sense  and
98           will be translated to inet.
99
100         {minimum_bytes_per_second, integer()}:
101           If given, sets a minimum of bytes per second value for connections.
102
103           If the value is unreached, the socket closes for that connection.
104
105           The option is good for reducing the risk of "slow DoS" attacks.
106
107       Erlang Web Server API Modules
108
109         {modules, [atom()]} :
110           Defines  which modules the HTTP server uses when handling requests.
111           Default is [mod_alias,  mod_auth,  mod_esi,  mod_actions,  mod_cgi,
112           mod_dir,  mod_get,  mod_head,  mod_log,  mod_disk_log]. Notice that
113           some mod-modules are dependent on others, so the  order  cannot  be
114           entirely  arbitrary. See the Inets Web Server Modules in the User's
115           Guide for details.
116
117       Limit properties
118
119         {customize, atom()}:
120           A callback module to customize the inets HTTP servers behaviour see
121           httpd_custom_api
122
123         {disable_chunked_transfer_encoding_send, boolean()}:
124           Allows  you to disable chunked transfer-encoding when sending a re‐
125           sponse to an HTTP/1.1 client. Default is false.
126
127         {keep_alive, boolean()}:
128           Instructs the server whether to use persistent connections when the
129           client claims to be HTTP/1.1 compliant. Default is true.
130
131         {keep_alive_timeout, integer()}:
132           The  number  of  seconds  the server waits for a subsequent request
133           from the client before closing the connection. Default is 150.
134
135         {max_body_size, integer()}:
136           Limits the size of the message body of an HTTP request. Default  is
137           no limit.
138
139         {max_clients, integer()}:
140           Limits  the  number of simultaneous requests that can be supported.
141           Default is 150.
142
143         {max_header_size, integer()}:
144           Limits the size of the message header of an HTTP  request.  Default
145           is 10240.
146
147         {max_content_length, integer()}:
148           Maximum  content-length  in an incoming request, in bytes. Requests
149           with content larger than this are answered with status 413. Default
150           is 100000000 (100 MB).
151
152         {max_uri_size, integer()}:
153           Limits the size of the HTTP request URI. Default is no limit.
154
155         {max_keep_alive_request, integer()}:
156           The number of requests that a client can do on one connection. When
157           the server has responded to  the  number  of  requests  defined  by
158           max_keep_alive_requests,  the  server  closes  the  connection. The
159           server closes it even if there are queued request.  Default  is  no
160           limit.
161
162         {max_client_body_chunk, integer()}:
163           Enforces  chunking  of a HTTP PUT or POST body data to be delivered
164           to the mod_esi callback. Note this is not  supported  for  mod_cgi.
165           Default  is no limit e.i the whole body is delivered as one entity,
166           which could be very memory consuming. mod_esi(3).
167
168       Administrative Properties
169
170         {mime_types, [{MimeType, Extension}] | path()}:
171           MimeType = string() and Extension = string().  Files  delivered  to
172           the  client are MIME typed according to RFC 1590. File suffixes are
173           mapped to MIME types before file delivery. The mapping between file
174           suffixes  and MIME types can be specified as an Apache-like file or
175           directly in the property list. Such a file can look like  the  fol‐
176           lowing:
177
178         # MIME type    Extension
179         text/html html htm
180         text/plain     asc txt
181
182           Default is [{"html","text/html"},{"htm","text/html"}].
183
184         {mime_type, string()}:
185           When  the server is asked to provide a document type that cannot be
186           determined by the MIME Type Settings, the server uses this  default
187           type.
188
189         {server_admin, string()}:
190           Defines  the  email-address  of  the server administrator to be in‐
191           cluded in any error messages returned by the server.
192
193         {server_tokens,       none|prod|major|minor|minimal|os|full|{private,
194         string()}}:
195           Defines the look of the value of the server header.
196
197           Example:  Assuming the version of Inets is 5.8.1, the server header
198           string can look as follows for the different values  of  server-to‐
199           kens:
200
201           none:
202             "" % A Server: header will not be generated
203
204           prod:
205             "inets"
206
207           major:
208             "inets/5"
209
210           minor:
211             "inets/5.8"
212
213           minimal:
214             "inets/5.8.1"
215
216           os:
217             "inets/5.8.1 (unix)"
218
219           full:
220             "inets/5.8.1 (unix/linux) OTP/R15B"
221
222           {private, "foo/bar"}:
223             "foo/bar"
224
225           By default, the value is as before, that is, minimal.
226
227         {logger, Options::list()}:
228           Currently only one option is supported:
229
230           {error, ServerID::atom()}:
231             Produces logger events on logger level error under the hierarchi‐
232             cal logger domain: [otp, inets, httpd, ServerID, error] The built
233             in logger formatting function produces log entries from the error
234             reports:
235
236           #{server_name => string()
237             protocol => internal | 'TCP' | 'TLS' | 'HTTP',
238             transport => "TCP "| "TLS", %% Present when protocol = 'HTTP'
239             uri => string(), %% Present when protocol = 'HTTP' and URI is valid
240             peer => inet:peername(),
241             host => inet:hostname(),
242             reason => term()
243           }
244
245
246             An example of a log entry with only default settings of logger
247
248           =ERROR REPORT==== 9-Oct-2019::09:33:27.350235 ===
249              Server: My Server
250            Protocol: HTTP
251           Transport: TLS
252                 URI: /not_there
253                Host: 127.0.1.1:80
254                Peer: 127.0.0.1:45253
255              Reason: [{statuscode,404},{description,"Object Not Found"}]
256
257
258             Using this option makes mod_log and mod_disk_log error  logs  re‐
259             dundant.
260
261             Add the filter
262
263           {fun logger_filters:domain/2,
264                {log,equal,[otp,inets, httpd, ServerID, error]}
265
266           [{kernel,
267            [{logger,
268             [{handler, http_error_test, logger_std_h,
269               #{config => #{ file => "log/http_error.log" },
270                 filters => [{inets_httpd, {fun logger_filters:domain/2,
271                                            {log, equal,
272                                             [otp, inets, httpd, my_server, error]
273                                            }}}],
274                 filter_default => stop }}]}]}].
275
276
277             or if you want to add it to the default logger via an API:
278
279           logger:add_handler_filter(default,
280                                     inets_httpd,
281                                     {fun logger_filters:domain/2,
282                                      {log, equal,
283                                       [otp, inets, httpd, my_server, error]}}).
284
285         {log_format, common | combined}:
286           Defines  if  access  logs are to be written according to the common
287           log format or the extended common log format. The common format  is
288           one  line looking like this: remotehost rfc931 authuser [date] "re‐
289           quest" status bytes.
290
291           Here:
292
293           remotehost:
294             Remote.
295
296           rfc931:
297             The remote username of the client (RFC 931).
298
299           authuser:
300             The username used for authentication.
301
302           [date]:
303             Date and time of the request (RFC 1123).
304
305           "request":
306             The request line as it came from the client (RFC 1945).
307
308           status:
309             The HTTP status code returned to the client (RFC 1945).
310
311           bytes:
312             The content-length of the document transferred.
313
314           The combined format is  one  line  looking  like  this:  remotehost
315           rfc931   authuser   [date]   "request"   status   bytes   "referer"
316           "user_agent"
317
318           In addition to the earlier:
319
320           "referer":
321             The URL the client was on before requesting the URL (if it  could
322             not be determined, a minus sign is placed in this field).
323
324           "user_agent":
325             The  software  the  client claims to be using (if it could not be
326             determined, a minus sign is placed in this field).
327
328           This affects the access logs written by mod_log and mod_disk_log.
329
330         {error_log_format, pretty | compact}:
331           Default is pretty. If the error log is meant to be read directly by
332           a human, pretty is the best option.
333
334           pretty has a format corresponding to:
335
336         io:format("[~s] ~s, reason: ~n ~p ~n~n", [Date, Msg, Reason]).
337
338           compact has a format corresponding to:
339
340         io:format("[~s] ~s, reason: ~w ~n", [Date, Msg, Reason]).
341
342           This affects the error logs written by mod_log and mod_disk_log.
343
344       URL Aliasing Properties - Requires mod_alias
345
346         {alias, {Alias, RealName}}:
347           Alias = string() and RealName = string(). alias allows documents to
348           be stored in the local file system instead of the document_root lo‐
349           cation. URLs with a path beginning with url-path is mapped to local
350           files beginning with directory-filename, for example:
351
352         {alias, {"/image", "/ftp/pub/image"}}
353
354           Access to http://your.server.org/image/foo.gif would refer  to  the
355           file /ftp/pub/image/foo.gif.
356
357         {re_write, {Re, Replacement}}:
358           Re = string() and Replacement = string(). re_write allows documents
359           to be stored in the local file system instead of the  document_root
360           location.  URLs  are rewritten by re:replace/3 to produce a path in
361           the local file-system, for example:
362
363         {re_write, {"^/[~]([^/]+)(.*)$", "/home/\\1/public\\2"}}
364
365           Access to http://your.server.org/~bob/foo.gif would  refer  to  the
366           file /home/bob/public/foo.gif.
367
368         {directory_index, [string()]}:
369           directory_index  specifies  a  list  of  resources to look for if a
370           client requests a directory using a / at the end of  the  directory
371           name.  file  depicts  the  name of a file in the directory. Several
372           files can be given, in which case the server returns the  first  it
373           finds, for example:
374
375         {directory_index, ["index.html", "welcome.html"]}
376
377           Access     to     http://your.server.org/docs/     would     return
378           http://your.server.org/docs/index.html                           or
379           http://your.server.org/docs/welcome.html if index.html does not ex‐
380           ist.
381
382       CGI Properties - Requires mod_cgi
383
384         {script_alias, {Alias, RealName}}:
385           Alias = string() and RealName = string(). Have the same behavior as
386           property  alias, except that they also mark the target directory as
387           containing CGI scripts. URLs with a path  beginning  with  url-path
388           are  mapped to scripts beginning with directory-filename, for exam‐
389           ple:
390
391         {script_alias, {"/cgi-bin/", "/web/cgi-bin/"}}
392
393           Access to http://your.server.org/cgi-bin/foo would cause the server
394           to run the script /web/cgi-bin/foo.
395
396         {script_re_write, {Re, Replacement}}:
397           Re = string() and Replacement = string(). Have the same behavior as
398           property re_write, except that they also mark the target  directory
399           as containing CGI scripts. URLs with a path beginning with url-path
400           are mapped to scripts beginning with directory-filename, for  exam‐
401           ple:
402
403         {script_re_write, {"^/cgi-bin/(\\d+)/", "/web/\\1/cgi-bin/"}}
404
405           Access  to  http://your.server.org/cgi-bin/17/foo  would  cause the
406           server to run the script /web/17/cgi-bin/foo.
407
408         {script_nocache, boolean()}:
409           If script_nocache is set to true, the HTTP server by  default  adds
410           the  header  fields  necessary  to prevent proxies from caching the
411           page. Generally this is preferred. Default to false.
412
413         {script_timeout, integer()}:
414           The time in seconds the web server waits between each chunk of data
415           from the script. If the CGI script does not deliver any data before
416           the timeout, the connection to the client is closed. Default is 15.
417
418         {action, {MimeType, CgiScript}} - requires mod_action:
419           MimeType = string() and CgiScript = string(). action adds an action
420           activating  a  CGI script whenever a file of a certain MIME type is
421           requested. It propagates the URL and file  path  of  the  requested
422           document using the standard CGI PATH_INFO and PATH_TRANSLATED envi‐
423           ronment variables.
424
425           Example:
426
427         {action, {"text/plain", "/cgi-bin/log_and_deliver_text"}}
428
429         {script, {Method, CgiScript}} - requires mod_action:
430           Method = string() and CgiScript = string(). script adds  an  action
431           activating  a  CGI script whenever a file is requested using a cer‐
432           tain HTTP method. The method is either GET or POST, as  defined  in
433           RFC 1945. It propagates the URL and file path of the requested doc‐
434           ument using the standard CGI PATH_INFO and PATH_TRANSLATED environ‐
435           ment variables.
436
437           Example:
438
439         {script, {"PUT", "/cgi-bin/put"}}
440
441       ESI Properties - Requires mod_esi
442
443         {erl_script_alias, {URLPath, [AllowedModule]}}:
444           URLPath  =  string()  and  AllowedModule = atom(). erl_script_alias
445           marks all URLs matching url-path as erl scheme scripts. A  matching
446           URL is mapped into a specific module and function, for example:
447
448         {erl_script_alias, {"/cgi-bin/example", [httpd_example]}}
449
450           A   request  to  http://your.server.org/cgi-bin/example/httpd_exam
451           ple:yahoo would refer to httpd_example:yahoo/3 or, if that does not
452           exist, httpd_example:yahoo/2 and http://your.server.org/cgi-bin/ex
453           ample/other:yahoo would not be allowed to execute.
454
455         {erl_script_nocache, boolean()}:
456           If erl_script_nocache is set to true, the server adds  HTTP  header
457           fields  preventing proxies from caching the page. This is generally
458           a good idea for dynamic content, as the content  often  varies  be‐
459           tween each request. Default is false.
460
461         {erl_script_timeout, integer()}:
462           If erl_script_timeout sets the time in seconds the server waits be‐
463           tween each chunk of data to be delivered through mod_esi:deliver/2.
464           Default  is  15. This is only relevant for scripts that use the erl
465           scheme.
466
467       Log Properties - Requires mod_log
468
469         {error_log, path()}:
470           Defines the filename of the error log file to be used to log server
471           errors.  If the filename does not begin with a slash (/), it is as‐
472           sumed to be relative to the server_root.
473
474         {security_log, path()}:
475           Defines the filename of the access log file to be used to log secu‐
476           rity events. If the filename does not begin with a slash (/), it is
477           assumed to be relative to the server_root.
478
479         {transfer_log, path()}:
480           Defines the filename of the access log file to be used to  log  in‐
481           coming  requests.  If the filename does not begin with a slash (/),
482           it is assumed to be relative to the server_root.
483
484       Disk Log Properties - Requires mod_disk_log
485
486         {disk_log_format, internal | external}:
487           Defines the file format of the log files. See disk_log for details.
488           If the internal file format is used, the log file is repaired after
489           a crash. When a log file is repaired, data can disappear. When  the
490           external  file format is used, httpd does not start if the log file
491           is broken. Default is external.
492
493         {error_disk_log, path()}:
494           Defines the filename of the (disk_log(3)) error log file to be used
495           to  log  server errors. If the filename does not begin with a slash
496           (/), it is assumed to be relative to the server_root.
497
498         {error_disk_log_size, {MaxBytes, MaxFiles}}:
499           MaxBytes = integer() and MaxFiles = integer(). Defines the  proper‐
500           ties of the (disk_log(3)) error log file. This file is of type wrap
501           log and max bytes is written to each file and max files is used be‐
502           fore the first file is truncated and reused.
503
504         {security_disk_log, path()}:
505           Defines  the  filename of the (disk_log(3)) access log file logging
506           incoming security events, that is, authenticated requests.  If  the
507           filename does not begin with a slash (/), it is assumed to be rela‐
508           tive to the server_root.
509
510         {security_disk_log_size, {MaxBytes, MaxFiles}}:
511           MaxBytes = integer() and MaxFiles = integer(). Defines the  proper‐
512           ties  of the disk_log(3) access log file. This file is of type wrap
513           log and max bytes is written to each file and max files is used be‐
514           fore the first file is truncated and reused.
515
516         {transfer_disk_log, path()}:
517           Defines  the  filename of the (disk_log(3)) access log file logging
518           incoming requests. If the filename does not begin with a slash (/),
519           it is assumed to be relative to the server_root.
520
521         {transfer_disk_log_size, {MaxBytes, MaxFiles}}:
522           MaxBytes  = integer() and MaxFiles = integer(). Defines the proper‐
523           ties of the disk_log(3) access log file. This file is of type  wrap
524           log and max bytes is written to each file and max files is used be‐
525           fore the first file is truncated and reused.
526
527       Authentication Properties - Requires mod_auth
528
529       {directory, {path(), [{property(), term()}]}}
530
531       The properties for directories are as follows:
532
533         {allow_from, all | [RegxpHostString]}:
534           Defines a set of hosts to be granted access to a  given  directory,
535           for example:
536
537         {allow_from, ["123.34.56.11", "150.100.23"]}
538
539           The host 123.34.56.11 and all machines on the 150.100.23 subnet are
540           allowed access.
541
542         {deny_from, all | [RegxpHostString]}:
543           Defines a set of hosts to be denied access to  a  given  directory,
544           for example:
545
546         {deny_from, ["123.34.56.11", "150.100.23"]}
547
548           The host 123.34.56.11 and all machines on the 150.100.23 subnet are
549           not allowed access.
550
551         {auth_type, plain | dets | mnesia}:
552           Sets the type of authentication database that is used for  the  di‐
553           rectory.  The  key difference between the different methods is that
554           dynamic data can be saved when Mnesia and Dets are used.
555
556         {auth_user_file, path()}:
557           Sets the name of a file containing the list of users and  passwords
558           for  user  authentication.  The  filename can be either absolute or
559           relative to the server_root. If using  the  plain  storage  method,
560           this  file is a plain text file where each line contains a username
561           followed by a colon, followed by  the  non-encrypted  password.  If
562           usernames are duplicated, the behavior is undefined.
563
564           Example:
565
566          ragnar:s7Xxv7
567          edward:wwjau8
568
569           If the Dets storage method is used, the user database is maintained
570           by Dets and must not be edited by hand. Use the  API  functions  in
571           module mod_auth to create/edit the user database. This directive is
572           ignored if the Mnesia storage method is used. For security reasons,
573           ensure  that  auth_user_file is stored outside the document tree of
574           the web server. If it is placed in the directory that it  protects,
575           clients can download it.
576
577         {auth_group_file, path()}:
578           Sets the name of a file containing the list of user groups for user
579           authentication. The filename can be either absolute or relative  to
580           the  server_root.  If  the  plain storage method is used, the group
581           file is a plain text file, where each line contains  a  group  name
582           followed by a colon, followed by the members usernames separated by
583           spaces.
584
585           Example:
586
587         group1: bob joe ante
588
589           If the Dets storage method is used, the  group  database  is  main‐
590           tained by Dets and must not be edited by hand. Use the API for mod‐
591           ule mod_auth to create/edit the group database. This  directive  is
592           ignored if the Mnesia storage method is used. For security reasons,
593           ensure that the auth_group_file is stored outside the document tree
594           of  the  web  server. If it is placed in the directory that it pro‐
595           tects, clients can download it.
596
597         {auth_name, string()}:
598           Sets the name of the authorization realm (auth-domain) for a direc‐
599           tory. This string informs the client about which username and pass‐
600           word to use.
601
602         {auth_access_password, string()}:
603           If set to other than "NoPassword", the password is required for all
604           API  calls. If the password is set to "DummyPassword", the password
605           must be changed before any other API calls. To secure the authenti‐
606           cating  data,  the password must be changed after the web server is
607           started. Otherwise it is written in clear text in the configuration
608           file.
609
610         {require_user, [string()]}:
611           Defines  users  to grant access to a given directory using a secret
612           password.
613
614         {require_group, [string()]}:
615           Defines users to grant access to a given directory using  a  secret
616           password.
617
618       Security Properties - Requires mod_security
619
620       {security_directory, {path(), [{property(), term()}]}}
621
622       The properties for the security directories are as follows:
623
624         {data_file, path()}:
625           Name of the security data file. The filename can either be absolute
626           or relative to the server_root. This file is used to store  persis‐
627           tent data for module mod_security.
628
629         {max_retries, integer()}:
630           Specifies the maximum number of attempts to authenticate a user be‐
631           fore the user is blocked out. If a user successfully  authenticates
632           while  blocked,  the  user receives a 403 (Forbidden) response from
633           the server. If the user makes a failed attempt while  blocked,  the
634           server returns 401 (Unauthorized), for security reasons. Default is
635           3. Can be set to infinity.
636
637         {block_time, integer()}:
638           Specifies the number of minutes a user is blocked. After this  time
639           has passed, the user automatically regains access. Default is 60.
640
641         {fail_expire_time, integer()}:
642           Specifies the number of minutes a failed user authentication is re‐
643           membered. If a user authenticates after this time has  passed,  the
644           previous failed authentications are forgotten. Default is 30.
645
646         {auth_timeout, integer()}:
647            Specifies  the  number of seconds a successful user authentication
648           is remembered. After this time has passed, the authentication is no
649           longer reported. Default is 30.
650

EXPORTS

652       info(Pid) ->
653       info(Pid, Properties) -> [{Option, Value}]
654
655              Types:
656
657                 Properties = [property()]
658                 Option = property()
659                 Value = term()
660
661              Fetches information about the HTTP server. When called with only
662              the pid, all properties are fetched. When called with a list  of
663              specific  properties, they are fetched. The available properties
664              are the same as the start options of the server.
665
666          Note:
667              Pid is the pid returned from inets:start/[2,3]. Can also be  re‐
668              trieved form inets:services/0 and inets:services_info/0, see in‐
669              ets(3).
670
671
672       info(Address, Port) ->
673       info(Address, Port, Profile) ->
674       info(Address, Port, Profile, Properties) -> [{Option, Value}]
675       info(Address, Port, Properties) -> [{Option, Value}]
676
677              Types:
678
679                 Address = ip_address()
680                 Port = integer()
681                 Profile = atom()
682                 Properties = [property()]
683                 Option = property()
684                 Value = term()
685
686              Fetches information about the HTTP server. When called with only
687              Address and Port, all properties are fetched. When called with a
688              list of specific properties, they  are  fetched.  The  available
689              properties are the same as the start options of the server.
690
691          Note:
692              The address must be the IP address and cannot be the hostname.
693
694
695       reload_config(Config, Mode) -> ok | {error, Reason}
696
697              Types:
698
699                 Config = path() | [{Option, Value}]
700                 Option = property()
701                 Value = term()
702                 Mode = non_disturbing | disturbing
703
704              Reloads  the  HTTP  server  configuration without restarting the
705              server. Incoming requests are answered  with  a  temporary  down
706              message during the reload time.
707
708          Note:
709              Available  properties  are  the same as the start options of the
710              server, but the  properties  bind_address  and  port  cannot  be
711              changed.
712
713
714              If mode is disturbing, the server is blocked forcefully, all on‐
715              going requests terminates, and the reload starts immediately. If
716              mode is non-disturbing, no new connections are accepted, but on‐
717              going requests are allowed to  complete  before  the  reload  is
718              done.
719

ERLANG WEB SERVER API DATA TYPES

721       The Erlang web server API data types are as follows:
722
723             ModData = #mod{}
724
725             -record(mod, {
726                 data = [],
727                 socket_type = ip_comm,
728                 socket,
729                 config_db,
730                 method,
731                 absolute_uri,
732                 request_uri,
733                 http_version,
734                 request_line,
735                 parsed_header = [],
736                 entity_body,
737                 connection
738            }).
739
740       To access the record in your callback-module use:
741
742        -include_lib("inets/include/httpd.hrl").
743
744       The fields of record mod have the following meaning:
745
746         data:
747           Type  [{InteractionKey,InteractionValue}] is used to propagate data
748           between modules. Depicted interaction_data() in function type  dec‐
749           larations.
750
751         socket_type:
752           socket_type()  indicates  whether  it  is  an  IP  socket or an ssl
753           socket.
754
755         socket:
756           The socket, in format ip_comm or ssl, depending on socket_type.
757
758         config_db:
759           The config file directives stored as key-value tuples in an ETS ta‐
760           ble. Depicted config_db() in function type declarations.
761
762         method:
763           Type "GET" | "POST" | "HEAD" | "TRACE", that is, the HTTP method.
764
765         absolute_uri:
766           If  the request is an HTTP/1.1 request, the URI can be in the abso‐
767           lute URI format. In that case, httpd saves the absolute URI in this
768           field.   An   Example   of   an  absolute  URI  is  "http://Server
769           Name:Part/cgi-bin/find.pl?person=jocke"
770
771         request_uri:
772           The Request-URI  as  defined  in  RFC  1945,  for  example,  "/cgi-
773           bin/find.pl?person=jocke".
774
775         http_version:
776           The   HTTP   version  of  the  request,  that  is,  "HTTP/1.0",  or
777           "HTTP/1.1".
778
779         request_line:
780           The Request-Line as defined inRFC 1945,  for  example,  "GET  /cgi-
781           bin/find.pl?person=jocke HTTP/1.0".
782
783         parsed_header:
784           Type  [{HeaderKey,HeaderValue}].  parsed_header  contains  all HTTP
785           header fields from the HTTP request stored in a list  as  key-value
786           tuples.  See RFC 2616 for a listing of all header fields. For exam‐
787           ple, the date field is stored as {"date","Wed, 15 Oct 1997 14:35:17
788           GMT"}.  RFC  2616  defines that HTTP is a case-insensitive protocol
789           and the header fields can be in lower case or upper case. httpd en‐
790           sures that all header field names are in lower case.
791
792         entity_body:
793           The entity-Body as defined in RFC 2616, for example, data sent from
794           a CGI script using the POST method.
795
796         connection:
797           true | false. If set to true, the connection to  the  client  is  a
798           persistent connection and is not closed when the request is served.
799

ERLANG WEB SERVER API CALLBACK FUNCTIONS

EXPORTS

802       Module:do(ModData)->  {proceed, OldData} | {proceed, NewData} | {break,
803       NewData} | done
804
805              Types:
806
807                 OldData = list()
808                 NewData = [{response,{StatusCode,Body}}]
809                 | [{response,{response,Head,Body}}]
810                 | [{response,{already_sent,Statuscode,Size}}]
811                 StatusCode = integer()
812                 Body = io_list() | nobody | {Fun, Arg}
813                 Head = [HeaderOption]
814                 HeaderOption = {Option, Value} | {code, StatusCode}
815                 Option = accept_ranges | allow
816                 | cache_control | content_MD5
817                 | content_encoding | content_language
818                 | content_length | content_location
819                 | content_range | content_type | date
820                 | etag | expires | last_modified
821                 | location | pragma | retry_after
822                 | server | trailer | transfer_encoding
823                 Value = string()
824                 Fun = fun( Arg ) -> sent| close | Body
825                 Arg = [term()]
826
827              When a valid request reaches httpd, it calls do/1 in  each  mod‐
828              ule, defined by the configuration option of Module. The function
829              can generate data for other modules or a response  that  can  be
830              sent back to the client.
831
832              The  field  data in ModData is a list. This list is the list re‐
833              turned from the last call to do/1.
834
835              Body is the body of the HTTP response that is sent back  to  the
836              client.  An  appropriate header is appended to the message. Sta‐
837              tusCode is the status code of the response, see RFC 2616 for the
838              appropriate values.
839
840              Head  is a key value list of HTTP header fields. The server con‐
841              structs an HTTP header from this data. See RFC 2616 for the  ap‐
842              propriate  value  for  each  header  field.  If the client is an
843              HTTP/1.0 client, the  server  filters  the  list  so  that  only
844              HTTP/1.0 header fields are sent back to the client.
845
846              If Body is returned and equal to {Fun,Arg}, the web server tries
847              apply/2 on Fun with Arg as argument. The web server expects that
848              the  fun  either returns a list (Body) that is an HTTP response,
849              or the atom sent if the  HTTP  response  is  sent  back  to  the
850              client.  If  close  is returned from the fun, something has gone
851              wrong and the server signals this to the client by  closing  the
852              connection.
853
854       Module:remove(ConfigDB) -> ok | {error, Reason}
855
856              Types:
857
858                 ConfigDB = ets_table()
859                 Reason = term()
860
861              When  httpd  is  shut down, it tries to execute remove/1 in each
862              Erlang web server callback module. The programmer can  use  this
863              function to clean up resources created in the store function.
864
865       Module:store({Option, Value}, Config)-> {ok, {Option, NewValue}} | {er‐
866       ror, Reason}
867
868              Types:
869
870                 Line = string()
871                 Option = property()
872                 Config = [{Option, Value}]
873                 Value = term()
874                 Reason = term()
875
876              Checks the validity of the configuration options  before  saving
877              them  in  the  internal  database. This function can also have a
878              side effect, that is, setup of necessary extra resources implied
879              by the configuration option. It can also resolve possible depen‐
880              dencies among configuration options by changing the value of the
881              option.  This function only needs clauses for the options imple‐
882              mented by this particular callback module.
883

ERLANG WEB SERVER API HELP FUNCTIONS

EXPORTS

886       parse_query(QueryString) -> [{Key,Value}]
887
888              Types:
889
890                 QueryString = string()
891                 Key = string()
892                 Value = string()
893
894              parse_query/1 parses incoming data to erl and eval scripts  (see
895              mod_esi(3))  as defined in the standard URL format, that is, '+'
896              becomes 'space' and decoding of hexadecimal characters (%xx).
897

SEE ALSO

899       RFC 2616, inets(3), ssl(3)
900
901
902
903Ericsson AB                       inets 7.5.3                         httpd(3)
Impressum