framework.texi 4.82 KB
@menu
* Folder::                      Folder.
* Mailbox::                     Mailbox.
* Mailer::                      Protocol Used to Send Mail.
* Message::                     Message.
* Envelope::                    Envelope.
* Headers::                     Headers.
* Body::                        Body.
* Attribute::                   Attribute.
* Stream::                      Stream.
* Iterator::                    Iterator.
* Authenticator::               Authenticator.
* Address::                     Address.
* Locker::                      Locker.
* URL::                         Unified Ressource Locator.

@end menu

Where ever the mail is and whatever format it is store in, the same operations
to manipulate emails are common.  To unified the C API, GNU mailutils offers
an heteroclite set of objects that work in aggregation to do operations on
emails.  Each object do a specific task and delegate non related tasks to
others.  The object comes alive by specifying a @emph{URL} parameter when
created, it will indicate the storage format or protocol
(POP3, IMAP4, MH, MAILDIR, etc ..).

@example
@group

                          folder_t                  url_t
  -/var/mail-    +- .. ->+-----------------+   +-->+------------+
 (  alain *-)-+  |       |   url_t       *-|---+   |   port     |
  ----------- |  |       |-----------------|       |   hostname |
 (  jakob *-)-+--+       |   auth_t      *-|---+   |   file     |
  ----------- |          |-----------------|   |   |   ...      |
 (  jeff  *-)-+          |   stream_t      |   |   +------------+
  ----------- |          |-----------------|   |
 (  shaleh*-)-+          |   .....         |   |    auth_t
  ----------             |-----------------|   +-->+------------+
                     +---|-* mailbox_t[]   |       |   ticket_t |
  mailbox_t          |   +-----------------+       +------------+
 +----------------+<-+
 |   locker_t  *--|-------------+
 |----------------|             |
 |   url_t        |             |          locker_t
 |----------------|             +-------->+---------+
 |   stream_t     |                       | lock    |
 |----------------|                       | unlock  |
 |  message_t[] *-|-------+               +---------+
 +----------------+       |                     envelope_t
                          |          +-------->+-----------+
  message_t               |          |         | date      |
 +----------------+<------+          |         | from      |
 |   envelope_t *-|------------------+         | to        |
 |----------------|              header_t      +-----------+
 |   header_t   *-|------------>+--------------+
 |----------------|             |   stream_t   |
 |   body_t     *-|----+        +--------------+
 +----------------+    |    body_t
                       +-->+--------------+
                           |   stream_t   |
                           +--------------+
@end group
@end example

For example writing a simple @code{from} command that will list the
@emph{From} and @emph{Subject} headers of every mail in a mailbox.

@example
@include sfrom.c.texi
@end example

@example
@cartouche
% MAIL=pop://alain@@localhost ./sfrom
Passwd: xxxx
Jim Meyering <meyering@@foo.org>      fetish(shellutils) beta
Fran@,{c}ois Pinard <pinard@@bar.org> recode new alpha
@dots{}
@end cartouche
@end example

@node Folder
@comment  node-name,  next,  previous,  up
@section Folder
@cindex Folder

@include folder.texi

@node Mailbox
@comment  node-name,  next,  previous,  up
@section Mailbox
@cindex Mailbox

@include mailbox.texi

@node Mailer
@comment  node-name,  next,  previous,  up
@section Mailer
@cindex Mailer

@include mailer.texi

@node Message
@comment  node-name,  next,  previous,  up
@section Message
@cindex Message

@include message.texi

@node Envelope
@comment  node-name,  next,  previous,  up
@section Envelope
@cindex Envelope

@include envelope.texi

@node Headers
@comment  node-name,  next,  previous,  up
@section Headers
@cindex Headers

@include headers.texi

@node Body
@comment  node-name,  next,  previous,  up
@section Body
@cindex Body

@include body.texi

@node Attribute
@comment  node-name,  next,  previous,  up
@section Attribute
@cindex Attribute

@include attribute.texi

@node Stream
@comment  node-name,  next,  previous,  up
@section Stream
@cindex Stream

@include stream.texi

@node Iterator
@comment  node-name,  next,  previous,  up
@section Iterator
@cindex Iterator

@include iterator.texi

@node Authenticator
@comment  node-name,  next,  previous,  up
@section Authenticator
@cindex Authenticator

@include auth.texi

@node Address
@comment  node-name,  next,  previous,  up
@section Address
@cindex Address

@include address.texi

@node Locker
@comment  node-name,  next,  previous,  up
@section Locker
@cindex Locker

@include locker.texi

@node URL
@comment  node-name,  next,  previous,  up
@section URL
@cindex URL

@include url.texi