Scroll to navigation

Mojo::Content::MultiPart(3pm) User Contributed Perl Documentation Mojo::Content::MultiPart(3pm)

NAME

Mojo::Content::MultiPart - HTTP 1.1 multipart content container

SYNOPSIS

  use Mojo::Content::MultiPart;
  my $multi = Mojo::Content::MultiPart->new;
  $multi->parse('Content-Type: multipart/mixed; boundary=---foobar');
  my $single = $multi->parts->[4];

DESCRIPTION

Mojo::Content::MultiPart is a container for HTTP 1.1 multipart content as described in RFC 2616.

EVENTS

Mojo::Content::Multipart inherits all events from Mojo::Content and can emit the following new ones.

"part"

  $multi->on(part => sub {
    my ($multi, $single) = @_;
    ...
  });
Emitted when a new Mojo::Content::Single part starts.
  $multi->on(part => sub {
    my ($multi, $single) = @_;
    return unless $single->headers->content_disposition =~ /name="([^"]+)"/;
    say "Field: $1";
  });

ATTRIBUTES

Mojo::Content::MultiPart inherits all attributes from Mojo::Content and implements the following new ones.

"parts"

  my $parts = $multi->parts;
  $multi    = $multi->parts([]);
Content parts embedded in this multipart content, usually Mojo::Content::Single objects.

METHODS

Mojo::Content::MultiPart inherits all methods from Mojo::Content and implements the following new ones.

"new"

  my $multi = Mojo::Content::MultiPart->new;
Construct a new Mojo::Content::MultiPart object and subscribe to "read" event with default content parser.

"body_contains"

  my $success = $multi->body_contains('foobarbaz');
Check if content parts contain a specific string.

"body_size"

  my $size = $multi->body_size;
Content size in bytes.

"build_boundary"

  my $boundary = $multi->build_boundary;
Generate a suitable boundary for content.

"clone"

  my $clone = $multi->clone;
Clone content if possible, otherwise return "undef".

"get_body_chunk"

  my $chunk = $multi->get_body_chunk(0);
Get a chunk of content starting from a specfic position.

"is_multipart"

  my $true = $multi->is_multipart;
True.

SEE ALSO

Mojolicious, Mojolicious::Guides, <http://mojolicio.us>.
2012-09-05 perl v5.14.2