diff options
author | David Golden <dagolden@cpan.org> | 2014-02-18 15:41:28 -0500 |
---|---|---|
committer | David Golden <dagolden@cpan.org> | 2014-02-18 15:42:53 -0500 |
commit | 351ec230d480130439db26b86b4e19da52a96028 (patch) | |
tree | 201028322a509379458383c3c79204fda8301bbb /cpan/HTTP-Tiny/lib/HTTP/Tiny.pm | |
parent | 1c604e7c7f7b510f20ef069f870edef1578207fe (diff) | |
download | perl-351ec230d480130439db26b86b4e19da52a96028.tar.gz |
Update HTTP-Tiny to CPAN version 0.042
[DELTA]
[ADDED]
- If IO::Socket::IP 0.25+ is installed, HTTP::Tiny will use it for
transparent IPv4 or IPv6 support.
Diffstat (limited to 'cpan/HTTP-Tiny/lib/HTTP/Tiny.pm')
-rw-r--r-- | cpan/HTTP-Tiny/lib/HTTP/Tiny.pm | 46 |
1 files changed, 25 insertions, 21 deletions
diff --git a/cpan/HTTP-Tiny/lib/HTTP/Tiny.pm b/cpan/HTTP-Tiny/lib/HTTP/Tiny.pm index 9ed66bc1a3..6db995ce5d 100644 --- a/cpan/HTTP-Tiny/lib/HTTP/Tiny.pm +++ b/cpan/HTTP-Tiny/lib/HTTP/Tiny.pm @@ -3,7 +3,7 @@ package HTTP::Tiny; use strict; use warnings; # ABSTRACT: A small, simple, correct HTTP/1.1 client -our $VERSION = '0.041'; # VERSION +our $VERSION = '0.042'; # VERSION use Carp (); @@ -416,9 +416,6 @@ sub request { # reference. If data is provided as a hash reference, the key/value pairs in the # resulting string will be sorted by key and value for consistent ordering. # -# To preserve the order (r -# -# # =cut sub www_form_urlencode { @@ -843,6 +840,14 @@ use warnings; use Errno qw[EINTR EPIPE]; use IO::Socket qw[SOCK_STREAM]; +# PERL_HTTP_TINY_IPV4_ONLY is a private environment variable to force old +# behavior if someone is unable to boostrap CPAN from a new perl install; it is +# not intended for general, per-client use and may be removed in the future +my $SOCKET_CLASS = + $ENV{PERL_HTTP_TINY_IPV4_ONLY} ? 'IO::Socket::INET' : + eval { require IO::Socket::IP; IO::Socket::IP->VERSION(0.25) } ? 'IO::Socket::IP' : + 'IO::Socket::INET'; + sub BUFSIZE () { 32768 } ## no critic my $Printable = sub { @@ -879,7 +884,7 @@ sub connect { elsif ( $scheme ne 'http' ) { die(qq/Unsupported URL scheme '$scheme'\n/); } - $self->{fh} = 'IO::Socket::INET'->new( + $self->{fh} = $SOCKET_CLASS->new( PeerHost => $host, PeerPort => $port, $self->{local_address} ? @@ -1419,7 +1424,7 @@ HTTP::Tiny - A small, simple, correct HTTP/1.1 client =head1 VERSION -version 0.041 +version 0.042 =head1 SYNOPSIS @@ -1441,12 +1446,17 @@ version 0.041 =head1 DESCRIPTION -This is a very simple HTTP/1.1 client, designed for doing simple GET +This is a very simple HTTP/1.1 client, designed for doing simple requests without the overhead of a large framework like L<LWP::UserAgent>. It is more correct and more complete than L<HTTP::Lite>. It supports proxies and redirection. It also correctly resumes after EINTR. +If L<IO::Socket::IP> 0.25 or later is installed, HTTP::Tiny will use it instead +of L<IO::Socket::INET> for transparent support for both IPv4 and IPv6. + +Cookie support requires L<HTTP::CookieJar> or an equivalent class. + =head1 METHODS =head2 new @@ -1742,8 +1752,6 @@ array reference, the key will be repeated with each of the values of the array reference. If data is provided as a hash reference, the key/value pairs in the resulting string will be sorted by key and value for consistent ordering. -To preserve the order (r - =for Pod::Coverage SSL_options agent cookie_jar @@ -1913,10 +1921,6 @@ mandated by the specification. There is no automatic support for status 305 =item * -Cookie support requires L<HTTP::CookieJar> or an equivalent class. - -=item * - There is no provision for delaying a request body using an C<Expect> header. Unexpected C<1XX> responses are silently ignored as per the specification. @@ -1928,15 +1932,11 @@ Only 'chunked' C<Transfer-Encoding> is supported. There is no support for a Request-URI of '*' for the 'OPTIONS' request. -=item * - -There is no support for IPv6 of any kind. - =back -Despite the limitations listed above, HTTP::Tiny is considered nearly -feature-complete. If there are enhancements unrelated to the underlying -transport, please consider them for L<HTTP::Tiny::UA> instead. +Despite the limitations listed above, HTTP::Tiny is considered +feature-complete. New feature requests should be directed to +L<HTTP::Tiny::UA>. =head1 SEE ALSO @@ -1944,7 +1944,7 @@ transport, please consider them for L<HTTP::Tiny::UA> instead. =item * -L<HTTP::Tiny::UA> — Higher level UA features for HTTP::Tiny +L<HTTP::Tiny::UA> - Higher level UA features for HTTP::Tiny =item * @@ -1956,6 +1956,10 @@ L<HTTP::Tiny::Mech> - Wrap L<WWW::Mechanize> instance in HTTP::Tiny compatible i =item * +L<IO::Socket::IP> - Required for IPv6 support + +=item * + L<IO::Socket::SSL> - Required for SSL support =item * |