9 Better pathname validation.
10 A couple of small fixes.
14 Support listening on random port number (Lucien Pullen)
18 Compare on the path-string. (matthieupeeters)
19 speed up shutdown and avoid timeout on the listening socket (Felix Lange)
20 clarify definition of handler function (Robert Smith)
21 [doc] fix ID clash in index.xml (Alex Dunn)
25 Avoid double URL decoding, reported by muyinliu (Hans Huebner)
26 Remove a duplicate word in the documentation (William Halliburton)
27 Call convert-hack in name also (José Ronquillo Rivera)
31 decode URL considering content-type's charset (Tim Richardt)
35 Ignore malformed session IDs (Hans Huebner)
36 prevent failures when session cookie is malformed (Andrey Kutejko)
37 correct started-p for lispworks (LinkFly)
41 Adds the session-regenerate-cookie-value function (Florian Margaine)
42 Bugfix: using variables within with-accessors (Dmitry Igrishin)
43 Added Gitter link (The Gitter Badger)
44 Add "charset" property to Content-Type HTTP header (Dmitry Igrishin)
45 "Connection: close" on unthreaded builds (Philipp Marek)
46 Make the RFC 6585 status constants external (Grim Schjetne)
47 Add HTTP status codes described in RFC 6585 (Grim Schjetne)
48 Add charset to Content-Type when serving static (Dmitry Igrishin)
49 Fix to PROCESS-CONNECTION leaking socket fds (Jussi Lahdenniemi)
53 Adds HttpOnly and remove cookie on remove-session (Florian MARGAINE)
57 Clear content-length before emitting 304 (Jason Miller)
58 Treat errors during url decoding as bad requests. (Stas Boukarev)
62 temporarily revert ipv6 changes (Hans Huebner)
66 Remove dead links and update support information (Hans Huebner)
67 restore listening to usocket:*wildcard-host* (Hans Huebner)
68 deal with IPv6 addresses from usocket (Hans Huebner)
69 eliminate duplicate logging of warnings (reported by loke) (Hans Huebner)
70 add DETACH-SOCKET function (Hans Huebner)
71 Add the ability to prevent the sockets from being closed after a request has been processed. (Elias Mårtenson)
72 document *FINISH-PROCESSING-SOCKET* (Hans Huebner)
73 Make check for stream timeouts more robust (Raymond Wiker)
77 fix warning about missing NAME keyword arg at start-thread (Mark H. David)
78 remove tbnl-announce list (Hans Huebner)
79 correct speling eror (Hans Huebner)
80 Update request.lisp (muyinliu)
81 file upload file name encoding error fixed (muyinliu)
82 support use of logical file names for document-root and error-template-directory (Hans Huebner)
83 Generate www/hunchentoot-doc.html. (Stas Boukarev)
84 Remove mentions of asdf-install and the darcs mirror from docs. (Stas Boukarev)
88 Optimize get-peer/local-address-and-port. (Stas Boukarev)
89 Close SSL streams after processing connection. (Stas Boukarev)
93 allow for handler setting of the "connection" header (William Halliburton)
97 Use version number from ASDF system definition, not special var (Hans Huebner)
101 Don't set the Connection header to Close if it's already set (AndrejSuc/Stas Boukarev)
105 Print header value (if number) in base 10 (Chaitanya Gupta)
106 Fix for CLISP compilation (Anton Vodonosov)
110 Fix capitalization inconsistencies in docs (reported by Stas Boukarev)
114 Don't rely on asdf to find default document directory
115 Add m4v mime type (Wes Henderson)
119 Fix ACCEPTOR-REMOVE-SESSION default implementation (Stas Boukarev, Mathieu Lemoine)
123 Prevent errors when basic auth user or password contains colon
124 Add missing implementation for client-as-string for Lispworks, contributed by Raymond Wiker
128 New START-THREAD API function (Faré Rideau)
132 Fix bug that caused error when requesting nonexistent page.
136 Fix race condition in acceptor shutdown (Faré Rideau)
140 Call ACCEPTOR-STATUS-MESSAGE in a saner and more useful fashion (sponsored by Ron Garret)
144 fix wrong documented signature in acceptor-status-message (reported by Zach Beane)
148 Various documentation updates
149 Fix bug in static file handling that caused Safari to hang on 304 responses by Hunchentoot (reported by Wim Oudshoorn)
153 Fix bug in MD5-HEX that could cause session keys to be reused
157 Add local-addr* and local-port* functions
161 Fix test script to accomodate for Drakma fix regarding redirect from POST to GET
162 Fix range handling once again
166 ECL fixes (Juan Jose Giarcia-Ripoll)
170 Fix documentation for COOKIE-IN, which returns a string, not a cookie.
171 Hunchentoot could not deal with / pointing to a static file directory (Stas Boukarev).
172 Fixes to pathname sanitizing when handling static files.
173 Further Range: header handling fixes
174 Fix some export names relating to taskmaster thread count (Faré Rideau)
178 Doc fixes, add .pre-release.sh script
182 High-load multithread stability fixes (Mathieu Lemoine)
186 Remove dead code & style fixes (Ala'a Mohammad)
187 Bug fix: setting *print-base* / *print-radix* caused invalid cookie values (Scott L. Burson)
188 Various documentation and style updates
189 Fix documentation bug found (Mathieu Lemoine)
190 Fix bug that could hang Hunchentoot under load (Mathieu Lemoine)
194 Fix crash when error occurs while logging error (reported by Xu Jingtao)
195 Fix compilation with :hunchentoot-no-ssl feature (Mark Evenson)
196 Fix Range header handling (Simon Sandlund)
197 Export acceptor-remove-session
198 ECL timeout support (Juan Jose Giarcia-Ripoll)
199 Changed cookie handling - Hunchentoot no longer encodes cookies
200 automatically. Applications must make sure that they only set cookies
201 to permitted values (refer to RFC6265 for the details, thanks to Ralf
202 Stoye for debugging help)
206 Fix warning on LispWorks (Nico de Jager)
207 Documentation updates
208 Remove obsolete symbols from export list
209 Add easy-ssl-acceptor
210 Document acceptor-remove-session, remove obsolete *session-removal-hook* export (Issue #15)
211 Added :description to asdf system definition
212 Add documentation section describing how to bind to privileged ports
216 Use FINISH-OUTPUT instead of FORCE-OUTPUT at connection end (I. Perminov)
217 Documentation updates
218 External format EOL style fixes for Windows (Anton Kovalenko)
222 Fix to allow send-service-unavailable-reply to work (Faré Rideau)
223 Make sure we always have a cooked message to send in case of error (Faré Rideau)
224 Add www/ directory with default file tree that is being served
225 Add error template mechanism and improve error reporting in general.
226 Improve automatic testing, SBCL kludge to support asdf:test-op
227 Allegro CL modern mode fixes
228 Fix bugs in serving partial responses
229 Limit maximum number of threads that Hunchentoot creates (Dan Weinreb, Scott McKay)
230 Export fixes (Gordon Sims, Andrey Moskvitin, Faré Rideau)
231 Factor out easy-handler logic into separate acceptor subclass
232 Export two session functions (Nico de Jager)
233 Allow no Content-Type header (Chaitanya Gupta)
234 Patch for compilation with ECL (Sohail Somani)
235 Fix DEFINE-EASY-HANDLER for multiple acceptors (Nicolas Neuss)
236 Revived *SHOW-LISP-BACKTRACES-P*
237 Made sure "100 Continue" is returned even if the client sends "Expect: 100-continue" twice (reported by Gordon Sims)
238 Fixed typo in code which interprets transfer encodings
242 Exported WITHIN-REQUEST-P (Faré Rideau)
243 Safeguard measures against XSS attacks (J.P. Larocque)
244 Prevent potential leak when closing stream (Matt Lamari, Martin Simmons)
245 Change some occurrences of HANDLER-CASE* to HANDLER-CASE (Hans Hübner, Allan Dee)
249 Architectural changes - see HANDLE-REQUEST (thanks to Andreas Fuchs and Frode Fjeld)
250 Re-introduced *CATCH-ERRORS-P* and MAYBE-INVOKE-DEBUGGER
251 Integration with trivial-backtrace (see *LOG-LISP-BACKTRACES-P*)
252 Treat :UNSPECIFIC like NIL in pathname components (reported by Frode Fjeld)
254 Prepared for LispWorks 6 (Nico de Jager)
255 Fixed reading of post parameters (Peter Seibel and Stephen P. Compall)
256 Fixed STOP by supplying the :READY-ONLY keyword to USOCKET:WAIT-FOR-INPUT
257 Enabled SSL key passwords for Lisps other than LW (Vsevolod)
261 Complete architectural redesign (together with Hans Hübner)
262 Lots of small fixes and improvements, too many to enumerate here
266 Fixed embarrassingly mis-placed parentheses (thanks to Hans Hübner)
270 Removed FORCE-OUTPUT* and thus the ACL-COMPAT dependency (thanks to Hans Hübner)
271 Support for MP-less CMUCL (thanks to Hans Hübner)
275 Fixed unportable LOOP usage (caught by "C S S")
279 Added CODE parameter to REDIRECT (thanks to Michael Weber)
283 Fixed typo in test.lisp (thanks to Ben Hyde)
284 Changed wrong usage of EQ to EQL (thanks to Ariel Badichi)
285 Fixed typo in default handler (thanks to Eugene Ossintsev)
289 Uses CL-FAD for HANDLE-STATIC-FILE now
290 Better error reporting for CREATE-FOLDER-DISPATCHER-AND-HANDLER (suggested by Cyrus Harmon)
291 Faster version of WRITE-HEADER-LINE (thanks to V. Segu�)
295 Added support for CLISP (thanks to Anton Vodonosov)
299 Replace ENOUGH-NAMESTRING with ENOUGH-URL (patch by Kilian Sprotte and Hans Hübner)
303 Fix compilation order (thanks to Tiarnan O'Corrain and Chris Dean)
307 Robustified MAKE-SOCKET-STREAM against potential leak (thanks to Alain Picard)
308 Replaced #-FOO #-FOO constructs for OpenMCL (patch by Michael Weber)
309 Updated tutorial links
313 Made log stream shared on OpenMCL (thanks to Gary Byers)
317 Enabled GET-GID-FROM-NAME for newer versions of SBCL (patch by Cyrus Harmon)
321 Better handling of PORT parameter in REDIRECT (thanks to Vladimir Sedach)
325 Fixed bug where you couldn't set "Server" header (caught by Ralf Mattes)
326 Documentation clarification for HEADER-OUT function
330 Added support for "HttpOnly" cookie attribute
334 Added *METHODS-FOR-POST-PARAMETERS* (suggested by Jonathon McKitrick)
338 Better support for WITH-TIMEOUT on SBCL/Win32 (thanks to Anton Vodonosov)
342 Now uses bound for flexi stream returned by RAW-POST-DATA
343 Needs FLEXI-STREAMS 0.12.0 or higher
348 Added declaration in server.lisp to appease SBCL
352 Fixes for OpenMCL (thanks to Lennart Staflin and Tiarnan O'Corrain)
356 Added server names and coupled them with easy handlers (suggested by Mac Chan)
357 Exported SESSION-COOKIE-VALUE instead of SESSION-STRING (suggested by Slava Akhmechet)
358 Documentation fixes (thanks to Victor Kryukov and Igor Plekhov)
362 Made MAYBE-INVOKE-DEBUGGER a generic function and exported it (suggested by Vladimir Sedach)
366 Fixed CREATE-FOLDER-DISPATCHER-AND-HANDLER in the presence of URL-encoded URLs (bug caught by Nicolas Lamirault)
370 Made DEF-HTTP-RETURN-CODE more flexible (suggested by Jong-won Choi)
374 Added PORT parameter to REDIRECT (suggested by Cyrus Harmon)
375 Exported REMOVE-SESSION (suggested by Vamsee Kanakala)
379 Added socket timeouts for AllegroCL
380 Catch IO timeout conditions for AllegroCL, SBCL and CMUCL (suggested by Red Daly and others)
381 Added per-server dispatch tables (suggested by Robert Synnott and Andrei Stebakov)
385 USE the CL package explicitly when defining HUNCHENTOOT-MP (bug report by Joel Boehland)
389 Correct behaviour for "100 Continue" responses
397 Don't use chunked encoding for empty (NIL) bodies
401 Really exported REASON-PHRASE this time (and also *CURRENT-PROCESS*)
405 Added HUNCHENTOOT-MP package (suggested by Cyrus Harmon)
406 Only invoke MARK-AND-SWEEP for 32-bit versions of LW (thanks to Chris Dean)
407 Exported REASON-PHRASE
411 Added *APPROVED-RETURN-CODES*, *HEADER-STREAM*, and +HTTP-FAILED-DEPENDENCY+
412 Exported MIME-TYPE and SSL-P
417 Added +HTTP-MULTI-STATUS+
421 Fix test suite to properly handle non-base characters in LW (bug caught by Jong-won Choi)
425 Fixed last change (thanks to Marko Kocic)
429 Development port (no threads) to SBCL/Win32 (patch by Marko Kocic)
430 Support for compilation without SSL
434 Don't use NSTRING-UPCASE for outgoing headers (bug caught by Saurabh Nanda)
435 Changed ProxyPass example in docs from /lisp to /hunchentoot
439 Reset to "faithful" external format on each iteration (bug caught by Viljo Marrandi and Ury Marshak)
443 Accept chunked transfer encoding for mod_lisp request bodies (thanks to Hugh Winkler's mod_lisp additions)
444 Robustify against erroneous form-data submissions (caught by Ury Marshak)
448 Even more flexible behaviour of RAW-POST-DATA
452 More flexible behaviour of RAW-POST-DATA
453 Robustified PARSE-CONTENT-TYPE
457 More meaningful results for RAW-POST-DATA
461 Added favicon.ico to example website (thanks to Yoni Rabkin Katzenell, Toby, and Uwe von Loh)
465 Added Hunchentoot logo by Uwe von Loh
469 Exported symbols related to session GC (suggested by Nico de Jager)
473 Added *HANDLE-HTTP-ERRORS-P* (thanks to Marijn Haverbeke)
474 Remove duplicate headers when reading from mod_lisp
478 Fixed HEADER-OUT (thanks to Robert J. Macomber)
482 Fixed bug in START-OUTPUT which confused mod_lisp
486 Changed behaviour of REAL-REMOTE-ADDR (as suggested by Robert J. Macomber)
487 Fixed COOKIE-OUT (thanks to Robert J. Macomber)
491 Don't bind *DISPATCH-TABLE* too early (thanks to Marijn Haverbeke)
495 Fixed bug in AUTHORIZATION function (reported by Michael J. Forster)
499 Correct SSL check in REDIRECT function
500 LOG-MESSAGE now checks for (BOUNDP '*SERVER*)
504 OpenMCL fixes (by Ralf Stoye)
508 No timeouts for mod_lisp servers (as in Hunchentoot 0.3.x)
512 Fixed a typo in easy-handlers.lisp (caught by Travis Cross)
516 Ported to CMUCL, SBCL, OpenMCL, and AllegroCL
518 Tons of small changes, too many to list them individually
522 Uses TBNL's WITH-DEBUGGER now
526 Added *CATCH-ERRORS-P* (from TBNL)
530 Accept HTTP requests with chunked transfer encoding
531 Use Chunga for chunking
535 Skip START-OUTPUT advice completely if working for TBNL
539 Added write timeouts for LW 5.0
540 Updated LW links in documentation
544 Serves as infrastructure for TBNL now (to replace KMRCL)
545 For HTTP/1.1 only send 'Keep-Alive' headers if explicitly requested
549 Connection headers are separated by commas, not semicolons
553 Refactored streams.lisp to appease LW compiler (thanks to Martin Simmons)
554 Changed handling of version string
555 Changed package handling in system definition (thanks to Christophe Rhodes)
559 Removed KMRCL workaround
563 Mention TBNL version number in server name header
567 Fixed package stuff and HYPERDOC support
571 Initial public release
573 [For earlier changes see the file "CHANGELOG_TBNL" that is included with the release.]