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
|
package HTML::FormFu::Upload;
use strict;
use Carp qw( croak );
use HTML::FormFu::Attribute qw( mk_item_accessors );
use HTML::FormFu::ObjectUtil qw( form parent populate );
use HTML::FormFu::UploadParam;
use Scalar::Util qw( reftype );
__PACKAGE__->mk_item_accessors(qw( headers filename size type ));
sub new {
my $class = shift;
my %attrs;
if (@_) {
croak "attributes argument must be a hashref"
if reftype( $_[0] ) ne 'HASH';
%attrs = %{ $_[0] };
}
my $self = bless \%attrs, $class;
$self->populate( \%attrs );
return $self;
}
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 : ();
}
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
|