# phpman > man > Mail::Box-Overview(3pm)

## NAME
    [Mail::Box](https://www.chedong.com/phpMan.php/perldoc/Mail%3A%3ABox/markdown)-Overview - objects used by [Mail::Box](https://www.chedong.com/phpMan.php/perldoc/Mail%3A%3ABox/markdown)

## DESCRIPTION
### Introduction
    The MailBox package is a suite of classes for accessing and managing email folders in a
    folder-independent manner. This package is an alternative to the "[Mail::Folder](https://www.chedong.com/phpMan.php/perldoc/Mail%3A%3AFolder/markdown)" and "MIME::*"
    packages. It abstracts the details of messages, message storage, and message threads, while
    providing better performance than older mail packages. It is meant to provide an object-oriented
    toolset for all kinds of e-mail applications, under which Mail User-Agents (MUA) and mail
    filtering programs.

    This package is modular --parts of it can be used independently of the rest. For example, the
    [Mail::Box::Manager](https://www.chedong.com/phpMan.php/perldoc/Mail%3A%3ABox%3A%3AManager/markdown) can automatically determine that a folder is in Mbox format and return an
    object of the [Mail::Box::Mbox](https://www.chedong.com/phpMan.php/perldoc/Mail%3A%3ABox%3A%3AMbox/markdown) class, or the user program can bypass the manager and create
    [Mail::Box::Mbox](https://www.chedong.com/phpMan.php/perldoc/Mail%3A%3ABox%3A%3AMbox/markdown) objects directly. Similarly, if the user program is only manipulating a single
    message, a [Mail::Message](https://www.chedong.com/phpMan.php/perldoc/Mail%3A%3AMessage/markdown).

    The [Mail::Box](https://www.chedong.com/phpMan.php/perldoc/Mail%3A%3ABox/markdown) package has special features to help MUA's access folder data quickly in random
    order. You will not really benefit (neither slower) if you need the full folder sequentially.

    You may want to have a look at the sample scripts in the "scripts" directory.

### Distributions
    Up to MailBox v2, all "Mail::*" modules were released as a single distribution. From v3, there
    are a few separate distributions in an attempt to reduce the dependencies:

    *   [Mail::Message](https://www.chedong.com/phpMan.php/perldoc/Mail%3A%3AMessage/markdown)

    *   [Mail::Transfer](https://www.chedong.com/phpMan.php/perldoc/Mail%3A%3ATransfer/markdown)

    *   [Mail::Box](https://www.chedong.com/phpMan.php/perldoc/Mail%3A%3ABox/markdown)

    *   [Mail::Box::IMAP4](https://www.chedong.com/phpMan.php/perldoc/Mail%3A%3ABox%3A%3AIMAP4/markdown)

    *   [Mail::Box::POP3](https://www.chedong.com/phpMan.php/perldoc/Mail%3A%3ABox%3A%3APOP3/markdown)

    *   [Mail::Box::Parser::C](https://www.chedong.com/phpMan.php/perldoc/Mail%3A%3ABox%3A%3AParser%3A%3AC/markdown)

    The names of the classes are not always ideal: the 'Mail' namespace on CPAN is quite full.

### The class relations
    [Mail::Box::Manager](https://www.chedong.com/phpMan.php/perldoc/Mail%3A%3ABox%3A%3AManager/markdown) objects play a central role in any program which is built with MailBox. Each
    program will create one manager, and then open folders via that manager. Besides folders, the
    manager can also be used to discover message threads: sequences of messages with their
    follow-ups.

                           <has-a>      [Mail::Box::Mbox](https://www.chedong.com/phpMan.php/perldoc/Mail%3A%3ABox%3A%3AMbox/markdown)
      [Mail::Box::Manager](https://www.chedong.com/phpMan.php/perldoc/Mail%3A%3ABox%3A%3AManager/markdown) <---------*    ([Mail::Box::MH](https://www.chedong.com/phpMan.php/perldoc/Mail%3A%3ABox%3A%3AMH/markdown))
             ^                :         ([Mail::Box::Maildir](https://www.chedong.com/phpMan.php/perldoc/Mail%3A%3ABox%3A%3AMaildir/markdown))
             |           (maintains)    ([Mail::Box::POP3](https://www.chedong.com/phpMan.php/perldoc/Mail%3A%3ABox%3A%3APOP3/markdown))
             |                :
             |                :
             `---------------------*  [Mail::Box::Thread::Manager](https://www.chedong.com/phpMan.php/perldoc/Mail%3A%3ABox%3A%3AThread%3A%3AManager/markdown)
                          (<has-a>)

    Each folder maintains a list of messages. Much effort is made to hide differences between folder
    types and kinds of messages. Your program can be used for MBOX, MH, Maildir, and POP3 folders
    with no change at all (as long as you stick to the rules).

     [Mail::Box::Mbox](https://www.chedong.com/phpMan.php/perldoc/Mail%3A%3ABox%3A%3AMbox/markdown)  <-----------* [Mail::Box::Mbox::Message](https://www.chedong.com/phpMan.php/perldoc/Mail%3A%3ABox%3A%3AMbox%3A%3AMessage/markdown)
            ^             <has-a>            ^
            | <isa>                          | <isa>
            |                                |
        [Mail::Box](https://www.chedong.com/phpMan.php/perldoc/Mail%3A%3ABox/markdown)     ............. [Mail::Box::Message](https://www.chedong.com/phpMan.php/perldoc/Mail%3A%3ABox%3A%3AMessage/markdown)
                                             ^
                                             | <isa>
                                             |
                                       [Mail::Message](https://www.chedong.com/phpMan.php/perldoc/Mail%3A%3AMessage/markdown)
                                            / \
                                           <has-a>
                                          /     \
                               [Mail::Message](https://www.chedong.com/phpMan.php/perldoc/Mail%3A%3AMessage/markdown)   [Mail::Message](https://www.chedong.com/phpMan.php/perldoc/Mail%3A%3AMessage/markdown)
                                 ::Body            ::Head

    The situation for MH and Maildir folders is a little more complicated, because they have an
    extra intermediate level of abstraction: [Mail::Box::Dir](https://www.chedong.com/phpMan.php/perldoc/Mail%3A%3ABox%3A%3ADir/markdown). The POP3 folder has an intermediate
    [Mail::Box::Net](https://www.chedong.com/phpMan.php/perldoc/Mail%3A%3ABox%3A%3ANet/markdown).

    In the future, when more Mbox-like folder types get implemented, there may be a [Mail::Box::File](https://www.chedong.com/phpMan.php/perldoc/Mail%3A%3ABox%3A%3AFile/markdown)
    level too. The following is also true for the mail boxes

     [MB::MH::Message](https://www.chedong.com/phpMan.php/perldoc/MB%3A%3AMH%3A%3AMessage/markdown)                 [MB::POP3::Message](https://www.chedong.com/phpMan.php/perldoc/MB%3A%3APOP3%3A%3AMessage/markdown)
           \  [MB::Maildir::Message](https://www.chedong.com/phpMan.php/perldoc/MB%3A%3AMaildir%3A%3AMessage/markdown)            /
            \         /                      /
             \       /   [MB::Mbox::Message](https://www.chedong.com/phpMan.php/perldoc/MB%3A%3AMbox%3A%3AMessage/markdown)  /
              \     /         |            /
            [MB::Dir::Message](https://www.chedong.com/phpMan.php/perldoc/MB%3A%3ADir%3A%3AMessage/markdown)  |   [MB::Net::Message](https://www.chedong.com/phpMan.php/perldoc/MB%3A%3ANet%3A%3AMessage/markdown)
                         \    |    /
                          \   |   /
                          [MB::Message](https://www.chedong.com/phpMan.php/perldoc/MB%3A%3AMessage/markdown)
                              |
                              |
                         [Mail::Message](https://www.chedong.com/phpMan.php/perldoc/Mail%3A%3AMessage/markdown)

### The Manager
    The mailbox manager [Mail::Box::Manager](https://www.chedong.com/phpMan.php/perldoc/Mail%3A%3ABox%3A%3AManager/markdown) encapsulates folder management issues. It maintains a set
    of open mail folders (mailboxes), and provides methods for opening and closing them, efficiently
    moving messages between folders, and efficiently appending messages to folders. It contains
    [Mail::Box](https://www.chedong.com/phpMan.php/perldoc/Mail%3A%3ABox/markdown) objects which may be of different types. Most folder types can be detected
    automatically.

    The main manager also manages message-thread detector objects, and informs them when the
    contents of a folder have changed. This manager class is the only one you instantiate yourself:
    objects of all other classes will be provided by your folder manager.

    You are strongly advised to use this object, but you can often do without it and open a specific
    folder-type directly.

### The Messages
    [Mail::Message](https://www.chedong.com/phpMan.php/perldoc/Mail%3A%3AMessage/markdown)
        A base class that defines an interface for manipulating the head and body of a message.
        There are various header object types ([Mail::Message::Head](https://www.chedong.com/phpMan.php/perldoc/Mail%3A%3AMessage%3A%3AHead/markdown)'s) and a bunch of body object
        types ([Mail::Message::Body](https://www.chedong.com/phpMan.php/perldoc/Mail%3A%3AMessage%3A%3ABody/markdown)'s).

        The [Mail::Message::Construct](https://www.chedong.com/phpMan.php/perldoc/Mail%3A%3AMessage%3A%3AConstruct/markdown) package is loaded when more complex tasks have to be performed
        on messages, like creating replies, bounces, or a forward message. These functionalities are
        described and implemented in the ::Construct file, but are automatically added to the
        [Mail::Message](https://www.chedong.com/phpMan.php/perldoc/Mail%3A%3AMessage/markdown) namespace when used.

        Message types which are foreign to MailBox can be used in the MailBox environment: there are
        some converters implemented via [Mail::Message::Convert](https://www.chedong.com/phpMan.php/perldoc/Mail%3A%3AMessage%3A%3AConvert/markdown). Particularly the popular
        [Mail::Internet](https://www.chedong.com/phpMan.php/perldoc/Mail%3A%3AInternet/markdown) and [MIME::Entity](https://www.chedong.com/phpMan.php/perldoc/MIME%3A%3AEntity/markdown) are supported.

    [Mail::Box::Message](https://www.chedong.com/phpMan.php/perldoc/Mail%3A%3ABox%3A%3AMessage/markdown)
        An abstract base class which defines an interface for mail messages which are stored in any
        folder. It inherits from [Mail::Message](https://www.chedong.com/phpMan.php/perldoc/Mail%3A%3AMessage/markdown), and adds the basic idea of *location* to a message.

    [Mail::Message::Body](https://www.chedong.com/phpMan.php/perldoc/Mail%3A%3AMessage%3A%3ABody/markdown)
        This is the base class for all message bodies. It describes what you can do with any kind of
        body. The body types differ on the way how the keep the body content during the run of your
        program.

        One special case of the body types is the [Mail::Message::Body::Multipart](https://www.chedong.com/phpMan.php/perldoc/Mail%3A%3AMessage%3A%3ABody%3A%3AMultipart/markdown), which contains a
        set of [Mail::Message::Part](https://www.chedong.com/phpMan.php/perldoc/Mail%3A%3AMessage%3A%3APart/markdown) objects. These are just like normal messages, except that they
        are contained in an other message. The [Mail::Message::Body::Nested](https://www.chedong.com/phpMan.php/perldoc/Mail%3A%3AMessage%3A%3ABody%3A%3ANested/markdown) body type is comparible,
        but contains only one message: they are used for "message/rfc822" message encodings.

        When needed, the functionality of the body objects is extended with
        [Mail::Message::Body::Construct](https://www.chedong.com/phpMan.php/perldoc/Mail%3A%3AMessage%3A%3ABody%3A%3AConstruct/markdown) and [Mail::Message::Body::Encode](https://www.chedong.com/phpMan.php/perldoc/Mail%3A%3AMessage%3A%3ABody%3A%3AEncode/markdown). The former package
        implements things like concatenation, the later controls message encoding and decoding. In
        the current implementation this is limited to transfer encodings (implemented in the
        [Mail::Message::TransferEnc](https://www.chedong.com/phpMan.php/perldoc/Mail%3A%3AMessage%3A%3ATransferEnc/markdown) packages). Automatic character and mime recodings are on the
        wish-list.

    [Mail::Message::Head](https://www.chedong.com/phpMan.php/perldoc/Mail%3A%3AMessage%3A%3AHead/markdown)
        The header for a single message. Maintains a set of [Mail::Message::Field](https://www.chedong.com/phpMan.php/perldoc/Mail%3A%3AMessage%3A%3AField/markdown) objects, each
        containing one header line. Fields are the only objects which have no logging and tracing
        facilities, purely for reasons of performance.

        The header object has three sub-classes: the [Mail::Message::Head::Complete](https://www.chedong.com/phpMan.php/perldoc/Mail%3A%3AMessage%3A%3AHead%3A%3AComplete/markdown) version knows all
        lines for sure, [Mail::Message::Head::Subset](https://www.chedong.com/phpMan.php/perldoc/Mail%3A%3AMessage%3A%3AHead%3A%3ASubset/markdown) maintains an unknown subset of lines, and the
        [Mail::Message::Head::Delayed](https://www.chedong.com/phpMan.php/perldoc/Mail%3A%3AMessage%3A%3AHead%3A%3ADelayed/markdown) has no lines yet but knows where to get them.

        The latter two will automatically get the missing header lines from the mailbox files when
        needed, and so transform into a "::Complete" header. It is fully transparent to the user of
        MailBox in which shape the header really is on the moment.

### The Folder types
    [Mail::Box](https://www.chedong.com/phpMan.php/perldoc/Mail%3A%3ABox/markdown)
        A base class that defines a standard interface for mail boxes which is independent of
        mailbox type. Objects of this class contain a [Mail::Box::Locker](https://www.chedong.com/phpMan.php/perldoc/Mail%3A%3ABox%3A%3ALocker/markdown) and a list of
        [Mail::Box::Message](https://www.chedong.com/phpMan.php/perldoc/Mail%3A%3ABox%3A%3AMessage/markdown) objects.

    [Mail::Box::Dir](https://www.chedong.com/phpMan.php/perldoc/Mail%3A%3ABox%3A%3ADir/markdown)
        The base class for all folders which use a directory organization: each message is a
        separate entity (file) grouped in a directory. Each [Mail::Box::Dir::Message](https://www.chedong.com/phpMan.php/perldoc/Mail%3A%3ABox%3A%3ADir%3A%3AMessage/markdown) represents one
        message, one such entity.

    [Mail::Box::Net](https://www.chedong.com/phpMan.php/perldoc/Mail%3A%3ABox%3A%3ANet/markdown)
        The base class for all folders which have the messages outside direct reach of the MailBox
        library, for instance on a remote system, or in a database.

    [Mail::Box::Mbox](https://www.chedong.com/phpMan.php/perldoc/Mail%3A%3ABox%3A%3AMbox/markdown)
        This class derives from [Mail::Box](https://www.chedong.com/phpMan.php/perldoc/Mail%3A%3ABox/markdown), and implements its interface for mbox-style folders. It
        maintains a set of [Mail::Box::Mbox::Message](https://www.chedong.com/phpMan.php/perldoc/Mail%3A%3ABox%3A%3AMbox%3A%3AMessage/markdown) objects, which are derived from a
        [Mail::Box::Message](https://www.chedong.com/phpMan.php/perldoc/Mail%3A%3ABox%3A%3AMessage/markdown).

        Mbox-style folders have one file containing multiple messages per folder. When folders get
        large, access tends to get slow.

    [Mail::Box::MH](https://www.chedong.com/phpMan.php/perldoc/Mail%3A%3ABox%3A%3AMH/markdown)
        This class derives from [Mail::Box::Dir](https://www.chedong.com/phpMan.php/perldoc/Mail%3A%3ABox%3A%3ADir/markdown), and implements its interface for MH-style folders.
        It maintains a set of [Mail::Box::MH::Message](https://www.chedong.com/phpMan.php/perldoc/Mail%3A%3ABox%3A%3AMH%3A%3AMessage/markdown) objects, which are derived from a
        [Mail::Box::Dir::Message](https://www.chedong.com/phpMan.php/perldoc/Mail%3A%3ABox%3A%3ADir%3A%3AMessage/markdown).

        MH-style folders are represented by a directory, where each message is stored in a separate
        file. The message files are sequentially numbered. It is fast to open one single message,
        but hard to get an overview.

    [Mail::Box::MH::Index](https://www.chedong.com/phpMan.php/perldoc/Mail%3A%3ABox%3A%3AMH%3A%3AIndex/markdown)
        The base class for MH mailbox indexes which provides methods for reading, writing, and
        managing message indexes. These indexes are used to speed-up access to directory based
        folders.

    [Mail::Box::MH::Labels](https://www.chedong.com/phpMan.php/perldoc/Mail%3A%3ABox%3A%3AMH%3A%3ALabels/markdown)
        Also for efficiency reasons, a separate file is maintained which contains flags about the
        messages. This file for instance lists new files. This way, the MH message files do not have
        to be opened to find that out.

    [Mail::Box::Maildir](https://www.chedong.com/phpMan.php/perldoc/Mail%3A%3ABox%3A%3AMaildir/markdown)
        Like the MH folder type, this class derives from [Mail::Box::Dir](https://www.chedong.com/phpMan.php/perldoc/Mail%3A%3ABox%3A%3ADir/markdown). It implements its interface
        for Maildir-style folders. It maintains a set of [Mail::Box::Maildir::Message](https://www.chedong.com/phpMan.php/perldoc/Mail%3A%3ABox%3A%3AMaildir%3A%3AMessage/markdown) objects, which
        are derived from a [Mail::Box::Dir::Message](https://www.chedong.com/phpMan.php/perldoc/Mail%3A%3ABox%3A%3ADir%3A%3AMessage/markdown).

    [Mail::Box::POP3](https://www.chedong.com/phpMan.php/perldoc/Mail%3A%3ABox%3A%3APOP3/markdown)
        Implements the POP3 protocol based on [Mail::Box::Net](https://www.chedong.com/phpMan.php/perldoc/Mail%3A%3ABox%3A%3ANet/markdown). The [Mail::Transport::POP3](https://www.chedong.com/phpMan.php/perldoc/Mail%3A%3ATransport%3A%3APOP3/markdown)
        implementation handles the protocol details. In this kind of folders, you can only read and
        delete messages.

### Various Other Classes
    [Mail::Box::Thread::Manager](https://www.chedong.com/phpMan.php/perldoc/Mail%3A%3ABox%3A%3AThread%3A%3AManager/markdown)
        Maintains a set of message-threads over one or more folders. A message-thread is a start
        message with all the replies on it. And the replies on replies, and so on. This object is
        used to construct the thread for a set of open folders.

        This object maintains linked lists of [Mail::Box::Thread::Node](https://www.chedong.com/phpMan.php/perldoc/Mail%3A%3ABox%3A%3AThread%3A%3ANode/markdown) objects.
        [Mail::Message::Dummy](https://www.chedong.com/phpMan.php/perldoc/Mail%3A%3AMessage%3A%3ADummy/markdown)'s fill-up some holes.

    [Mail::Box::Locker](https://www.chedong.com/phpMan.php/perldoc/Mail%3A%3ABox%3A%3ALocker/markdown)
        Provides a folder locking interface which is inherited by the [Mail::Box](https://www.chedong.com/phpMan.php/perldoc/Mail%3A%3ABox/markdown) class. Currently it
        supports dot-file locking ("filename.lock"), flock filehandle locking, and locking over NFS.
        Each is implemented in a separate class. A multi-locker, using a set of lock-methods at the
        same time is also available.

    [Mail::Box::Search](https://www.chedong.com/phpMan.php/perldoc/Mail%3A%3ABox%3A%3ASearch/markdown)
        The set of search packages implement various search techniques in an uniformal way. Although
        implementing your own search algorithm is simple in general, in practice multiparts,
        encodings, and mime-types complicate things.

    [Mail::Box::Parser](https://www.chedong.com/phpMan.php/perldoc/Mail%3A%3ABox%3A%3AParser/markdown)
        The parser reads messages, and transforms them into data-structures such that the content of
        header and body can be used within the program. The first parser is implemented in pure
        Perl. A second parser is under development, and will written in C, to gain speed.

    [Mail::Box::Tie](https://www.chedong.com/phpMan.php/perldoc/Mail%3A%3ABox%3A%3ATie/markdown)
        Provides hash ([Mail::Box::Tie::HASH](https://www.chedong.com/phpMan.php/perldoc/Mail%3A%3ABox%3A%3ATie%3A%3AHASH/markdown)) or array tied ([Mail::Box::Tie::ARRAY](https://www.chedong.com/phpMan.php/perldoc/Mail%3A%3ABox%3A%3ATie%3A%3AARRAY/markdown)) access to any
        mail folder derived from [Mail::Box](https://www.chedong.com/phpMan.php/perldoc/Mail%3A%3ABox/markdown). This beautifies your code in some applications.

    [Mail::Transport](https://www.chedong.com/phpMan.php/perldoc/Mail%3A%3ATransport/markdown)
        Various ways of sending and receiving messages are implemented. Sending is possible via
        external programs, like "mail", "Mailx", "sendmail", or autonomously with direct SMTP.
        Receiving is currently only implemented via POP3.

    [Mail::Reporter](https://www.chedong.com/phpMan.php/perldoc/Mail%3A%3AReporter/markdown)
        A debugging and logging class which is inherited by most of the Mail:: modules. For each
        object, you can say what log and error reports must be kept or directly presented to the
        user. This way you can decide to have [Mail::Box](https://www.chedong.com/phpMan.php/perldoc/Mail%3A%3ABox/markdown) report about problems, or do it all
        yourself.

    All classes are written to be extensible.

## SEE ALSO
    This module is part of Mail-Box distribution version 3.009, built on August 18, 2020. Website:
    <http://perl.overmeer.net/CPAN/>

## LICENSE
    Copyrights 2001-2020 by [Mark Overmeer]. For other contributors see ChangeLog.

    This program is free software; you can redistribute it and/or modify it under the same terms as
    Perl itself. See <http://dev.perl.org/licenses/>

