CINXE.COM
Jigsaw Overview
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN" "http://www.w3.org/TR/REC-html40/loose.dtd"> <html> <head> <title>Jigsaw Overview</title> <style type="text/css"> body { margin-left: 20pt; font-family: Helvetica; } .right { float: right; margin-bottom: 60px; } .left { float: left; } .colored { font-family: helvetica, sans-serif; font-weight: bold; color: teal; font-variant: small-caps } .announce { font-family: helvetica, sans-serif; text-align: center; border: thin solid teal; } H1 { font-size: 24pt; text-align: center; margin-bottom: 30pt; } UL.nodeco { list-style-type: none; } .bar { display: inline; width: 30%; float: left; } P.foo { text-indent: 5%; margin-right: 20pt; text-align: justify } TD { margin-left: 5px; width: 40%; } </style> </head> <body bgcolor="white"> <div align="left" class="left"> <img src="icons/jigsaw.gif" alt="Jigsaw Logo"></div> <div align="right" class="right"> <img src="icons/jigpower.gif" alt="Powered by Jigsaw!"></div> <h1 align="center" class="colored" style="clear: left">Jigsaw News</h1> <h2 class="colored">Devel News</h2> <p class="foo">The following lines are just describing some bug fixes and enhancements that happened recently, it is edited by hand and is far from being complete (We forgot to update it quite often). We plan to have an automatically updated version based on cvs commit. Also we don't put resolution time, which may be useful to understand that doing XML based serialization of resources takes more than one day ;)</p> <p class="foo">The current work on Jigsaw is focused on stability and HTTP/1.1 comformance, thanks to the great work done on <a href="http://coad.measurement-factory.com/">CoAdvisor</a> by <a href="http://www.measurement-factory.com/">The Measurement Factory</a>.</p> <h3 class="colored"><a href="https://jigsaw.w3.org/Devel/classes-2.3/">Upcoming</a></h3> <ul> <li><strong>(20100202)</strong> Range request fix in the available byte count of ByteRangeOutputStream</li> <li><strong>(20100119)</strong> Fixed pageCompile last segment size calculation</li> <li><strong>(20080903)</strong> Range request checks the unit of the requested range</li> <li><strong>(20070928)</strong> Changed handling of resource size from int to long, to cope wiht 2GB+ files/streams</li> <li><strong>(20070817)</strong> Stricter checks for stream closing, HttpURLConnection fixed to clean the stream only when needed (previously, garbage collecting the object was improperly closing the stream)</li> <li><strong>(20070320)</strong> Fixed cookie parsing bug, if the cookie value contains a '='</li> <li><strong>(20070228)</strong> Fixed SAX parsing of stores and remote resource description (allow multiple 'characters' call for one value)</li> <li><strong>(20070228)</strong> Added support for other SAX parsers, a patched version of Piccolo, then XP, then Xerces</li> <li><strong>(20070228)</strong> Removed an unneeded synchronization point in HTTPFrame.getURL()</li> <li><strong>(20070228)</strong> Added an extra SP when exporting auth headers with different components</li> <li><strong>(20070228)</strong> Fixed source code to remove 'enum' as it is now a keywork starting with JDK 1.5</li> <li><strong>(20050531)</strong> Added a "detach" method to HttpBasicConnection to remove a connection from the list of used client connections but without closing the socket immediately (used when the client hits a HTTP/1.0 server that doesn't send Content-Length). </li> <li><strong>(20050527)</strong> Fixed client connection deletion in connection reuse, it was leading to a leak in the client hashtable (and to lots of connections in CLOSE_WAIT).</li> <li><strong>(20050516)</strong> Fixed bug in DateParser (wrong timezone offset) thanks to Menno Jonkers</li> <li><strong>(20050221)</strong> Optimized a bit Digest Auth (the RFC2069 one) and implemented Digest Auth with qop="auth" per RFC2617 (available with SecurityLevel set to 2), See DigestQopAuthPrincipal</li> <li><strong>(20041123)</strong> Fixed a few WebDAV properties that were using wrong formats</li> <li><strong>(20041123)</strong> Added a method to print Dates in ISO 8601 format without milliseconds</li> <li><strong>(20041123)</strong> HeaderFilter now sets the relevant headers even when the reply is sent via the exception mechanism.</li> <li><strong>(20041104)</strong> More SSL and servlet related patches from Thomas Kopp.</li> <li><strong>(20041022)</strong> ActiveStream patch, under some condition, the same data could be re-read a data chunk (thanks to Doug Borland)</li> <li><strong>(20041013)</strong> The servlet parameter decoding now uses the right charset.</li> <li><strong>(20040906)</strong> The Servlet runner thread now use the server timeout mechanism to interrupt the running thread when the server is closing the request on timeout.</li> <li><strong>(20040830)</strong> Added a socket timeout on request parsing, to avoid having it linked to request timeout</li> <li><strong>(20040720)</strong> Fixed error when file timestamp was not modified but the file was actually modified.</li> <li><strong>(20040720)</strong> Fixed deadlock during store change notification when the sweeper is running (very rare)</li> <li><strong>(20040331)</strong> Fixed server client count when load is raising from LIGHT to DEAD</li> <li><strong>(20040325)</strong> Fixed Segment information unpickle, as the segment start and size were not properly parsed, leading to an infinite loop</li> <li><strong>(20040324)</strong> More SSL patches from Thomas Kopp, see <a href="http://dev.w3.org/cvsweb/java/classes/org/w3c/jigsaw/https/SSLAdapter.java?rev=1.7&content-type=text/x-cvsweb-markup">changelog</a> for more details.</li> <li><strong>(20040311)</strong> Fixed connection count when MimeParser did not started and connection was new.</li> <li><strong>(20040311)</strong> Added a default policy to reuse the same connection when the thread matches (in HttpBasicConnection)</li> <li><strong>(20040311)</strong> Added support for connection reuse policies in the Client stack.</li> <li><strong>(20040225)</strong> Client stack now reuses the connection timeout parameter.</li> </ul> <p></p> <hr noshade="noshade"> <h3 class="colored">2.2.4</h3> <ul> <li><strong>(20040211)</strong> Fix in the client stack persistent connection handler. It now closes the socket and mark the connection free when a "Connection: close" header is in the reply.</li> <li><strong>(20040210)</strong> SSL patches from Thomas Kopp.</li> <li><strong>(20040210)</strong> Container key generation now uses a wider range for key creation</li> <li><strong>(20040202)</strong> URI components now generate an exception when a separator is found</li> <li><strong>(20040121)</strong> Memory usage optimization of the serialization of a resource.</li> <li><strong>(20040121)</strong> Read/write of stores is now more fault tolerant.</li> <li><strong>(20040109)</strong> Fixed the client stack use of connections, also the global server knowledge hastable is now trimmed the right way.</li> <li><strong>(20040109)</strong> Fixed StatisticsFrame to use less StringBuffers</li> <li><strong>(20040106)</strong> Added a configurable timeout on connect, for the HTTP client stack. <code>org.w3c.www.protocol.http.connections.connTimeout</code> (defaulting to 1000ms)</li> <li><strong>(20040106)</strong> Fixed ContainerResource check for duplicate key, the "new key" algorithm is now more random (ie it uses the whole scale instead of the object serial mask), as it was leading to infinite loops on huge sites.</li> </ul> <p></p> <hr noshade="noshade"> <h3 class="colored">2.2.3</h3> <ul> <li><strong>(20031030)</strong> Added internal COPY/MOVE in DAVFrame. The default external one was not working for SSL-elabled webdav servers. Note that a copy on a remote SSL server still won't work.</li> <li><strong>(20031020)</strong> Removed mime type check on PUT</li> <li><strong>(20031014)</strong> Added the underlying exception in the HttpManager to distinguish between errors in the client stack.</li> <li><strong>(20030905</strong> Fixed deadlock in NegotiatedFrame. getVary() allowed a backward sync chain.</li> <li><strong>(20030701)</strong> Added a "equiv" method in MimeType to check for text/xml - application/xml rough equivalence on PUT</li> <li><strong>(20030701)</strong> Added Long support in HttpBuffer and HttpParser</li> <li><strong>(20030701)</strong> Fixed lock ordering in NewStoreEntry to avoid a deadlock</li> <li><strong>(20030701)</strong> Verification of connection availability on POST changed (need to have a fd_err + select to do it in a better way)</li> <li><strong>(20030606)</strong> Fixed deadlock when a file resource mark its parent as modified (backward locking, again)</li> <li><strong>(20030604)</strong> CvsRunner now uses File.createTempFile instead of hardcoded /tmp (was <a href="http://lists.w3.org/Archives/Public/www-jigsaw/2003MayJun/0019.html">problematic on windows platform</a>)</li> <li><strong>(20030528)</strong> Fixed deadlock in FileResource (backward locking on directory listing creation))</li> <li><strong>(20030430)</strong> Fixed CgiFrame to accept more output from Cgis (triggered my perl cgi library)</li> <li><strong>(20030429)</strong> Added TeraBytes support for statistics frame</li> <li><strong>(20030416)</strong> Fixed notifyUnload in ForwardFrame to avoid nullpointer exception (<a href="http://lists.w3.org/Archives/Public/www-jigsaw/2003MarApr/0019.html">patch from Brian Laird</a>)</li> <li><strong>(20030415)</strong> Fixed getParameterMap of ServlerRequest to map servlet2.3 spec (thanks to Thomas Kopp)</li> <li><strong>(20030402)</strong> CacheFilter now normalize the URL before any processing to avoid duplication on capitalization</li> <li><strong>(20030325)</strong> Fixed test for socket close in jdk1.4 specific part, added a property to allow retries on two-steps request, in the case of error on headers (thx to Phil Blake from IBM pointing me this one)</li> <li><strong>(20030228)</strong> Writers for resource serialization, both in admin server and ResourceStoreManager now force UTF-8 encoding (as XML is declared to be UTF-8)</li> <li><strong>(20030227)</strong> Error recovery on parsing errors of serialized resources, allowing stores to continue loading</li> <li><strong>(20030227)</strong> Cleaned stat generation and added hits/sec</li> <li><strong>(20030226)</strong> HtmlGenerator now uses HTML4.01 and adds the charset parameter if it is known</li> <li><strong>(20030225)</strong> Added finer grain statistics by separating dynamic from static generated replies</li> <li><strong>(20030225)</strong> Fixed replaying of 1xx replies back to the client</li> <li><strong>(20030224)</strong> Fixed HttpCacheControl to add new values for a directive that appears several times</li> <li><strong>(20030224)</strong> Re-fixed validators for If-Match</li> <li><strong>(20030224)</strong> dupRequest in proxy now removes Proxy-Authorization, thx to Thomas Kriegelstein</li> <li><strong>(20030224)</strong> Client now send back a BAD_REQUEST when the http request parser in strict mode throw an exception</li> <li><strong>(20030222)</strong> Fixed header name+":" parsing to include implied LWS</li> <li><strong>(20030221)</strong> proxy now serves GATEWAY_TIMEOUT and BAD_GATEWAY as it should</li> <li><strong>(20030221l</strong>) Kludge for Age and maxValue -> must use Long instead of integers</li> <li><strong>(20030221)</strong> Fixed sharing default for the cache to match the one of CacheProp (true)</li> <li><strong>(20030221)</strong> Strict HTTP header parsing mode made more valid wrt quoted strings</li> <li><strong>(20030221)</strong> More error handling in strict mode to generate BAD_REQUEST replies</li> <li><strong>(20030220)</strong> A server-side "lenient" HTTP parsing property has been added, decoupled from the client-side one, settable via GeneralProperties in JigAdmin</li> <li><strong>(20030220)</strong> Parsing of field-value now has a strict/lenient mode</li> <li><strong>(20030220)</strong> Revalidation on HEAD now invalidates on new values</li> <li><strong>(20030219)</strong>Parsing of HttpInteger now generates an exception on overflow</li> <li><strong>(20030219)</strong>Fixed handling of errors during HTTP headers parsing in the proxy, now returns a BAD_GATEWAY</li> <li><strong>(20030219)</strong>Accept header is no longer automatically added by the proxy when the client request do not have it.</li> <li><strong>(20030218)</strong>Fixed deadlock in ServletWrapper wrt lock ordering of timeout manager, when different instances of the servlet are created while some are timeouting</li> <li><strong>(20030218)</strong> Handling of HTTP exception in the ForwardFrame is changed, direct HTTP exception now generates a 502 Bad Gateway instead of a 504</li> <li><strong>(20030218)</strong> Precondition failed in the cache now generate an exception with a complete reply (ie: not reusing "wrong" informations from the cached resource)</li> <li><strong>(20030217)</strong> HttpCacheControl raw bytes shouldn't be unquoted before parsing</li> <li><strong>(20030217)</strong> Replies from a shared cache now remove the header list protected by a private cache-control</li> <li><strong>(20030217)</strong> Headers protected by a no-cache directive are no longer stored</li> <li><strong>(20030216)</strong> Cache-Control now parses extensions instead of throwing an exception</li> <li><strong>(20030216)</strong> Host header normalization now uses case insensitive URI scheme comparison</li> <li><strong>(20030216)</strong> Proxy now forwards back the 100 Continue reply from the upstream server</li> <li><strong>(20030216)</strong> Multiple 100 results now in multiple ContinueEvents</li> <li><strong>(20030215)</strong> Validators (If-None-Match...) in the EntityCacheResource are now matching the one in HTTPFrame</li> <li><strong>(20030215)</strong> Default freshness lifetime for cgi with no header info is now 0.</li> <li><strong>(20030214)</strong> Cache is not used when a no-store directive is present in the request</li> <li><strong>(20030214)</strong> Overflow in Max-Forward leads to an exception and a 5xx reply now, instead of forwarding a wrong value</li> <li><strong>(20030214)</strong> Added consistency checks in the cache for revalidated resources</li> <li><strong>(20030214)</strong> Fixed ForwardFrame to check chuked/Content-Length mismatch by reusing the duplicated request/reply that actually has the right information</li> <li><strong>(20030213)</strong> Fixed CacheFilter to do stricter host:port check before invalidating resources on PUT/POST/DELETE</li> <li><strong>(20030213)</strong> Invalidation of Content-Location now uses relative URIs (was partly done, a typo was in the way)</li> <li><strong>(20030213)</strong> Fixed CacheStore to avoid calls on LRUNodes, as synchronization is missing on the SyncLRUList in this case.</li> <li><strong>(20030213)</strong> CacheGeneration uses a more stricter way of crawling the LRUlist of files to delete</li> <li><strong>(20030211)</strong> Fixed parsing of Content-Range (support for unknown length)</li> <li><strong>(20030210)</strong> Fixed XMP parsing in JpegHeaders</li> <li><strong>(20030204)</strong> Fixed servlet flush notification to avoid race condition problems with sendError/sendRedirect and such.</li> <li><strong>(20030204)</strong> Fixed http Client to avoid aborting on strange servlet related IOExceptions (see org.w3c.jigsaw.http.Client rev1.71 log for in depth explanations)</li> <li><strong>(20030203)</strong> CgiFrame now display in the server console stderr of forked Cgis (prevent some cgi lockups on Win platform)</li> <li><strong>(20030131)</strong> Added a way to restransmit some buggy but not defined in rfc2616 headers (cookies, not to name it)</li> <li><strong>(20030131)</strong> Invalidation of Location and Content-Location was wrongly assuming that resource were live in the cache, leading to errors for valid requests</li> <li><strong>(20030127)</strong> Fixed If-Match if the resource ETag is weak (currently, it can happen only in the cache)</li> <li><strong>(20030127)</strong> Fixed JpegHeaders to deliver XMP at the beginning of the XML and not at the beginning of the chunk</li> <li><strong>(20030124)</strong> Fixed JpegComFrame, the parameter was unescaped twice, problematic with application/???+xml mime types</li> <li><strong>(20030124)</strong> Added JpegXmpFrame, to extract automatically XMP from Jpeg images</li> <li><strong>(20030124)</strong> Fixed revalidation in HTTPFrame when both If-None-Match and If-Modified-Since are present</li> <li><strong>(20030124)</strong> Implemented Vary support and revalidation of negotiated resources in the client-side HTTP cache</li> <li><strong>(20030122)</strong> Implemented 410 Gone permanent support via the new "shrinkable" flag of DirectoryResource (similar to "extensible" for for deletions)</li> <li><strong>(20030122)</strong> Cached resources were incorrectly asking for revalidation every time once marked invalid.</li> <li><strong>(20030122)</strong> Cache now serve HEAD from the cache</li> <li><strong>(20030122)</strong> Cache now invalidate resource in Location or Content-Location for POST, PUT and DELETE, if host matches the requested URL</li> <li><strong>(20030121)</strong> Added \CHAR escaping in quoted string of a header parameter</li> <li><strong>(20030120)</strong> Client stack will retry requests only if it is a known idempotent resource</li> <li><strong>(20030120)</strong> Fixed TRACE to allow it again to be proxied</li> <li><strong>(20030120)</strong> Fixed bug in Expectation check in the proxy, and in the general case.</li> <li><strong>(20030120)</strong> Fixed bug in continuation with empty lines</li> <li><strong>(20030115)</strong> Fixed bug in header continuation parsing</li> <li><strong>(20030114)</strong> GZIPFilter was incorrectly setting Transfer-Encoding instead of Content-Encoding</li> </ul> <p></p> <hr noshade="noshade"> <h3 class="colored">2.2.2</h3> <ul> <li><strong>(20030106)</strong> Fixed ForwardFrame to forbid forward of Content-Location when reply is chunked</li> <li><strong>(20030106)</strong> Fixed ForwardFrame to remove received Trailer header</li> <li><strong>(20030106)</strong> Fixed HTTP stack's Reply to allow body on OPTIONS per rfc2616</li> <li><strong>(20021206)</strong> Fixed lock ordering in HTTPFrame regarding methods on Container (deadlock reported 5/12/2002)</li> <li><strong>(20021017)</strong> Fixed deadlock in Resource.getParent(), when both child and parent try to lock each other.</li> <li><strong>(20021017)</strong> Fixed another deadlock in the HTTP client stack.</li> <li><strong>(20020918)</strong> Fixed bug in ip -> string optimized function that was leading to wrong values</li> <li><strong>(20020916)</strong> Added more servlet 2.3 supported methods.</li> <li><strong>(20020911)</strong> Deadlock fixes in the HTTP client stack</li> <li><strong>(20020911)</strong> Removed potential conflicting Connection: header values in the HTTP client stack during discovery of HTTP capabilities</li> <li><strong>(20020911)</strong> FIxed RedirectedFrame to avoid ipv6-like hosts when it is a ipv4 one.</li> <li><strong>(20020902)</strong> Added a way to optimize by not unloading big stores, depending on a tunable limit.</li> <li><strong>(20020827)</strong> Ensure that keys in the ResourceStoreManager are not used twice when generated</li> <li><strong>(20020808)</strong> Fixed the default encoding used in JigsawHttpServletResponse per servlet 2.3 javadoc</li> <li><strong>(20020808)</strong> Solved the deadlock problem with negotiated frame, directory listing, and everything that needs backward traversal of the resource tree.</li> <li><strong>(20020805)</strong> Fixed JigsawHttpServletResponse, it now checks that the stream has been commited before (wrongly) barfing</li> <li><strong>(20020729)</strong> Fixed Base64Decoder based on Jeffery Collins <jcollins@boulder.net> original patch</li> <li><strong>(20020729)</strong> Fixed JigsawHttpServletRequest getCharacterEncoding to return null when undefined instead of the iso-8859-1 default.</li> <li><strong>(20020729)</strong> Implemented JigsawHttpServletRequest setEncoding and other servlet 2.3 API methods</li> <li><strong>(20020726)</strong> Fixed ContentLengthInputStream, it now send an IOException when the stream is cut too early in read()</li> <li><strong>(20020725)</strong> Fixed HttpURLConnection getContentType was raising an exception rather than returning null</li> <li><strong>(20020717)</strong> Various updates in the HTTP stack, to consume less memory and use non-deprecated Date API.</li> <li><strong>(20020715)</strong> Integrated cookie parsing patch contributed by Julien Mudry <jmu@elca.ch></li> <li><strong>(20020711)</strong> URL in jdk1.4 can have an empty file element, it is now translated to '/' for all methods but OPTIONS, where it is '*'</li> <li><strong>(20020711)</strong> Special files "aux", "con", etc. can no longer be created by the indexer on windows platform (still possible on other platforms as those files are not special there).</li> <li><strong>(20020708)</strong> Fixed servlet wrapper to close the input stream when needed, also when a relocate or an error is triggered from the servlet, an exception is raised if the client already got (part of) the reply.</li> <li><strong>(20020705)</strong> ServletWrapper now take the feeding thread from a thread cache (avoid keeping too many open threads)</li> <li><strong>(20020702)</strong> Fixed reuse of connection in the HTTP Client stack, by using jdk1.4 method on socket (uses reflection to keep the code backward compatible)</li> <li><strong>(20020702)</strong> Fixed HTTP compliance of chunked request, and proxy of request without body</li> <li><strong>(20020626)</strong> Improved AclW3Cdb, saving space in the indexing phase, sligthly improved lookup</li> <li><strong>(20020619)</strong> Redid the InetAddress dump in the logger as well as the status code dump</li> <li><strong>(20020619)</strong> Memory and performance upgrade of the infamous CommonLogger and ExtendedCommonLogger, who were the primary culprits in the memory usage once the stores are loaded.</li> <li><strong>(20020612)</strong> Almost all memory should be kept at a minimal level now, the worst thing being the Logger now</li> <li><strong>(20020603)</strong> Started to find and elimnate all unnecessary memory allocated</li> <li><strong>(20020529)</strong> Fixed directory index of ZipDirectoryResource, to delete and get size information the right way</li> <li><strong>(20020529)</strong> Fixed ZipFrame to allow automagic destruction of stale entries in the underlying zip</li> <li><strong>(20020527)</strong> Error reported when an error occur in the file system does not display the PATH any longer to avoid disclosing</li> <li><strong>(20020516)</strong> FIxed a potential leak (never emptied hashtable) in HttpManager</li> <li><strong>(20020411)</strong> Fixed RelocateFrame to accomodate new ipv6 scan of host in URL</li> </ul> <p></p> <hr noshade="noshade"> <h3 class="colored">2.2.1</h3> <ul> <li><strong>(20020327)</strong> Changed the way ETags are computed for Jigedit, to be in sycn with our server farm</li> <li><strong>(20020321)</strong> Previously uncaught error (ie: non Protocol ones) during lookup are now resoved by sending a 400 Bad Request</li> <li><strong>(20020319)</strong> Implemented getErrorStream of HttpUrlConnection per jdk1.2 API</li> <li><strong>(20020318)</strong> Fixed the way exception filters are called in httpd. Side effect, ErrorFilter works again</li> <li><strong>(20020219)</strong> Added TidyPutFilter to clean HTML on PUT.</li> <li><strong>(20020130)</strong> Fixed a bug in TE Filter that was compressiong twice the stream (need to figure out why it was called twice though)</li> <li><strong>(20020130)</strong> Added a way to avoid IP matching for AclW3Cdb (for future jigedit use)</li> <li><strong>(20020130)</strong> Fixed semantic of ; in the URI, with the right info given during lookup</li> <li><strong>(20020128)</strong> Fixed security bug regarding URI parsing, with %00 and wrongly unescaped %5C (/)</li> <li><strong>(20020122)</strong> Resurrected -port as an undocumented deprecated feature.</li> <li><strong>(20020104)</strong> Added a flag to remove the URI from default error pages as well as the proxy module (avoiding cross scripting attacks)</li> <li><strong>(20011112)</strong> Fixed ServletMapper to do redirect the right way (host parsing). It was interacting with new jdk1.4 ipv6 scan</li> <li><strong>(20011026)</strong> Merged patches from <a href="mailto:Thomas.Kopp@dialogika.de">Thomas Kopp</a> concerning servlets: servlet loading, behaviour of SingleThreadModel</li> <li><strong>(20011005)</strong> Reverted 1.3 API calls to 1.2, or used reflection to use jdk1.3 only methods in the push package</li> <li><strong>(20011003)</strong> Added the cache push contribution to the tree</li> <li><strong>(20010926)</strong> Added a specific frame to handle MKCOL and other collection-related WebDAV methods in Jigedit</li> <li><strong>(20010831)</strong> Fixed WebDAV implementation, it now sends all the requested properties in a PROPFIND, with the right statuds for the undefined ones.</li> <li><strong>(20010831)</strong> Modified AclFilter to take benefit of skipBody</li> <li><strong>(20010831)</strong> Added skipBody in Request, it allows a filter to skip an eventual body in a better way than error recovery.</li> <li><strong>(20010830)</strong> Fixed bug when Content-Type was not set (it was set but the value of the HttpMimeType was null, defeating the usual check)</li> <li><strong>(20010829)</strong> Implemented WebDAV powered Jigedit</li> <li><strong>(20010822)</strong> Fixed If-None-Match during the creation of a FileResource</li> <li><strong>(20010822)</strong> Fixed trailing / for negotiated resources, it was ignored, resulting in bad relative links</li> <li><strong>(20010820)</strong> Fixed If-None-Match in HTTPFrame, it now handles *</li> <li><strong>(20010717)</strong> ResourceStoreManager will issue a warning when a store raise an exception during save, the general save will continue (it was not the case before)</li> <li><strong>(20010711)</strong> In CvsFileFrame, cvs update is performed also prior to a PUT.</li> <li><strong>(20010710)</strong> Added stronger synchronization for log rotation.</li> <li><strong>(20010705)</strong> Fixed indexer so that fake file resource can be created, as it may be dangerous for directories, it is still forbidden on those.</li> <li><strong>(20010618)</strong> Fixed deadlock in DirectoryListerFrame, a lock was not done resulting in locks done in the wrong order in concurrent access</li> <li><strong>(20010617)</strong> Fix NewStoreEntry, hashtable of loaded ResourceReference is now cleared when the store is unloaded.</li> <li><strong>(20010528)</strong> Fix in EditableSlider, now a textfield can resize the boundaries of the slider, a non-extensible mode is also available</li> <li><strong>(20010513)</strong> Fixed RedirectedFrame to add Content-Location after the internal redirect, and Referer is kept.</li> <li><strong>(20010511)</strong> Added synchronization fo class loading in servlet's class loader</li> <li><strong>(20010412)</strong> Added CountInputStream, to get the actual number of bytes read.</li> <li><strong>(20010412)</strong> ByteArrayOutputStream now accept also InputStream</li> <li><strong>(20010412)</strong> Implementation of Apache <a href="http://httpd.apache.org/docs/mod/mod_asis.html">mod_asis</a></li> <li><strong>(20010409)</strong> Fixed NegotiatedFrame to gather filters from the selected resource, collected during the lookup, instead of the perform. However perform may select the resource if the state is lost because of another filter.</li> <li><strong>(20010404)</strong> Fixed error replies for JigEdit on a 412 for example.</li> </ul> <p></p> <hr noshade="noshade"> <h3 class="colored">2.2.0/2.0.6</h3> <ul> <li><strong>(20010307)</strong> Added synchronization in nonce change to avoid burst changes</li> <li><strong>(20010307)</strong> Fixed HttpChallenge again for quoted/unquoted mix.</li> <li><strong>(20010214)</strong> Fixed log time when the server ran into daylight saving changes.</li> <li><strong>(20010214)</strong> Fixed compliancy bug for OPTIONS * (Content-Length is now explicitly 0)</li> <li><strong>(20010213)</strong> Added more information in the ToolsLister for jigedit</li> <li><strong>(20010213)</strong> Fixed bug in HttpBasicServer, when the number of IP for a host is updated with less IPs, it may end up in a loop of errors</li> <li><strong>(20010212)</strong> Winie fix for password reuse with digest auth</li> <li><strong>(20010209)</strong> Trace removed while chunking, thanks to Dan Hansen</li> <li><strong>(20010120)</strong> Various fixes for persistent jdbc connections</li> <li><strong>(20010111)</strong> Fix problem with servlet timeouts and errors/redirects.</li> <li><strong>(20010106)</strong> The use of one state was incorrect (cast btw URL and String in some cases), normalized to URLs now)</li> <li><strong>(20001221)</strong> Robustness fix, servlet are now killed after the right timeout, and possible deadlocks are (hopefully) broken.</li> <li><strong>(20001216)</strong> Fixed TRACE method, now done directly at the server level, as it is only used as an echo.</li> <li><strong>(20001207)</strong> Fixed Digest Auth bug (well update of the spec) regarding unquoted parameters in the credential (it is BAD)</li> <li><strong>(20001207)</strong> Added more statistics about resource store usage</li> <li><strong>(20001204)</strong> ServletMapper sets the original URL for logging</li> <li><strong>(20001204)</strong> Logger can now log the original URL during an internal redirect</li> <li><strong>(20001122)</strong> Creation of NegotiatedResources in DirectoryResource is now incremental.</li> <li><strong>(20001114)</strong> Winie: fixed If-Match bug when remote file deleted</li> <li><strong>(20001114)</strong> Winie: fixed bug in dialog yes-no-cancel</li> <li><strong>(20001109)</strong> Added support for mirroring from a non-root resource (providing all the underneath links are relatives)</li> <li><strong>(20001107)</strong> Connection: close requests now adds the header automatically in the reply</li> <li><strong>(20001107)</strong> Chunking is allowed on Connection: close</li> <li><strong>(20001103)</strong> Servlet errors are now propagated the right way, and the monitor always released.</li> <li><strong>(20001102)</strong> Fixed ServletWrapper, now everything goes back to the Jigsaw model, which means valid HTTP, chunking if needed, and filter cascading.</li> <li><strong>(20001102)</strong> Fixed Chunking when 0 bytes were received, the stream was wrongly closed.</li> <li><strong>(20001031)</strong> Fixed NullPointerException in ETag-based PUT on Negotiated Resource.</li> <li><strong>(20001027)</strong> Fixed slider in JigAdmin to auto expand near the limits</li> <li><strong>(20001024)</strong> WebDAV in Jigsaw almost done, starting tests.</li> <li><strong>(20001019)</strong> Compliancy fix in the cache, entity headers removed from a Not Modified reply</li> <li><strong>(20001017)</strong> Fixed Content-Length to 0 for a 201 Created without a body</li> <li><strong>(20001002)</strong> Fixed logname for october</li> <li><strong>(20000926)</strong> Fixed caching for authenticated resources</li> <li><strong>(20000926)</strong> org.w3c.util.DateParser: a parser for date in ISO 8601 format.</li> <li><strong>(20000926)</strong> WEBDAV: parsing of headers and XML body finished.</li> <li><strong>(20000926)</strong> Fixed / -> %2F for the URI trick for rdf metadata</li> <li><strong>(20000921)</strong> Jigsaw use another SAX Parser (xerces)</li> <li><strong>(20000905)</strong> Fixed VirtualHostFrame for fully qualified request in the URI on not default ports.</li> <li><strong>(20000824)</strong> Winie: Focus management modified</li> <li><strong>(20000824)</strong> Winie: Keyboard shortcuts added</li> <li><strong>(20000822)</strong> Winie: preferences directory is now ".winie"</li> <li><strong>(20000818)</strong> RuntimeException throwned when the servlet container has no ServletDirectory.</li> <li><strong>(20000816)</strong> Bug Fixed in Winie</li> <li><strong>(20000816)</strong> Bug fixed in ServletProperties Reader (InitArgs separator)</li> <li><strong>(20000814)</strong> Fixed Host: header checking for HTTP/1.1 requests</li> <li><strong>(20000814)</strong> Fixed VirtualHost lookup to use the host part of the resolved URI instead of only the Host header</li> <li><strong>(20000811)</strong> URL/File synchronization added in Winie</li> <li><strong>(20000811)</strong> Fixed jigadmin to allow removing some attributes.</li> <li><strong>(20000811)</strong> StringAttribute now accept null as a valid value.</li> <li><strong>(20000810)</strong> Fixed Allow: header depending on the frame configuration.</li> </ul> <p></p> <hr noshade="noshade"> <h3 class="colored">2.1.2/2.0.6</h3> <ul> <li><strong>(20000804)</strong> Many bugs fixed in Winie</li> <li><strong>(20000804)</strong> New buttons for Winie</li> <li><strong>(20000803)</strong> New FileInputStream that Support Mark/Reset MSFileInputStream</li> <li><strong>(20000803)</strong> Better error messages in Winie.</li> <li><strong>(20000803)</strong> Fixed FowardFrame to close connection when amgibuity can be raised by the client-side reply concerning Content-Length.</li> <li><strong>(20000803)</strong> Added HTTP/0.9 support in the client side API (should we hang people using this? ;) )</li> <li><strong>(20000803)</strong> Fixed HTTP/1.0 request in client side when a body is there and an error is replied (and connection cut) before the end of the body.</li> <li><strong>(20000727)</strong> Fixed a bug in jdbc Package.</li> <li><strong>(20000726)</strong> Package <code>org.w3c.tools.Jdbc </code>finished and tested with a sample jsp application.</li> <li><strong>(20000726)</strong> Fixed PropertySet to use the new unsafeGetValue(), it was leading to bad serialization for the admin server</li> <li><strong>(20000726)</strong> ThreadCache is now using a FIFO for the free threads, notify->notifyAll due to some broken implementations</li> <li><strong>(20000725)</strong> Fixed a bug in JigsawHttpServletRequest (ContextPath)</li> <li><strong>(20000724)</strong> Ensure FD are close in the client stack.</li> <li><strong>(20000724)</strong> Remove too many caching attempts.</li> <li><strong>(20000721)</strong> Fixed synchronization in the http client pool</li> <li><strong>(20000720)</strong> Fixed last deadlock in stores</li> <li><strong>(20000713)</strong> Fixed ConfigResourceIndexer to avoid exceptions when an invalid MimeType is set</li> <li><strong>(20000713)</strong> Removed unnecessary headers in cached responses</li> <li><strong>(20000711)</strong> Fixed a bug in ServletResponse.sendRedirect()</li> <li><strong>(20000710)</strong> Fixed a deadlock in 2.1, when a resource was created and at the same time its parent was serialized, done by doing smarter "synchronized" calls.</li> <li><strong>(20000707)</strong> Fixed a bug in ServletMappefFrame (pathinfo not corectly set)</li> <li><strong>(20000707)</strong> Fixed Slider in Jigadmin so that it checks the bound to avoid problems</li> <li><strong>(20000707)</strong> Fixed several deadlocks in 2.1 during indexing+save+event processing (quite hairy part)</li> </ul> <p></p> <hr noshade="noshade"> <h3 class="colored">2.1.2/2.0.5</h3> <ul> <li><!-- We are the champions! 02 Jul 2000 --> <strong>(20000703)</strong> Added ConfigResourceIndexer, that use a .meta/foo.meta to override some configuration defaults.</li> <li><strong>(20000630)</strong> Fixed Jigsaw 2.1 cache, some headers were forgotten, also fixed a race condition leading to a leak in the precache Hashtable.</li> <li><strong>(20000629)</strong> Fixed loggers to deal with HTTP/0.9 requests on dateless replies.</li> <li><strong>(20000627)</strong> Fixed JigAdmin to correct URI not ended with '/' (leading to an error when using jdk1.3)</li> <li><strong>(20000623)</strong> Fixed a bug in HTTPFrame (cached header)</li> <li><strong>(20000623)</strong> Resurrected -host option</li> <li><strong>(20000623)</strong> Fixed AclRealm so that AuthUser state is added to the request</li> <li><strong>(20000621)</strong> Usage stats has a debug mode to show threads state.</li> <li><strong>(20000621)</strong> Enhanced idle client removal under high load.</li> <li><strong>(20000616)</strong> Added Jdbc classes for persistent connection to a database.</li> <li><strong>(20000613)</strong> Added Shutdown hook in 2.0 to save the configuration on brutal exit.</li> <li><strong>(20000608)</strong> Fixed CommonLogger, some entries were missing when the buffer length was reached.</li> <li><strong>(20000607)</strong> Fixed XMLResourceWriter, the list of children was not endoded, resulting in invalid caracthers being sent.</li> <li><strong>(20000605)</strong> Fixed CgiFrame for the weak ETag</li> <li><strong>(20000531)</strong> Fixed JpegHeaders to release the file descriptor</li> <li><strong>(20000525)</strong> Fixed ETag generation when a non-file resource is there.</li> <li><strong>(20000521)</strong> Fixed deadlock due to JVM bug in the client side (notify->notifyAll)</li> <li><strong>(20000418)</strong> Last changes to SocketClientFactory, the sweep thread is now a daemon thread, and the way idle client connection are stopped is now cleaner.</li> <li><strong>(20000411)</strong> CgiFrame now reuses the default configuration of the frame to produce more specific headers, previously, the configuration was just simply ignored (it is still if the script is generating all the headers by itself)</li> <li><strong>(20000411)</strong> Idle clients are now removed to either reach max free or max idle (it was max free only before that)</li> <li><strong>(20000411)</strong> Fixed another bug in SocketClientFactory, free clients were not always marked as free.</li> <li><strong>(20000406)</strong> Fixed bug in SocketClientFactory leading to lost clients, it was appearing only under high loads.</li> <li><strong>(20000331)</strong> Fixed bug in JigsawHttpServletRequest, some parameters were lost.</li> <li><strong>(20000331)</strong> Fixed JpegHeaders to get the comments written by some digital cameras.</li> <li><strong>(20000330)</strong> Fixed NegotiatedFrame to have ordering also for Accept: header</li> <li><strong>(20000329)</strong> Fixed Client, to avoid bad client idle count when extra body is skipped.</li> <li><strong>(20000329)</strong> More status information in SocketClientProperty, idle and free client list are now synchronized</li> <li><strong>(20000327)</strong> Lenient parsing is now triggered by a property</li> <li><strong>(20000324)</strong> Fix in client-side Reply, chunked encoding is now detected first as some server are sending both Transreft-Encoding: chunked and a Content-Length</li> <li><strong>(20000324)</strong> MimeParser has now a lenient mode (enabled by default) to ignore incorrect headers instead of stopping the parsing directly.</li> <li><strong>(20000322)</strong> Reverted IO.java to jdk1.1 only calls.</li> <li><strong>(20000322)</strong> Fixed idle count in the SocketClientFactory, interrupted idle clients were causing idle connections leak, leading potentially to higher load, hence reduction of number of client kept alive.</li> <li><strong>(20000321)</strong> New statistics scheme</li> <li><strong>(20000317)</strong> Reused connections that were closed by the remote server are now removed from the pool, and connection count updated.</li> <li><strong>(20000317)</strong> Fixed problem with getServerName and Host with no port number. (port 80)</li> <li><strong>(20000315)</strong> JSP Documentation</li> <li><strong>(20000314)</strong> Fixed RequestDispatcher with Virtual Hosts.</li> <li><strong>(20000314)</strong> Fixed return code when servlet is unavailable.</li> <li><strong>(20000313)</strong> Fixed getServletPath for included servlets and redirections.</li> <li><strong>(20000313)</strong> Fixed HTML4 compliancy of container listing. Moved HTMLGenerator to use HTML4.0 transitional dtd.</li> <li><strong>(20000310)</strong> Documentation layout modified.</li> <li><strong>(20000310)</strong> Fixed init of rotation level in CommonLogger</li> <li><strong>(20000310)</strong> Fixed HttpBasicConnection to avoid caching IP forever. Unfortunately we can't use the DNS ttl...</li> <li><strong>(20000309)</strong> Fixed deprecated calls in many classes</li> <li><strong>(20000309)</strong> Fixed JpegComFrame to not rely on jdk 1.2</li> <li><strong>(20000307)</strong> Fix for jsp in ServletMapperFrame</li> </ul> <p></p> <hr noshade="noshade"> <h3 class="colored">2.1.1/2.0.5</h3> <ul> <li><strong>(20000303)</strong> Fixed ServletPropertiesReader, inited flag was not updated.</li> <li><strong>(20000303)</strong> Fixed getRealPath method in ServletContext.</li> <li><strong>(20000301)</strong> Fixed default port recognition in the lookup phase of the proxy</li> <li><strong>(20000229)</strong> Fixed synchornized calls in HttpBasicServer to avoid a deadlock</li> <li><strong>(20000225)</strong> Added support for log rotation in all the loggers, with multiple levels of rotation</li> <li><strong>(20000224)</strong> Fixed clone in httpd so that https can now be run with the Unix stuff before.</li> <li><strong>(20000222)</strong> Fixed init code of AttributeHolder</li> <li><strong>(20000222)</strong> Fixed race condition in resource store loading</li> <li><strong>(20000218)</strong> Reindex locally (not recursively)</li> <li><strong>(20000218)</strong> HTTPFrame can generate index for ContainerResource too.</li> <li><strong>(20000218)</strong> HTTPFrame can have multiple index.</li> <li><strong>(20000216)</strong> JpegComFrame now uses ;type for Content-Location and direct queries</li> <li><strong>(20000216)</strong> Fixed LookupState to use ; in the delimiters for URI</li> <li><strong>(20000216)</strong> ServerHandlers are now started in two step, preinit (properties and socket bindings), then run, it fixes a problem with chroot and Jigsaw 2.1 serializer, and it is cleaner ;)</li> <li><strong>(20000215)</strong> Fixed the statistics frame (used thread, style and such)</li> <li><strong>(20000215)</strong> Servlet API 2.2 implemented (except the war files features)</li> <li><strong>(20000209)</strong> Relocate now uses a request state to pass the original URL of the request, used in the container redirect on missing /</li> <li><strong>(20000207)</strong> Fxed HttpAccept so that the contructor now uses the quality factor as it should.</li> <li><strong>(20000202)</strong> Redone the Relocate and Redirect frames, thay are now allowing you to do redirect for some methods only (all by default)</li> <li><strong>(20000201)</strong> Fixed a bug in relocate frame preventing query string to be passed to the redirected URI.</li> <li><strong>(20000201)</strong> Fixed RelocateFrame so that internal redirect can go through virtual hosts.</li> <li><strong>(20000128)</strong> bug fixed preventing binding on a specific IP</li> </ul> <p></p> <hr noshade="noshade"> <h3 class="colored">2.1.1/2.0.4</h3> <ul> <li><strong>(20000121)</strong> bug fixed in RealmCatalog & AuthRealm</li> <li><strong>(20000120)</strong> bug fixed in servlet pre-loading.</li> <li><strong>(20000113)</strong> Fixed a lookup bug in ProxyFrame during internal requests.</li> <li><strong>(20000113)</strong> servlets documentation updated.</li> <li><strong>(20000112)</strong> servlet.properties can now be used to configure servlets.</li> <li><strong>(20000112)</strong> Added support for a shutdown hook, to ensure synchronization of the stores</li> <li><strong>(20000111)</strong> Added getClone and addParameter to MimeType, to avoid doing too much dirty work in the code.</li> <li><strong>(20000111)</strong> Added Charset support so that an indexer can match a charset and update the defaults directly.</li> <li><strong>(20000111)</strong> Fixed a potential bug, when the Hashtable of a frame was called with frames, but the size of the frame array equals to 0</li> <li><strong>(19991210)</strong> Fixed an unload notification that was not passed to frames</li> <li><strong>(19991202)</strong> Added getSMaxAge/setSMaxAge in HttpMessage to deal with expiration on shared caches.</li> <li><strong>(19991201)</strong> Fixed a deadlock in the ResourceStoreManager.</li> <li><strong>(19991201)</strong> Fixed an extra Content-Type sent in the admin protocol.</li> <li><strong>(19991130)</strong> ChunkedInputStream now notifies an EOF if it happens while you ask to read for more bytes than available (was potentially waiting forever before that!)</li> <li><strong>(19991130)</strong> Fixed HttpBasicServer, when the client part has to do a two stage HTTP/1.1 request on behalf of a 1.0 client (proxy), then 100 Continue replies are now discarded.</li> <li><strong>(19991129)</strong> Added the NoCache filter which transforms Pragma: no-cache into Cache-Control: max-age=0, used to fix some HTTP/1.0 client brokenness to allow a better use of the cache, especially while in disconnected mode.</li> <li><strong>(19991126)</strong> Fixed jigsaw.Reply, chunking, see below.</li> <li><strong>(19991126)</strong> Fixed ChunkedOutputStream, it is now more optimized and a potential char to byte convertion problem has been removed. Also, the closing of the stream has been fixed.</li> <li><strong>(19991125)</strong> Fixed Base64 encoder and decoder, to avoid a potential char to byte conversion error, no more deprecated method used!</li> <li><strong>(19991125)</strong> Fixed cached entry invalidation, it now marks the entry to be revalidated next time rather than removing it directly from the cache (helps disconnected operation).</li> <li><strong>(19991125)</strong> Fixed header update during revalidation not matching 200 or 304 (ex: auth failed)</li> <li><strong>(19991116)</strong> modified the attribute name for last modified, as it was interacting badly with revalidations.</li> <li><strong>(199910 25)</strong> JigsawRequestDispatcher in servlet is now cloning the request before an include or a forward</li> <li><strong>(199910 21)</strong> Fixed the upgrader according to the latest (jdk1.2.1_04 and 1.3) specifications. The upgrade has been tested on the new jigedit, used to edit this entry!</li> <li><strong>(19991019. yl)</strong> Fixed MimeType matching to have a better ordering, maybe more lovel of matching will be added in the future, if needed</li> <li><strong>(19991019)</strong> Announced Winie, the HTTP standalone PUT and GET tool.</li> <li><strong>(19991018)</strong> New class to infere MimeTypes.</li> <li><strong>(19991013)</strong> ImageComments may now be PUT, provided you use the right ETag.</li> <li><strong>(19991011)</strong> Code cleanup, there were ambiguities in one class about which method to call that SUN's compiler didn't spotted.</li> <li><strong>(199910 06)</strong> JpegCommentHandler now can return readers and writers of comment within a jpeg stream, bug fix for COM12 images (infinite loop). CommentWriter completed.</li> <li><strong>(1999 09 23)</strong> CacheFilter no longer caches replies with Set-Cookies because of loops, it breaks the model but it is required to work well :( )</li> <li><strong>(19990923)</strong> Fixed bug in HttpMessage, The proxy stopped to forward the SetCookie header because of a modification I made.</li> <li><strong>(19990923)</strong> Fixed 2.1 bug in FileAttribute. It can now pickle a String (mandatory for remote admin)</li> <li><strong>(19990922)</strong> JpegComFrame, to allow getting directly the text chunks out of a jpeg image (Content Negotiation)</li> <li><strong>(19990920)</strong> Bug fixed: invalid XML characters are now encoded (eg: & => &amp;)</li> <li><strong>(19990920)</strong> Added a more clever (and expensive) loop check in the Proxy, it check for the IP and not for the host only</li> </ul> <p></p> <hr noshade="noshade"> <h3 class="colored">2.1.0/2.0.4</h3> <ul> <li><strong>(19990906)</strong> HttpRange can now be created using -500, 500- using "-1" as the default value</li> <li><strong>(19990831)</strong> Client now gracefully skip the body of the request if it is sent (due to problems, the 100-continue should not be trusted as there maybe some timeouts involved)</li> <li><strong>(19990818)</strong> directory listing now ends the URI of the containers with / to avoid one redirection (be nice the the net!)</li> <li><strong>(19990818)</strong> lister in Jigedit now put the action in the FORM tag, as it should</li> <li><strong>(19990817)</strong> Now checking for redefined attribute names</li> <li><strong>(19990809)</strong> PutList now has a default "unknown" author when no authentication is done</li> <li><strong>(19990809)</strong> Namespace added to jxml.</li> <li><strong>(19990809)</strong> Servlet bug fixed in getResource()</li> <li><strong>(19990806)</strong> Logger has now a property to specify the log directory.</li> <li><strong>(19990805)</strong> Servlet bug fixed: now servlets are destroyed only if all connections are closed.</li> <li><strong>(19990802)</strong> Wrote documentation about the new store format (jxml).</li> <li><strong>(19990801)</strong> Upgrader tool finished (convert classic store to XML).</li> </ul> <h3 class="colored">2.1.0/2.0.3</h3> <ul> <li><strong>(19990722)</strong> Logger can now be changed while the server is running</li> <li><strong>(19990722)</strong> Servlet timeout could be disabled (if equals to -1)</li> <li><strong>(19990722)</strong> Servlet: session cookie maxage could be equals to -1 now.</li> <li><strong>(19990716)</strong> first working version of the XML based Jigsaw.</li> <li><strong>(19990715)</strong> SSIFrame now cut the connection, to cope with problem between servlets (write directly on the stream) and ChunkedEncoding.</li> <li><strong>(19990715)</strong> Fixed ServletTimeout unit</li> <li><strong>(19990713)</strong> Fixed Language negotiation to match well the subtags (required to distinguish zh-tw from zh-cn)</li> <li><strong>(19990701)</strong> Fixed content negotiation for language and the level of rejection (only bad content types are rejected now), also "*" is now a valid language.</li> <li><strong>(19990630)</strong> Fixed ResourceStoreManager initialization which was causing trouble when the root resource was changed</li> <li><strong>(19990620)</strong> Changed ACL api, so that every information can be taken from the Request to help the authentication process.</li> <li><strong>(19990607)</strong> Fix in content negotiation, Language is now handled in a better way, with language modifier, request order.</li> <li><strong>(19990607)</strong> Port change now fixed for main server.</li> <li><strong>(19990607)</strong> Added a specific feeder for realm's user names.</li> <li><strong>(19990604)</strong> Fixed the infamous cookie bug, now several cookies => several Set-Cookie headers.</li> <li><strong>(19990604)</strong> Added Bind Address, so that multiple server on a machine with many interface can be opened, each on a specific interface (old style virtual hosting)</li> <li><strong>(19990604)</strong> Fixed loop in proxy when set to port 80 and when a page on the server itself is requested</li> <li><strong>(19990521)</strong> Added ProxyAuthenticate rule to ProxyDispatcher, it allows client to use a Proxy-Authenticate header even if they can't set it.</li> <li><strong>(19990520)</strong> Added MimeTypeArrayAttribute, StringArrayEditor can be used to edit MimeTypeArray.</li> <li><b>(19990504)</b> Added SimpleGrepFilter in jigedit to simply block unwanted strings in only text/* entities.</li> <li><b>(19990504)</b> Cached VaryResource are now checking ETags the right way, no more 304 replies when a normal request was sent if a revalidation happened.</li> <li><b>(19990503)</b> Sort-of fixed bug in the port number change (It tries to restart the server, with or without luck).</li> <li><b>(19990503)</b> Fixed max connection and notification of waiting threads during deletion of an old kept-alive connection.</li> <li><b>(19990429)</b> Fixed timestamp problem with modification in the past of file resources</li> <li><b>(19990429)</b> RedirecterFrame now handles PATH_INFO</li> <li><b>(19990429)</b> Added RegexRedirectFilter, which uses the oromatcher package. We can't distribute that package due to licensing conditions, and it may be a pain for people wanting to compile Jigsaw, it will be on CVS once a regexp package will be in org.w3c.tools.regex :)</li> <li><strong>(19990428)</strong> Fixed ResourceEvent bug (unloaded resource should not received event)</li> <li><strong>(19990428)</strong> Fixed ServletRequest to merge url parameters and body ones.</li> <li><b>(19990428)</b> Fixed cache to avoid blocking on non-sized multipart documents in the cache (neverending wait for connection cut (size information))</li> <li><strong>(19990427)</strong> First implementation of ACL for Authentication (Basic and Digest) (AclFilter associated to an AclRealm).</li> <li><b>(19990426)</b> Fixed servlet getReader behaviour to get the right encoding (taken from the request headers)</li> <li><b>(19990421)</b> Added more headers for Bad Request</li> <li><b>(19990421)</b> Cache is now sending the right Content-Length with null documents.</li> <li><b>(19990419)</b> Improved Idle Client garbage collection scheme, allowing smoother operation when load occurs (with performance improvements)</li> <li><b>(19990419)</b> Fixed wrong Bad Request on a cut connection (no influence as the connection was cut anyway)</li> <li><b>(19990419)</b> Fixed Null Pointer trace when "help" was called with no resource selected (jigadmin2)</li> <li><b>(19990419)</b> Bad file permission check now raises an exception instead of (sometimes) blocking.</li> <li><b>(19990415)</b> Fixed makefiles</li> <li><b>(19990414)</b> Fixed null value of MimeAttribute in old Jigadmin to default to *none* as expected.</li> <li><b>(19990413)</b> Fixed bug in servlet indexer with full package name</li> <li><b>(19990409)</b>cvs add in CvsFileFrame now checks if the object sent is binary or not (based on Content-Type)</li> <li><b>(19990408)</b> Fixed part of Bad Request handling, they are now processed as they should for missing Host. still work to do for bad request due to incorrect http header values sent.</li> <li><b>(19990407)</b> MirrorFrame now tweak the redirects also for temporary redirects</li> <li><strong>(19990407)</strong> Servlets: Headers are sent when the servlet start to write on the stream, not before.</li> <li><b>(19990407)</b> Md5 constructor fixed to allow encoding string.</li> </ul> <p></p> <hr noshade="noshade" width="30%" align="left"> <a href="mailto:jigsaw@w3.org">Jigsaw Team</a> <!-- <DIV align="right"> <IMG CLASS="right" SRC="icons/jigpower.gif" ALT="Jigsaw Powered" BORDER="0" WIDTH="94" HEIGHT="52" ALIGN="Right"> </DIV> --> </body> </html>