1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104
|
package HTML::FormFu::Upload;
use Moose;
use MooseX::Attribute::Chained;
with 'HTML::FormFu::Role::Populate';
use Carp qw( croak );
use HTML::FormFu::ObjectUtil qw( form parent );
use HTML::FormFu::UploadParam;
use Scalar::Util qw( reftype );
has headers => ( is => 'rw', traits => ['Chained'] );
has filename => ( is => 'rw', traits => ['Chained'] );
has size => ( is => 'rw', traits => ['Chained'] );
has type => ( is => 'rw', traits => ['Chained'] );
sub BUILD {}
sub _param {
my ( $self, $param ) = @_;
if ( @_ > 1 ) {
$param = HTML::FormFu::UploadParam->new( { param => $param, } );
$param->form( $self->form );
$self->{_param} = $param;
}
return defined $self->{_param} ? $self->{_param}->param : ();
}
sub slurp {
my ($self) = @_;
my $fh = $self->fh;
return if !defined $fh;
binmode $fh;
local $/;
return <$fh>;
}
__PACKAGE__->meta->make_immutable;
1;
__END__
=head1 NAME
HTML::FormFu::Upload - uploaded file
=head1 DESCRIPTION
An instance is created for each uploaded file.
You will normally get an object of one of the following classes, which inherit
from L<HTML::FormFu::Upload>:
=over
=item L<HTML::FormFu::QueryType::CGI>
=item L<HTML::FormFu::QueryType::Catalyst>
=item L<HTML::FormFu::QueryType::CGI::Simple>
=back
=head1 METHODS
=head2 parent
Returns the L<field|HTML::FormFu::Element::_Field> object that the upload
object is associated with.
=head2 form
Returns the L<HTML::FormFu> object that the upload object's field is attached
to.
=head2 populate
See L<HTML::FormFu/populate> for details.
=head1 SEE ALSO
L<HTML::FormFu>
=head1 AUTHOR
Carl Franks, C<cfranks@cpan.org>
=head1 LICENSE
This library is free software, you can redistribute it and/or modify it under
the same terms as Perl itself.
=cut
|