NAME
Mail::Dir - Compliant Maildir and Maildir++ delivery mechanism
SYNOPSIS
use Mail::Dir;
my $maildir = Mail::Dir->open("$ENV{'HOME'}/Maildir");
$maildir->deliver('somefile.msg');
#
# Create a new Maildir++ mailbox with sub-mailboxes
#
my $maildirPP = Mail::Dir->open("$ENV{'HOME'}/newmaildir",
'maildir++' => 1,
'create' => 1
);
$maildirPP->create_mailbox('INBOX.foo');
$maildirPP->create_mailbox('INBOX.foo.bar');
$maildirPP->select_mailbox('INBOX.foo.bar');
$maildirPP->deliver(\*STDIN);
DESCRIPTION
Mail::Dir
provides a straightforward mechanism for delivering mail messages to a Maildir or Maildir++ mailbox.
OPENING OR CREATING A MAILBOX
Mail::Dir->open($dir, %opts)
-
Open or create a mailbox, in a manner dependent on the flags specified in %opts, and returns an object representing the Maildir structure.
Recognized option flags are:
create
When specified, create a Maildir inbox at $dir if one does not already exist.
maildir++
When specified, enable management and usage of Maildir++ sub-mailboxes.
MANIPULATING MAILBOXES
The following methods require Maildir++ extensions to be enabled.
$maildir->select_mailbox($mailbox)
-
Change the current mailbox to which mail is delivered, to $mailbox.
$maildir->mailbox()
-
Returns the name of the currently selected mailbox.
$maildir->mailbox_exists($mailbox)
-
Returns true if $mailbox exists.
$maildir->create_mailbox($mailbox)
-
Create the new $mailbox if it does not already exist. Will throw an error if the parent mailbox does not already exist.
DELIVERING MESSAGES
$maildir->deliver($from)
-
Deliver a piece of mail from the source indicated by $from. The following types of values can be specified in $from:
A
CODE
referenceWhen passed a
CODE
reference, the subroutine specified in $from is called, with a file handle passed that the subroutine may write mail data to.A file handle
The file handle passed in $from is read until end-of-file condition is reached, and spooled to a new message in the current mailbox.
A filename
The message at the filename indicated by $from is spooled into the current mailbox.
RETRIEVING MESSAGES
$maildir->messages(%opts)
-
Return a list of Mail::Dir::Message references containing mail messages as selected by the criteria specified in %opts. Options include:
tmp
,new
,cur
When any of these are set to 1, messages in those queues are processed.
filter
A subroutine can be passed via
CODE
reference which filters for messages that are desired. Each Mail::Dir::Message object is passed to the subroutine as its sole argument, and is kept if the subroutine returns 1.
PURGING EXPIRED MESSAGES
$maildir->purge()
-
Purge all messages in the
tmp
queue that have not been accessed for the past 36 hours.
SEE ALSO
Mail::Dir::Message
- Manipulate messages in a Maildir queue
AUTHOR
Xan Tronix <xan@cpan.org>
COPYRIGHT
Copyright (c) 2014, cPanel, Inc. Distributed under the terms of the MIT license. See the LICENSE file for further details.