NAME

Mojo::Transaction::HTTP - HTTP transaction

SYNOPSIS

use Mojo::Transaction::HTTP;

# Client
my $tx = Mojo::Transaction::HTTP->new;
$tx->req->method('GET');
$tx->req->url->parse('http://example.com');
$tx->req->headers->accept('application/json');
say $tx->res->code;
say $tx->res->headers->content_type;
say $tx->res->body;
say $tx->remote_address;

# Server
my $tx = Mojo::Transaction::HTTP->new;
say $tx->req->method;
say $tx->req->url->to_abs;
say $tx->req->headers->accept;
say $tx->remote_address;
$tx->res->code(200);
$tx->res->headers->content_type('text/plain');
$tx->res->body('Hello World!');

DESCRIPTION

Mojo::Transaction::HTTP is a container for HTTP transactions as described in RFC 2616.

EVENTS

Mojo::Transaction::HTTP inherits all events from Mojo::Transaction and can emit the following new ones.

request

$tx->on(request => sub {
  my $tx = shift;
  ...
});

Emitted when a request is ready and needs to be handled.

$tx->on(request => sub {
  my $tx = shift;
  $tx->res->headers->header('X-Bender' => 'Bite my shiny metal ass!');
});

unexpected

$tx->on(unexpected => sub {
  my ($tx, $res) = @_;
  ...
});

Emitted for unexpected 1xx responses that will be ignored.

$tx->on(unexpected => sub {
  my $tx = shift;
  $tx->res->on(finish => sub { say 'Followup response is finished.' });
});

upgrade

$tx->on(upgrade => sub {
  my ($tx, $ws) = @_;
  ...
});

Emitted when transaction gets upgraded to a Mojo::Transaction::WebSocket object.

$tx->on(upgrade => sub {
  my ($tx, $ws) = @_;
  $ws->res->headers->header('X-Bender' => 'Bite my shiny metal ass!');
});

ATTRIBUTES

Mojo::Transaction::HTTP inherits all attributes from Mojo::Transaction and implements the following new ones.

previous

my $previous = $tx->previous;
$tx          = $tx->previous(Mojo::Transaction->new);

Previous transaction that triggered this followup transaction.

# Path of previous request
say $tx->previous->req->url->path;

METHODS

Mojo::Transaction::HTTP inherits all methods from Mojo::Transaction and implements the following new ones.

client_read

$tx->client_read($bytes);

Read data client-side, used to implement user agents.

client_write

my $bytes = $tx->client_write;

Write data client-side, used to implement user agents.

is_empty

my $bool = $tx->is_empty;

Check transaction for HEAD request and 1xx, 204 or 304 response.

keep_alive

my $bool = $tx->keep_alive;

Check if connection can be kept alive.

redirects

my $redirects = $tx->redirects;

Return a list of all previous transactions that preceded this followup transaction.

# Paths of all previous requests
say $_->req->url->path for @{$tx->redirects};

server_read

$tx->server_read($bytes);

Read data server-side, used to implement web servers.

server_write

my $bytes = $tx->server_write;

Write data server-side, used to implement web servers.

SEE ALSO

Mojolicious, Mojolicious::Guides, http://mojolicio.us.