Provided by: libprotocol-http2-perl_1.10-3_all
NAME
Protocol::HTTP2::Client - HTTP/2 client
SYNOPSIS
use Protocol::HTTP2::Client; # Create client object my $client = Protocol::HTTP2::Client->new; # Prepare first request $client->request( # HTTP/2 headers ':scheme' => 'http', ':authority' => 'localhost:8000', ':path' => '/', ':method' => 'GET', # HTTP/1.1 headers headers => [ 'accept' => '*/*', 'user-agent' => 'perl-Protocol-HTTP2/0.13', ], # Callback when receive server's response on_done => sub { my ( $headers, $data ) = @_; ... }, ); # Protocol::HTTP2 is just HTTP/2 protocol decoder/encoder # so you must create connection yourself use AnyEvent; use AnyEvent::Socket; use AnyEvent::Handle; my $w = AnyEvent->condvar; # Plain-text HTTP/2 connection tcp_connect 'localhost', 8000, sub { my ($fh) = @_ or die "connection failed: $!\n"; my $handle; $handle = AnyEvent::Handle->new( fh => $fh, autocork => 1, on_error => sub { $_[0]->destroy; print "connection error\n"; $w->send; }, on_eof => sub { $handle->destroy; $w->send; } ); # First write preface to peer while ( my $frame = $client->next_frame ) { $handle->push_write($frame); } # Receive servers frames # Reply to server $handle->on_read( sub { my $handle = shift; $client->feed( $handle->{rbuf} ); $handle->{rbuf} = undef; while ( my $frame = $client->next_frame ) { $handle->push_write($frame); } # Terminate connection if all done $handle->push_shutdown if $client->shutdown; } ); }; $w->recv;
DESCRIPTION
Protocol::HTTP2::Client is HTTP/2 client library. It's intended to make http2-client implementations on top of your favorite event-loop. METHODS new Initialize new client object my $client = Procotol::HTTP2::Client->new( %options ); Available options: on_push => sub {...} If server send push promise this callback will be invoked on_push => sub { # received PUSH PROMISE headers my $pp_header = shift; ... # if we want reject this push # return undef # if we want to accept pushed resource # return callback to receive data return sub { my ( $headers, $data ) = @_; ... } }, upgrade => 0|1 Use HTTP/1.1 Upgrade to upgrade protocol from HTTP/1.1 to HTTP/2. Upgrade possible only on plain (non-tls) connection. Default value is 0. See Starting HTTP/2 for "http" URIs <https://tools.ietf.org/html/rfc7540#section-3.2> keepalive => 0|1 Keep connection alive after requests. Default value is 0. Don't forget to explicitly call close method if set this to true. on_error => sub {...} Callback invoked on protocol errors on_error => sub { my $error = shift; ... }, on_change_state => sub {...} Callback invoked every time when http/2 streams change their state. See Stream States <https://tools.ietf.org/html/rfc7540#section-5.1> on_change_state => sub { my ( $stream_id, $previous_state, $current_state ) = @_; ... }, request Prepare HTTP/2 request. $client->request( # HTTP/2 headers ':scheme' => 'http', ':authority' => 'localhost:8000', ':path' => '/items', ':method' => 'POST', # HTTP/1.1 headers headers => [ 'content-type' => 'application/x-www-form-urlencoded', 'user-agent' => 'perl-Protocol-HTTP2/0.06', ], # Callback when receive server's response on_done => sub { my ( $headers, $data ) = @_; ... }, # Callback when receive stream reset on_error => sub { my $error_code = shift; }, # Body of POST request data => "hello=world&test=done", ); You can chaining request one by one: $client->request( 1-st request )->request( 2-nd request ); Available callbacks: on_done => sub {...} Invoked when full servers response is available on_done => sub { my ( $headers, $data ) = @_; ... }, on_headers => sub {...} Invoked as soon as headers have been successfully received from the server on_headers => sub { my $headers = shift; ... # if we want reject any data # return undef # continue return 1 } on_data => sub {...} If specified all data will be passed to this callback instead if on_done. on_done will receive empty string. on_data => sub { my ( $partial_data, $headers ) = @_; ... # if we want cancel download # return undef # continue downloading return 1 } on_error => sub {...} Callback invoked on stream errors on_error => sub { my $error = shift; ... } keepalive Keep connection alive after requests my $bool = $client->keepalive; $client = $client->keepalive($bool); shutdown Get connection status: 0 - active 1 - closed (you can terminate connection) close Explicitly close connection (send GOAWAY frame). This is required if client has keepalive option enabled. next_frame get next frame to send over connection to server. Returns: undef - on error 0 - nothing to send binary string - encoded frame # Example while ( my $frame = $client->next_frame ) { syswrite $fh, $frame; } feed Feed decoder with chunks of server's response sysread $fh, $binary_data, 4096; $client->feed($binary_data); ping Send ping frame to server (to keep connection alive) $client->ping or $client->ping($payload); Payload can be arbitrary binary string and must contain 8 octets. If payload argument is omitted client will send random data.