ViewVC Help
View File | Revision Log | Show Annotations | Download File
/cvs/AnyEvent-HTTP/Changes
Revision: 1.69
Committed: Thu Feb 24 12:13:11 2011 UTC (13 years, 2 months ago) by root
Branch: MAIN
CVS Tags: rel-2_1
Changes since 1.68: +9 -0 lines
Log Message:
2.1

File Contents

# User Rev Content
1 root 1.2 Revision history for AnyEvent::HTTP
2 root 1.1
3 root 1.18 TODO: provide lwp_request function that takes an lwp http requets and returns a http response.
4 root 1.68 TODO: httpbis: $location = URI->new_abs($location, "$scheme://$host:$port$path_query")->as_string;
5 root 1.46
6 root 1.69 2.1 Thu Feb 24 13:11:51 CET 2011
7     - the keepalive and persistent parameters were actually named
8     differently in the code - they now work as documented.
9     - fix a bug where callbacks would sometimes never be called when
10     the request timeout is near or below the persistent conenction
11     timeout (testcase by Cindy Wang).
12     - destroying the guard would have no effect when a request was
13     recursing or being retired.
14    
15 root 1.68 2.04 Sat Feb 19 07:45:24 CET 2011
16     - "proxy => undef" now overrides any global proxy when specified.
17 root 1.66 - require scheme in urls, also use a stricter match to match urls,
18     leading or trailing garbage is no longer tolerated.
19 root 1.68 - EXPERIMENTAL: allow '=' in cookie values.
20 root 1.66
21 root 1.65 2.03 Tue Jan 18 18:49:35 CET 2011
22     - dummy reupload, file gone from cpan somehow.
23    
24 root 1.64 2.02 Wed Jan 12 04:29:37 CET 2011
25     - do not lowercase cookie names, only parameter names.
26    
27 root 1.63 2.01 Tue Jan 11 07:38:15 CET 2011
28 root 1.62 - add missing dependency on common::sense.
29 root 1.63 - add a resume download example.
30 root 1.62
31 root 1.59 2.0 Tue Jan 4 09:16:56 CET 2011
32 root 1.48 - hopefully fully upgraded to HTTP/1.1.
33 root 1.59 - support HTTP/1.1 persistent and HTTP/1.0 keep-alive connections.
34     - drop https-proxy-connection support. seems unused and ill-specified.
35 root 1.60 - use more differentiated 59x status codes.
36     - properly use url (not proxy) hostname to verify server certificate.
37 root 1.48 - much improved cookie implementation:
38 root 1.53 - properly implement cookie expiry (for new cookies).
39     - new function to expire cookies and sessions: cookie_jar_expire.
40 root 1.48 - add special exception to parse broken expires= keys in
41     set-cookie headers.
42 root 1.49 - do not quote cookie values when not strictly necessary, to
43     improve compatibility with broken servers.
44 root 1.50 - accept and send lots of invalid cookie values exactly as
45     they were received - this should not impact valid values.
46 root 1.48 - lowercase cookie parameter names for improved compatibility.
47 root 1.60 - support the max-age cookie parameter, overrides expires.
48 root 1.53 - support cookie dates (and a few others) in parse_date.
49 root 1.60 - properly support value-less parameters (e.g. secure, httponly).
50 root 1.57 - do not send Host: header in a proxy CONNECT request.
51     - use common::sense.
52     - lowercase hostnames and schemes.
53     - ignore leading zeroes in http version.
54     - handle spaces in content-length headers more gracefully.
55 root 1.47
56 root 1.46 1.5 Fri Dec 31 04:47:08 CET 2010
57 root 1.45 - bugfix: after headers were received, if any error occured the wrong
58     (server-sent) Status and Reason fields would be passed to the callback.
59     - when an error occurs during transfer, preserve status/reason.
60 root 1.41 - add socks4a connect example.
61 root 1.40 - new "tcp_connect" parameter.
62 root 1.42 - new format_date and parse_date functions.
63 root 1.45 - diagnose unexpected eof as such when the length is known.
64     - add 205 to the responses without body.
65 root 1.37
66 root 1.39 1.46 Mon Sep 6 08:29:34 CEST 2010
67 root 1.38 - some (broken) servers differentiate between empty search parts
68     and nonexistant search parts, work around this (problem
69     analyzed by Sergey Zasenko).
70     - possibly increase robustness by always setting an on_error
71 root 1.39 callback on the AnyEvent::Handle object (especially in case
72     of user errors, such as nehative timeouts).
73     - we now always follow 301/302/303 redirects and mutate POST to GET.
74     - we now always follow 307 redirects, even for POST.
75     - header-less responses are not parsed correctly (at a negative
76     speed penatly :).
77 root 1.38
78 root 1.37 1.45 Wed Jun 16 21:15:26 CEST 2010
79 root 1.38 - fix a bug where the handle would go away directly after a successful
80 root 1.37 connect (analyzed and patch by Maxim Dounin).
81     - due to popular demand, introduce the Redirect pseudo response header.
82     - document URL pseudo-header better.
83     - explain how to implement DNS caching.
84 root 1.30
85 root 1.35 1.44 Sat Dec 5 16:36:20 CET 2009
86     - do not generate content-length on get requests (if the body is empty),
87     as there are even more broken servers out there.
88 root 1.34 - allow set_proxy to clear the proxy again.
89     - set_proxy will now croak on invalid urls.
90 root 1.35 - support overriding the Host-header (requested by Tatsuhiko Miyagawa).
91 root 1.34
92 root 1.33 1.43 Fri Aug 14 17:02:02 CEST 2009
93     - provide on_prepare callback on common request.
94    
95 root 1.31 1.42 Wed Aug 5 18:43:01 CEST 2009
96 root 1.61 - allow suppression of auto-supplied header fields by specifying undef
97 root 1.30 (requested by Mr Guest).
98     - allow proxy scheme to be missing, as documented
99     (reported by Mr Guest).
100     - do not follow redirects if we do not have a location header
101     (requested by Mr Guest).
102    
103 root 1.29 1.41 Sat Jul 25 03:27:05 CEST 2009
104     - correctly parse completely headerless responses (e.g. by gatling).
105     (analysed by Robin Redeker).
106    
107 root 1.28 1.4 Tue Jul 7 02:14:53 CEST 2009
108 root 1.25 - http_request would not instantly clear the connection slot on
109     tcp_connect failures, potentially leading to deadlocks.
110 root 1.28 - fix a bug where a connection error is wrongly reported
111     as EINPROGRESS.
112 root 1.26 - new parameters: on_header, on_body, want_body_handle.
113     - redirects will be followed when recurse is enabled whether or not
114     the body dowload was successful or not.
115 root 1.27 - include :port in Host header when given in the url (many sites break
116     when it's always there, and many break if it's missing...).
117 root 1.26 - pass the empty string, not undef, when there is no body but
118     no error occured.
119     - allow passing of tls_ctx, predefine two https security profiles.
120 root 1.25 - ucfirst all error messages generated internally.
121     - include "U" token in User-Agent.
122 root 1.27 - document $AnyEvent::HTTP::MAX_PER_HOST.
123     - allow empty field names in response headers (microsoft hits. microsoft
124     hits. microsoft hits. you die).
125 root 1.25
126 root 1.24 1.12 Thu Jun 11 14:45:18 CEST 2009
127 root 1.23 - $scheme wasn't optional in the proxy specification (reported by
128     Felix Antonius Wilhelm Ostmann).
129    
130 root 1.22 1.11 Fri Nov 21 09:18:11 CET 2008
131     - work around a perl core bug not properly refcounting function arguments,
132     causing "200 OK" with random body results (reported by Дмитрий Шалашов).
133    
134 root 1.21 1.1 Thu Oct 30 04:46:27 CET 2008
135 root 1.18 - work around different behaviour of AnyEvent::Handle in TLS mode.
136 root 1.17 - cleanup cookie implementation, many examples and comments were
137     provided by Дмитрий Шалашов.
138     - document the return values of http_* functions better.
139 root 1.19 - separate multiple header values by "," not "\x00" (this does not
140     break correctly written users of the old API).
141     - improve Set-Cookie: parsing.
142     - add experimental https-over-http-proxy support.
143     - downgrade https-over-https proxy to https-over-http.
144     - ignore spurious CR characters in headers, they show up
145     in the weirdest of places.
146     - ucfirst the request headers, for a slightly less weird look.
147 root 1.20 - work around (some) memleaks in perl regarding qr.
148 root 1.17
149 root 1.16 1.05 Mon Sep 29 15:49:58 CEST 2008
150     - fix a regex when parsing cookie domains
151     (patch by Дмитрий Шалашов).
152    
153 root 1.15 1.04 Thu Jul 24 08:00:46 CEST 2008
154 root 1.14 - parse reason-less http status responses.
155     - parse more forms of broken location headers.
156    
157 root 1.13 1.03 Thu Jul 3 03:47:58 CEST 2008
158 root 1.10 - fix http_post, which was totally broken (patch by Pedro Melo).
159 root 1.13 - do not recurse on POST requests, as per HTTP/1.[01] (this might
160     change as the recommendation isn't followed by anybody else).
161     - implement preliminary support for 303/307 redirects.
162 root 1.10
163 root 1.9 1.02 Thu Jun 12 13:50:08 CEST 2008
164     - make the request URL available in the callback of http_request.
165 root 1.7 - export http_post, http_head.
166    
167 root 1.6 1.01 Fri Jun 6 14:56:37 CEST 2008
168 elmex 1.5 - fixed prototypes for http_* functions
169    
170 root 1.4 1.0 Thu Jun 5 20:41:43 CEST 2008
171 root 1.3 - original version, an AnyEvent::AIO clone.