use IO::File;
use File::Temp 0.14;
+use File::Spec;
=head1 NAME
=head1 SYNOPSIS
- use HTTP::Body::Multipart;
+ use HTTP::Body::MultiPart;
=head1 DESCRIPTION
=cut
+our $basename_regexp = qr/[^.]+(\.[^\\\/]+)$/;
+our $file_temp_suffix = '.upload';
+our $file_temp_template;
+our %file_temp_parameters;
+
sub handler {
my ( $self, $part ) = @_;
$part->{filename} = $filename;
if ( $filename ne "" ) {
- my $suffix = $filename =~ /[^.]+(\.[^\\\/]+)$/ ? $1 : q{};
+ my $basename = (File::Spec->splitpath($filename))[2];
+ my $suffix = $basename =~ $basename_regexp ? $1 : q{};
- my $fh = File::Temp->new( UNLINK => 0, DIR => $self->tmpdir, SUFFIX => $suffix );
+ my $fh = File::Temp->new(
+ UNLINK => 0, DIR => $self->tmpdir, SUFFIX => ($file_temp_suffix||$suffix),
+ ( $file_temp_template ? ( TEMPLATE => $file_temp_template ) : () ),
+ %file_temp_parameters,
+ );
$part->{fh} = $fh;
$part->{tempname} = $fh->filename;
$self->upload( $part->{name}, $part );
}
}
+ # If we have more than the content-disposition, we need to create a
+ # data key so that we don't waste the headers.
else {
$self->param( $part->{name}, $part->{data} );
+ $self->part_data( $part->{name}, $part )
}
}
}
=back
+=head1 SUPPORT
+
+See L<HTTP::Body>
+
=head1 AUTHOR
Christian Hansen, C<ch@ngmedia.com>