CHANGES revision 1.40
11.40Smrg$NetBSD: CHANGES,v 1.40 2019/02/28 09:16:42 mrg Exp $
21.37Smrg
31.40Smrgchanges in bozohttpd 20190228:
41.40Smrg	o  extend timeout facility to ssl and stop servers hanging forever
51.40Smrg	   if the client never sends anything.  reported by Steffen in netbsd
61.40Smrg	   PR#50655.
71.37Smrg	o  don't display special files in the directory index.  they aren't
81.37Smrg	   served, but links to them are generated.
91.36Smrg	o  fix CGI '+' parameter handling, some error checking, and a double
101.36Smrg	   free.  from rajeev_v_pillai@yahoo.com
111.36Smrg	o  more directory indexing clean up.  from rajeev_v_pillai@yahoo.com
121.32Sleot
131.32Sleotchanges in bozohttpd 20181215:
141.34Smrg	o  fix .htpasswd bypass for authenticated users.  reported by JP,
151.32Sleot	   from leot@netbsd.org
161.32Sleot	o  avoid possible null dereference when receiving a big request that
171.32Sleot	   timeout.  reported by maya@netbsd.org, from leot@netbsd.org
181.32Sleot	o  fix handling of -T option, from leot@netbsd.org
191.32Sleot	o  cleanups and portability improvements, from maya@netbsd.org
201.33Smrg	o  change directory indexing to use html tables, from
211.31Smrg	   rajeev_v_pillai@yahoo.com
221.29Smrg
231.29Smrgchanges in bozohttpd 20181125:
241.30Smrg	o  fixes for option parsing introduced in bozohttpd 20181123
251.26Smrg
261.28Smrgchanges in bozohttpd 20181121:
271.26Smrg	o  add url remap support via .bzremap file, from martin@netbsd.org
281.26Smrg	o  handle redirections for any protocol, not just http:
291.26Smrg	o  fix a denial of service attack against header contents, which
301.27Smrg	   is now bounded at 16KiB.  reported by JP
311.27Smrg	o  reduce default timeouts, and add expand timeouts to handle the
321.27Smrg	   initial line, each header, and the total time spent
331.27Smrg	o  add -T option to expose new timeout settings
341.27Smrg	o  minor RFC fixes related to timeout handling
351.30Smrg	o  fix special file (.htpasswd, .bz*) bypass.  reported by JP
361.25Smrg
371.25Smrgchanges in bozohttpd 20170201:
381.25Smrg	o  fix an infinite loop in cgi processing
391.25Smrg	o  fixes and clean up for the testsuite
401.25Smrg	o  no longer sends encoding header for compressed formats
411.11Smrg
421.23Sagcchanges in bozohttpd 20160517:
431.25Smrg	o  add a bozo_get_version() function which returns the version number
441.23Sagc
451.22Smrgchanges in bozohttpd 20160415:
461.22Smrg	o  add search-word support for CGI
471.22Smrg	o  fix a security issue in CGI suffix handler support which would
481.22Smrg	   allow remote code execution, from shm@netbsd.org
491.22Smrg	o  -C option supports now CGI scripts only
501.22Smrg
511.21Sshmchanges in bozohttpd 20151028:
521.21Sshm	o  add CGI support for ~user translation (-E switch)
531.21Sshm	o  add redirects to ~user translation
541.21Sshm	o  fix bugs around ~user translation
551.21Sshm	o  add schema detection for absolute redirects
561.21Sshm	o  fixed few memory leaks
571.21Sshm	o  bunch of minor tweaks
581.21Sshm	o  removed -r support
591.21Sshm	o  smarter redirects 
601.21Sshm
611.20Smrgchanges in bozohttpd 20150320:
621.20Smrg	o  fix redirection handling
631.20Smrg	o  support transport stream (.ts) and video object (.vob) files
641.20Smrg	o  directory listings show correct file sizes for large files
651.20Smrg
661.19Smrgchanges in bozohttpd 20140717:
671.20Smrg	o  properly handle SSL errors
681.19Smrg
691.18Smrgchanges in bozohttpd 20140708:
701.18Smrg	o  fixes for virtual host support, from rajeev_v_pillai@yahoo.com
711.18Smrg	o  avoid printing double errors, from shm@netbsd.org
721.18Smrg	o  fix a security issue in basic HTTP authentication which would allow
731.18Smrg	   authentication to be bypassed, from shm@netbsd.org
741.18Smrg
751.15Smrgchanges in bozohttpd 20140201:
761.16Smrg	o  support .svg files
771.15Smrg	o  fix a core dump when requests timeout
781.15Smrg
791.15Smrgchanges in bozohttpd 20140102:
801.14Smrg	o  update a few content types
811.14Smrg	o  add support for directly calling lua scripts to handle
821.14Smrg	   processes, from mbalmer@netbsd.org
831.13Smrg	o  properly escape generated HTML
841.13Smrg	o  add authentication for redirections, from martin@netbsd.org
851.13Smrg	o  handle chained ssl certifications, from elric@netbsd.org
861.13Smrg	o  add basic support for gzipped files, from elric@netbsd.org
871.12Smrg	o  properly escape generated URIs
881.12Smrg
891.15Smrgchanges in bozohttpd 20111118:
901.11Smrg	o  add -P <pidfile> option, from jmmv@netbsd.org
911.11Smrg	o  avoid crashes with http basic auth, from pooka@netbsd.org
921.11Smrg	o  add support for REDIRECT_STATUS variable, from tls@netbsd.org
931.11Smrg	o  support .mp4 files in the default map
941.11Smrg	o  directory indexes with files with : are now displayed properly, from
951.11Smrg	   reed@netbsd.org
961.11Smrg	o  allow -I option to be useful in non-inetd mode as well
971.9Smrg
981.15Smrgchanges in bozohttpd 20100920:
991.9Smrg	o  properly fully disable multi-file mode for now
1001.9Smrg	o  fix the -t and -U options when used without the -e option, broken since
1011.9Smrg	   the library-ifcation
1021.9Smrg	o  be explicit that logs go to the FTP facility in syslog
1031.10Smrg	o  use scandir() with alphasort() for sorted directory lists, from moof
1041.10Smrg	o  fix a serious error in vhost handling; "Host:.." would allow access to
1051.10Smrg	   the next level directory from the virtual root directory, from seanb
1061.10Smrg	o  fix some various non standard compile time errors, from rudolf
1071.10Smrg	o  fix dynamic CGI content maps, from rudolf
1081.7Smrg
1091.15Smrgchanges in bozohttpd 20100617:
1101.7Smrg	o  fix some compile issues
1111.8Smrg	o  fix SSL mode.  from rtr
1121.8Smrg	o  fix some cgi-bin issues, as seen with cvsweb
1131.8Smrg	o  disable multi-file daemon mode for now, it breaks
1141.8Smrg	o  return 404's instead of 403's when chdir of ~user dirs fail
1151.8Smrg	o  remove "noreturn" attribute from bozo_http_error() that was
1161.8Smrg	   causing incorrect runtime behaviour
1171.6Smrg
1181.15Smrgchanges in bozohttpd 20100509:
1191.6Smrg	o  major rework and clean up of internal interfaces.  move the main
1201.30Smrg	   program into main.c, the remaining parts are useable as library
1211.6Smrg	   add bindings for lua.  by Alistair G. Crooks <agc@netbsd.org>
1221.6Smrg	o  fix http://bugs.debian.org/cgi-bin/bugreport.cgi?bug=566325
1231.4Smrg
1241.15Smrgchanges in bozohttpd 20090522:
1251.4Smrg	o  avoid dying in daemon mode for some uncommon, but recoverable, errors
1261.4Smrg	o  close leaking file descriptors for CGI and daemon mode
1271.4Smrg	o  handle poll errors properly
1281.4Smrg	o  don't try to handle more than one request per process yet
1291.5Smrg	o  add subdirs for build "debug" and "small" versions
1301.5Smrg	o  clean up a bad merge / duplicate code
1311.5Smrg	o  make mmap() usage portable, fixes linux & ranges: support
1321.5Smrg	o  document the -f option
1331.5Smrg	o  daemon mode now serves 6 files per child
1341.3Smrg
1351.15Smrgchanges in bozohttpd 20090417:
1361.3Smrg	o  make bozohttpd internally more modular, preparing the way
1371.3Smrg	   to handle more than one request per process
1381.3Smrg	o  fix http-auth, set $REMOTE_USER not $REMOTEUSER.  also fix
1391.3Smrg	   cgi-bin with cvsweb, from Holger Weiss <holger@CIS.FU-Berlin.DE>
1401.3Smrg	o  fix an uninitialised variable use in daemon mode
1411.3Smrg	o  fix ssl mode with newer OpenSSL
1421.3Smrg	o  mmap large files in manageable sizes so we can serve any size file
1431.3Smrg	o  refactor url processing to handle query strings correctly for CGI
1441.3Smrg	   from Sergey Katsev at Coyote Point
1451.3Smrg	o  add If-Modified-Since support, from Joerg Sonnenberger
1461.3Smrg	   <joerg@netbsd.org>
1471.3Smrg	o  many more manual fixes, from NetBSD
1481.3Smrg
1491.15Smrgchanges in bozohttpd 20080303:
1501.3Smrg	o  fix some cgi header processing, from <thelsdj@gmail.com>
1511.3Smrg	o  add simple Range: header processing, from <bad@bsd.de>
1521.3Smrg	o  man page fixes, from NetBSD
1531.3Smrg	o  clean up various parts, from NetBSD
1541.3Smrg
1551.15Smrgchanges in bozohttpd 20060710:
1561.3Smrg	o  prefix some function names with "bozo"
1571.3Smrg	o  align directory indexing <hr> markers
1581.3Smrg	o  clean up some code GCC4 grumbled about
1591.1Stls
1601.15Smrgchanges in bozohttpd 20060517:
1611.1Stls	o  don't allow "/.." or "../" files
1621.1Stls	o  don't write ":80" into urls for the http port
1631.1Stls	o  fix a fd leak when fork() fails
1641.1Stls	o  make directory indexing mode not look so ugly
1651.1Stls	o  build a text version of the manual page
1661.1Stls	o  make "make clean" work properly
1671.1Stls
1681.15Smrgchanges in bozohttpd 20050410:
1691.1Stls	o  fix some off-by-one errors from <roland.illig@gmx.de>
1701.1Stls	o  properly support nph- CGI
1711.1Stls	o  make content maps case insensitive
1721.1Stls	o  fix proto header merging to include the missing comma
1731.1Stls	o  major source reorganisation; most features are in separate files now
1741.1Stls	o  new -V flag that makes unknown virtualhosts use slashdir
1751.1Stls	   from <rumble@ephemeral.org>
1761.1Stls	o  HTTP/1.x protocol headers are now properly merged for CGI
1771.1Stls
1781.15Smrgchanges in bozohttpd 20040808:
1791.1Stls	o  CGI status is now properly handled (-a flag has been removed)
1801.1Stls	o  CGI file upload support works
1811.1Stls	o  %xy translations are no longer ever applied after the first '?',
1821.1Stls	   ala RFC2396.  from lukem
1831.1Stls	o  daemon mode (-b) should no longer hang spinning forever if it
1841.1Stls	   sees no children.  from lukem
1851.1Stls	o  new .bzabsredirect file support. from <martin@netbsd.org>
1861.1Stls	o  return a 404 error if we see %00 or %2f (/)
1871.1Stls	o  don't print 2 "200" headers for CGI
1881.1Stls	o  support .torrent files
1891.1Stls
1901.15Smrgchanges in bozohttpd 20040218:
1911.1Stls	o  new .bzredirect file support for sane directory redirection
1921.1Stls	o  new -Z option that enables SSL mode, from <rtr@eterna.com.au>
1931.1Stls	o  the -C option has been changed to take two explicit options, rather
1941.1Stls	   than a single option with a space separating the suffix and the
1951.1Stls	   interpreter.  ``-C ".foo /path/to/bar"'' should now be written
1961.1Stls	   as ``-C .foo /path/to/bar''
1971.1Stls	o  the -M option has been changed like -C and no longer requires or
1981.1Stls	   supports a single argument with space-separated options
1991.1Stls	o  with -a, still print the 200 OK.  from <rtr@eterna.com.au>
2001.1Stls	o  with -r, if a .bzdirect file appears in a directory, allow direct
2011.1Stls	   access to this directory
2021.1Stls
2031.15Smrgchanges in bozohttpd 20031005:
2041.1Stls	o  fixes for basic authorisation.  from <ecu@ipv42.net>
2051.1Stls	o  always display file size in directory index mode
2061.1Stls	o  add .xbel, .xml & .xsl -> text/xml mappings.  from
2071.1Stls	   <wiz@danbala.ifoer.tuwien.ac.at>
2081.1Stls
2091.15Smrgchanges in bozohttpd 20030626:
2101.1Stls	o  fix a recent core dump when given no input
2111.1Stls	o  add new -r flag that ensures referrer is set to this host
2121.1Stls	o  fix several compile time errors with -DNO_CGIBIN_SUPPORT
2131.1Stls	o  fix some man page details. from lukem@wasabisystems.com
2141.1Stls	o  re-add a missing memset(), fixing a core dump. from lukem
2151.1Stls	o  support HTTP basic authorisation, disabled by default.  from lukem
2161.1Stls	o  print the port number in redirects and errors. from lukem
2171.1Stls	o  only syslog the basename of the program. from lukem
2181.1Stls	o  add __attribute__() format checking. from lukem
2191.1Stls	o  fix cgibin SCRIPT_NAME to have a leading /.  from zakj@nox.cx
2201.1Stls	o  simplify some code in -C to avoid a core dump.  from lukem
2211.1Stls	o  add a .css -> css/text entry to the content_map[].  from zakj@nox.cx
2221.1Stls
2231.15Smrgchanges in bozohttpd 20030409:
2241.1Stls	o  -d without DEBUG enabled only prints one warning and continues
2251.1Stls	o  one can now define the C macro SERVER_SOFTWARE when building to
2261.1Stls	   change the Server: header and CGI variable of the same name
2271.1Stls	o  add new -s flag the force logging output to stderr. from zakj@nox.cx
2281.1Stls	o  add new -a flag for CGI bin that stops bozohttpd from outputting
2291.1Stls	   any HTTP reply, the CGI program must output these.  from zakj@nox.cx
2301.1Stls	o  new REQUEST_URI and DATE_GMT environment variables for CGI.  from
2311.1Stls	   zakj@nox.cx
2321.1Stls	o  add a "Makefile.boot" that should work with any make program
2331.1Stls	o  build on linux again
2341.1Stls	o  fix core dumps when using -C
2351.1Stls
2361.15Smrgchanges in bozohttpd 20030313:
2371.1Stls	o  deprecate -r flag; make this the default and silently ignore -r now
2381.1Stls	o  add support for file extentions to call CGI programs (from lukem)
2391.1Stls	o  add dynamic support to add new content map entries, allowing both
2401.1Stls	   new file types and non /cgi-bin CGI programs to be run with the
2411.1Stls	   new -C "suffix cgihandler" and -M "suffix type encoding encoding11"
2421.1Stls	   options
2431.1Stls	o  in -b mode, set the http date after accept() returns, not before we
2441.1Stls	   call accept()
2451.1Stls	o  in -b mode, bind all addresses found not just the first one
2461.1Stls	o  unsupport old hostname API
2471.1Stls	o  in -b mode, set the SO_REUSEADDR socket option (lukem)
2481.1Stls	o  allow -x (index.html) mode to work with CGI handlers
2491.1Stls
2501.15Smrgchanges in bozohttpd 20021106:
2511.1Stls	o  add .bz2 support
2521.1Stls	o  properly escape <, > and & in error messages, partly from
2531.1Stls	   Nicolas Jombart <ecu@mariejeanne.net>
2541.1Stls	o  new -H flag to hide .* files in directory index mode
2551.1Stls	o  fix buffer reallocation when parsing a request, to avoid
2561.1Stls	   overflowing the buffer with carriage returns (\r)
2571.1Stls	o  do not decode "%XY"-style cgi-bin data beyond the "?"
2581.1Stls
2591.15Smrgchanges in bozohttpd 5.15 (20020913):
2601.1Stls	o  add .ogg support -> `application/x-ogg'
2611.1Stls	o  fix CGI requests with "/" in the query part
2621.1Stls
2631.15Smrgchanges in bozohttpd 5.14 (20020823):
2641.1Stls	o  allow -X mode to work for "/"
2651.1Stls	o  work on systems without MADV_SEQUENTIAL
2661.1Stls	o  make a local cut-down copy of "queue.h" (fixes linux & solaris
2671.1Stls	   support at the very least)
2681.1Stls	o  portability fixes for pre-ipv6 socket api systems (eg, solaris 7)
2691.1Stls	o  portability fixes for missing _PATH_DEFPATH, LOG_FTP and __progname
2701.1Stls	o  better documentation on virtual host support
2711.1Stls
2721.15Smrgchanges in bozohttpd 5.13 (20020804):
2731.1Stls	o  support .mp3 files (type audio/mpeg)
2741.1Stls	o  use stat() to find out if something is a directory, for -X mode
2751.1Stls
2761.15Smrgchanges in bozohttpd 5.12 (20020803):
2771.1Stls	o  constification
2781.1Stls	o  fixes & enhancements for directory index mode (-X)
2791.1Stls
2801.15Smrgchanges in bozohttpd 5.11 (20020730):
2811.1Stls	o  more man page fixes from Thomas Klausner
2821.1Stls	   <wiz@danbala.ifoer.tuwien.ac.at>
2831.1Stls	o  de-K&R C-ification
2841.1Stls	o  fix Date: header for daemon mode
2851.1Stls	o  fix core dump when asking for /cgi-bin/ when CGI isn't configured
2861.1Stls	o  use a valid Server: header
2871.1Stls
2881.15Smrgchanges in bozohttpd 5.10 (20020710):
2891.1Stls	- add freebsd support 
2901.1Stls	- fix a couple of header typos
2911.1Stls	- many cgi-bin fixes from lukem@netbsd.org
2921.1Stls	- add -T chrootdir and -U user, plus several minor other cleanups
2931.1Stls	with signals and return values.  from xs@kittenz.org
2941.1Stls	- add -e that does not clear the environment for -T/-U
2951.1Stls	- fix a formatting error noticed by ISIHARA Takanori <ishit@oak.dti.ne.jp>
2961.1Stls
2971.15Smrgchanges in bozohttpd 5.09 (20010922):
2981.1Stls	- add a daemon mode
2991.1Stls	- document how to use bozohttpd in netbsd inetd with more than 40 
3001.1Stls	connections per minute and also with cgibin
3011.1Stls	- man page fixes from wiz@netbsd.org
3021.1Stls
3031.15Smrgchanges in bozohttpd 5.08 (20010812):
3041.1Stls	- add directory index generation support (-X) from ad@netbsd.org
3051.1Stls	- add .pa as an alias for .pac
3061.1Stls	- make server software version configurable (RFC)
3071.1Stls
3081.15Smrgchanges in bozohttpd 5.07 (20010610):
3091.1Stls	- add .png support 
3101.1Stls	- new "-x index.html" flag to change default file
3111.1Stls	- new "-p public_html" flag to change default ~user directory
3121.1Stls	- fixes cgi-bin support and more from chuck@research.att.com
3131.1Stls	- add many new content-types, now support most common ones
3141.1Stls
3151.15Smrgchanges in bozohttpd 5.06 (20000825):
3161.33Smrg	- add IPv6 support from itojun@iijlab.net
3171.1Stls	- man page fixes from jlam@netbsd.org
3181.1Stls
3191.15Smrgchanges in bozohttpd 5.05 (20000815):
3201.1Stls	- fix a virtual host bug, from kleink@netbsd.org
3211.1Stls
3221.15Smrgchanges in bozohttpd 5.04 (20000427):
3231.1Stls	- fix virtual host support; URI takes precedence over Host:
3241.1Stls
3251.15Smrgchanges in bozohttpd 5.03 (20000427):
3261.1Stls	- fix a bug with chdir() 
3271.1Stls
3281.15Smrgchanges in bozohttpd 5.02 (20000426):
3291.1Stls	- .pac spport from simonb
3301.1Stls
3311.15Smrgchanges in bozohttpd 5.01 (20000421):
3321.1Stls	- .swf support 
3331.1Stls	- virtual hosting support 
334