NAME
Net::IMAP::Server::Mailbox - A user's view of a mailbox
DESCRIPTION
This class encapsulates the view of messages in a mailbox. You may wish to subclass this class in order to source our messages from, say, a database.
METHODS
Initialization
new
Creates a new mailbox; returns undef
if a mailbox with the same full path already exists. It calls "init", then "load_data".
init
Sets up basic properties of the mailbox:
"uidnext" is set to 1000
"messages" and "uids" are initialized to an empty list reference and an empty hash reference, respectively.
"children" is set to an empty list reference.
"uidvalidity" is set to the number of seconds since the epoch.
"subscribed" and "is_selectable" are set true.
load_data
This default mailbox implementation simply returns an empty mailbox. Subclasses will probably wish to override this method.
name
Gets or sets the name of the mailbox. This includes a workaround for Zimbra, which doesn't understand mailbox names with colons in them -- so we substitute dashes.
Actions
poll
Called when the server wishes the mailbox to update its state. By default, does nothing. Subclasses will probably wish to override this method.
add_message MESSAGE
Adds the gven Net::IMAP::Server::Message MESSAGE
to the mailbox, setting its "sequence" in Net::IMAP::Server::Message and "mailbox" in Net::IMAP::Server::Message. "uid" in Net::IMAP::Server::Message is set to "uidnext" if the message does not already have a uid
.
add_child [...]
Creates a mailbox under this mailbox, of the same class as this mailbox is. Any arguments are passed to "new". Returns the newly added subfolder, or undef if a folder with that name already exists.
create [...]
Identical to "add_child". Should return false if the create is denied or fails.
reparent MAILBOX
Reparents this mailbox to be a child of the given Net::IMAP::Server::Mailbox MAILBOX
. Shold return 0 if the reparenting is denied or fails.
delete
Deletes this mailbox, removing it from its parent's list of children. Should return false if the deletion is denied or fails.
expunge [ARRAYREF]
Expunges messages marked as \Deleted
. If an arrayref of message sequence numbers is provided, only expunges message from that set.
append MESSAGE
Appends, and returns, the given MESSAGE
, which should be a string containing the message. Returns false is the append is denied or fails.
status
close
Called when the client selects a different mailbox, or when the client's connection closes. By default, does nothing.
Inspection
separator
Returns the path separator. Note that only the path separator of the root mailbox matters. Defaults to a forward slash.
full_path [purge => 1]
Returns the full path to this mailbox. This value is cached aggressively on a per-connection basis; passing purge
flushes this cache, if the path name has changed.
flags
Returns the list of flags that this mailbox supports.
can_set_flag FLAG
Returns true if the client is allowed to set the given flag in this mailbox; this simply scans "flags" to check.
exists
Returns the number of messages in this mailbox. Observing this also sets the "high water mark" for notifying the client of messages added.
recent
Returns the number of messages which have the \Recent
flag set.
first_unseen
Returns the sequence number of the first message which does not have the \Seen
flag set. Returns 0 if all messages have been marked as \Seen
.
unseen
Returns the number of messages which have the \Seen
flag set.
permanentflags
Returns the flags which will be stored permanently for this mailbox; defaults to the same set as "flags" returns.
read_only
Returns true if this mailbox is read-only. By default, always returns false.
selected
Returns true if this mailbox is the mailbox selected by the current Net::IMAP::Server::Connection.
get_uids STR
Parses and returns messages fitting the given UID range.
get_messages STR
Parses and returns messages fitting the given sequence range. Note that since sequence numbers are connection-dependent, this simply passes the buck to "Net::IMAP::Server::Connection/get_messages".
update_tree
Called before the model's children are listed to the client. This is the right place to hook into for mailboxes whose children shift with time.
prep_for_destroy
Called before the mailbox is destroyed; this deals with cleaning up the several circular references involved. In turn, it calls "prep_for_destroy" on all child mailboxes, as well as all messages it has.