3 Better pathname validation.
4 A couple of small fixes.
8 Support listening on random port number (Lucien Pullen)
12 Compare on the path-string. (matthieupeeters)
13 speed up shutdown and avoid timeout on the listening socket (Felix Lange)
14 clarify definition of handler function (Robert Smith)
15 [doc] fix ID clash in index.xml (Alex Dunn)
19 Avoid double URL decoding, reported by muyinliu (Hans Huebner)
20 Remove a duplicate word in the documentation (William Halliburton)
21 Call convert-hack in name also (José Ronquillo Rivera)
25 decode URL considering content-type's charset (Tim Richardt)
29 Ignore malformed session IDs (Hans Huebner)
30 prevent failures when session cookie is malformed (Andrey Kutejko)
31 correct started-p for lispworks (LinkFly)
35 Adds the session-regenerate-cookie-value function (Florian Margaine)
36 Bugfix: using variables within with-accessors (Dmitry Igrishin)
37 Added Gitter link (The Gitter Badger)
38 Add "charset" property to Content-Type HTTP header (Dmitry Igrishin)
39 "Connection: close" on unthreaded builds (Philipp Marek)
40 Make the RFC 6585 status constants external (Grim Schjetne)
41 Add HTTP status codes described in RFC 6585 (Grim Schjetne)
42 Add charset to Content-Type when serving static (Dmitry Igrishin)
43 Fix to PROCESS-CONNECTION leaking socket fds (Jussi Lahdenniemi)
47 Adds HttpOnly and remove cookie on remove-session (Florian MARGAINE)
51 Clear content-length before emitting 304 (Jason Miller)
52 Treat errors during url decoding as bad requests. (Stas Boukarev)
56 temporarily revert ipv6 changes (Hans Huebner)
60 Remove dead links and update support information (Hans Huebner)
61 restore listening to usocket:*wildcard-host* (Hans Huebner)
62 deal with IPv6 addresses from usocket (Hans Huebner)
63 eliminate duplicate logging of warnings (reported by loke) (Hans Huebner)
64 add DETACH-SOCKET function (Hans Huebner)
65 Add the ability to prevent the sockets from being closed after a request has been processed. (Elias Mårtenson)
66 document *FINISH-PROCESSING-SOCKET* (Hans Huebner)
67 Make check for stream timeouts more robust (Raymond Wiker)
71 fix warning about missing NAME keyword arg at start-thread (Mark H. David)
72 remove tbnl-announce list (Hans Huebner)
73 correct speling eror (Hans Huebner)
74 Update request.lisp (muyinliu)
75 file upload file name encoding error fixed (muyinliu)
76 support use of logical file names for document-root and error-template-directory (Hans Huebner)
77 Generate www/hunchentoot-doc.html. (Stas Boukarev)
78 Remove mentions of asdf-install and the darcs mirror from docs. (Stas Boukarev)
82 Optimize get-peer/local-address-and-port. (Stas Boukarev)
83 Close SSL streams after processing connection. (Stas Boukarev)
87 allow for handler setting of the "connection" header (William Halliburton)
91 Use version number from ASDF system definition, not special var (Hans Huebner)
95 Don't set the Connection header to Close if it's already set (AndrejSuc/Stas Boukarev)
99 Print header value (if number) in base 10 (Chaitanya Gupta)
100 Fix for CLISP compilation (Anton Vodonosov)
104 Fix capitalization inconsistencies in docs (reported by Stas Boukarev)
108 Don't rely on asdf to find default document directory
109 Add m4v mime type (Wes Henderson)
113 Fix ACCEPTOR-REMOVE-SESSION default implementation (Stas Boukarev, Mathieu Lemoine)
117 Prevent errors when basic auth user or password contains colon
118 Add missing implementation for client-as-string for Lispworks, contributed by Raymond Wiker
122 New START-THREAD API function (Faré Rideau)
126 Fix bug that caused error when requesting nonexistent page.
130 Fix race condition in acceptor shutdown (Faré Rideau)
134 Call ACCEPTOR-STATUS-MESSAGE in a saner and more useful fashion (sponsored by Ron Garret)
138 fix wrong documented signature in acceptor-status-message (reported by Zach Beane)
142 Various documentation updates
143 Fix bug in static file handling that caused Safari to hang on 304 responses by Hunchentoot (reported by Wim Oudshoorn)
147 Fix bug in MD5-HEX that could cause session keys to be reused
151 Add local-addr* and local-port* functions
155 Fix test script to accomodate for Drakma fix regarding redirect from POST to GET
156 Fix range handling once again
160 ECL fixes (Juan Jose Giarcia-Ripoll)
164 Fix documentation for COOKIE-IN, which returns a string, not a cookie.
165 Hunchentoot could not deal with / pointing to a static file directory (Stas Boukarev).
166 Fixes to pathname sanitizing when handling static files.
167 Further Range: header handling fixes
168 Fix some export names relating to taskmaster thread count (Faré Rideau)
172 Doc fixes, add .pre-release.sh script
176 High-load multithread stability fixes (Mathieu Lemoine)
180 Remove dead code & style fixes (Ala'a Mohammad)
181 Bug fix: setting *print-base* / *print-radix* caused invalid cookie values (Scott L. Burson)
182 Various documentation and style updates
183 Fix documentation bug found (Mathieu Lemoine)
184 Fix bug that could hang Hunchentoot under load (Mathieu Lemoine)
188 Fix crash when error occurs while logging error (reported by Xu Jingtao)
189 Fix compilation with :hunchentoot-no-ssl feature (Mark Evenson)
190 Fix Range header handling (Simon Sandlund)
191 Export acceptor-remove-session
192 ECL timeout support (Juan Jose Giarcia-Ripoll)
193 Changed cookie handling - Hunchentoot no longer encodes cookies
194 automatically. Applications must make sure that they only set cookies
195 to permitted values (refer to RFC6265 for the details, thanks to Ralf
196 Stoye for debugging help)
200 Fix warning on LispWorks (Nico de Jager)
201 Documentation updates
202 Remove obsolete symbols from export list
203 Add easy-ssl-acceptor
204 Document acceptor-remove-session, remove obsolete *session-removal-hook* export (Issue #15)
205 Added :description to asdf system definition
206 Add documentation section describing how to bind to privileged ports
210 Use FINISH-OUTPUT instead of FORCE-OUTPUT at connection end (I. Perminov)
211 Documentation updates
212 External format EOL style fixes for Windows (Anton Kovalenko)
216 Fix to allow send-service-unavailable-reply to work (Faré Rideau)
217 Make sure we always have a cooked message to send in case of error (Faré Rideau)
218 Add www/ directory with default file tree that is being served
219 Add error template mechanism and improve error reporting in general.
220 Improve automatic testing, SBCL kludge to support asdf:test-op
221 Allegro CL modern mode fixes
222 Fix bugs in serving partial responses
223 Limit maximum number of threads that Hunchentoot creates (Dan Weinreb, Scott McKay)
224 Export fixes (Gordon Sims, Andrey Moskvitin, Faré Rideau)
225 Factor out easy-handler logic into separate acceptor subclass
226 Export two session functions (Nico de Jager)
227 Allow no Content-Type header (Chaitanya Gupta)
228 Patch for compilation with ECL (Sohail Somani)
229 Fix DEFINE-EASY-HANDLER for multiple acceptors (Nicolas Neuss)
230 Revived *SHOW-LISP-BACKTRACES-P*
231 Made sure "100 Continue" is returned even if the client sends "Expect: 100-continue" twice (reported by Gordon Sims)
232 Fixed typo in code which interprets transfer encodings
236 Exported WITHIN-REQUEST-P (Faré Rideau)
237 Safeguard measures against XSS attacks (J.P. Larocque)
238 Prevent potential leak when closing stream (Matt Lamari, Martin Simmons)
239 Change some occurrences of HANDLER-CASE* to HANDLER-CASE (Hans Hübner, Allan Dee)
243 Architectural changes - see HANDLE-REQUEST (thanks to Andreas Fuchs and Frode Fjeld)
244 Re-introduced *CATCH-ERRORS-P* and MAYBE-INVOKE-DEBUGGER
245 Integration with trivial-backtrace (see *LOG-LISP-BACKTRACES-P*)
246 Treat :UNSPECIFIC like NIL in pathname components (reported by Frode Fjeld)
248 Prepared for LispWorks 6 (Nico de Jager)
249 Fixed reading of post parameters (Peter Seibel and Stephen P. Compall)
250 Fixed STOP by supplying the :READY-ONLY keyword to USOCKET:WAIT-FOR-INPUT
251 Enabled SSL key passwords for Lisps other than LW (Vsevolod)
255 Complete architectural redesign (together with Hans Hübner)
256 Lots of small fixes and improvements, too many to enumerate here
260 Fixed embarrassingly mis-placed parentheses (thanks to Hans Hübner)
264 Removed FORCE-OUTPUT* and thus the ACL-COMPAT dependency (thanks to Hans Hübner)
265 Support for MP-less CMUCL (thanks to Hans Hübner)
269 Fixed unportable LOOP usage (caught by "C S S")
273 Added CODE parameter to REDIRECT (thanks to Michael Weber)
277 Fixed typo in test.lisp (thanks to Ben Hyde)
278 Changed wrong usage of EQ to EQL (thanks to Ariel Badichi)
279 Fixed typo in default handler (thanks to Eugene Ossintsev)
283 Uses CL-FAD for HANDLE-STATIC-FILE now
284 Better error reporting for CREATE-FOLDER-DISPATCHER-AND-HANDLER (suggested by Cyrus Harmon)
285 Faster version of WRITE-HEADER-LINE (thanks to V. Segu�)
289 Added support for CLISP (thanks to Anton Vodonosov)
293 Replace ENOUGH-NAMESTRING with ENOUGH-URL (patch by Kilian Sprotte and Hans Hübner)
297 Fix compilation order (thanks to Tiarnan O'Corrain and Chris Dean)
301 Robustified MAKE-SOCKET-STREAM against potential leak (thanks to Alain Picard)
302 Replaced #-FOO #-FOO constructs for OpenMCL (patch by Michael Weber)
303 Updated tutorial links
307 Made log stream shared on OpenMCL (thanks to Gary Byers)
311 Enabled GET-GID-FROM-NAME for newer versions of SBCL (patch by Cyrus Harmon)
315 Better handling of PORT parameter in REDIRECT (thanks to Vladimir Sedach)
319 Fixed bug where you couldn't set "Server" header (caught by Ralf Mattes)
320 Documentation clarification for HEADER-OUT function
324 Added support for "HttpOnly" cookie attribute
328 Added *METHODS-FOR-POST-PARAMETERS* (suggested by Jonathon McKitrick)
332 Better support for WITH-TIMEOUT on SBCL/Win32 (thanks to Anton Vodonosov)
336 Now uses bound for flexi stream returned by RAW-POST-DATA
337 Needs FLEXI-STREAMS 0.12.0 or higher
342 Added declaration in server.lisp to appease SBCL
346 Fixes for OpenMCL (thanks to Lennart Staflin and Tiarnan O'Corrain)
350 Added server names and coupled them with easy handlers (suggested by Mac Chan)
351 Exported SESSION-COOKIE-VALUE instead of SESSION-STRING (suggested by Slava Akhmechet)
352 Documentation fixes (thanks to Victor Kryukov and Igor Plekhov)
356 Made MAYBE-INVOKE-DEBUGGER a generic function and exported it (suggested by Vladimir Sedach)
360 Fixed CREATE-FOLDER-DISPATCHER-AND-HANDLER in the presence of URL-encoded URLs (bug caught by Nicolas Lamirault)
364 Made DEF-HTTP-RETURN-CODE more flexible (suggested by Jong-won Choi)
368 Added PORT parameter to REDIRECT (suggested by Cyrus Harmon)
369 Exported REMOVE-SESSION (suggested by Vamsee Kanakala)
373 Added socket timeouts for AllegroCL
374 Catch IO timeout conditions for AllegroCL, SBCL and CMUCL (suggested by Red Daly and others)
375 Added per-server dispatch tables (suggested by Robert Synnott and Andrei Stebakov)
379 USE the CL package explicitly when defining HUNCHENTOOT-MP (bug report by Joel Boehland)
383 Correct behaviour for "100 Continue" responses
391 Don't use chunked encoding for empty (NIL) bodies
395 Really exported REASON-PHRASE this time (and also *CURRENT-PROCESS*)
399 Added HUNCHENTOOT-MP package (suggested by Cyrus Harmon)
400 Only invoke MARK-AND-SWEEP for 32-bit versions of LW (thanks to Chris Dean)
401 Exported REASON-PHRASE
405 Added *APPROVED-RETURN-CODES*, *HEADER-STREAM*, and +HTTP-FAILED-DEPENDENCY+
406 Exported MIME-TYPE and SSL-P
411 Added +HTTP-MULTI-STATUS+
415 Fix test suite to properly handle non-base characters in LW (bug caught by Jong-won Choi)
419 Fixed last change (thanks to Marko Kocic)
423 Development port (no threads) to SBCL/Win32 (patch by Marko Kocic)
424 Support for compilation without SSL
428 Don't use NSTRING-UPCASE for outgoing headers (bug caught by Saurabh Nanda)
429 Changed ProxyPass example in docs from /lisp to /hunchentoot
433 Reset to "faithful" external format on each iteration (bug caught by Viljo Marrandi and Ury Marshak)
437 Accept chunked transfer encoding for mod_lisp request bodies (thanks to Hugh Winkler's mod_lisp additions)
438 Robustify against erroneous form-data submissions (caught by Ury Marshak)
442 Even more flexible behaviour of RAW-POST-DATA
446 More flexible behaviour of RAW-POST-DATA
447 Robustified PARSE-CONTENT-TYPE
451 More meaningful results for RAW-POST-DATA
455 Added favicon.ico to example website (thanks to Yoni Rabkin Katzenell, Toby, and Uwe von Loh)
459 Added Hunchentoot logo by Uwe von Loh
463 Exported symbols related to session GC (suggested by Nico de Jager)
467 Added *HANDLE-HTTP-ERRORS-P* (thanks to Marijn Haverbeke)
468 Remove duplicate headers when reading from mod_lisp
472 Fixed HEADER-OUT (thanks to Robert J. Macomber)
476 Fixed bug in START-OUTPUT which confused mod_lisp
480 Changed behaviour of REAL-REMOTE-ADDR (as suggested by Robert J. Macomber)
481 Fixed COOKIE-OUT (thanks to Robert J. Macomber)
485 Don't bind *DISPATCH-TABLE* too early (thanks to Marijn Haverbeke)
489 Fixed bug in AUTHORIZATION function (reported by Michael J. Forster)
493 Correct SSL check in REDIRECT function
494 LOG-MESSAGE now checks for (BOUNDP '*SERVER*)
498 OpenMCL fixes (by Ralf Stoye)
502 No timeouts for mod_lisp servers (as in Hunchentoot 0.3.x)
506 Fixed a typo in easy-handlers.lisp (caught by Travis Cross)
510 Ported to CMUCL, SBCL, OpenMCL, and AllegroCL
512 Tons of small changes, too many to list them individually
516 Uses TBNL's WITH-DEBUGGER now
520 Added *CATCH-ERRORS-P* (from TBNL)
524 Accept HTTP requests with chunked transfer encoding
525 Use Chunga for chunking
529 Skip START-OUTPUT advice completely if working for TBNL
533 Added write timeouts for LW 5.0
534 Updated LW links in documentation
538 Serves as infrastructure for TBNL now (to replace KMRCL)
539 For HTTP/1.1 only send 'Keep-Alive' headers if explicitly requested
543 Connection headers are separated by commas, not semicolons
547 Refactored streams.lisp to appease LW compiler (thanks to Martin Simmons)
548 Changed handling of version string
549 Changed package handling in system definition (thanks to Christophe Rhodes)
553 Removed KMRCL workaround
557 Mention TBNL version number in server name header
561 Fixed package stuff and HYPERDOC support
565 Initial public release
567 [For earlier changes see the file "CHANGELOG_TBNL" that is included with the release.]