Provided by: libmojolicious-perl_4.63+dfsg-1_all
NAME
Mojo::Content::Single - HTTP content
SYNOPSIS
use Mojo::Content::Single; my $single = Mojo::Content::Single->new; $single->parse("Content-Length: 12\x0d\x0a\x0d\x0aHello World!"); say $single->headers->content_length;
DESCRIPTION
Mojo::Content::Single is a container for HTTP content as described in RFC 2616.
EVENTS
Mojo::Content::Single inherits all events from Mojo::Content and can emit the following new ones. upgrade $single->on(upgrade => sub { my ($single, $multi) = @_; ... }); Emitted when content gets upgraded to a Mojo::Content::MultiPart object. $single->on(upgrade => sub { my ($single, $multi) = @_; return unless $multi->headers->content_type =~ /multipart\/([^;]+)/i; say "Multipart: $1"; });
ATTRIBUTES
Mojo::Content::Single inherits all attributes from Mojo::Content and implements the following new ones. asset my $asset = $single->asset; $single = $single->asset(Mojo::Asset::Memory->new); The actual content, defaults to a Mojo::Asset::Memory object with "auto_upgrade" enabled. auto_upgrade my $upgrade = $single->auto_upgrade; $single = $single->auto_upgrade(0); Try to detect multipart content and automatically upgrade to a Mojo::Content::MultiPart object, defaults to 1.
METHODS
Mojo::Content::Single inherits all methods from Mojo::Content and implements the following new ones. new my $single = Mojo::Content::Single->new; Construct a new Mojo::Content::Single object and subscribe to "read" event with default content parser. body_contains my $bool = $single->body_contains('1234567'); Check if content contains a specific string. body_size my $size = $single->body_size; Content size in bytes. clone my $clone = $single->clone; Clone content if possible, otherwise return "undef". get_body_chunk my $bytes = $single->get_body_chunk(0); Get a chunk of content starting from a specific position. parse $single = $single->parse("Content-Length: 12\x0d\x0a\x0d\x0aHello World!"); my $multi = $single->parse("Content-Type: multipart/form-data\x0d\x0a\x0d\x0a"); Parse content chunk and upgrade to Mojo::Content::MultiPart object if necessary.
SEE ALSO
Mojolicious, Mojolicious::Guides, <http://mojolicio.us>.