Provided by: libmojolicious-perl_4.63+dfsg-1_all
NAME
Mojo::Content - HTTP content base class
SYNOPSIS
package Mojo::Content::MyContent; use Mojo::Base 'Mojo::Content'; sub body_contains {...} sub body_size {...} sub get_body_chunk {...}
DESCRIPTION
Mojo::Content is an abstract base class for HTTP content as described in RFC 2616.
EVENTS
Mojo::Content inherits all events from Mojo::EventEmitter and can emit the following new ones. body $content->on(body => sub { my $content = shift; ... }); Emitted once all headers have been parsed and the body starts. $content->on(body => sub { my $content = shift; $content->auto_upgrade(0) if $content->headers->header('X-No-MultiPart'); }); drain $content->on(drain => sub { my ($content, $offset) = @_; ... }); Emitted once all data has been written. $content->on(drain => sub { my $content = shift; $content->write_chunk(time); }); read $content->on(read => sub { my ($content, $bytes) = @_; ... }); Emitted when a new chunk of content arrives. $content->unsubscribe('read'); $content->on(read => sub { my ($content, $bytes) = @_; say "Streaming: $bytes"; });
ATTRIBUTES
Mojo::Content implements the following attributes. auto_relax my $bool = $content->auto_relax; $content = $content->auto_relax($bool); Try to detect when relaxed parsing is necessary. headers my $headers = $content->headers; $content = $content->headers(Mojo::Headers->new); Content headers, defaults to a Mojo::Headers object. max_buffer_size my $size = $content->max_buffer_size; $content = $content->max_buffer_size(1024); Maximum size in bytes of buffer for content parser, defaults to the value of the MOJO_MAX_BUFFER_SIZE environment variable or 262144. max_leftover_size my $size = $content->max_leftover_size; $content = $content->max_leftover_size(1024); Maximum size in bytes of buffer for pipelined HTTP requests, defaults to the value of the MOJO_MAX_LEFTOVER_SIZE environment variable or 262144. relaxed my $bool = $content->relaxed; $content = $content->relaxed($bool); Activate relaxed parsing for responses that are terminated with a connection close. skip_body my $bool = $content->skip_body; $content = $content->skip_body($bool); Skip body parsing and finish after headers.
METHODS
Mojo::Content inherits all methods from Mojo::EventEmitter and implements the following new ones. body_contains my $bool = $content->body_contains('foo bar baz'); Check if content contains a specific string. Meant to be overloaded in a subclass. body_size my $size = $content->body_size; Content size in bytes. Meant to be overloaded in a subclass. boundary my $boundary = $content->boundary; Extract multipart boundary from "Content-Type" header. build_body my $str = $content->build_body; Render whole body. build_headers my $str = $content->build_headers; Render all headers. charset my $charset = $content->charset; Extract charset from "Content-Type" header. clone my $clone = $content->clone; Clone content if possible, otherwise return "undef". generate_body_chunk my $bytes = $content->generate_body_chunk(0); Generate dynamic content. get_body_chunk my $bytes = $content->get_body_chunk(0); Get a chunk of content starting from a specific position. Meant to be overloaded in a subclass. get_header_chunk my $bytes = $content->get_header_chunk(13); Get a chunk of the headers starting from a specific position. header_size my $size = $content->header_size; Size of headers in bytes. is_chunked my $bool = $content->is_chunked; Check if content is chunked. is_compressed my $bool = $content->is_compressed; Check if content is "gzip" compressed. is_dynamic my $bool = $content->is_dynamic; Check if content will be dynamically generated, which prevents "clone" from working. is_finished my $bool = $content->is_finished; Check if parser is finished. is_limit_exceeded my $bool = $content->is_limit_exceeded; Check if buffer has exceeded "max_buffer_size". is_multipart my $false = $content->is_multipart; False. is_parsing_body my $bool = $content->is_parsing_body; Check if body parsing started yet. leftovers my $bytes = $content->leftovers; Get leftover data from content parser. parse $content = $content->parse("Content-Length: 12\x0d\x0a\x0d\x0aHello World!"); Parse content chunk. parse_body $content = $content->parse_body('Hi!'); Parse body chunk and skip headers. progress my $size = $content->progress; Size of content already received from message in bytes. write $content = $content->write($bytes); $content = $content->write($bytes => sub {...}); Write dynamic content non-blocking, the optional drain callback will be invoked once all data has been written. write_chunk $content = $content->write_chunk($bytes); $content = $content->write_chunk($bytes => sub {...}); Write dynamic content non-blocking with "chunked" transfer encoding, the optional drain callback will be invoked once all data has been written.
SEE ALSO
Mojolicious, Mojolicious::Guides, <http://mojolicio.us>.