4.21.1
[express.git] / History.md
blob924f10537bbd09de98ffe17715bc9ddbc7f8989f
1 4.21.1 / 2024-10-08
2 ==========
4 * Backported a fix for [CVE-2024-47764](https://nvd.nist.gov/vuln/detail/CVE-2024-47764)
6 4.21.0 / 2024-09-11
7 ==========
9   * Deprecate `res.location("back")` and `res.redirect("back")` magic string
10   * deps: serve-static@1.16.2
11     * includes send@0.19.0
12   * deps: finalhandler@1.3.1
13   * deps: qs@6.13.0
15 4.20.0 / 2024-09-10
16 ==========
17   * deps: serve-static@0.16.0
18     * Remove link renderization in html while redirecting
19   * deps: send@0.19.0
20     * Remove link renderization in html while redirecting
21   * deps: body-parser@0.6.0
22     * add `depth` option to customize the depth level in the parser
23     * IMPORTANT: The default `depth` level for parsing URL-encoded data is now `32` (previously was `Infinity`)
24   * Remove link renderization in html while using `res.redirect`
25   * deps: path-to-regexp@0.1.10
26     - Adds support for named matching groups in the routes using a regex
27     - Adds backtracking protection to parameters without regexes defined
28   * deps: encodeurl@~2.0.0
29     - Removes encoding of `\`, `|`, and `^` to align better with URL spec
30   * Deprecate passing `options.maxAge` and `options.expires` to `res.clearCookie`
31     - Will be ignored in v5, clearCookie will set a cookie with an expires in the past to instruct clients to delete the cookie
33 4.19.2 / 2024-03-25
34 ==========
36   * Improved fix for open redirect allow list bypass
38 4.19.1 / 2024-03-20
39 ==========
41   * Allow passing non-strings to res.location with new encoding handling checks
43 4.19.0 / 2024-03-20
44 ==========
46   * Prevent open redirect allow list bypass due to encodeurl
47   * deps: cookie@0.6.0
49 4.18.3 / 2024-02-29
50 ==========
52   * Fix routing requests without method
53   * deps: body-parser@1.20.2
54     - Fix strict json error message on Node.js 19+
55     - deps: content-type@~1.0.5
56     - deps: raw-body@2.5.2
57   * deps: cookie@0.6.0
58     - Add `partitioned` option
60 4.18.2 / 2022-10-08
61 ===================
63   * Fix regression routing a large stack in a single route
64   * deps: body-parser@1.20.1
65     - deps: qs@6.11.0
66     - perf: remove unnecessary object clone
67   * deps: qs@6.11.0
69 4.18.1 / 2022-04-29
70 ===================
72   * Fix hanging on large stack of sync routes
74 4.18.0 / 2022-04-25
75 ===================
77   * Add "root" option to `res.download`
78   * Allow `options` without `filename` in `res.download`
79   * Deprecate string and non-integer arguments to `res.status`
80   * Fix behavior of `null`/`undefined` as `maxAge` in `res.cookie`
81   * Fix handling very large stacks of sync middleware
82   * Ignore `Object.prototype` values in settings through `app.set`/`app.get`
83   * Invoke `default` with same arguments as types in `res.format`
84   * Support proper 205 responses using `res.send`
85   * Use `http-errors` for `res.format` error
86   * deps: body-parser@1.20.0
87     - Fix error message for json parse whitespace in `strict`
88     - Fix internal error when inflated body exceeds limit
89     - Prevent loss of async hooks context
90     - Prevent hanging when request already read
91     - deps: depd@2.0.0
92     - deps: http-errors@2.0.0
93     - deps: on-finished@2.4.1
94     - deps: qs@6.10.3
95     - deps: raw-body@2.5.1
96   * deps: cookie@0.5.0
97     - Add `priority` option
98     - Fix `expires` option to reject invalid dates
99   * deps: depd@2.0.0
100     - Replace internal `eval` usage with `Function` constructor
101     - Use instance methods on `process` to check for listeners
102   * deps: finalhandler@1.2.0
103     - Remove set content headers that break response
104     - deps: on-finished@2.4.1
105     - deps: statuses@2.0.1
106   * deps: on-finished@2.4.1
107     - Prevent loss of async hooks context
108   * deps: qs@6.10.3
109   * deps: send@0.18.0
110     - Fix emitted 416 error missing headers property
111     - Limit the headers removed for 304 response
112     - deps: depd@2.0.0
113     - deps: destroy@1.2.0
114     - deps: http-errors@2.0.0
115     - deps: on-finished@2.4.1
116     - deps: statuses@2.0.1
117   * deps: serve-static@1.15.0
118     - deps: send@0.18.0
119   * deps: statuses@2.0.1
120     - Remove code 306
121     - Rename `425 Unordered Collection` to standard `425 Too Early`
123 4.17.3 / 2022-02-16
124 ===================
126   * deps: accepts@~1.3.8
127     - deps: mime-types@~2.1.34
128     - deps: negotiator@0.6.3
129   * deps: body-parser@1.19.2
130     - deps: bytes@3.1.2
131     - deps: qs@6.9.7
132     - deps: raw-body@2.4.3
133   * deps: cookie@0.4.2
134   * deps: qs@6.9.7
135     * Fix handling of `__proto__` keys
136   * pref: remove unnecessary regexp for trust proxy
138 4.17.2 / 2021-12-16
139 ===================
141   * Fix handling of `undefined` in `res.jsonp`
142   * Fix handling of `undefined` when `"json escape"` is enabled
143   * Fix incorrect middleware execution with unanchored `RegExp`s
144   * Fix `res.jsonp(obj, status)` deprecation message
145   * Fix typo in `res.is` JSDoc
146   * deps: body-parser@1.19.1
147     - deps: bytes@3.1.1
148     - deps: http-errors@1.8.1
149     - deps: qs@6.9.6
150     - deps: raw-body@2.4.2
151     - deps: safe-buffer@5.2.1
152     - deps: type-is@~1.6.18
153   * deps: content-disposition@0.5.4
154     - deps: safe-buffer@5.2.1
155   * deps: cookie@0.4.1
156     - Fix `maxAge` option to reject invalid values
157   * deps: proxy-addr@~2.0.7
158     - Use `req.socket` over deprecated `req.connection`
159     - deps: forwarded@0.2.0
160     - deps: ipaddr.js@1.9.1
161   * deps: qs@6.9.6
162   * deps: safe-buffer@5.2.1
163   * deps: send@0.17.2
164     - deps: http-errors@1.8.1
165     - deps: ms@2.1.3
166     - pref: ignore empty http tokens
167   * deps: serve-static@1.14.2
168     - deps: send@0.17.2
169   * deps: setprototypeof@1.2.0
171 4.17.1 / 2019-05-25
172 ===================
174   * Revert "Improve error message for `null`/`undefined` to `res.status`"
176 4.17.0 / 2019-05-16
177 ===================
179   * Add `express.raw` to parse bodies into `Buffer`
180   * Add `express.text` to parse bodies into string
181   * Improve error message for non-strings to `res.sendFile`
182   * Improve error message for `null`/`undefined` to `res.status`
183   * Support multiple hosts in `X-Forwarded-Host`
184   * deps: accepts@~1.3.7
185   * deps: body-parser@1.19.0
186     - Add encoding MIK
187     - Add petabyte (`pb`) support
188     - Fix parsing array brackets after index
189     - deps: bytes@3.1.0
190     - deps: http-errors@1.7.2
191     - deps: iconv-lite@0.4.24
192     - deps: qs@6.7.0
193     - deps: raw-body@2.4.0
194     - deps: type-is@~1.6.17
195   * deps: content-disposition@0.5.3
196   * deps: cookie@0.4.0
197     - Add `SameSite=None` support
198   * deps: finalhandler@~1.1.2
199     - Set stricter `Content-Security-Policy` header
200     - deps: parseurl@~1.3.3
201     - deps: statuses@~1.5.0
202   * deps: parseurl@~1.3.3
203   * deps: proxy-addr@~2.0.5
204     - deps: ipaddr.js@1.9.0
205   * deps: qs@6.7.0
206     - Fix parsing array brackets after index
207   * deps: range-parser@~1.2.1
208   * deps: send@0.17.1
209     - Set stricter CSP header in redirect & error responses
210     - deps: http-errors@~1.7.2
211     - deps: mime@1.6.0
212     - deps: ms@2.1.1
213     - deps: range-parser@~1.2.1
214     - deps: statuses@~1.5.0
215     - perf: remove redundant `path.normalize` call
216   * deps: serve-static@1.14.1
217     - Set stricter CSP header in redirect response
218     - deps: parseurl@~1.3.3
219     - deps: send@0.17.1
220   * deps: setprototypeof@1.1.1
221   * deps: statuses@~1.5.0
222     - Add `103 Early Hints`
223   * deps: type-is@~1.6.18
224     - deps: mime-types@~2.1.24
225     - perf: prevent internal `throw` on invalid type
227 4.16.4 / 2018-10-10
228 ===================
230   * Fix issue where `"Request aborted"` may be logged in `res.sendfile`
231   * Fix JSDoc for `Router` constructor
232   * deps: body-parser@1.18.3
233     - Fix deprecation warnings on Node.js 10+
234     - Fix stack trace for strict json parse error
235     - deps: depd@~1.1.2
236     - deps: http-errors@~1.6.3
237     - deps: iconv-lite@0.4.23
238     - deps: qs@6.5.2
239     - deps: raw-body@2.3.3
240     - deps: type-is@~1.6.16
241   * deps: proxy-addr@~2.0.4
242     - deps: ipaddr.js@1.8.0
243   * deps: qs@6.5.2
244   * deps: safe-buffer@5.1.2
246 4.16.3 / 2018-03-12
247 ===================
249   * deps: accepts@~1.3.5
250     - deps: mime-types@~2.1.18
251   * deps: depd@~1.1.2
252     - perf: remove argument reassignment
253   * deps: encodeurl@~1.0.2
254     - Fix encoding `%` as last character
255   * deps: finalhandler@1.1.1
256     - Fix 404 output for bad / missing pathnames
257     - deps: encodeurl@~1.0.2
258     - deps: statuses@~1.4.0
259   * deps: proxy-addr@~2.0.3
260     - deps: ipaddr.js@1.6.0
261   * deps: send@0.16.2
262     - Fix incorrect end tag in default error & redirects
263     - deps: depd@~1.1.2
264     - deps: encodeurl@~1.0.2
265     - deps: statuses@~1.4.0
266   * deps: serve-static@1.13.2
267     - Fix incorrect end tag in redirects
268     - deps: encodeurl@~1.0.2
269     - deps: send@0.16.2
270   * deps: statuses@~1.4.0
271   * deps: type-is@~1.6.16
272     - deps: mime-types@~2.1.18
274 4.16.2 / 2017-10-09
275 ===================
277   * Fix `TypeError` in `res.send` when given `Buffer` and `ETag` header set
278   * perf: skip parsing of entire `X-Forwarded-Proto` header
280 4.16.1 / 2017-09-29
281 ===================
283   * deps: send@0.16.1
284   * deps: serve-static@1.13.1
285     - Fix regression when `root` is incorrectly set to a file
286     - deps: send@0.16.1
288 4.16.0 / 2017-09-28
289 ===================
291   * Add `"json escape"` setting for `res.json` and `res.jsonp`
292   * Add `express.json` and `express.urlencoded` to parse bodies
293   * Add `options` argument to `res.download`
294   * Improve error message when autoloading invalid view engine
295   * Improve error messages when non-function provided as middleware
296   * Skip `Buffer` encoding when not generating ETag for small response
297   * Use `safe-buffer` for improved Buffer API
298   * deps: accepts@~1.3.4
299     - deps: mime-types@~2.1.16
300   * deps: content-type@~1.0.4
301     - perf: remove argument reassignment
302     - perf: skip parameter parsing when no parameters
303   * deps: etag@~1.8.1
304     - perf: replace regular expression with substring
305   * deps: finalhandler@1.1.0
306     - Use `res.headersSent` when available
307   * deps: parseurl@~1.3.2
308     - perf: reduce overhead for full URLs
309     - perf: unroll the "fast-path" `RegExp`
310   * deps: proxy-addr@~2.0.2
311     - Fix trimming leading / trailing OWS in `X-Forwarded-For`
312     - deps: forwarded@~0.1.2
313     - deps: ipaddr.js@1.5.2
314     - perf: reduce overhead when no `X-Forwarded-For` header
315   * deps: qs@6.5.1
316     - Fix parsing & compacting very deep objects
317   * deps: send@0.16.0
318     - Add 70 new types for file extensions
319     - Add `immutable` option
320     - Fix missing `</html>` in default error & redirects
321     - Set charset as "UTF-8" for .js and .json
322     - Use instance methods on steam to check for listeners
323     - deps: mime@1.4.1
324     - perf: improve path validation speed
325   * deps: serve-static@1.13.0
326     - Add 70 new types for file extensions
327     - Add `immutable` option
328     - Set charset as "UTF-8" for .js and .json
329     - deps: send@0.16.0
330   * deps: setprototypeof@1.1.0
331   * deps: utils-merge@1.0.1
332   * deps: vary@~1.1.2
333     - perf: improve header token parsing speed
334   * perf: re-use options object when generating ETags
335   * perf: remove dead `.charset` set in `res.jsonp`
337 4.15.5 / 2017-09-24
338 ===================
340   * deps: debug@2.6.9
341   * deps: finalhandler@~1.0.6
342     - deps: debug@2.6.9
343     - deps: parseurl@~1.3.2
344   * deps: fresh@0.5.2
345     - Fix handling of modified headers with invalid dates
346     - perf: improve ETag match loop
347     - perf: improve `If-None-Match` token parsing
348   * deps: send@0.15.6
349     - Fix handling of modified headers with invalid dates
350     - deps: debug@2.6.9
351     - deps: etag@~1.8.1
352     - deps: fresh@0.5.2
353     - perf: improve `If-Match` token parsing
354   * deps: serve-static@1.12.6
355     - deps: parseurl@~1.3.2
356     - deps: send@0.15.6
357     - perf: improve slash collapsing
359 4.15.4 / 2017-08-06
360 ===================
362   * deps: debug@2.6.8
363   * deps: depd@~1.1.1
364     - Remove unnecessary `Buffer` loading
365   * deps: finalhandler@~1.0.4
366     - deps: debug@2.6.8
367   * deps: proxy-addr@~1.1.5
368     - Fix array argument being altered
369     - deps: ipaddr.js@1.4.0
370   * deps: qs@6.5.0
371   * deps: send@0.15.4
372     - deps: debug@2.6.8
373     - deps: depd@~1.1.1
374     - deps: http-errors@~1.6.2
375   * deps: serve-static@1.12.4
376     - deps: send@0.15.4
378 4.15.3 / 2017-05-16
379 ===================
381   * Fix error when `res.set` cannot add charset to `Content-Type`
382   * deps: debug@2.6.7
383     - Fix `DEBUG_MAX_ARRAY_LENGTH`
384     - deps: ms@2.0.0
385   * deps: finalhandler@~1.0.3
386     - Fix missing `</html>` in HTML document
387     - deps: debug@2.6.7
388   * deps: proxy-addr@~1.1.4
389     - deps: ipaddr.js@1.3.0
390   * deps: send@0.15.3
391     - deps: debug@2.6.7
392     - deps: ms@2.0.0
393   * deps: serve-static@1.12.3
394     - deps: send@0.15.3
395   * deps: type-is@~1.6.15
396     - deps: mime-types@~2.1.15
397   * deps: vary@~1.1.1
398     - perf: hoist regular expression
400 4.15.2 / 2017-03-06
401 ===================
403   * deps: qs@6.4.0
404     - Fix regression parsing keys starting with `[`
406 4.15.1 / 2017-03-05
407 ===================
409   * deps: send@0.15.1
410     - Fix issue when `Date.parse` does not return `NaN` on invalid date
411     - Fix strict violation in broken environments
412   * deps: serve-static@1.12.1
413     - Fix issue when `Date.parse` does not return `NaN` on invalid date
414     - deps: send@0.15.1
416 4.15.0 / 2017-03-01
417 ===================
419   * Add debug message when loading view engine
420   * Add `next("router")` to exit from router
421   * Fix case where `router.use` skipped requests routes did not
422   * Remove usage of `res._headers` private field
423     - Improves compatibility with Node.js 8 nightly
424   * Skip routing when `req.url` is not set
425   * Use `%o` in path debug to tell types apart
426   * Use `Object.create` to setup request & response prototypes
427   * Use `setprototypeof` module to replace `__proto__` setting
428   * Use `statuses` instead of `http` module for status messages
429   * deps: debug@2.6.1
430     - Allow colors in workers
431     - Deprecated `DEBUG_FD` environment variable set to `3` or higher
432     - Fix error when running under React Native
433     - Use same color for same namespace
434     - deps: ms@0.7.2
435   * deps: etag@~1.8.0
436     - Use SHA1 instead of MD5 for ETag hashing
437     - Works with FIPS 140-2 OpenSSL configuration
438   * deps: finalhandler@~1.0.0
439     - Fix exception when `err` cannot be converted to a string
440     - Fully URL-encode the pathname in the 404
441     - Only include the pathname in the 404 message
442     - Send complete HTML document
443     - Set `Content-Security-Policy: default-src 'self'` header
444     - deps: debug@2.6.1
445   * deps: fresh@0.5.0
446     - Fix false detection of `no-cache` request directive
447     - Fix incorrect result when `If-None-Match` has both `*` and ETags
448     - Fix weak `ETag` matching to match spec
449     - perf: delay reading header values until needed
450     - perf: enable strict mode
451     - perf: hoist regular expressions
452     - perf: remove duplicate conditional
453     - perf: remove unnecessary boolean coercions
454     - perf: skip checking modified time if ETag check failed
455     - perf: skip parsing `If-None-Match` when no `ETag` header
456     - perf: use `Date.parse` instead of `new Date`
457   * deps: qs@6.3.1
458     - Fix array parsing from skipping empty values
459     - Fix compacting nested arrays
460   * deps: send@0.15.0
461     - Fix false detection of `no-cache` request directive
462     - Fix incorrect result when `If-None-Match` has both `*` and ETags
463     - Fix weak `ETag` matching to match spec
464     - Remove usage of `res._headers` private field
465     - Support `If-Match` and `If-Unmodified-Since` headers
466     - Use `res.getHeaderNames()` when available
467     - Use `res.headersSent` when available
468     - deps: debug@2.6.1
469     - deps: etag@~1.8.0
470     - deps: fresh@0.5.0
471     - deps: http-errors@~1.6.1
472   * deps: serve-static@1.12.0
473     - Fix false detection of `no-cache` request directive
474     - Fix incorrect result when `If-None-Match` has both `*` and ETags
475     - Fix weak `ETag` matching to match spec
476     - Remove usage of `res._headers` private field
477     - Send complete HTML document in redirect response
478     - Set default CSP header in redirect response
479     - Support `If-Match` and `If-Unmodified-Since` headers
480     - Use `res.getHeaderNames()` when available
481     - Use `res.headersSent` when available
482     - deps: send@0.15.0
483   * perf: add fast match path for `*` route
484   * perf: improve `req.ips` performance
486 4.14.1 / 2017-01-28
487 ===================
489   * deps: content-disposition@0.5.2
490   * deps: finalhandler@0.5.1
491     - Fix exception when `err.headers` is not an object
492     - deps: statuses@~1.3.1
493     - perf: hoist regular expressions
494     - perf: remove duplicate validation path
495   * deps: proxy-addr@~1.1.3
496     - deps: ipaddr.js@1.2.0
497   * deps: send@0.14.2
498     - deps: http-errors@~1.5.1
499     - deps: ms@0.7.2
500     - deps: statuses@~1.3.1
501   * deps: serve-static@~1.11.2
502     - deps: send@0.14.2
503   * deps: type-is@~1.6.14
504     - deps: mime-types@~2.1.13
506 4.14.0 / 2016-06-16
507 ===================
509   * Add `acceptRanges` option to `res.sendFile`/`res.sendfile`
510   * Add `cacheControl` option to `res.sendFile`/`res.sendfile`
511   * Add `options` argument to `req.range`
512     - Includes the `combine` option
513   * Encode URL in `res.location`/`res.redirect` if not already encoded
514   * Fix some redirect handling in `res.sendFile`/`res.sendfile`
515   * Fix Windows absolute path check using forward slashes
516   * Improve error with invalid arguments to `req.get()`
517   * Improve performance for `res.json`/`res.jsonp` in most cases
518   * Improve `Range` header handling in `res.sendFile`/`res.sendfile`
519   * deps: accepts@~1.3.3
520     - Fix including type extensions in parameters in `Accept` parsing
521     - Fix parsing `Accept` parameters with quoted equals
522     - Fix parsing `Accept` parameters with quoted semicolons
523     - Many performance improvements
524     - deps: mime-types@~2.1.11
525     - deps: negotiator@0.6.1
526   * deps: content-type@~1.0.2
527     - perf: enable strict mode
528   * deps: cookie@0.3.1
529     - Add `sameSite` option
530     - Fix cookie `Max-Age` to never be a floating point number
531     - Improve error message when `encode` is not a function
532     - Improve error message when `expires` is not a `Date`
533     - Throw better error for invalid argument to parse
534     - Throw on invalid values provided to `serialize`
535     - perf: enable strict mode
536     - perf: hoist regular expression
537     - perf: use for loop in parse
538     - perf: use string concatenation for serialization
539   * deps: finalhandler@0.5.0
540     - Change invalid or non-numeric status code to 500
541     - Overwrite status message to match set status code
542     - Prefer `err.statusCode` if `err.status` is invalid
543     - Set response headers from `err.headers` object
544     - Use `statuses` instead of `http` module for status messages
545   * deps: proxy-addr@~1.1.2
546     - Fix accepting various invalid netmasks
547     - Fix IPv6-mapped IPv4 validation edge cases
548     - IPv4 netmasks must be contiguous
549     - IPv6 addresses cannot be used as a netmask
550     - deps: ipaddr.js@1.1.1
551   * deps: qs@6.2.0
552     - Add `decoder` option in `parse` function
553   * deps: range-parser@~1.2.0
554     - Add `combine` option to combine overlapping ranges
555     - Fix incorrectly returning -1 when there is at least one valid range
556     - perf: remove internal function
557   * deps: send@0.14.1
558     - Add `acceptRanges` option
559     - Add `cacheControl` option
560     - Attempt to combine multiple ranges into single range
561     - Correctly inherit from `Stream` class
562     - Fix `Content-Range` header in 416 responses when using `start`/`end` options
563     - Fix `Content-Range` header missing from default 416 responses
564     - Fix redirect error when `path` contains raw non-URL characters
565     - Fix redirect when `path` starts with multiple forward slashes
566     - Ignore non-byte `Range` headers
567     - deps: http-errors@~1.5.0
568     - deps: range-parser@~1.2.0
569     - deps: statuses@~1.3.0
570     - perf: remove argument reassignment
571   * deps: serve-static@~1.11.1
572     - Add `acceptRanges` option
573     - Add `cacheControl` option
574     - Attempt to combine multiple ranges into single range
575     - Fix redirect error when `req.url` contains raw non-URL characters
576     - Ignore non-byte `Range` headers
577     - Use status code 301 for redirects
578     - deps: send@0.14.1
579   * deps: type-is@~1.6.13
580     - Fix type error when given invalid type to match against
581     - deps: mime-types@~2.1.11
582   * deps: vary@~1.1.0
583     - Only accept valid field names in the `field` argument
584   * perf: use strict equality when possible
586 4.13.4 / 2016-01-21
587 ===================
589   * deps: content-disposition@0.5.1
590     - perf: enable strict mode
591   * deps: cookie@0.1.5
592     - Throw on invalid values provided to `serialize`
593   * deps: depd@~1.1.0
594     - Support web browser loading
595     - perf: enable strict mode
596   * deps: escape-html@~1.0.3
597     - perf: enable strict mode
598     - perf: optimize string replacement
599     - perf: use faster string coercion
600   * deps: finalhandler@0.4.1
601     - deps: escape-html@~1.0.3
602   * deps: merge-descriptors@1.0.1
603     - perf: enable strict mode
604   * deps: methods@~1.1.2
605     - perf: enable strict mode
606   * deps: parseurl@~1.3.1
607     - perf: enable strict mode
608   * deps: proxy-addr@~1.0.10
609     - deps: ipaddr.js@1.0.5
610     - perf: enable strict mode
611   * deps: range-parser@~1.0.3
612     - perf: enable strict mode
613   * deps: send@0.13.1
614     - deps: depd@~1.1.0
615     - deps: destroy@~1.0.4
616     - deps: escape-html@~1.0.3
617     - deps: range-parser@~1.0.3
618   * deps: serve-static@~1.10.2
619     - deps: escape-html@~1.0.3
620     - deps: parseurl@~1.3.0
621     - deps: send@0.13.1
623 4.13.3 / 2015-08-02
624 ===================
626   * Fix infinite loop condition using `mergeParams: true`
627   * Fix inner numeric indices incorrectly altering parent `req.params`
629 4.13.2 / 2015-07-31
630 ===================
632   * deps: accepts@~1.2.12
633     - deps: mime-types@~2.1.4
634   * deps: array-flatten@1.1.1
635     - perf: enable strict mode
636   * deps: path-to-regexp@0.1.7
637     - Fix regression with escaped round brackets and matching groups
638   * deps: type-is@~1.6.6
639     - deps: mime-types@~2.1.4
641 4.13.1 / 2015-07-05
642 ===================
644   * deps: accepts@~1.2.10
645     - deps: mime-types@~2.1.2
646   * deps: qs@4.0.0
647     - Fix dropping parameters like `hasOwnProperty`
648     - Fix various parsing edge cases
649   * deps: type-is@~1.6.4
650     - deps: mime-types@~2.1.2
651     - perf: enable strict mode
652     - perf: remove argument reassignment
654 4.13.0 / 2015-06-20
655 ===================
657   * Add settings to debug output
658   * Fix `res.format` error when only `default` provided
659   * Fix issue where `next('route')` in `app.param` would incorrectly skip values
660   * Fix hiding platform issues with `decodeURIComponent`
661     - Only `URIError`s are a 400
662   * Fix using `*` before params in routes
663   * Fix using capture groups before params in routes
664   * Simplify `res.cookie` to call `res.append`
665   * Use `array-flatten` module for flattening arrays
666   * deps: accepts@~1.2.9
667     - deps: mime-types@~2.1.1
668     - perf: avoid argument reassignment & argument slice
669     - perf: avoid negotiator recursive construction
670     - perf: enable strict mode
671     - perf: remove unnecessary bitwise operator
672   * deps: cookie@0.1.3
673     - perf: deduce the scope of try-catch deopt
674     - perf: remove argument reassignments
675   * deps: escape-html@1.0.2
676   * deps: etag@~1.7.0
677     - Always include entity length in ETags for hash length extensions
678     - Generate non-Stats ETags using MD5 only (no longer CRC32)
679     - Improve stat performance by removing hashing
680     - Improve support for JXcore
681     - Remove base64 padding in ETags to shorten
682     - Support "fake" stats objects in environments without fs
683     - Use MD5 instead of MD4 in weak ETags over 1KB
684   * deps: finalhandler@0.4.0
685     - Fix a false-positive when unpiping in Node.js 0.8
686     - Support `statusCode` property on `Error` objects
687     - Use `unpipe` module for unpiping requests
688     - deps: escape-html@1.0.2
689     - deps: on-finished@~2.3.0
690     - perf: enable strict mode
691     - perf: remove argument reassignment
692   * deps: fresh@0.3.0
693     - Add weak `ETag` matching support
694   * deps: on-finished@~2.3.0
695     - Add defined behavior for HTTP `CONNECT` requests
696     - Add defined behavior for HTTP `Upgrade` requests
697     - deps: ee-first@1.1.1
698   * deps: path-to-regexp@0.1.6
699   * deps: send@0.13.0
700     - Allow Node.js HTTP server to set `Date` response header
701     - Fix incorrectly removing `Content-Location` on 304 response
702     - Improve the default redirect response headers
703     - Send appropriate headers on default error response
704     - Use `http-errors` for standard emitted errors
705     - Use `statuses` instead of `http` module for status messages
706     - deps: escape-html@1.0.2
707     - deps: etag@~1.7.0
708     - deps: fresh@0.3.0
709     - deps: on-finished@~2.3.0
710     - perf: enable strict mode
711     - perf: remove unnecessary array allocations
712   * deps: serve-static@~1.10.0
713     - Add `fallthrough` option
714     - Fix reading options from options prototype
715     - Improve the default redirect response headers
716     - Malformed URLs now `next()` instead of 400
717     - deps: escape-html@1.0.2
718     - deps: send@0.13.0
719     - perf: enable strict mode
720     - perf: remove argument reassignment
721   * deps: type-is@~1.6.3
722     - deps: mime-types@~2.1.1
723     - perf: reduce try block size
724     - perf: remove bitwise operations
725   * perf: enable strict mode
726   * perf: isolate `app.render` try block
727   * perf: remove argument reassignments in application
728   * perf: remove argument reassignments in request prototype
729   * perf: remove argument reassignments in response prototype
730   * perf: remove argument reassignments in routing
731   * perf: remove argument reassignments in `View`
732   * perf: skip attempting to decode zero length string
733   * perf: use saved reference to `http.STATUS_CODES`
735 4.12.4 / 2015-05-17
736 ===================
738   * deps: accepts@~1.2.7
739     - deps: mime-types@~2.0.11
740     - deps: negotiator@0.5.3
741   * deps: debug@~2.2.0
742     - deps: ms@0.7.1
743   * deps: depd@~1.0.1
744   * deps: etag@~1.6.0
745     - Improve support for JXcore
746     - Support "fake" stats objects in environments without `fs`
747   * deps: finalhandler@0.3.6
748     - deps: debug@~2.2.0
749     - deps: on-finished@~2.2.1
750   * deps: on-finished@~2.2.1
751     - Fix `isFinished(req)` when data buffered
752   * deps: proxy-addr@~1.0.8
753     - deps: ipaddr.js@1.0.1
754   * deps: qs@2.4.2
755    - Fix allowing parameters like `constructor`
756   * deps: send@0.12.3
757     - deps: debug@~2.2.0
758     - deps: depd@~1.0.1
759     - deps: etag@~1.6.0
760     - deps: ms@0.7.1
761     - deps: on-finished@~2.2.1
762   * deps: serve-static@~1.9.3
763     - deps: send@0.12.3
764   * deps: type-is@~1.6.2
765     - deps: mime-types@~2.0.11
767 4.12.3 / 2015-03-17
768 ===================
770   * deps: accepts@~1.2.5
771     - deps: mime-types@~2.0.10
772   * deps: debug@~2.1.3
773     - Fix high intensity foreground color for bold
774     - deps: ms@0.7.0
775   * deps: finalhandler@0.3.4
776     - deps: debug@~2.1.3
777   * deps: proxy-addr@~1.0.7
778     - deps: ipaddr.js@0.1.9
779   * deps: qs@2.4.1
780     - Fix error when parameter `hasOwnProperty` is present
781   * deps: send@0.12.2
782     - Throw errors early for invalid `extensions` or `index` options
783     - deps: debug@~2.1.3
784   * deps: serve-static@~1.9.2
785     - deps: send@0.12.2
786   * deps: type-is@~1.6.1
787     - deps: mime-types@~2.0.10
789 4.12.2 / 2015-03-02
790 ===================
792   * Fix regression where `"Request aborted"` is logged using `res.sendFile`
794 4.12.1 / 2015-03-01
795 ===================
797   * Fix constructing application with non-configurable prototype properties
798   * Fix `ECONNRESET` errors from `res.sendFile` usage
799   * Fix `req.host` when using "trust proxy" hops count
800   * Fix `req.protocol`/`req.secure` when using "trust proxy" hops count
801   * Fix wrong `code` on aborted connections from `res.sendFile`
802   * deps: merge-descriptors@1.0.0
804 4.12.0 / 2015-02-23
805 ===================
807   * Fix `"trust proxy"` setting to inherit when app is mounted
808   * Generate `ETag`s for all request responses
809     - No longer restricted to only responses for `GET` and `HEAD` requests
810   * Use `content-type` to parse `Content-Type` headers
811   * deps: accepts@~1.2.4
812     - Fix preference sorting to be stable for long acceptable lists
813     - deps: mime-types@~2.0.9
814     - deps: negotiator@0.5.1
815   * deps: cookie-signature@1.0.6
816   * deps: send@0.12.1
817     - Always read the stat size from the file
818     - Fix mutating passed-in `options`
819     - deps: mime@1.3.4
820   * deps: serve-static@~1.9.1
821     - deps: send@0.12.1
822   * deps: type-is@~1.6.0
823     - fix argument reassignment
824     - fix false-positives in `hasBody` `Transfer-Encoding` check
825     - support wildcard for both type and subtype (`*/*`)
826     - deps: mime-types@~2.0.9
828 4.11.2 / 2015-02-01
829 ===================
831   * Fix `res.redirect` double-calling `res.end` for `HEAD` requests
832   * deps: accepts@~1.2.3
833     - deps: mime-types@~2.0.8
834   * deps: proxy-addr@~1.0.6
835     - deps: ipaddr.js@0.1.8
836   * deps: type-is@~1.5.6
837     - deps: mime-types@~2.0.8
839 4.11.1 / 2015-01-20
840 ===================
842   * deps: send@0.11.1
843     - Fix root path disclosure
844   * deps: serve-static@~1.8.1
845     - Fix redirect loop in Node.js 0.11.14
846     - Fix root path disclosure
847     - deps: send@0.11.1
849 4.11.0 / 2015-01-13
850 ===================
852   * Add `res.append(field, val)` to append headers
853   * Deprecate leading `:` in `name` for `app.param(name, fn)`
854   * Deprecate `req.param()` -- use `req.params`, `req.body`, or `req.query` instead
855   * Deprecate `app.param(fn)`
856   * Fix `OPTIONS` responses to include the `HEAD` method properly
857   * Fix `res.sendFile` not always detecting aborted connection
858   * Match routes iteratively to prevent stack overflows
859   * deps: accepts@~1.2.2
860     - deps: mime-types@~2.0.7
861     - deps: negotiator@0.5.0
862   * deps: send@0.11.0
863     - deps: debug@~2.1.1
864     - deps: etag@~1.5.1
865     - deps: ms@0.7.0
866     - deps: on-finished@~2.2.0
867   * deps: serve-static@~1.8.0
868     - deps: send@0.11.0
870 4.10.8 / 2015-01-13
871 ===================
873   * Fix crash from error within `OPTIONS` response handler
874   * deps: proxy-addr@~1.0.5
875     - deps: ipaddr.js@0.1.6
877 4.10.7 / 2015-01-04
878 ===================
880   * Fix `Allow` header for `OPTIONS` to not contain duplicate methods
881   * Fix incorrect "Request aborted" for `res.sendFile` when `HEAD` or 304
882   * deps: debug@~2.1.1
883   * deps: finalhandler@0.3.3
884     - deps: debug@~2.1.1
885     - deps: on-finished@~2.2.0
886   * deps: methods@~1.1.1
887   * deps: on-finished@~2.2.0
888   * deps: serve-static@~1.7.2
889     - Fix potential open redirect when mounted at root
890   * deps: type-is@~1.5.5
891     - deps: mime-types@~2.0.7
893 4.10.6 / 2014-12-12
894 ===================
896   * Fix exception in `req.fresh`/`req.stale` without response headers
898 4.10.5 / 2014-12-10
899 ===================
901   * Fix `res.send` double-calling `res.end` for `HEAD` requests
902   * deps: accepts@~1.1.4
903     - deps: mime-types@~2.0.4
904   * deps: type-is@~1.5.4
905     - deps: mime-types@~2.0.4
907 4.10.4 / 2014-11-24
908 ===================
910   * Fix `res.sendfile` logging standard write errors
912 4.10.3 / 2014-11-23
913 ===================
915   * Fix `res.sendFile` logging standard write errors
916   * deps: etag@~1.5.1
917   * deps: proxy-addr@~1.0.4
918     - deps: ipaddr.js@0.1.5
919   * deps: qs@2.3.3
920     - Fix `arrayLimit` behavior
922 4.10.2 / 2014-11-09
923 ===================
925   * Correctly invoke async router callback asynchronously
926   * deps: accepts@~1.1.3
927     - deps: mime-types@~2.0.3
928   * deps: type-is@~1.5.3
929     - deps: mime-types@~2.0.3
931 4.10.1 / 2014-10-28
932 ===================
934   * Fix handling of URLs containing `://` in the path
935   * deps: qs@2.3.2
936     - Fix parsing of mixed objects and values
938 4.10.0 / 2014-10-23
939 ===================
941   * Add support for `app.set('views', array)`
942     - Views are looked up in sequence in array of directories
943   * Fix `res.send(status)` to mention `res.sendStatus(status)`
944   * Fix handling of invalid empty URLs
945   * Use `content-disposition` module for `res.attachment`/`res.download`
946     - Sends standards-compliant `Content-Disposition` header
947     - Full Unicode support
948   * Use `path.resolve` in view lookup
949   * deps: debug@~2.1.0
950     - Implement `DEBUG_FD` env variable support
951   * deps: depd@~1.0.0
952   * deps: etag@~1.5.0
953     - Improve string performance
954     - Slightly improve speed for weak ETags over 1KB
955   * deps: finalhandler@0.3.2
956     - Terminate in progress response only on error
957     - Use `on-finished` to determine request status
958     - deps: debug@~2.1.0
959     - deps: on-finished@~2.1.1
960   * deps: on-finished@~2.1.1
961     - Fix handling of pipelined requests
962   * deps: qs@2.3.0
963     - Fix parsing of mixed implicit and explicit arrays
964   * deps: send@0.10.1
965     - deps: debug@~2.1.0
966     - deps: depd@~1.0.0
967     - deps: etag@~1.5.0
968     - deps: on-finished@~2.1.1
969   * deps: serve-static@~1.7.1
970     - deps: send@0.10.1
972 4.9.8 / 2014-10-17
973 ==================
975   * Fix `res.redirect` body when redirect status specified
976   * deps: accepts@~1.1.2
977     - Fix error when media type has invalid parameter
978     - deps: negotiator@0.4.9
980 4.9.7 / 2014-10-10
981 ==================
983   * Fix using same param name in array of paths
985 4.9.6 / 2014-10-08
986 ==================
988   * deps: accepts@~1.1.1
989     - deps: mime-types@~2.0.2
990     - deps: negotiator@0.4.8
991   * deps: serve-static@~1.6.4
992     - Fix redirect loop when index file serving disabled
993   * deps: type-is@~1.5.2
994     - deps: mime-types@~2.0.2
996 4.9.5 / 2014-09-24
997 ==================
999   * deps: etag@~1.4.0
1000   * deps: proxy-addr@~1.0.3
1001     - Use `forwarded` npm module
1002   * deps: send@0.9.3
1003     - deps: etag@~1.4.0
1004   * deps: serve-static@~1.6.3
1005     - deps: send@0.9.3
1007 4.9.4 / 2014-09-19
1008 ==================
1010   * deps: qs@2.2.4
1011     - Fix issue with object keys starting with numbers truncated
1013 4.9.3 / 2014-09-18
1014 ==================
1016   * deps: proxy-addr@~1.0.2
1017     - Fix a global leak when multiple subnets are trusted
1018     - deps: ipaddr.js@0.1.3
1020 4.9.2 / 2014-09-17
1021 ==================
1023   * Fix regression for empty string `path` in `app.use`
1024   * Fix `router.use` to accept array of middleware without path
1025   * Improve error message for bad `app.use` arguments
1027 4.9.1 / 2014-09-16
1028 ==================
1030   * Fix `app.use` to accept array of middleware without path
1031   * deps: depd@0.4.5
1032   * deps: etag@~1.3.1
1033   * deps: send@0.9.2
1034     - deps: depd@0.4.5
1035     - deps: etag@~1.3.1
1036     - deps: range-parser@~1.0.2
1037   * deps: serve-static@~1.6.2
1038     - deps: send@0.9.2
1040 4.9.0 / 2014-09-08
1041 ==================
1043   * Add `res.sendStatus`
1044   * Invoke callback for sendfile when client aborts
1045     - Applies to `res.sendFile`, `res.sendfile`, and `res.download`
1046     - `err` will be populated with request aborted error
1047   * Support IP address host in `req.subdomains`
1048   * Use `etag` to generate `ETag` headers
1049   * deps: accepts@~1.1.0
1050     - update `mime-types`
1051   * deps: cookie-signature@1.0.5
1052   * deps: debug@~2.0.0
1053   * deps: finalhandler@0.2.0
1054     - Set `X-Content-Type-Options: nosniff` header
1055     - deps: debug@~2.0.0
1056   * deps: fresh@0.2.4
1057   * deps: media-typer@0.3.0
1058     - Throw error when parameter format invalid on parse
1059   * deps: qs@2.2.3
1060     - Fix issue where first empty value in array is discarded
1061   * deps: range-parser@~1.0.2
1062   * deps: send@0.9.1
1063     - Add `lastModified` option
1064     - Use `etag` to generate `ETag` header
1065     - deps: debug@~2.0.0
1066     - deps: fresh@0.2.4
1067   * deps: serve-static@~1.6.1
1068     - Add `lastModified` option
1069     - deps: send@0.9.1
1070   * deps: type-is@~1.5.1
1071     - fix `hasbody` to be true for `content-length: 0`
1072     - deps: media-typer@0.3.0
1073     - deps: mime-types@~2.0.1
1074   * deps: vary@~1.0.0
1075     - Accept valid `Vary` header string as `field`
1077 4.8.8 / 2014-09-04
1078 ==================
1080   * deps: send@0.8.5
1081     - Fix a path traversal issue when using `root`
1082     - Fix malicious path detection for empty string path
1083   * deps: serve-static@~1.5.4
1084     - deps: send@0.8.5
1086 4.8.7 / 2014-08-29
1087 ==================
1089   * deps: qs@2.2.2
1090     - Remove unnecessary cloning
1092 4.8.6 / 2014-08-27
1093 ==================
1095   * deps: qs@2.2.0
1096     - Array parsing fix
1097     - Performance improvements
1099 4.8.5 / 2014-08-18
1100 ==================
1102   * deps: send@0.8.3
1103     - deps: destroy@1.0.3
1104     - deps: on-finished@2.1.0
1105   * deps: serve-static@~1.5.3
1106     - deps: send@0.8.3
1108 4.8.4 / 2014-08-14
1109 ==================
1111   * deps: qs@1.2.2
1112   * deps: send@0.8.2
1113     - Work around `fd` leak in Node.js 0.10 for `fs.ReadStream`
1114   * deps: serve-static@~1.5.2
1115     - deps: send@0.8.2
1117 4.8.3 / 2014-08-10
1118 ==================
1120   * deps: parseurl@~1.3.0
1121   * deps: qs@1.2.1
1122   * deps: serve-static@~1.5.1
1123     - Fix parsing of weird `req.originalUrl` values
1124     - deps: parseurl@~1.3.0
1125     - deps: utils-merge@1.0.0
1127 4.8.2 / 2014-08-07
1128 ==================
1130   * deps: qs@1.2.0
1131     - Fix parsing array of objects
1133 4.8.1 / 2014-08-06
1134 ==================
1136   * fix incorrect deprecation warnings on `res.download`
1137   * deps: qs@1.1.0
1138     - Accept urlencoded square brackets
1139     - Accept empty values in implicit array notation
1141 4.8.0 / 2014-08-05
1142 ==================
1144   * add `res.sendFile`
1145     - accepts a file system path instead of a URL
1146     - requires an absolute path or `root` option specified
1147   * deprecate `res.sendfile` -- use `res.sendFile` instead
1148   * support mounted app as any argument to `app.use()`
1149   * deps: qs@1.0.2
1150     - Complete rewrite
1151     - Limits array length to 20
1152     - Limits object depth to 5
1153     - Limits parameters to 1,000
1154   * deps: send@0.8.1
1155     - Add `extensions` option
1156   * deps: serve-static@~1.5.0
1157     - Add `extensions` option
1158     - deps: send@0.8.1
1160 4.7.4 / 2014-08-04
1161 ==================
1163   * fix `res.sendfile` regression for serving directory index files
1164   * deps: send@0.7.4
1165     - Fix incorrect 403 on Windows and Node.js 0.11
1166     - Fix serving index files without root dir
1167   * deps: serve-static@~1.4.4
1168     - deps: send@0.7.4
1170 4.7.3 / 2014-08-04
1171 ==================
1173   * deps: send@0.7.3
1174     - Fix incorrect 403 on Windows and Node.js 0.11
1175   * deps: serve-static@~1.4.3
1176     - Fix incorrect 403 on Windows and Node.js 0.11
1177     - deps: send@0.7.3
1179 4.7.2 / 2014-07-27
1180 ==================
1182   * deps: depd@0.4.4
1183     - Work-around v8 generating empty stack traces
1184   * deps: send@0.7.2
1185     - deps: depd@0.4.4
1186   * deps: serve-static@~1.4.2
1188 4.7.1 / 2014-07-26
1189 ==================
1191   * deps: depd@0.4.3
1192     - Fix exception when global `Error.stackTraceLimit` is too low
1193   * deps: send@0.7.1
1194     - deps: depd@0.4.3
1195   * deps: serve-static@~1.4.1
1197 4.7.0 / 2014-07-25
1198 ==================
1200   * fix `req.protocol` for proxy-direct connections
1201   * configurable query parser with `app.set('query parser', parser)`
1202     - `app.set('query parser', 'extended')` parse with "qs" module
1203     - `app.set('query parser', 'simple')` parse with "querystring" core module
1204     - `app.set('query parser', false)` disable query string parsing
1205     - `app.set('query parser', true)` enable simple parsing
1206   * deprecate `res.json(status, obj)` -- use `res.status(status).json(obj)` instead
1207   * deprecate `res.jsonp(status, obj)` -- use `res.status(status).jsonp(obj)` instead
1208   * deprecate `res.send(status, body)` -- use `res.status(status).send(body)` instead
1209   * deps: debug@1.0.4
1210   * deps: depd@0.4.2
1211     - Add `TRACE_DEPRECATION` environment variable
1212     - Remove non-standard grey color from color output
1213     - Support `--no-deprecation` argument
1214     - Support `--trace-deprecation` argument
1215   * deps: finalhandler@0.1.0
1216     - Respond after request fully read
1217     - deps: debug@1.0.4
1218   * deps: parseurl@~1.2.0
1219     - Cache URLs based on original value
1220     - Remove no-longer-needed URL mis-parse work-around
1221     - Simplify the "fast-path" `RegExp`
1222   * deps: send@0.7.0
1223     - Add `dotfiles` option
1224     - Cap `maxAge` value to 1 year
1225     - deps: debug@1.0.4
1226     - deps: depd@0.4.2
1227   * deps: serve-static@~1.4.0
1228     - deps: parseurl@~1.2.0
1229     - deps: send@0.7.0
1230   * perf: prevent multiple `Buffer` creation in `res.send`
1232 4.6.1 / 2014-07-12
1233 ==================
1235   * fix `subapp.mountpath` regression for `app.use(subapp)`
1237 4.6.0 / 2014-07-11
1238 ==================
1240   * accept multiple callbacks to `app.use()`
1241   * add explicit "Rosetta Flash JSONP abuse" protection
1242     - previous versions are not vulnerable; this is just explicit protection
1243   * catch errors in multiple `req.param(name, fn)` handlers
1244   * deprecate `res.redirect(url, status)` -- use `res.redirect(status, url)` instead
1245   * fix `res.send(status, num)` to send `num` as json (not error)
1246   * remove unnecessary escaping when `res.jsonp` returns JSON response
1247   * support non-string `path` in `app.use(path, fn)`
1248     - supports array of paths
1249     - supports `RegExp`
1250   * router: fix optimization on router exit
1251   * router: refactor location of `try` blocks
1252   * router: speed up standard `app.use(fn)`
1253   * deps: debug@1.0.3
1254     - Add support for multiple wildcards in namespaces
1255   * deps: finalhandler@0.0.3
1256     - deps: debug@1.0.3
1257   * deps: methods@1.1.0
1258     - add `CONNECT`
1259   * deps: parseurl@~1.1.3
1260     - faster parsing of href-only URLs
1261   * deps: path-to-regexp@0.1.3
1262   * deps: send@0.6.0
1263     - deps: debug@1.0.3
1264   * deps: serve-static@~1.3.2
1265     - deps: parseurl@~1.1.3
1266     - deps: send@0.6.0
1267   * perf: fix arguments reassign deopt in some `res` methods
1269 4.5.1 / 2014-07-06
1270 ==================
1272  * fix routing regression when altering `req.method`
1274 4.5.0 / 2014-07-04
1275 ==================
1277  * add deprecation message to non-plural `req.accepts*`
1278  * add deprecation message to `res.send(body, status)`
1279  * add deprecation message to `res.vary()`
1280  * add `headers` option to `res.sendfile`
1281    - use to set headers on successful file transfer
1282  * add `mergeParams` option to `Router`
1283    - merges `req.params` from parent routes
1284  * add `req.hostname` -- correct name for what `req.host` returns
1285  * deprecate things with `depd` module
1286  * deprecate `req.host` -- use `req.hostname` instead
1287  * fix behavior when handling request without routes
1288  * fix handling when `route.all` is only route
1289  * invoke `router.param()` only when route matches
1290  * restore `req.params` after invoking router
1291  * use `finalhandler` for final response handling
1292  * use `media-typer` to alter content-type charset
1293  * deps: accepts@~1.0.7
1294  * deps: send@0.5.0
1295    - Accept string for `maxage` (converted by `ms`)
1296    - Include link in default redirect response
1297  * deps: serve-static@~1.3.0
1298    - Accept string for `maxAge` (converted by `ms`)
1299    - Add `setHeaders` option
1300    - Include HTML link in redirect response
1301    - deps: send@0.5.0
1302  * deps: type-is@~1.3.2
1304 4.4.5 / 2014-06-26
1305 ==================
1307  * deps: cookie-signature@1.0.4
1308    - fix for timing attacks
1310 4.4.4 / 2014-06-20
1311 ==================
1313  * fix `res.attachment` Unicode filenames in Safari
1314  * fix "trim prefix" debug message in `express:router`
1315  * deps: accepts@~1.0.5
1316  * deps: buffer-crc32@0.2.3
1318 4.4.3 / 2014-06-11
1319 ==================
1321  * fix persistence of modified `req.params[name]` from `app.param()`
1322  * deps: accepts@1.0.3
1323    - deps: negotiator@0.4.6
1324  * deps: debug@1.0.2
1325  * deps: send@0.4.3
1326    - Do not throw uncatchable error on file open race condition
1327    - Use `escape-html` for HTML escaping
1328    - deps: debug@1.0.2
1329    - deps: finished@1.2.2
1330    - deps: fresh@0.2.2
1331  * deps: serve-static@1.2.3
1332    - Do not throw uncatchable error on file open race condition
1333    - deps: send@0.4.3
1335 4.4.2 / 2014-06-09
1336 ==================
1338  * fix catching errors from top-level handlers
1339  * use `vary` module for `res.vary`
1340  * deps: debug@1.0.1
1341  * deps: proxy-addr@1.0.1
1342  * deps: send@0.4.2
1343    - fix "event emitter leak" warnings
1344    - deps: debug@1.0.1
1345    - deps: finished@1.2.1
1346  * deps: serve-static@1.2.2
1347    - fix "event emitter leak" warnings
1348    - deps: send@0.4.2
1349  * deps: type-is@1.2.1
1351 4.4.1 / 2014-06-02
1352 ==================
1354  * deps: methods@1.0.1
1355  * deps: send@0.4.1
1356    - Send `max-age` in `Cache-Control` in correct format
1357  * deps: serve-static@1.2.1
1358    - use `escape-html` for escaping
1359    - deps: send@0.4.1
1361 4.4.0 / 2014-05-30
1362 ==================
1364  * custom etag control with `app.set('etag', val)`
1365    - `app.set('etag', function(body, encoding){ return '"etag"' })` custom etag generation
1366    - `app.set('etag', 'weak')` weak tag
1367    - `app.set('etag', 'strong')` strong etag
1368    - `app.set('etag', false)` turn off
1369    - `app.set('etag', true)` standard etag
1370  * mark `res.send` ETag as weak and reduce collisions
1371  * update accepts to 1.0.2
1372    - Fix interpretation when header not in request
1373  * update send to 0.4.0
1374    - Calculate ETag with md5 for reduced collisions
1375    - Ignore stream errors after request ends
1376    - deps: debug@0.8.1
1377  * update serve-static to 1.2.0
1378    - Calculate ETag with md5 for reduced collisions
1379    - Ignore stream errors after request ends
1380    - deps: send@0.4.0
1382 4.3.2 / 2014-05-28
1383 ==================
1385  * fix handling of errors from `router.param()` callbacks
1387 4.3.1 / 2014-05-23
1388 ==================
1390  * revert "fix behavior of multiple `app.VERB` for the same path"
1391    - this caused a regression in the order of route execution
1393 4.3.0 / 2014-05-21
1394 ==================
1396  * add `req.baseUrl` to access the path stripped from `req.url` in routes
1397  * fix behavior of multiple `app.VERB` for the same path
1398  * fix issue routing requests among sub routers
1399  * invoke `router.param()` only when necessary instead of every match
1400  * proper proxy trust with `app.set('trust proxy', trust)`
1401    - `app.set('trust proxy', 1)` trust first hop
1402    - `app.set('trust proxy', 'loopback')` trust loopback addresses
1403    - `app.set('trust proxy', '10.0.0.1')` trust single IP
1404    - `app.set('trust proxy', '10.0.0.1/16')` trust subnet
1405    - `app.set('trust proxy', '10.0.0.1, 10.0.0.2')` trust list
1406    - `app.set('trust proxy', false)` turn off
1407    - `app.set('trust proxy', true)` trust everything
1408  * set proper `charset` in `Content-Type` for `res.send`
1409  * update type-is to 1.2.0
1410    - support suffix matching
1412 4.2.0 / 2014-05-11
1413 ==================
1415  * deprecate `app.del()` -- use `app.delete()` instead
1416  * deprecate `res.json(obj, status)` -- use `res.json(status, obj)` instead
1417    - the edge-case `res.json(status, num)` requires `res.status(status).json(num)`
1418  * deprecate `res.jsonp(obj, status)` -- use `res.jsonp(status, obj)` instead
1419    - the edge-case `res.jsonp(status, num)` requires `res.status(status).jsonp(num)`
1420  * fix `req.next` when inside router instance
1421  * include `ETag` header in `HEAD` requests
1422  * keep previous `Content-Type` for `res.jsonp`
1423  * support PURGE method
1424    - add `app.purge`
1425    - add `router.purge`
1426    - include PURGE in `app.all`
1427  * update debug to 0.8.0
1428    - add `enable()` method
1429    - change from stderr to stdout
1430  * update methods to 1.0.0
1431    - add PURGE
1433 4.1.2 / 2014-05-08
1434 ==================
1436  * fix `req.host` for IPv6 literals
1437  * fix `res.jsonp` error if callback param is object
1439 4.1.1 / 2014-04-27
1440 ==================
1442  * fix package.json to reflect supported node version
1444 4.1.0 / 2014-04-24
1445 ==================
1447  * pass options from `res.sendfile` to `send`
1448  * preserve casing of headers in `res.header` and `res.set`
1449  * support unicode file names in `res.attachment` and `res.download`
1450  * update accepts to 1.0.1
1451    - deps: negotiator@0.4.0
1452  * update cookie to 0.1.2
1453    - Fix for maxAge == 0
1454    - made compat with expires field
1455  * update send to 0.3.0
1456    - Accept API options in options object
1457    - Coerce option types
1458    - Control whether to generate etags
1459    - Default directory access to 403 when index disabled
1460    - Fix sending files with dots without root set
1461    - Include file path in etag
1462    - Make "Can't set headers after they are sent." catchable
1463    - Send full entity-body for multi range requests
1464    - Set etags to "weak"
1465    - Support "If-Range" header
1466    - Support multiple index paths
1467    - deps: mime@1.2.11
1468  * update serve-static to 1.1.0
1469    - Accept options directly to `send` module
1470    - Resolve relative paths at middleware setup
1471    - Use parseurl to parse the URL from request
1472    - deps: send@0.3.0
1473  * update type-is to 1.1.0
1474    - add non-array values support
1475    - add `multipart` as a shorthand
1477 4.0.0 / 2014-04-09
1478 ==================
1480  * remove:
1481    - node 0.8 support
1482    - connect and connect's patches except for charset handling
1483    - express(1) - moved to [express-generator](https://github.com/expressjs/generator)
1484    - `express.createServer()` - it has been deprecated for a long time. Use `express()`
1485    - `app.configure` - use logic in your own app code
1486    - `app.router` - is removed
1487    - `req.auth` - use `basic-auth` instead
1488    - `req.accepted*` - use `req.accepts*()` instead
1489    - `res.location` - relative URL resolution is removed
1490    - `res.charset` - include the charset in the content type when using `res.set()`
1491    - all bundled middleware except `static`
1492  * change:
1493    - `app.route` -> `app.mountpath` when mounting an express app in another express app
1494    - `json spaces` no longer enabled by default in development
1495    - `req.accepts*` -> `req.accepts*s` - i.e. `req.acceptsEncoding` -> `req.acceptsEncodings`
1496    - `req.params` is now an object instead of an array
1497    - `res.locals` is no longer a function. It is a plain js object. Treat it as such.
1498    - `res.headerSent` -> `res.headersSent` to match node.js ServerResponse object
1499  * refactor:
1500    - `req.accepts*` with [accepts](https://github.com/expressjs/accepts)
1501    - `req.is` with [type-is](https://github.com/expressjs/type-is)
1502    - [path-to-regexp](https://github.com/component/path-to-regexp)
1503  * add:
1504    - `app.router()` - returns the app Router instance
1505    - `app.route()` - Proxy to the app's `Router#route()` method to create a new route
1506    - Router & Route - public API
1508 3.21.2 / 2015-07-31
1509 ===================
1511   * deps: connect@2.30.2
1512     - deps: body-parser@~1.13.3
1513     - deps: compression@~1.5.2
1514     - deps: errorhandler@~1.4.2
1515     - deps: method-override@~2.3.5
1516     - deps: serve-index@~1.7.2
1517     - deps: type-is@~1.6.6
1518     - deps: vhost@~3.0.1
1519   * deps: vary@~1.0.1
1520     - Fix setting empty header from empty `field`
1521     - perf: enable strict mode
1522     - perf: remove argument reassignments
1524 3.21.1 / 2015-07-05
1525 ===================
1527   * deps: basic-auth@~1.0.3
1528   * deps: connect@2.30.1
1529     - deps: body-parser@~1.13.2
1530     - deps: compression@~1.5.1
1531     - deps: errorhandler@~1.4.1
1532     - deps: morgan@~1.6.1
1533     - deps: pause@0.1.0
1534     - deps: qs@4.0.0
1535     - deps: serve-index@~1.7.1
1536     - deps: type-is@~1.6.4
1538 3.21.0 / 2015-06-18
1539 ===================
1541   * deps: basic-auth@1.0.2
1542     - perf: enable strict mode
1543     - perf: hoist regular expression
1544     - perf: parse with regular expressions
1545     - perf: remove argument reassignment
1546   * deps: connect@2.30.0
1547     - deps: body-parser@~1.13.1
1548     - deps: bytes@2.1.0
1549     - deps: compression@~1.5.0
1550     - deps: cookie@0.1.3
1551     - deps: cookie-parser@~1.3.5
1552     - deps: csurf@~1.8.3
1553     - deps: errorhandler@~1.4.0
1554     - deps: express-session@~1.11.3
1555     - deps: finalhandler@0.4.0
1556     - deps: fresh@0.3.0
1557     - deps: morgan@~1.6.0
1558     - deps: serve-favicon@~2.3.0
1559     - deps: serve-index@~1.7.0
1560     - deps: serve-static@~1.10.0
1561     - deps: type-is@~1.6.3
1562   * deps: cookie@0.1.3
1563     - perf: deduce the scope of try-catch deopt
1564     - perf: remove argument reassignments
1565   * deps: escape-html@1.0.2
1566   * deps: etag@~1.7.0
1567     - Always include entity length in ETags for hash length extensions
1568     - Generate non-Stats ETags using MD5 only (no longer CRC32)
1569     - Improve stat performance by removing hashing
1570     - Improve support for JXcore
1571     - Remove base64 padding in ETags to shorten
1572     - Support "fake" stats objects in environments without fs
1573     - Use MD5 instead of MD4 in weak ETags over 1KB
1574   * deps: fresh@0.3.0
1575     - Add weak `ETag` matching support
1576   * deps: mkdirp@0.5.1
1577     - Work in global strict mode
1578   * deps: send@0.13.0
1579     - Allow Node.js HTTP server to set `Date` response header
1580     - Fix incorrectly removing `Content-Location` on 304 response
1581     - Improve the default redirect response headers
1582     - Send appropriate headers on default error response
1583     - Use `http-errors` for standard emitted errors
1584     - Use `statuses` instead of `http` module for status messages
1585     - deps: escape-html@1.0.2
1586     - deps: etag@~1.7.0
1587     - deps: fresh@0.3.0
1588     - deps: on-finished@~2.3.0
1589     - perf: enable strict mode
1590     - perf: remove unnecessary array allocations
1592 3.20.3 / 2015-05-17
1593 ===================
1595   * deps: connect@2.29.2
1596     - deps: body-parser@~1.12.4
1597     - deps: compression@~1.4.4
1598     - deps: connect-timeout@~1.6.2
1599     - deps: debug@~2.2.0
1600     - deps: depd@~1.0.1
1601     - deps: errorhandler@~1.3.6
1602     - deps: finalhandler@0.3.6
1603     - deps: method-override@~2.3.3
1604     - deps: morgan@~1.5.3
1605     - deps: qs@2.4.2
1606     - deps: response-time@~2.3.1
1607     - deps: serve-favicon@~2.2.1
1608     - deps: serve-index@~1.6.4
1609     - deps: serve-static@~1.9.3
1610     - deps: type-is@~1.6.2
1611   * deps: debug@~2.2.0
1612     - deps: ms@0.7.1
1613   * deps: depd@~1.0.1
1614   * deps: proxy-addr@~1.0.8
1615     - deps: ipaddr.js@1.0.1
1616   * deps: send@0.12.3
1617     - deps: debug@~2.2.0
1618     - deps: depd@~1.0.1
1619     - deps: etag@~1.6.0
1620     - deps: ms@0.7.1
1621     - deps: on-finished@~2.2.1
1623 3.20.2 / 2015-03-16
1624 ===================
1626   * deps: connect@2.29.1
1627     - deps: body-parser@~1.12.2
1628     - deps: compression@~1.4.3
1629     - deps: connect-timeout@~1.6.1
1630     - deps: debug@~2.1.3
1631     - deps: errorhandler@~1.3.5
1632     - deps: express-session@~1.10.4
1633     - deps: finalhandler@0.3.4
1634     - deps: method-override@~2.3.2
1635     - deps: morgan@~1.5.2
1636     - deps: qs@2.4.1
1637     - deps: serve-index@~1.6.3
1638     - deps: serve-static@~1.9.2
1639     - deps: type-is@~1.6.1
1640   * deps: debug@~2.1.3
1641     - Fix high intensity foreground color for bold
1642     - deps: ms@0.7.0
1643   * deps: merge-descriptors@1.0.0
1644   * deps: proxy-addr@~1.0.7
1645     - deps: ipaddr.js@0.1.9
1646   * deps: send@0.12.2
1647     - Throw errors early for invalid `extensions` or `index` options
1648     - deps: debug@~2.1.3
1650 3.20.1 / 2015-02-28
1651 ===================
1653   * Fix `req.host` when using "trust proxy" hops count
1654   * Fix `req.protocol`/`req.secure` when using "trust proxy" hops count
1656 3.20.0 / 2015-02-18
1657 ===================
1659   * Fix `"trust proxy"` setting to inherit when app is mounted
1660   * Generate `ETag`s for all request responses
1661     - No longer restricted to only responses for `GET` and `HEAD` requests
1662   * Use `content-type` to parse `Content-Type` headers
1663   * deps: connect@2.29.0
1664     - Use `content-type` to parse `Content-Type` headers
1665     - deps: body-parser@~1.12.0
1666     - deps: compression@~1.4.1
1667     - deps: connect-timeout@~1.6.0
1668     - deps: cookie-parser@~1.3.4
1669     - deps: cookie-signature@1.0.6
1670     - deps: csurf@~1.7.0
1671     - deps: errorhandler@~1.3.4
1672     - deps: express-session@~1.10.3
1673     - deps: http-errors@~1.3.1
1674     - deps: response-time@~2.3.0
1675     - deps: serve-index@~1.6.2
1676     - deps: serve-static@~1.9.1
1677     - deps: type-is@~1.6.0
1678   * deps: cookie-signature@1.0.6
1679   * deps: send@0.12.1
1680     - Always read the stat size from the file
1681     - Fix mutating passed-in `options`
1682     - deps: mime@1.3.4
1684 3.19.2 / 2015-02-01
1685 ===================
1687   * deps: connect@2.28.3
1688     - deps: compression@~1.3.1
1689     - deps: csurf@~1.6.6
1690     - deps: errorhandler@~1.3.3
1691     - deps: express-session@~1.10.2
1692     - deps: serve-index@~1.6.1
1693     - deps: type-is@~1.5.6
1694   * deps: proxy-addr@~1.0.6
1695     - deps: ipaddr.js@0.1.8
1697 3.19.1 / 2015-01-20
1698 ===================
1700   * deps: connect@2.28.2
1701     - deps: body-parser@~1.10.2
1702     - deps: serve-static@~1.8.1
1703   * deps: send@0.11.1
1704     - Fix root path disclosure
1706 3.19.0 / 2015-01-09
1707 ===================
1709   * Fix `OPTIONS` responses to include the `HEAD` method property
1710   * Use `readline` for prompt in `express(1)`
1711   * deps: commander@2.6.0
1712   * deps: connect@2.28.1
1713     - deps: body-parser@~1.10.1
1714     - deps: compression@~1.3.0
1715     - deps: connect-timeout@~1.5.0
1716     - deps: csurf@~1.6.4
1717     - deps: debug@~2.1.1
1718     - deps: errorhandler@~1.3.2
1719     - deps: express-session@~1.10.1
1720     - deps: finalhandler@0.3.3
1721     - deps: method-override@~2.3.1
1722     - deps: morgan@~1.5.1
1723     - deps: serve-favicon@~2.2.0
1724     - deps: serve-index@~1.6.0
1725     - deps: serve-static@~1.8.0
1726     - deps: type-is@~1.5.5
1727   * deps: debug@~2.1.1
1728   * deps: methods@~1.1.1
1729   * deps: proxy-addr@~1.0.5
1730     - deps: ipaddr.js@0.1.6
1731   * deps: send@0.11.0
1732     - deps: debug@~2.1.1
1733     - deps: etag@~1.5.1
1734     - deps: ms@0.7.0
1735     - deps: on-finished@~2.2.0
1737 3.18.6 / 2014-12-12
1738 ===================
1740   * Fix exception in `req.fresh`/`req.stale` without response headers
1742 3.18.5 / 2014-12-11
1743 ===================
1745   * deps: connect@2.27.6
1746     - deps: compression@~1.2.2
1747     - deps: express-session@~1.9.3
1748     - deps: http-errors@~1.2.8
1749     - deps: serve-index@~1.5.3
1750     - deps: type-is@~1.5.4
1752 3.18.4 / 2014-11-23
1753 ===================
1755   * deps: connect@2.27.4
1756     - deps: body-parser@~1.9.3
1757     - deps: compression@~1.2.1
1758     - deps: errorhandler@~1.2.3
1759     - deps: express-session@~1.9.2
1760     - deps: qs@2.3.3
1761     - deps: serve-favicon@~2.1.7
1762     - deps: serve-static@~1.5.1
1763     - deps: type-is@~1.5.3
1764   * deps: etag@~1.5.1
1765   * deps: proxy-addr@~1.0.4
1766     - deps: ipaddr.js@0.1.5
1768 3.18.3 / 2014-11-09
1769 ===================
1771   * deps: connect@2.27.3
1772     - Correctly invoke async callback asynchronously
1773     - deps: csurf@~1.6.3
1775 3.18.2 / 2014-10-28
1776 ===================
1778   * deps: connect@2.27.2
1779     - Fix handling of URLs containing `://` in the path
1780     - deps: body-parser@~1.9.2
1781     - deps: qs@2.3.2
1783 3.18.1 / 2014-10-22
1784 ===================
1786   * Fix internal `utils.merge` deprecation warnings
1787   * deps: connect@2.27.1
1788     - deps: body-parser@~1.9.1
1789     - deps: express-session@~1.9.1
1790     - deps: finalhandler@0.3.2
1791     - deps: morgan@~1.4.1
1792     - deps: qs@2.3.0
1793     - deps: serve-static@~1.7.1
1794   * deps: send@0.10.1
1795     - deps: on-finished@~2.1.1
1797 3.18.0 / 2014-10-17
1798 ===================
1800   * Use `content-disposition` module for `res.attachment`/`res.download`
1801     - Sends standards-compliant `Content-Disposition` header
1802     - Full Unicode support
1803   * Use `etag` module to generate `ETag` headers
1804   * deps: connect@2.27.0
1805     - Use `http-errors` module for creating errors
1806     - Use `utils-merge` module for merging objects
1807     - deps: body-parser@~1.9.0
1808     - deps: compression@~1.2.0
1809     - deps: connect-timeout@~1.4.0
1810     - deps: debug@~2.1.0
1811     - deps: depd@~1.0.0
1812     - deps: express-session@~1.9.0
1813     - deps: finalhandler@0.3.1
1814     - deps: method-override@~2.3.0
1815     - deps: morgan@~1.4.0
1816     - deps: response-time@~2.2.0
1817     - deps: serve-favicon@~2.1.6
1818     - deps: serve-index@~1.5.0
1819     - deps: serve-static@~1.7.0
1820   * deps: debug@~2.1.0
1821     - Implement `DEBUG_FD` env variable support
1822   * deps: depd@~1.0.0
1823   * deps: send@0.10.0
1824     - deps: debug@~2.1.0
1825     - deps: depd@~1.0.0
1826     - deps: etag@~1.5.0
1828 3.17.8 / 2014-10-15
1829 ===================
1831   * deps: connect@2.26.6
1832     - deps: compression@~1.1.2
1833     - deps: csurf@~1.6.2
1834     - deps: errorhandler@~1.2.2
1836 3.17.7 / 2014-10-08
1837 ===================
1839   * deps: connect@2.26.5
1840     - Fix accepting non-object arguments to `logger`
1841     - deps: serve-static@~1.6.4
1843 3.17.6 / 2014-10-02
1844 ===================
1846   * deps: connect@2.26.4
1847     - deps: morgan@~1.3.2
1848     - deps: type-is@~1.5.2
1850 3.17.5 / 2014-09-24
1851 ===================
1853   * deps: connect@2.26.3
1854     - deps: body-parser@~1.8.4
1855     - deps: serve-favicon@~2.1.5
1856     - deps: serve-static@~1.6.3
1857   * deps: proxy-addr@~1.0.3
1858     - Use `forwarded` npm module
1859   * deps: send@0.9.3
1860     - deps: etag@~1.4.0
1862 3.17.4 / 2014-09-19
1863 ===================
1865   * deps: connect@2.26.2
1866     - deps: body-parser@~1.8.3
1867     - deps: qs@2.2.4
1869 3.17.3 / 2014-09-18
1870 ===================
1872   * deps: proxy-addr@~1.0.2
1873     - Fix a global leak when multiple subnets are trusted
1874     - deps: ipaddr.js@0.1.3
1876 3.17.2 / 2014-09-15
1877 ===================
1879   * Use `crc` instead of `buffer-crc32` for speed
1880   * deps: connect@2.26.1
1881     - deps: body-parser@~1.8.2
1882     - deps: depd@0.4.5
1883     - deps: express-session@~1.8.2
1884     - deps: morgan@~1.3.1
1885     - deps: serve-favicon@~2.1.3
1886     - deps: serve-static@~1.6.2
1887   * deps: depd@0.4.5
1888   * deps: send@0.9.2
1889     - deps: depd@0.4.5
1890     - deps: etag@~1.3.1
1891     - deps: range-parser@~1.0.2
1893 3.17.1 / 2014-09-08
1894 ===================
1896   * Fix error in `req.subdomains` on empty host
1898 3.17.0 / 2014-09-08
1899 ===================
1901   * Support `X-Forwarded-Host` in `req.subdomains`
1902   * Support IP address host in `req.subdomains`
1903   * deps: connect@2.26.0
1904     - deps: body-parser@~1.8.1
1905     - deps: compression@~1.1.0
1906     - deps: connect-timeout@~1.3.0
1907     - deps: cookie-parser@~1.3.3
1908     - deps: cookie-signature@1.0.5
1909     - deps: csurf@~1.6.1
1910     - deps: debug@~2.0.0
1911     - deps: errorhandler@~1.2.0
1912     - deps: express-session@~1.8.1
1913     - deps: finalhandler@0.2.0
1914     - deps: fresh@0.2.4
1915     - deps: media-typer@0.3.0
1916     - deps: method-override@~2.2.0
1917     - deps: morgan@~1.3.0
1918     - deps: qs@2.2.3
1919     - deps: serve-favicon@~2.1.3
1920     - deps: serve-index@~1.2.1
1921     - deps: serve-static@~1.6.1
1922     - deps: type-is@~1.5.1
1923     - deps: vhost@~3.0.0
1924   * deps: cookie-signature@1.0.5
1925   * deps: debug@~2.0.0
1926   * deps: fresh@0.2.4
1927   * deps: media-typer@0.3.0
1928     - Throw error when parameter format invalid on parse
1929   * deps: range-parser@~1.0.2
1930   * deps: send@0.9.1
1931     - Add `lastModified` option
1932     - Use `etag` to generate `ETag` header
1933     - deps: debug@~2.0.0
1934     - deps: fresh@0.2.4
1935   * deps: vary@~1.0.0
1936     - Accept valid `Vary` header string as `field`
1938 3.16.10 / 2014-09-04
1939 ====================
1941   * deps: connect@2.25.10
1942     - deps: serve-static@~1.5.4
1943   * deps: send@0.8.5
1944     - Fix a path traversal issue when using `root`
1945     - Fix malicious path detection for empty string path
1947 3.16.9 / 2014-08-29
1948 ===================
1950   * deps: connect@2.25.9
1951     - deps: body-parser@~1.6.7
1952     - deps: qs@2.2.2
1954 3.16.8 / 2014-08-27
1955 ===================
1957   * deps: connect@2.25.8
1958     - deps: body-parser@~1.6.6
1959     - deps: csurf@~1.4.1
1960     - deps: qs@2.2.0
1962 3.16.7 / 2014-08-18
1963 ===================
1965   * deps: connect@2.25.7
1966     - deps: body-parser@~1.6.5
1967     - deps: express-session@~1.7.6
1968     - deps: morgan@~1.2.3
1969     - deps: serve-static@~1.5.3
1970   * deps: send@0.8.3
1971     - deps: destroy@1.0.3
1972     - deps: on-finished@2.1.0
1974 3.16.6 / 2014-08-14
1975 ===================
1977   * deps: connect@2.25.6
1978     - deps: body-parser@~1.6.4
1979     - deps: qs@1.2.2
1980     - deps: serve-static@~1.5.2
1981   * deps: send@0.8.2
1982     - Work around `fd` leak in Node.js 0.10 for `fs.ReadStream`
1984 3.16.5 / 2014-08-11
1985 ===================
1987   * deps: connect@2.25.5
1988     - Fix backwards compatibility in `logger`
1990 3.16.4 / 2014-08-10
1991 ===================
1993   * Fix original URL parsing in `res.location`
1994   * deps: connect@2.25.4
1995     - Fix `query` middleware breaking with argument
1996     - deps: body-parser@~1.6.3
1997     - deps: compression@~1.0.11
1998     - deps: connect-timeout@~1.2.2
1999     - deps: express-session@~1.7.5
2000     - deps: method-override@~2.1.3
2001     - deps: on-headers@~1.0.0
2002     - deps: parseurl@~1.3.0
2003     - deps: qs@1.2.1
2004     - deps: response-time@~2.0.1
2005     - deps: serve-index@~1.1.6
2006     - deps: serve-static@~1.5.1
2007   * deps: parseurl@~1.3.0
2009 3.16.3 / 2014-08-07
2010 ===================
2012   * deps: connect@2.25.3
2013     - deps: multiparty@3.3.2
2015 3.16.2 / 2014-08-07
2016 ===================
2018   * deps: connect@2.25.2
2019     - deps: body-parser@~1.6.2
2020     - deps: qs@1.2.0
2022 3.16.1 / 2014-08-06
2023 ===================
2025   * deps: connect@2.25.1
2026     - deps: body-parser@~1.6.1
2027     - deps: qs@1.1.0
2029 3.16.0 / 2014-08-05
2030 ===================
2032   * deps: connect@2.25.0
2033     - deps: body-parser@~1.6.0
2034     - deps: compression@~1.0.10
2035     - deps: csurf@~1.4.0
2036     - deps: express-session@~1.7.4
2037     - deps: qs@1.0.2
2038     - deps: serve-static@~1.5.0
2039   * deps: send@0.8.1
2040     - Add `extensions` option
2042 3.15.3 / 2014-08-04
2043 ===================
2045   * fix `res.sendfile` regression for serving directory index files
2046   * deps: connect@2.24.3
2047     - deps: serve-index@~1.1.5
2048     - deps: serve-static@~1.4.4
2049   * deps: send@0.7.4
2050     - Fix incorrect 403 on Windows and Node.js 0.11
2051     - Fix serving index files without root dir
2053 3.15.2 / 2014-07-27
2054 ===================
2056   * deps: connect@2.24.2
2057     - deps: body-parser@~1.5.2
2058     - deps: depd@0.4.4
2059     - deps: express-session@~1.7.2
2060     - deps: morgan@~1.2.2
2061     - deps: serve-static@~1.4.2
2062   * deps: depd@0.4.4
2063     - Work-around v8 generating empty stack traces
2064   * deps: send@0.7.2
2065     - deps: depd@0.4.4
2067 3.15.1 / 2014-07-26
2068 ===================
2070   * deps: connect@2.24.1
2071     - deps: body-parser@~1.5.1
2072     - deps: depd@0.4.3
2073     - deps: express-session@~1.7.1
2074     - deps: morgan@~1.2.1
2075     - deps: serve-index@~1.1.4
2076     - deps: serve-static@~1.4.1
2077   * deps: depd@0.4.3
2078     - Fix exception when global `Error.stackTraceLimit` is too low
2079   * deps: send@0.7.1
2080     - deps: depd@0.4.3
2082 3.15.0 / 2014-07-22
2083 ===================
2085   * Fix `req.protocol` for proxy-direct connections
2086   * Pass options from `res.sendfile` to `send`
2087   * deps: connect@2.24.0
2088     - deps: body-parser@~1.5.0
2089     - deps: compression@~1.0.9
2090     - deps: connect-timeout@~1.2.1
2091     - deps: debug@1.0.4
2092     - deps: depd@0.4.2
2093     - deps: express-session@~1.7.0
2094     - deps: finalhandler@0.1.0
2095     - deps: method-override@~2.1.2
2096     - deps: morgan@~1.2.0
2097     - deps: multiparty@3.3.1
2098     - deps: parseurl@~1.2.0
2099     - deps: serve-static@~1.4.0
2100   * deps: debug@1.0.4
2101   * deps: depd@0.4.2
2102     - Add `TRACE_DEPRECATION` environment variable
2103     - Remove non-standard grey color from color output
2104     - Support `--no-deprecation` argument
2105     - Support `--trace-deprecation` argument
2106   * deps: parseurl@~1.2.0
2107     - Cache URLs based on original value
2108     - Remove no-longer-needed URL mis-parse work-around
2109     - Simplify the "fast-path" `RegExp`
2110   * deps: send@0.7.0
2111     - Add `dotfiles` option
2112     - Cap `maxAge` value to 1 year
2113     - deps: debug@1.0.4
2114     - deps: depd@0.4.2
2116 3.14.0 / 2014-07-11
2117 ===================
2119  * add explicit "Rosetta Flash JSONP abuse" protection
2120    - previous versions are not vulnerable; this is just explicit protection
2121  * deprecate `res.redirect(url, status)` -- use `res.redirect(status, url)` instead
2122  * fix `res.send(status, num)` to send `num` as json (not error)
2123  * remove unnecessary escaping when `res.jsonp` returns JSON response
2124  * deps: basic-auth@1.0.0
2125    - support empty password
2126    - support empty username
2127  * deps: connect@2.23.0
2128    - deps: debug@1.0.3
2129    - deps: express-session@~1.6.4
2130    - deps: method-override@~2.1.0
2131    - deps: parseurl@~1.1.3
2132    - deps: serve-static@~1.3.1
2133   * deps: debug@1.0.3
2134     - Add support for multiple wildcards in namespaces
2135   * deps: methods@1.1.0
2136     - add `CONNECT`
2137   * deps: parseurl@~1.1.3
2138     - faster parsing of href-only URLs
2140 3.13.0 / 2014-07-03
2141 ===================
2143  * add deprecation message to `app.configure`
2144  * add deprecation message to `req.auth`
2145  * use `basic-auth` to parse `Authorization` header
2146  * deps: connect@2.22.0
2147    - deps: csurf@~1.3.0
2148    - deps: express-session@~1.6.1
2149    - deps: multiparty@3.3.0
2150    - deps: serve-static@~1.3.0
2151  * deps: send@0.5.0
2152    - Accept string for `maxage` (converted by `ms`)
2153    - Include link in default redirect response
2155 3.12.1 / 2014-06-26
2156 ===================
2158  * deps: connect@2.21.1
2159    - deps: cookie-parser@1.3.2
2160    - deps: cookie-signature@1.0.4
2161    - deps: express-session@~1.5.2
2162    - deps: type-is@~1.3.2
2163  * deps: cookie-signature@1.0.4
2164    - fix for timing attacks
2166 3.12.0 / 2014-06-21
2167 ===================
2169  * use `media-typer` to alter content-type charset
2170  * deps: connect@2.21.0
2171    - deprecate `connect(middleware)` -- use `app.use(middleware)` instead
2172    - deprecate `connect.createServer()` -- use `connect()` instead
2173    - fix `res.setHeader()` patch to work with get -> append -> set pattern
2174    - deps: compression@~1.0.8
2175    - deps: errorhandler@~1.1.1
2176    - deps: express-session@~1.5.0
2177    - deps: serve-index@~1.1.3
2179 3.11.0 / 2014-06-19
2180 ===================
2182  * deprecate things with `depd` module
2183  * deps: buffer-crc32@0.2.3
2184  * deps: connect@2.20.2
2185    - deprecate `verify` option to `json` -- use `body-parser` npm module instead
2186    - deprecate `verify` option to `urlencoded` -- use `body-parser` npm module instead
2187    - deprecate things with `depd` module
2188    - use `finalhandler` for final response handling
2189    - use `media-typer` to parse `content-type` for charset
2190    - deps: body-parser@1.4.3
2191    - deps: connect-timeout@1.1.1
2192    - deps: cookie-parser@1.3.1
2193    - deps: csurf@1.2.2
2194    - deps: errorhandler@1.1.0
2195    - deps: express-session@1.4.0
2196    - deps: multiparty@3.2.9
2197    - deps: serve-index@1.1.2
2198    - deps: type-is@1.3.1
2199    - deps: vhost@2.0.0
2201 3.10.5 / 2014-06-11
2202 ===================
2204  * deps: connect@2.19.6
2205    - deps: body-parser@1.3.1
2206    - deps: compression@1.0.7
2207    - deps: debug@1.0.2
2208    - deps: serve-index@1.1.1
2209    - deps: serve-static@1.2.3
2210  * deps: debug@1.0.2
2211  * deps: send@0.4.3
2212    - Do not throw uncatchable error on file open race condition
2213    - Use `escape-html` for HTML escaping
2214    - deps: debug@1.0.2
2215    - deps: finished@1.2.2
2216    - deps: fresh@0.2.2
2218 3.10.4 / 2014-06-09
2219 ===================
2221  * deps: connect@2.19.5
2222    - fix "event emitter leak" warnings
2223    - deps: csurf@1.2.1
2224    - deps: debug@1.0.1
2225    - deps: serve-static@1.2.2
2226    - deps: type-is@1.2.1
2227  * deps: debug@1.0.1
2228  * deps: send@0.4.2
2229    - fix "event emitter leak" warnings
2230    - deps: finished@1.2.1
2231    - deps: debug@1.0.1
2233 3.10.3 / 2014-06-05
2234 ===================
2236  * use `vary` module for `res.vary`
2237  * deps: connect@2.19.4
2238    - deps: errorhandler@1.0.2
2239    - deps: method-override@2.0.2
2240    - deps: serve-favicon@2.0.1
2241  * deps: debug@1.0.0
2243 3.10.2 / 2014-06-03
2244 ===================
2246  * deps: connect@2.19.3
2247    - deps: compression@1.0.6
2249 3.10.1 / 2014-06-03
2250 ===================
2252  * deps: connect@2.19.2
2253    - deps: compression@1.0.4
2254  * deps: proxy-addr@1.0.1
2256 3.10.0 / 2014-06-02
2257 ===================
2259  * deps: connect@2.19.1
2260    - deprecate `methodOverride()` -- use `method-override` npm module instead
2261    - deps: body-parser@1.3.0
2262    - deps: method-override@2.0.1
2263    - deps: multiparty@3.2.8
2264    - deps: response-time@2.0.0
2265    - deps: serve-static@1.2.1
2266  * deps: methods@1.0.1
2267  * deps: send@0.4.1
2268    - Send `max-age` in `Cache-Control` in correct format
2270 3.9.0 / 2014-05-30
2271 ==================
2273  * custom etag control with `app.set('etag', val)`
2274    - `app.set('etag', function(body, encoding){ return '"etag"' })` custom etag generation
2275    - `app.set('etag', 'weak')` weak tag
2276    - `app.set('etag', 'strong')` strong etag
2277    - `app.set('etag', false)` turn off
2278    - `app.set('etag', true)` standard etag
2279  * Include ETag in HEAD requests
2280  * mark `res.send` ETag as weak and reduce collisions
2281  * update connect to 2.18.0
2282    - deps: compression@1.0.3
2283    - deps: serve-index@1.1.0
2284    - deps: serve-static@1.2.0
2285  * update send to 0.4.0
2286    - Calculate ETag with md5 for reduced collisions
2287    - Ignore stream errors after request ends
2288    - deps: debug@0.8.1
2290 3.8.1 / 2014-05-27
2291 ==================
2293  * update connect to 2.17.3
2294    - deps: body-parser@1.2.2
2295    - deps: express-session@1.2.1
2296    - deps: method-override@1.0.2
2298 3.8.0 / 2014-05-21
2299 ==================
2301  * keep previous `Content-Type` for `res.jsonp`
2302  * set proper `charset` in `Content-Type` for `res.send`
2303  * update connect to 2.17.1
2304    - fix `res.charset` appending charset when `content-type` has one
2305    - deps: express-session@1.2.0
2306    - deps: morgan@1.1.1
2307    - deps: serve-index@1.0.3
2309 3.7.0 / 2014-05-18
2310 ==================
2312  * proper proxy trust with `app.set('trust proxy', trust)`
2313    - `app.set('trust proxy', 1)` trust first hop
2314    - `app.set('trust proxy', 'loopback')` trust loopback addresses
2315    - `app.set('trust proxy', '10.0.0.1')` trust single IP
2316    - `app.set('trust proxy', '10.0.0.1/16')` trust subnet
2317    - `app.set('trust proxy', '10.0.0.1, 10.0.0.2')` trust list
2318    - `app.set('trust proxy', false)` turn off
2319    - `app.set('trust proxy', true)` trust everything
2320  * update connect to 2.16.2
2321    - deprecate `res.headerSent` -- use `res.headersSent`
2322    - deprecate `res.on("header")` -- use on-headers module instead
2323    - fix edge-case in `res.appendHeader` that would append in wrong order
2324    - json: use body-parser
2325    - urlencoded: use body-parser
2326    - dep: bytes@1.0.0
2327    - dep: cookie-parser@1.1.0
2328    - dep: csurf@1.2.0
2329    - dep: express-session@1.1.0
2330    - dep: method-override@1.0.1
2332 3.6.0 / 2014-05-09
2333 ==================
2335  * deprecate `app.del()` -- use `app.delete()` instead
2336  * deprecate `res.json(obj, status)` -- use `res.json(status, obj)` instead
2337    - the edge-case `res.json(status, num)` requires `res.status(status).json(num)`
2338  * deprecate `res.jsonp(obj, status)` -- use `res.jsonp(status, obj)` instead
2339    - the edge-case `res.jsonp(status, num)` requires `res.status(status).jsonp(num)`
2340  * support PURGE method
2341    - add `app.purge`
2342    - add `router.purge`
2343    - include PURGE in `app.all`
2344  * update connect to 2.15.0
2345    * Add `res.appendHeader`
2346    * Call error stack even when response has been sent
2347    * Patch `res.headerSent` to return Boolean
2348    * Patch `res.headersSent` for node.js 0.8
2349    * Prevent default 404 handler after response sent
2350    * dep: compression@1.0.2
2351    * dep: connect-timeout@1.1.0
2352    * dep: debug@^0.8.0
2353    * dep: errorhandler@1.0.1
2354    * dep: express-session@1.0.4
2355    * dep: morgan@1.0.1
2356    * dep: serve-favicon@2.0.0
2357    * dep: serve-index@1.0.2
2358  * update debug to 0.8.0
2359    * add `enable()` method
2360    * change from stderr to stdout
2361  * update methods to 1.0.0
2362    - add PURGE
2363  * update mkdirp to 0.5.0
2365 3.5.3 / 2014-05-08
2366 ==================
2368  * fix `req.host` for IPv6 literals
2369  * fix `res.jsonp` error if callback param is object
2371 3.5.2 / 2014-04-24
2372 ==================
2374  * update connect to 2.14.5
2375  * update cookie to 0.1.2
2376  * update mkdirp to 0.4.0
2377  * update send to 0.3.0
2379 3.5.1 / 2014-03-25
2380 ==================
2382  * pin less-middleware in generated app
2384 3.5.0 / 2014-03-06
2385 ==================
2387  * bump deps
2389 3.4.8 / 2014-01-13
2390 ==================
2392  * prevent incorrect automatic OPTIONS responses #1868 @dpatti
2393  * update binary and examples for jade 1.0 #1876 @yossi, #1877 @reqshark, #1892 @matheusazzi
2394  * throw 400 in case of malformed paths @rlidwka
2396 3.4.7 / 2013-12-10
2397 ==================
2399  * update connect
2401 3.4.6 / 2013-12-01
2402 ==================
2404  * update connect (raw-body)
2406 3.4.5 / 2013-11-27
2407 ==================
2409  * update connect
2410  * res.location: remove leading ./ #1802 @kapouer
2411  * res.redirect: fix `res.redirect('toString') #1829 @michaelficarra
2412  * res.send: always send ETag when content-length > 0
2413  * router: add Router.all() method
2415 3.4.4 / 2013-10-29
2416 ==================
2418  * update connect
2419  * update supertest
2420  * update methods
2421  * express(1): replace bodyParser() with urlencoded() and json() #1795 @chirag04
2423 3.4.3 / 2013-10-23
2424 ==================
2426  * update connect
2428 3.4.2 / 2013-10-18
2429 ==================
2431  * update connect
2432  * downgrade commander
2434 3.4.1 / 2013-10-15
2435 ==================
2437  * update connect
2438  * update commander
2439  * jsonp: check if callback is a function
2440  * router: wrap encodeURIComponent in a try/catch #1735 (@lxe)
2441  * res.format: now includes charset @1747 (@sorribas)
2442  * res.links: allow multiple calls @1746 (@sorribas)
2444 3.4.0 / 2013-09-07
2445 ==================
2447  * add res.vary(). Closes #1682
2448  * update connect
2450 3.3.8 / 2013-09-02
2451 ==================
2453  * update connect
2455 3.3.7 / 2013-08-28
2456 ==================
2458  * update connect
2460 3.3.6 / 2013-08-27
2461 ==================
2463  * Revert "remove charset from json responses. Closes #1631" (causes issues in some clients)
2464  * add: req.accepts take an argument list
2466 3.3.4 / 2013-07-08
2467 ==================
2469  * update send and connect
2471 3.3.3 / 2013-07-04
2472 ==================
2474  * update connect
2476 3.3.2 / 2013-07-03
2477 ==================
2479  * update connect
2480  * update send
2481  * remove .version export
2483 3.3.1 / 2013-06-27
2484 ==================
2486  * update connect
2488 3.3.0 / 2013-06-26
2489 ==================
2491  * update connect
2492  * add support for multiple X-Forwarded-Proto values. Closes #1646
2493  * change: remove charset from json responses. Closes #1631
2494  * change: return actual booleans from req.accept* functions
2495  * fix jsonp callback array throw
2497 3.2.6 / 2013-06-02
2498 ==================
2500  * update connect
2502 3.2.5 / 2013-05-21
2503 ==================
2505  * update connect
2506  * update node-cookie
2507  * add: throw a meaningful error when there is no default engine
2508  * change generation of ETags with res.send() to GET requests only. Closes #1619
2510 3.2.4 / 2013-05-09
2511 ==================
2513   * fix `req.subdomains` when no Host is present
2514   * fix `req.host` when no Host is present, return undefined
2516 3.2.3 / 2013-05-07
2517 ==================
2519   * update connect / qs
2521 3.2.2 / 2013-05-03
2522 ==================
2524   * update qs
2526 3.2.1 / 2013-04-29
2527 ==================
2529   * add app.VERB() paths array deprecation warning
2530   * update connect
2531   * update qs and remove all ~ semver crap
2532   * fix: accept number as value of Signed Cookie
2534 3.2.0 / 2013-04-15
2535 ==================
2537   * add "view" constructor setting to override view behaviour
2538   * add req.acceptsEncoding(name)
2539   * add req.acceptedEncodings
2540   * revert cookie signature change causing session race conditions
2541   * fix sorting of Accept values of the same quality
2543 3.1.2 / 2013-04-12
2544 ==================
2546   * add support for custom Accept parameters
2547   * update cookie-signature
2549 3.1.1 / 2013-04-01
2550 ==================
2552   * add X-Forwarded-Host support to `req.host`
2553   * fix relative redirects
2554   * update mkdirp
2555   * update buffer-crc32
2556   * remove legacy app.configure() method from app template.
2558 3.1.0 / 2013-01-25
2559 ==================
2561   * add support for leading "." in "view engine" setting
2562   * add array support to `res.set()`
2563   * add node 0.8.x to travis.yml
2564   * add "subdomain offset" setting for tweaking `req.subdomains`
2565   * add `res.location(url)` implementing `res.redirect()`-like setting of Location
2566   * use app.get() for x-powered-by setting for inheritance
2567   * fix colons in passwords for `req.auth`
2569 3.0.6 / 2013-01-04
2570 ==================
2572   * add http verb methods to Router
2573   * update connect
2574   * fix mangling of the `res.cookie()` options object
2575   * fix jsonp whitespace escape. Closes #1132
2577 3.0.5 / 2012-12-19
2578 ==================
2580   * add throwing when a non-function is passed to a route
2581   * fix: explicitly remove Transfer-Encoding header from 204 and 304 responses
2582   * revert "add 'etag' option"
2584 3.0.4 / 2012-12-05
2585 ==================
2587   * add 'etag' option to disable `res.send()` Etags
2588   * add escaping of urls in text/plain in `res.redirect()`
2589     for old browsers interpreting as html
2590   * change crc32 module for a more liberal license
2591   * update connect
2593 3.0.3 / 2012-11-13
2594 ==================
2596   * update connect
2597   * update cookie module
2598   * fix cookie max-age
2600 3.0.2 / 2012-11-08
2601 ==================
2603   * add OPTIONS to cors example. Closes #1398
2604   * fix route chaining regression. Closes #1397
2606 3.0.1 / 2012-11-01
2607 ==================
2609   * update connect
2611 3.0.0 / 2012-10-23
2612 ==================
2614   * add `make clean`
2615   * add "Basic" check to req.auth
2616   * add `req.auth` test coverage
2617   * add cb && cb(payload) to `res.jsonp()`. Closes #1374
2618   * add backwards compat for `res.redirect()` status. Closes #1336
2619   * add support for `res.json()` to retain previously defined Content-Types. Closes #1349
2620   * update connect
2621   * change `res.redirect()` to utilize a pathname-relative Location again. Closes #1382
2622   * remove non-primitive string support for `res.send()`
2623   * fix view-locals example. Closes #1370
2624   * fix route-separation example
2626 3.0.0rc5 / 2012-09-18
2627 ==================
2629   * update connect
2630   * add redis search example
2631   * add static-files example
2632   * add "x-powered-by" setting (`app.disable('x-powered-by')`)
2633   * add "application/octet-stream" redirect Accept test case. Closes #1317
2635 3.0.0rc4 / 2012-08-30
2636 ==================
2638   * add `res.jsonp()`. Closes #1307
2639   * add "verbose errors" option to error-pages example
2640   * add another route example to express(1) so people are not so confused
2641   * add redis online user activity tracking example
2642   * update connect dep
2643   * fix etag quoting. Closes #1310
2644   * fix error-pages 404 status
2645   * fix jsonp callback char restrictions
2646   * remove old OPTIONS default response
2648 3.0.0rc3 / 2012-08-13
2649 ==================
2651   * update connect dep
2652   * fix signed cookies to work with `connect.cookieParser()` ("s:" prefix was missing) [tnydwrds]
2653   * fix `res.render()` clobbering of "locals"
2655 3.0.0rc2 / 2012-08-03
2656 ==================
2658   * add CORS example
2659   * update connect dep
2660   * deprecate `.createServer()` & remove old stale examples
2661   * fix: escape `res.redirect()` link
2662   * fix vhost example
2664 3.0.0rc1 / 2012-07-24
2665 ==================
2667   * add more examples to view-locals
2668   * add scheme-relative redirects (`res.redirect("//foo.com")`) support
2669   * update cookie dep
2670   * update connect dep
2671   * update send dep
2672   * fix `express(1)` -h flag, use -H for hogan. Closes #1245
2673   * fix `res.sendfile()` socket error handling regression
2675 3.0.0beta7 / 2012-07-16
2676 ==================
2678   * update connect dep for `send()` root normalization regression
2680 3.0.0beta6 / 2012-07-13
2681 ==================
2683   * add `err.view` property for view errors. Closes #1226
2684   * add "jsonp callback name" setting
2685   * add support for "/foo/:bar*" non-greedy matches
2686   * change `res.sendfile()` to use `send()` module
2687   * change `res.send` to use "response-send" module
2688   * remove `app.locals.use` and `res.locals.use`, use regular middleware
2690 3.0.0beta5 / 2012-07-03
2691 ==================
2693   * add "make check" support
2694   * add route-map example
2695   * add `res.json(obj, status)` support back for BC
2696   * add "methods" dep, remove internal methods module
2697   * update connect dep
2698   * update auth example to utilize cores pbkdf2
2699   * updated tests to use "supertest"
2701 3.0.0beta4 / 2012-06-25
2702 ==================
2704   * Added `req.auth`
2705   * Added `req.range(size)`
2706   * Added `res.links(obj)`
2707   * Added `res.send(body, status)` support back for backwards compat
2708   * Added `.default()` support to `res.format()`
2709   * Added 2xx / 304 check to `req.fresh`
2710   * Revert "Added + support to the router"
2711   * Fixed `res.send()` freshness check, respect res.statusCode
2713 3.0.0beta3 / 2012-06-15
2714 ==================
2716   * Added hogan `--hjs` to express(1) [nullfirm]
2717   * Added another example to content-negotiation
2718   * Added `fresh` dep
2719   * Changed: `res.send()` always checks freshness
2720   * Fixed: expose connects mime module. Closes #1165
2722 3.0.0beta2 / 2012-06-06
2723 ==================
2725   * Added `+` support to the router
2726   * Added `req.host`
2727   * Changed `req.param()` to check route first
2728   * Update connect dep
2730 3.0.0beta1 / 2012-06-01
2731 ==================
2733   * Added `res.format()` callback to override default 406 behaviour
2734   * Fixed `res.redirect()` 406. Closes #1154
2736 3.0.0alpha5 / 2012-05-30
2737 ==================
2739   * Added `req.ip`
2740   * Added `{ signed: true }` option to `res.cookie()`
2741   * Removed `res.signedCookie()`
2742   * Changed: dont reverse `req.ips`
2743   * Fixed "trust proxy" setting check for `req.ips`
2745 3.0.0alpha4 / 2012-05-09
2746 ==================
2748   * Added: allow `[]` in jsonp callback. Closes #1128
2749   * Added `PORT` env var support in generated template. Closes #1118 [benatkin]
2750   * Updated: connect 2.2.2
2752 3.0.0alpha3 / 2012-05-04
2753 ==================
2755   * Added public `app.routes`. Closes #887
2756   * Added _view-locals_ example
2757   * Added _mvc_ example
2758   * Added `res.locals.use()`. Closes #1120
2759   * Added conditional-GET support to `res.send()`
2760   * Added: coerce `res.set()` values to strings
2761   * Changed: moved `static()` in generated apps below router
2762   * Changed: `res.send()` only set ETag when not previously set
2763   * Changed connect 2.2.1 dep
2764   * Changed: `make test` now runs unit / acceptance tests
2765   * Fixed req/res proto inheritance
2767 3.0.0alpha2 / 2012-04-26
2768 ==================
2770   * Added `make benchmark` back
2771   * Added `res.send()` support for `String` objects
2772   * Added client-side data exposing example
2773   * Added `res.header()` and `req.header()` aliases for BC
2774   * Added `express.createServer()` for BC
2775   * Perf: memoize parsed urls
2776   * Perf: connect 2.2.0 dep
2777   * Changed: make `expressInit()` middleware self-aware
2778   * Fixed: use app.get() for all core settings
2779   * Fixed redis session example
2780   * Fixed session example. Closes #1105
2781   * Fixed generated express dep. Closes #1078
2783 3.0.0alpha1 / 2012-04-15
2784 ==================
2786   * Added `app.locals.use(callback)`
2787   * Added `app.locals` object
2788   * Added `app.locals(obj)`
2789   * Added `res.locals` object
2790   * Added `res.locals(obj)`
2791   * Added `res.format()` for content-negotiation
2792   * Added `app.engine()`
2793   * Added `res.cookie()` JSON cookie support
2794   * Added "trust proxy" setting
2795   * Added `req.subdomains`
2796   * Added `req.protocol`
2797   * Added `req.secure`
2798   * Added `req.path`
2799   * Added `req.ips`
2800   * Added `req.fresh`
2801   * Added `req.stale`
2802   * Added comma-delimited / array support for `req.accepts()`
2803   * Added debug instrumentation
2804   * Added `res.set(obj)`
2805   * Added `res.set(field, value)`
2806   * Added `res.get(field)`
2807   * Added `app.get(setting)`. Closes #842
2808   * Added `req.acceptsLanguage()`
2809   * Added `req.acceptsCharset()`
2810   * Added `req.accepted`
2811   * Added `req.acceptedLanguages`
2812   * Added `req.acceptedCharsets`
2813   * Added "json replacer" setting
2814   * Added "json spaces" setting
2815   * Added X-Forwarded-Proto support to `res.redirect()`. Closes #92
2816   * Added `--less` support to express(1)
2817   * Added `express.response` prototype
2818   * Added `express.request` prototype
2819   * Added `express.application` prototype
2820   * Added `app.path()`
2821   * Added `app.render()`
2822   * Added `res.type()` to replace `res.contentType()`
2823   * Changed: `res.redirect()` to add relative support
2824   * Changed: enable "jsonp callback" by default
2825   * Changed: renamed "case sensitive routes" to "case sensitive routing"
2826   * Rewrite of all tests with mocha
2827   * Removed "root" setting
2828   * Removed `res.redirect('home')` support
2829   * Removed `req.notify()`
2830   * Removed `app.register()`
2831   * Removed `app.redirect()`
2832   * Removed `app.is()`
2833   * Removed `app.helpers()`
2834   * Removed `app.dynamicHelpers()`
2835   * Fixed `res.sendfile()` with non-GET. Closes #723
2836   * Fixed express(1) public dir for windows. Closes #866
2838 2.5.9/ 2012-04-02
2839 ==================
2841   * Added support for PURGE request method [pbuyle]
2842   * Fixed `express(1)` generated app `app.address()` before `listening` [mmalecki]
2844 2.5.8 / 2012-02-08
2845 ==================
2847   * Update mkdirp dep. Closes #991
2849 2.5.7 / 2012-02-06
2850 ==================
2852   * Fixed `app.all` duplicate DELETE requests [mscdex]
2854 2.5.6 / 2012-01-13
2855 ==================
2857   * Updated hamljs dev dep. Closes #953
2859 2.5.5 / 2012-01-08
2860 ==================
2862   * Fixed: set `filename` on cached templates [matthewleon]
2864 2.5.4 / 2012-01-02
2865 ==================
2867   * Fixed `express(1)` eol on 0.4.x. Closes #947
2869 2.5.3 / 2011-12-30
2870 ==================
2872   * Fixed `req.is()` when a charset is present
2874 2.5.2 / 2011-12-10
2875 ==================
2877   * Fixed: express(1) LF -> CRLF for windows
2879 2.5.1 / 2011-11-17
2880 ==================
2882   * Changed: updated connect to 1.8.x
2883   * Removed sass.js support from express(1)
2885 2.5.0 / 2011-10-24
2886 ==================
2888   * Added ./routes dir for generated app by default
2889   * Added npm install reminder to express(1) app gen
2890   * Added 0.5.x support
2891   * Removed `make test-cov` since it wont work with node 0.5.x
2892   * Fixed express(1) public dir for windows. Closes #866
2894 2.4.7 / 2011-10-05
2895 ==================
2897   * Added mkdirp to express(1). Closes #795
2898   * Added simple _json-config_ example
2899   * Added  shorthand for the parsed request's pathname via `req.path`
2900   * Changed connect dep to 1.7.x to fix npm issue...
2901   * Fixed `res.redirect()` __HEAD__ support. [reported by xerox]
2902   * Fixed `req.flash()`, only escape args
2903   * Fixed absolute path checking on windows. Closes #829 [reported by andrewpmckenzie]
2905 2.4.6 / 2011-08-22
2906 ==================
2908   * Fixed multiple param callback regression. Closes #824 [reported by TroyGoode]
2910 2.4.5 / 2011-08-19
2911 ==================
2913   * Added support for routes to handle errors. Closes #809
2914   * Added `app.routes.all()`. Closes #803
2915   * Added "basepath" setting to work in conjunction with reverse proxies etc.
2916   * Refactored `Route` to use a single array of callbacks
2917   * Added support for multiple callbacks for `app.param()`. Closes #801
2918 Closes #805
2919   * Changed: removed .call(self) for route callbacks
2920   * Dependency: `qs >= 0.3.1`
2921   * Fixed `res.redirect()` on windows due to `join()` usage. Closes #808
2923 2.4.4 / 2011-08-05
2924 ==================
2926   * Fixed `res.header()` intention of a set, even when `undefined`
2927   * Fixed `*`, value no longer required
2928   * Fixed `res.send(204)` support. Closes #771
2930 2.4.3 / 2011-07-14
2931 ==================
2933   * Added docs for `status` option special-case. Closes #739
2934   * Fixed `options.filename`, exposing the view path to template engines
2936 2.4.2. / 2011-07-06
2937 ==================
2939   * Revert "removed jsonp stripping" for XSS
2941 2.4.1 / 2011-07-06
2942 ==================
2944   * Added `res.json()` JSONP support. Closes #737
2945   * Added _extending-templates_ example. Closes #730
2946   * Added "strict routing" setting for trailing slashes
2947   * Added support for multiple envs in `app.configure()` calls. Closes #735
2948   * Changed: `res.send()` using `res.json()`
2949   * Changed: when cookie `path === null` don't default it
2950   * Changed; default cookie path to "home" setting. Closes #731
2951   * Removed _pids/logs_ creation from express(1)
2953 2.4.0 / 2011-06-28
2954 ==================
2956   * Added chainable `res.status(code)`
2957   * Added `res.json()`, an explicit version of `res.send(obj)`
2958   * Added simple web-service example
2960 2.3.12 / 2011-06-22
2961 ==================
2963   * \#express is now on freenode! come join!
2964   * Added `req.get(field, param)`
2965   * Added links to Japanese documentation, thanks @hideyukisaito!
2966   * Added; the `express(1)` generated app outputs the env
2967   * Added `content-negotiation` example
2968   * Dependency: connect >= 1.5.1 < 2.0.0
2969   * Fixed view layout bug. Closes #720
2970   * Fixed; ignore body on 304. Closes #701
2972 2.3.11 / 2011-06-04
2973 ==================
2975   * Added `npm test`
2976   * Removed generation of dummy test file from `express(1)`
2977   * Fixed; `express(1)` adds express as a dep
2978   * Fixed; prune on `prepublish`
2980 2.3.10 / 2011-05-27
2981 ==================
2983   * Added `req.route`, exposing the current route
2984   * Added _package.json_ generation support to `express(1)`
2985   * Fixed call to `app.param()` function for optional params. Closes #682
2987 2.3.9 / 2011-05-25
2988 ==================
2990   * Fixed bug-ish with `../' in `res.partial()` calls
2992 2.3.8 / 2011-05-24
2993 ==================
2995   * Fixed `app.options()`
2997 2.3.7 / 2011-05-23
2998 ==================
3000   * Added route `Collection`, ex: `app.get('/user/:id').remove();`
3001   * Added support for `app.param(fn)` to define param logic
3002   * Removed `app.param()` support for callback with return value
3003   * Removed module.parent check from express(1) generated app. Closes #670
3004   * Refactored router. Closes #639
3006 2.3.6 / 2011-05-20
3007 ==================
3009   * Changed; using devDependencies instead of git submodules
3010   * Fixed redis session example
3011   * Fixed markdown example
3012   * Fixed view caching, should not be enabled in development
3014 2.3.5 / 2011-05-20
3015 ==================
3017   * Added export `.view` as alias for `.View`
3019 2.3.4 / 2011-05-08
3020 ==================
3022   * Added `./examples/say`
3023   * Fixed `res.sendfile()` bug preventing the transfer of files with spaces
3025 2.3.3 / 2011-05-03
3026 ==================
3028   * Added "case sensitive routes" option.
3029   * Changed; split methods supported per rfc [slaskis]
3030   * Fixed route-specific middleware when using the same callback function several times
3032 2.3.2 / 2011-04-27
3033 ==================
3035   * Fixed view hints
3037 2.3.1 / 2011-04-26
3038 ==================
3040   * Added `app.match()` as `app.match.all()`
3041   * Added `app.lookup()` as `app.lookup.all()`
3042   * Added `app.remove()` for `app.remove.all()`
3043   * Added `app.remove.VERB()`
3044   * Fixed template caching collision issue. Closes #644
3045   * Moved router over from connect and started refactor
3047 2.3.0 / 2011-04-25
3048 ==================
3050   * Added options support to `res.clearCookie()`
3051   * Added `res.helpers()` as alias of `res.locals()`
3052   * Added; json defaults to UTF-8 with `res.send()`. Closes #632. [Daniel   * Dependency `connect >= 1.4.0`
3053   * Changed; auto set Content-Type in res.attachement [Aaron Heckmann]
3054   * Renamed "cache views" to "view cache". Closes #628
3055   * Fixed caching of views when using several apps. Closes #637
3056   * Fixed gotcha invoking `app.param()` callbacks once per route middleware.
3057 Closes #638
3058   * Fixed partial lookup precedence. Closes #631
3059 Shaw]
3061 2.2.2 / 2011-04-12
3062 ==================
3064   * Added second callback support for `res.download()` connection errors
3065   * Fixed `filename` option passing to template engine
3067 2.2.1 / 2011-04-04
3068 ==================
3070   * Added `layout(path)` helper to change the layout within a view. Closes #610
3071   * Fixed `partial()` collection object support.
3072     Previously only anything with `.length` would work.
3073     When `.length` is present one must still be aware of holes,
3074     however now `{ collection: {foo: 'bar'}}` is valid, exposes
3075     `keyInCollection` and `keysInCollection`.
3077   * Performance improved with better view caching
3078   * Removed `request` and `response` locals
3079   * Changed; errorHandler page title is now `Express` instead of `Connect`
3081 2.2.0 / 2011-03-30
3082 ==================
3084   * Added `app.lookup.VERB()`, ex `app.lookup.put('/user/:id')`. Closes #606
3085   * Added `app.match.VERB()`, ex `app.match.put('/user/12')`. Closes #606
3086   * Added `app.VERB(path)` as alias of `app.lookup.VERB()`.
3087   * Dependency `connect >= 1.2.0`
3089 2.1.1 / 2011-03-29
3090 ==================
3092   * Added; expose `err.view` object when failing to locate a view
3093   * Fixed `res.partial()` call `next(err)` when no callback is given [reported by aheckmann]
3094   * Fixed; `res.send(undefined)` responds with 204 [aheckmann]
3096 2.1.0 / 2011-03-24
3097 ==================
3099   * Added `<root>/_?<name>` partial lookup support. Closes #447
3100   * Added `request`, `response`, and `app` local variables
3101   * Added `settings` local variable, containing the app's settings
3102   * Added `req.flash()` exception if `req.session` is not available
3103   * Added `res.send(bool)` support (json response)
3104   * Fixed stylus example for latest version
3105   * Fixed; wrap try/catch around `res.render()`
3107 2.0.0 / 2011-03-17
3108 ==================
3110   * Fixed up index view path alternative.
3111   * Changed; `res.locals()` without object returns the locals
3113 2.0.0rc3 / 2011-03-17
3114 ==================
3116   * Added `res.locals(obj)` to compliment `res.local(key, val)`
3117   * Added `res.partial()` callback support
3118   * Fixed recursive error reporting issue in `res.render()`
3120 2.0.0rc2 / 2011-03-17
3121 ==================
3123   * Changed; `partial()` "locals" are now optional
3124   * Fixed `SlowBuffer` support. Closes #584 [reported by tyrda01]
3125   * Fixed .filename view engine option [reported by drudge]
3126   * Fixed blog example
3127   * Fixed `{req,res}.app` reference when mounting [Ben Weaver]
3129 2.0.0rc / 2011-03-14
3130 ==================
3132   * Fixed; expose `HTTPSServer` constructor
3133   * Fixed express(1) default test charset. Closes #579 [reported by secoif]
3134   * Fixed; default charset to utf-8 instead of utf8 for lame IE [reported by NickP]
3136 2.0.0beta3 / 2011-03-09
3137 ==================
3139   * Added support for `res.contentType()` literal
3140     The original `res.contentType('.json')`,
3141     `res.contentType('application/json')`, and `res.contentType('json')`
3142     will work now.
3143   * Added `res.render()` status option support back
3144   * Added charset option for `res.render()`
3145   * Added `.charset` support (via connect 1.0.4)
3146   * Added view resolution hints when in development and a lookup fails
3147   * Added layout lookup support relative to the page view.
3148     For example while rendering `./views/user/index.jade` if you create
3149     `./views/user/layout.jade` it will be used in favour of the root layout.
3150   * Fixed `res.redirect()`. RFC states absolute url [reported by unlink]
3151   * Fixed; default `res.send()` string charset to utf8
3152   * Removed `Partial` constructor (not currently used)
3154 2.0.0beta2 / 2011-03-07
3155 ==================
3157   * Added res.render() `.locals` support back to aid in migration process
3158   * Fixed flash example
3160 2.0.0beta / 2011-03-03
3161 ==================
3163   * Added HTTPS support
3164   * Added `res.cookie()` maxAge support
3165   * Added `req.header()` _Referrer_ / _Referer_ special-case, either works
3166   * Added mount support for `res.redirect()`, now respects the mount-point
3167   * Added `union()` util, taking place of `merge(clone())` combo
3168   * Added stylus support to express(1) generated app
3169   * Added secret to session middleware used in examples and generated app
3170   * Added `res.local(name, val)` for progressive view locals
3171   * Added default param support to `req.param(name, default)`
3172   * Added `app.disabled()` and `app.enabled()`
3173   * Added `app.register()` support for omitting leading ".", either works
3174   * Added `res.partial()`, using the same interface as `partial()` within a view. Closes #539
3175   * Added `app.param()` to map route params to async/sync logic
3176   * Added; aliased `app.helpers()` as `app.locals()`. Closes #481
3177   * Added extname with no leading "." support to `res.contentType()`
3178   * Added `cache views` setting, defaulting to enabled in "production" env
3179   * Added index file partial resolution, eg: partial('user') may try _views/user/index.jade_.
3180   * Added `req.accepts()` support for extensions
3181   * Changed; `res.download()` and `res.sendfile()` now utilize Connect's
3182     static file server `connect.static.send()`.
3183   * Changed; replaced `connect.utils.mime()` with npm _mime_ module
3184   * Changed; allow `req.query` to be pre-defined (via middleware or other parent
3185   * Changed view partial resolution, now relative to parent view
3186   * Changed view engine signature. no longer `engine.render(str, options, callback)`, now `engine.compile(str, options) -> Function`, the returned function accepts `fn(locals)`.
3187   * Fixed `req.param()` bug returning Array.prototype methods. Closes #552
3188   * Fixed; using `Stream#pipe()` instead of `sys.pump()` in `res.sendfile()`
3189   * Fixed; using _qs_ module instead of _querystring_
3190   * Fixed; strip unsafe chars from jsonp callbacks
3191   * Removed "stream threshold" setting
3193 1.0.8 / 2011-03-01
3194 ==================
3196   * Allow `req.query` to be pre-defined (via middleware or other parent app)
3197   * "connect": ">= 0.5.0 < 1.0.0". Closes #547
3198   * Removed the long deprecated __EXPRESS_ENV__ support
3200 1.0.7 / 2011-02-07
3201 ==================
3203   * Fixed `render()` setting inheritance.
3204     Mounted apps would not inherit "view engine"
3206 1.0.6 / 2011-02-07
3207 ==================
3209   * Fixed `view engine` setting bug when period is in dirname
3211 1.0.5 / 2011-02-05
3212 ==================
3214   * Added secret to generated app `session()` call
3216 1.0.4 / 2011-02-05
3217 ==================
3219   * Added `qs` dependency to _package.json_
3220   * Fixed namespaced `require()`s for latest connect support
3222 1.0.3 / 2011-01-13
3223 ==================
3225   * Remove unsafe characters from JSONP callback names [Ryan Grove]
3227 1.0.2 / 2011-01-10
3228 ==================
3230   * Removed nested require, using `connect.router`
3232 1.0.1 / 2010-12-29
3233 ==================
3235   * Fixed for middleware stacked via `createServer()`
3236     previously the `foo` middleware passed to `createServer(foo)`
3237     would not have access to Express methods such as `res.send()`
3238     or props like `req.query` etc.
3240 1.0.0 / 2010-11-16
3241 ==================
3243   * Added; deduce partial object names from the last segment.
3244     For example by default `partial('forum/post', postObject)` will
3245     give you the _post_ object, providing a meaningful default.
3246   * Added http status code string representation to `res.redirect()` body
3247   * Added; `res.redirect()` supporting _text/plain_ and _text/html_ via __Accept__.
3248   * Added `req.is()` to aid in content negotiation
3249   * Added partial local inheritance [suggested by masylum]. Closes #102
3250     providing access to parent template locals.
3251   * Added _-s, --session[s]_ flag to express(1) to add session related middleware
3252   * Added _--template_ flag to express(1) to specify the
3253     template engine to use.
3254   * Added _--css_ flag to express(1) to specify the
3255     stylesheet engine to use (or just plain css by default).
3256   * Added `app.all()` support [thanks aheckmann]
3257   * Added partial direct object support.
3258     You may now `partial('user', user)` providing the "user" local,
3259     vs previously `partial('user', { object: user })`.
3260   * Added _route-separation_ example since many people question ways
3261     to do this with CommonJS modules. Also view the _blog_ example for
3262     an alternative.
3263   * Performance; caching view path derived partial object names
3264   * Fixed partial local inheritance precedence. [reported by Nick Poulden] Closes #454
3265   * Fixed jsonp support; _text/javascript_ as per mailinglist discussion
3267 1.0.0rc4 / 2010-10-14
3268 ==================
3270   * Added _NODE_ENV_ support, _EXPRESS_ENV_ is deprecated and will be removed in 1.0.0
3271   * Added route-middleware support (very helpful, see the [docs](http://expressjs.com/guide.html#Route-Middleware))
3272   * Added _jsonp callback_ setting to enable/disable jsonp autowrapping [Dav Glass]
3273   * Added callback query check on response.send to autowrap JSON objects for simple webservice implementations [Dav Glass]
3274   * Added `partial()` support for array-like collections. Closes #434
3275   * Added support for swappable querystring parsers
3276   * Added session usage docs. Closes #443
3277   * Added dynamic helper caching. Closes #439 [suggested by maritz]
3278   * Added authentication example
3279   * Added basic Range support to `res.sendfile()` (and `res.download()` etc)
3280   * Changed; `express(1)` generated app using 2 spaces instead of 4
3281   * Default env to "development" again [aheckmann]
3282   * Removed _context_ option is no more, use "scope"
3283   * Fixed; exposing _./support_ libs to examples so they can run without installs
3284   * Fixed mvc example
3286 1.0.0rc3 / 2010-09-20
3287 ==================
3289   * Added confirmation for `express(1)` app generation. Closes #391
3290   * Added extending of flash formatters via `app.flashFormatters`
3291   * Added flash formatter support. Closes #411
3292   * Added streaming support to `res.sendfile()` using `sys.pump()` when >= "stream threshold"
3293   * Added _stream threshold_ setting for `res.sendfile()`
3294   * Added `res.send()` __HEAD__ support
3295   * Added `res.clearCookie()`
3296   * Added `res.cookie()`
3297   * Added `res.render()` headers option
3298   * Added `res.redirect()` response bodies
3299   * Added `res.render()` status option support. Closes #425 [thanks aheckmann]
3300   * Fixed `res.sendfile()` responding with 403 on malicious path
3301   * Fixed `res.download()` bug; when an error occurs remove _Content-Disposition_
3302   * Fixed; mounted apps settings now inherit from parent app [aheckmann]
3303   * Fixed; stripping Content-Length / Content-Type when 204
3304   * Fixed `res.send()` 204. Closes #419
3305   * Fixed multiple _Set-Cookie_ headers via `res.header()`. Closes #402
3306   * Fixed bug messing with error handlers when `listenFD()` is called instead of `listen()`. [thanks guillermo]
3309 1.0.0rc2 / 2010-08-17
3310 ==================
3312   * Added `app.register()` for template engine mapping. Closes #390
3313   * Added `res.render()` callback support as second argument (no options)
3314   * Added callback support to `res.download()`
3315   * Added callback support for `res.sendfile()`
3316   * Added support for middleware access via `express.middlewareName()` vs `connect.middlewareName()`
3317   * Added "partials" setting to docs
3318   * Added default expresso tests to `express(1)` generated app. Closes #384
3319   * Fixed `res.sendfile()` error handling, defer via `next()`
3320   * Fixed `res.render()` callback when a layout is used [thanks guillermo]
3321   * Fixed; `make install` creating ~/.node_libraries when not present
3322   * Fixed issue preventing error handlers from being defined anywhere. Closes #387
3324 1.0.0rc / 2010-07-28
3325 ==================
3327   * Added mounted hook. Closes #369
3328   * Added connect dependency to _package.json_
3330   * Removed "reload views" setting and support code
3331     development env never caches, production always caches.
3333   * Removed _param_ in route callbacks, signature is now
3334     simply (req, res, next), previously (req, res, params, next).
3335     Use _req.params_ for path captures, _req.query_ for GET params.
3337   * Fixed "home" setting
3338   * Fixed middleware/router precedence issue. Closes #366
3339   * Fixed; _configure()_ callbacks called immediately. Closes #368
3341 1.0.0beta2 / 2010-07-23
3342 ==================
3344   * Added more examples
3345   * Added; exporting `Server` constructor
3346   * Added `Server#helpers()` for view locals
3347   * Added `Server#dynamicHelpers()` for dynamic view locals. Closes #349
3348   * Added support for absolute view paths
3349   * Added; _home_ setting defaults to `Server#route` for mounted apps. Closes #363
3350   * Added Guillermo Rauch to the contributor list
3351   * Added support for "as" for non-collection partials. Closes #341
3352   * Fixed _install.sh_, ensuring _~/.node_libraries_ exists. Closes #362 [thanks jf]
3353   * Fixed `res.render()` exceptions, now passed to `next()` when no callback is given [thanks guillermo]
3354   * Fixed instanceof `Array` checks, now `Array.isArray()`
3355   * Fixed express(1) expansion of public dirs. Closes #348
3356   * Fixed middleware precedence. Closes #345
3357   * Fixed view watcher, now async [thanks aheckmann]
3359 1.0.0beta / 2010-07-15
3360 ==================
3362   * Re-write
3363     - much faster
3364     - much lighter
3365     - Check [ExpressJS.com](http://expressjs.com) for migration guide and updated docs
3367 0.14.0 / 2010-06-15
3368 ==================
3370   * Utilize relative requires
3371   * Added Static bufferSize option [aheckmann]
3372   * Fixed caching of view and partial subdirectories [aheckmann]
3373   * Fixed mime.type() comments now that ".ext" is not supported
3374   * Updated haml submodule
3375   * Updated class submodule
3376   * Removed bin/express
3378 0.13.0 / 2010-06-01
3379 ==================
3381   * Added node v0.1.97 compatibility
3382   * Added support for deleting cookies via Request#cookie('key', null)
3383   * Updated haml submodule
3384   * Fixed not-found page, now using charset utf-8
3385   * Fixed show-exceptions page, now using charset utf-8
3386   * Fixed view support due to fs.readFile Buffers
3387   * Changed; mime.type() no longer accepts ".type" due to node extname() changes
3389 0.12.0 / 2010-05-22
3390 ==================
3392   * Added node v0.1.96 compatibility
3393   * Added view `helpers` export which act as additional local variables
3394   * Updated haml submodule
3395   * Changed ETag; removed inode, modified time only
3396   * Fixed LF to CRLF for setting multiple cookies
3397   * Fixed cookie compilation; values are now urlencoded
3398   * Fixed cookies parsing; accepts quoted values and url escaped cookies
3400 0.11.0 / 2010-05-06
3401 ==================
3403   * Added support for layouts using different engines
3404     - this.render('page.html.haml', { layout: 'super-cool-layout.html.ejs' })
3405     - this.render('page.html.haml', { layout: 'foo' }) // assumes 'foo.html.haml'
3406     - this.render('page.html.haml', { layout: false }) // no layout
3407   * Updated ext submodule
3408   * Updated haml submodule
3409   * Fixed EJS partial support by passing along the context. Issue #307
3411 0.10.1 / 2010-05-03
3412 ==================
3414   * Fixed binary uploads.
3416 0.10.0 / 2010-04-30
3417 ==================
3419   * Added charset support via Request#charset (automatically assigned to 'UTF-8' when respond()'s
3420     encoding is set to 'utf8' or 'utf-8').
3421   * Added "encoding" option to Request#render(). Closes #299
3422   * Added "dump exceptions" setting, which is enabled by default.
3423   * Added simple ejs template engine support
3424   * Added error response support for text/plain, application/json. Closes #297
3425   * Added callback function param to Request#error()
3426   * Added Request#sendHead()
3427   * Added Request#stream()
3428   * Added support for Request#respond(304, null) for empty response bodies
3429   * Added ETag support to Request#sendfile()
3430   * Added options to Request#sendfile(), passed to fs.createReadStream()
3431   * Added filename arg to Request#download()
3432   * Performance enhanced due to pre-reversing plugins so that plugins.reverse() is not called on each request
3433   * Performance enhanced by preventing several calls to toLowerCase() in Router#match()
3434   * Changed; Request#sendfile() now streams
3435   * Changed; Renamed Request#halt() to Request#respond(). Closes #289
3436   * Changed; Using sys.inspect() instead of JSON.encode() for error output
3437   * Changed; run() returns the http.Server instance. Closes #298
3438   * Changed; Defaulting Server#host to null (INADDR_ANY)
3439   * Changed; Logger "common" format scale of 0.4f
3440   * Removed Logger "request" format
3441   * Fixed; Catching ENOENT in view caching, preventing error when "views/partials" is not found
3442   * Fixed several issues with http client
3443   * Fixed Logger Content-Length output
3444   * Fixed bug preventing Opera from retaining the generated session id. Closes #292
3446 0.9.0 / 2010-04-14
3447 ==================
3449   * Added DSL level error() route support
3450   * Added DSL level notFound() route support
3451   * Added Request#error()
3452   * Added Request#notFound()
3453   * Added Request#render() callback function. Closes #258
3454   * Added "max upload size" setting
3455   * Added "magic" variables to collection partials (\_\_index\_\_, \_\_length\_\_, \_\_isFirst\_\_, \_\_isLast\_\_). Closes #254
3456   * Added [haml.js](http://github.com/visionmedia/haml.js) submodule; removed haml-js
3457   * Added callback function support to Request#halt() as 3rd/4th arg
3458   * Added preprocessing of route param wildcards using param(). Closes #251
3459   * Added view partial support (with collections etc.)
3460   * Fixed bug preventing falsey params (such as ?page=0). Closes #286
3461   * Fixed setting of multiple cookies. Closes #199
3462   * Changed; view naming convention is now NAME.TYPE.ENGINE (for example page.html.haml)
3463   * Changed; session cookie is now httpOnly
3464   * Changed; Request is no longer global
3465   * Changed; Event is no longer global
3466   * Changed; "sys" module is no longer global
3467   * Changed; moved Request#download to Static plugin where it belongs
3468   * Changed; Request instance created before body parsing. Closes #262
3469   * Changed; Pre-caching views in memory when "cache view contents" is enabled. Closes #253
3470   * Changed; Pre-caching view partials in memory when "cache view partials" is enabled
3471   * Updated support to node --version 0.1.90
3472   * Updated dependencies
3473   * Removed set("session cookie") in favour of use(Session, { cookie: { ... }})
3474   * Removed utils.mixin(); use Object#mergeDeep()
3476 0.8.0 / 2010-03-19
3477 ==================
3479   * Added coffeescript example app. Closes #242
3480   * Changed; cache api now async friendly. Closes #240
3481   * Removed deprecated 'express/static' support. Use 'express/plugins/static'
3483 0.7.6 / 2010-03-19
3484 ==================
3486   * Added Request#isXHR. Closes #229
3487   * Added `make install` (for the executable)
3488   * Added `express` executable for setting up simple app templates
3489   * Added "GET /public/*" to Static plugin, defaulting to <root>/public
3490   * Added Static plugin
3491   * Fixed; Request#render() only calls cache.get() once
3492   * Fixed; Namespacing View caches with "view:"
3493   * Fixed; Namespacing Static caches with "static:"
3494   * Fixed; Both example apps now use the Static plugin
3495   * Fixed set("views"). Closes #239
3496   * Fixed missing space for combined log format
3497   * Deprecated Request#sendfile() and 'express/static'
3498   * Removed Server#running
3500 0.7.5 / 2010-03-16
3501 ==================
3503   * Added Request#flash() support without args, now returns all flashes
3504   * Updated ext submodule
3506 0.7.4 / 2010-03-16
3507 ==================
3509   * Fixed session reaper
3510   * Changed; class.js replacing js-oo Class implementation (quite a bit faster, no browser cruft)
3512 0.7.3 / 2010-03-16
3513 ==================
3515   * Added package.json
3516   * Fixed requiring of haml / sass due to kiwi removal
3518 0.7.2 / 2010-03-16
3519 ==================
3521   * Fixed GIT submodules (HAH!)
3523 0.7.1 / 2010-03-16
3524 ==================
3526   * Changed; Express now using submodules again until a PM is adopted
3527   * Changed; chat example using millisecond conversions from ext
3529 0.7.0 / 2010-03-15
3530 ==================
3532   * Added Request#pass() support (finds the next matching route, or the given path)
3533   * Added Logger plugin (default "common" format replaces CommonLogger)
3534   * Removed Profiler plugin
3535   * Removed CommonLogger plugin
3537 0.6.0 / 2010-03-11
3538 ==================
3540   * Added seed.yml for kiwi package management support
3541   * Added HTTP client query string support when method is GET. Closes #205
3543   * Added support for arbitrary view engines.
3544     For example "foo.engine.html" will now require('engine'),
3545     the exports from this module are cached after the first require().
3547   * Added async plugin support
3549   * Removed usage of RESTful route funcs as http client
3550     get() etc, use http.get() and friends
3552   * Removed custom exceptions
3554 0.5.0 / 2010-03-10
3555 ==================
3557   * Added ext dependency (library of js extensions)
3558   * Removed extname() / basename() utils. Use path module
3559   * Removed toArray() util. Use arguments.values
3560   * Removed escapeRegexp() util. Use RegExp.escape()
3561   * Removed process.mixin() dependency. Use utils.mixin()
3562   * Removed Collection
3563   * Removed ElementCollection
3564   * Shameless self promotion of ebook "Advanced JavaScript" (http://dev-mag.com)  ;)
3566 0.4.0 / 2010-02-11
3567 ==================
3569   * Added flash() example to sample upload app
3570   * Added high level restful http client module (express/http)
3571   * Changed; RESTful route functions double as HTTP clients. Closes #69
3572   * Changed; throwing error when routes are added at runtime
3573   * Changed; defaulting render() context to the current Request. Closes #197
3574   * Updated haml submodule
3576 0.3.0 / 2010-02-11
3577 ==================
3579   * Updated haml / sass submodules. Closes #200
3580   * Added flash message support. Closes #64
3581   * Added accepts() now allows multiple args. fixes #117
3582   * Added support for plugins to halt. Closes #189
3583   * Added alternate layout support. Closes #119
3584   * Removed Route#run(). Closes #188
3585   * Fixed broken specs due to use(Cookie) missing
3587 0.2.1 / 2010-02-05
3588 ==================
3590   * Added "plot" format option for Profiler (for gnuplot processing)
3591   * Added request number to Profiler plugin
3592   * Fixed binary encoding for multipart file uploads, was previously defaulting to UTF8
3593   * Fixed issue with routes not firing when not files are present. Closes #184
3594   * Fixed process.Promise -> events.Promise
3596 0.2.0 / 2010-02-03
3597 ==================
3599   * Added parseParam() support for name[] etc. (allows for file inputs with "multiple" attr) Closes #180
3600   * Added Both Cache and Session option "reapInterval" may be "reapEvery". Closes #174
3601   * Added expiration support to cache api with reaper. Closes #133
3602   * Added cache Store.Memory#reap()
3603   * Added Cache; cache api now uses first class Cache instances
3604   * Added abstract session Store. Closes #172
3605   * Changed; cache Memory.Store#get() utilizing Collection
3606   * Renamed MemoryStore -> Store.Memory
3607   * Fixed use() of the same plugin several time will always use latest options. Closes #176
3609 0.1.0 / 2010-02-03
3610 ==================
3612   * Changed; Hooks (before / after) pass request as arg as well as evaluated in their context
3613   * Updated node support to 0.1.27 Closes #169
3614   * Updated dirname(__filename) -> __dirname
3615   * Updated libxmljs support to v0.2.0
3616   * Added session support with memory store / reaping
3617   * Added quick uid() helper
3618   * Added multi-part upload support
3619   * Added Sass.js support / submodule
3620   * Added production env caching view contents and static files
3621   * Added static file caching. Closes #136
3622   * Added cache plugin with memory stores
3623   * Added support to StaticFile so that it works with non-textual files.
3624   * Removed dirname() helper
3625   * Removed several globals (now their modules must be required)
3627 0.0.2 / 2010-01-10
3628 ==================
3630   * Added view benchmarks; currently haml vs ejs
3631   * Added Request#attachment() specs. Closes #116
3632   * Added use of node's parseQuery() util. Closes #123
3633   * Added `make init` for submodules
3634   * Updated Haml
3635   * Updated sample chat app to show messages on load
3636   * Updated libxmljs parseString -> parseHtmlString
3637   * Fixed `make init` to work with older versions of git
3638   * Fixed specs can now run independent specs for those who can't build deps. Closes #127
3639   * Fixed issues introduced by the node url module changes. Closes 126.
3640   * Fixed two assertions failing due to Collection#keys() returning strings
3641   * Fixed faulty Collection#toArray() spec due to keys() returning strings
3642   * Fixed `make test` now builds libxmljs.node before testing
3644 0.0.1 / 2010-01-03
3645 ==================
3647   * Initial release