NAME

Mail::Audit::Attach - Mail::Audit plugin for attachment handling.

SYNOPSIS

  use Mail::Audit qw(Attach);

  my $mail = Mail::Audit->new;

  # ...

  my $num_attachment = $mail->num_attachments;
  my $attachments = $mail->attachments;

  remove_attachments(filename => "\.(exe|scr|pif)",
		     smaller_than => 20000);

  $mail->remove_attachments(mime_type => "text/html");

  foreach (@$attachments) {
      $_->save($attachdir) 
	  if ($_->mime_type =~ |^image/|);
      $_->remove 
	  if ($_->filename =~ |\.(vcf)$|);
  }

  $mail->make_singlepart; # if possible

DEFINITION

For the purpose of this plugin, an attachment is a MIME part that has a filename. Files attached to non-MIME messages will not be discovered.

DESCRIPTION

This is a Mail::Audit plugin which provides easy access to files attached to mail messages. Besides Mail::Audit, it requires the MIME::Entity module.

CONSTRUCTOR

new

This constructor is called by Mail::Audit; it should not be necessary to create a Mail::Audit::Attach object manually.

METHODS IN MAIL::AUDIT

num_attachments

Returns the number of attachments found

attachments

Returns a reference to a list of attachment objects

error

Returns a string with an error message (if an error ocurred).

remove_attachments

Removes attachments from the mail that match the criteria specified via the options, or all, if no options are specified. Currently, the following options (hash keys) are supported:

mime_type
file_name

Specify a regular expression; attachments whose MIME type or filename matches this expression are removed.

smaller_than
bigger_than

Specify file size limits; attachments smaller or bigger than these limits are removed.

An attachment must match all of the criteria to be removed. Returns the number of attachments removed.

ATTACHMENT PROPERTIES

The attachments are a subclass of MIME::Entity. Check out MIME::Entity to learn about useful methods like mime_type or bodyhandle that are inherited.

size

Returns the size of the attached file.

filename

Returns the original filename given in the MIME headers.

safe_filename

Returns the filename, with /\:;[]| and whitespace replaced by underscores, or 'attachment' if the original filename is empty.

ATTACHMENT ACTIONS

remove

Removes the attachment, ie. detaches the corresponding MIME entity and purges the body data.

save($location)

Saves the attachment as a file in $location. If $location is a directory (ie if -d $location), save uses safe_filename to store the file inside that directory, else $location is assumed to be a fully-qualified path with filename.

In both cases, save checks whether the target file exists and appends '.n' to the filename, with n being an integer that leads to a unique filename, if necessary.

Returns the filename used to save the file, or undef if an error ocurred (you might want to take a look at Mail::Audit::Attach::error in that case).

Note that the attachment is not removed.

ERROR FUNCTION

Mail::Audit::Attach::error will return an error message if an action failed (currently only set by save).

HISTORY

0.95, 2010-02-26
- Created GitHub repository
- Fixed RT#19546: Added missing dependency MIME::Base64
0.94 Sun Jun 05 23:00:00 2005
- Updated distribution to more modern format.
- Added POD tests.
0.93 Sat Apr 14 00:30:00 2003
- Mail::Audit->save died when passed an empty location. Fixed.
  location is now optional.
- Now uses File::Spec for more portability
- Introduced Mail::Audit::error (used by save)
- Localized $_ where used
0.92 Sat Feb 8 13:00:00 2003
- Now relies on MIME::Head to recognize attachments.
  "Never try to be too clever."
- No more warnings.
0.91 Thu Feb 6 22:30:00 2003
  - Now recognizes attachments with Content-Disposition inline,
    but a given filename. This became necessary because Netscape
   	Communicator and other clients send their attachments that way.

	  Thanks to Jeff Engelhardt and Vladimir Parkhaev for bringing
          this to my attention.
0.90 Sat Jun 1 19:35:24 2002
- original version; created by h2xs 1.19

DEVELOPMENT NOTES

Please report any bugs using the CPAN RT system. The development repository for this module is hosted on GitHub: http://github.com/crenz/Mail-Audit-Attach/.

AUTHOR

Christian Renz <crenz@web42.com>

LICENSE

Copyright (C) 2002-2010 Christian Renz <crenz@web42.com>

This program is free software; you can redistribute it and/or modify it under the same terms as Perl itself.

SEE ALSO

Mail::Audit. MIME::Entity.

2 POD Errors

The following errors were encountered while parsing the POD:

Around line 381:

'=item' outside of any '=over'

Around line 419:

You forgot a '=back' before '=head1'