table of contents
Mojo::IOLoop::Stream::HTTPClient(3pm) | User Contributed Perl Documentation | Mojo::IOLoop::Stream::HTTPClient(3pm) |
NAME¶
Mojo::IOLoop::Stream::HTTPClient - Non-blocking I/O HTTP client stream
SYNOPSIS¶
use Mojo::IOLoop::Client; use Mojo::IOLoop::Stream::HTTPClient; use Mojo::Transaction::HTTP; # Create transaction my $tx = Mojo::Transaction::HTTP->new; $tx->req->method('GET') $tx->url->parse('https://mojolicious.org'); $tx->on( finish => sub { my $tx = shift; say $tx->res->code; } ); # Create socket connection my $client = Mojo::IOLoop::Client->new; $client->on( connect => sub { my $stream = Mojo::IOLoop::Stream::HTTPClient->new(pop); $stream->start; $stream->process($tx); } ); $client->connect(address => 'mojolicious.org', port => 80); # Start reactor if necessary $stream->reactor->start unless $stream->reactor->is_running;
DESCRIPTION¶
Mojo::IOLoop::Stream::HTTPClient is a container for I/O streams used by Mojo::IOLoop to support the HTTP protocol client-side.
EVENTS¶
Mojo::IOLoop::Stream::HTTPClient inherits all events from Mojo::IOLoop::Stream and can emit the following new ones.
upgrade¶
$stream->on(upgrade => sub { my ($stream, $ws) = @_; ... });
Emitted when the connection should be upgraded to the WebSocket protocol.
ATTRIBUTES¶
Mojo::IOLoop::Stream::HTTPClient inherits all attributes from Mojo::IOLoop::Stream and implements the following ones.
request_timeout¶
my $timeout = $stream->request_timeout; $stream = $stream->request_timeout(5);
Maximum amount of time in seconds sending the request and receiving a whole response may take before getting canceled, defaults to 0. Setting the value to 0 will allow to wait indefinitely.
METHODS¶
Mojo::IOLoop::Stream::HTTPClient inherits all methods from Mojo::IOLoop::Stream and implements the following new ones.
new¶
my $stream = Mojo::IOLoop::Stream::HTTPClient->new($handle);
Construct a new Mojo::IOLoop::Stream::HTTPClient object.
process¶
$stream->process(Mojo::Transaction::HTTP->new);
Process a Mojo::Transaction::HTTP object with the current connection.
DEBUGGING¶
You can set the "MOJO_CLIENT_DEBUG" environment variable to get some advanced diagnostics information printed to "STDERR".
MOJO_CLIENT_DEBUG=1
SEE ALSO¶
Mojolicious, Mojolicious::Guides, <http://mojolicious.org>.
2018-07-28 | perl v5.26.2 |