1 | Revision history for AnyEvent::HTTP |
1 | Revision history for AnyEvent::HTTP |
2 | |
2 | |
3 | TODO: provide lwp_request function that takes an lwp http requets and returns a http response. |
3 | TODO: provide lwp_request function that takes an lwp http requets and returns a http response. |
4 | TODO: when recurse as initially true, geenerate error on rediretc loops etc. |
4 | TODO: httpbis: $location = URI->new_abs($location, "$scheme://$host:$port$path_query")->as_string; |
|
|
5 | |
|
|
6 | 2.11 Tue May 10 14:33:28 CEST 2011 |
|
|
7 | - the keepalive session cache wouldn't take port and scheme into account |
|
|
8 | when reusing connection - potentially causing information leaks |
|
|
9 | (reported by Nick Kostirya). |
|
|
10 | - bump AnyEvent dependency version (reported by Richard Harris). |
|
|
11 | |
|
|
12 | 2.1 Thu Feb 24 13:11:51 CET 2011 |
|
|
13 | - the keepalive and persistent parameters were actually named |
|
|
14 | differently in the code - they now work as documented. |
|
|
15 | - fix a bug where callbacks would sometimes never be called when |
|
|
16 | the request timeout is near or below the persistent connection |
|
|
17 | timeout (testcase by Cindy Wang). |
|
|
18 | - destroying the guard would have no effect when a request was |
|
|
19 | recursing or being retired. |
|
|
20 | |
|
|
21 | 2.04 Sat Feb 19 07:45:24 CET 2011 |
|
|
22 | - "proxy => undef" now overrides any global proxy when specified. |
|
|
23 | - require scheme in urls, also use a stricter match to match urls, |
|
|
24 | leading or trailing garbage is no longer tolerated. |
|
|
25 | - EXPERIMENTAL: allow '=' in cookie values. |
|
|
26 | |
|
|
27 | 2.03 Tue Jan 18 18:49:35 CET 2011 |
|
|
28 | - dummy reupload, file gone from cpan somehow. |
|
|
29 | |
|
|
30 | 2.02 Wed Jan 12 04:29:37 CET 2011 |
|
|
31 | - do not lowercase cookie names, only parameter names. |
|
|
32 | |
|
|
33 | 2.01 Tue Jan 11 07:38:15 CET 2011 |
|
|
34 | - add missing dependency on common::sense. |
|
|
35 | - add a resume download example. |
|
|
36 | |
|
|
37 | 2.0 Tue Jan 4 09:16:56 CET 2011 |
|
|
38 | - hopefully fully upgraded to HTTP/1.1. |
|
|
39 | - support HTTP/1.1 persistent and HTTP/1.0 keep-alive connections. |
|
|
40 | - drop https-proxy-connection support. seems unused and ill-specified. |
|
|
41 | - use more differentiated 59x status codes. |
|
|
42 | - properly use url (not proxy) hostname to verify server certificate. |
|
|
43 | - much improved cookie implementation: |
|
|
44 | - properly implement cookie expiry (for new cookies). |
|
|
45 | - new function to expire cookies and sessions: cookie_jar_expire. |
|
|
46 | - add special exception to parse broken expires= keys in |
|
|
47 | set-cookie headers. |
|
|
48 | - do not quote cookie values when not strictly necessary, to |
|
|
49 | improve compatibility with broken servers. |
|
|
50 | - accept and send lots of invalid cookie values exactly as |
|
|
51 | they were received - this should not impact valid values. |
|
|
52 | - lowercase cookie parameter names for improved compatibility. |
|
|
53 | - support the max-age cookie parameter, overrides expires. |
|
|
54 | - support cookie dates (and a few others) in parse_date. |
|
|
55 | - properly support value-less parameters (e.g. secure, httponly). |
|
|
56 | - do not send Host: header in a proxy CONNECT request. |
|
|
57 | - use common::sense. |
|
|
58 | - lowercase hostnames and schemes. |
|
|
59 | - ignore leading zeroes in http version. |
|
|
60 | - handle spaces in content-length headers more gracefully. |
|
|
61 | |
|
|
62 | 1.5 Fri Dec 31 04:47:08 CET 2010 |
|
|
63 | - bugfix: after headers were received, if any error occured the wrong |
|
|
64 | (server-sent) Status and Reason fields would be passed to the callback. |
|
|
65 | - when an error occurs during transfer, preserve status/reason. |
|
|
66 | - add socks4a connect example. |
|
|
67 | - new "tcp_connect" parameter. |
|
|
68 | - new format_date and parse_date functions. |
|
|
69 | - diagnose unexpected eof as such when the length is known. |
|
|
70 | - add 205 to the responses without body. |
|
|
71 | |
|
|
72 | 1.46 Mon Sep 6 08:29:34 CEST 2010 |
|
|
73 | - some (broken) servers differentiate between empty search parts |
|
|
74 | and nonexistant search parts, work around this (problem |
|
|
75 | analyzed by Sergey Zasenko). |
|
|
76 | - possibly increase robustness by always setting an on_error |
|
|
77 | callback on the AnyEvent::Handle object (especially in case |
|
|
78 | of user errors, such as nehative timeouts). |
|
|
79 | - we now always follow 301/302/303 redirects and mutate POST to GET. |
|
|
80 | - we now always follow 307 redirects, even for POST. |
|
|
81 | - header-less responses are not parsed correctly (at a negative |
|
|
82 | speed penatly :). |
|
|
83 | |
|
|
84 | 1.45 Wed Jun 16 21:15:26 CEST 2010 |
|
|
85 | - fix a bug where the handle would go away directly after a successful |
|
|
86 | connect (analyzed and patch by Maxim Dounin). |
|
|
87 | - due to popular demand, introduce the Redirect pseudo response header. |
|
|
88 | - document URL pseudo-header better. |
|
|
89 | - explain how to implement DNS caching. |
|
|
90 | |
|
|
91 | 1.44 Sat Dec 5 16:36:20 CET 2009 |
|
|
92 | - do not generate content-length on get requests (if the body is empty), |
|
|
93 | as there are even more broken servers out there. |
|
|
94 | - allow set_proxy to clear the proxy again. |
|
|
95 | - set_proxy will now croak on invalid urls. |
|
|
96 | - support overriding the Host-header (requested by Tatsuhiko Miyagawa). |
|
|
97 | |
|
|
98 | 1.43 Fri Aug 14 17:02:02 CEST 2009 |
|
|
99 | - provide on_prepare callback on common request. |
|
|
100 | |
|
|
101 | 1.42 Wed Aug 5 18:43:01 CEST 2009 |
|
|
102 | - allow suppression of auto-supplied header fields by specifying undef |
|
|
103 | (requested by Mr Guest). |
|
|
104 | - allow proxy scheme to be missing, as documented |
|
|
105 | (reported by Mr Guest). |
|
|
106 | - do not follow redirects if we do not have a location header |
|
|
107 | (requested by Mr Guest). |
5 | |
108 | |
6 | 1.41 Sat Jul 25 03:27:05 CEST 2009 |
109 | 1.41 Sat Jul 25 03:27:05 CEST 2009 |
7 | - correctly parse completely headerless responses (e.g. by gatling). |
110 | - correctly parse completely headerless responses (e.g. by gatling). |
8 | (analysed by Robin Redeker). |
111 | (analysed by Robin Redeker). |
9 | |
112 | |