655 lines
21 KiB
Plaintext
655 lines
21 KiB
Plaintext
1/ Introduction
|
|
---------------
|
|
|
|
libEtPan! is mainly a library that will handle all kind of mailbox access.
|
|
For example: IMAPrev4, POP3, NNTP, mbox, MH.
|
|
|
|
You have two kinds of mailbox access, either using low-level functions
|
|
with a different interface for each kind of access or using higher-level
|
|
functions, using a driver to wrap the higher-level API.
|
|
|
|
|
|
2/ Low-level
|
|
------------
|
|
|
|
2.1/ IMAP4rev1 - Internet Message Access Protocol - Version 4rev1
|
|
-----------------------------------------------------------------
|
|
|
|
Each command of the IMAP4rev1 Standard (RFC 2060) is implemented in
|
|
the IMAP4rev1 module. Directory imap/.
|
|
|
|
2.1.1/ References
|
|
|
|
- RFC 2060 - INTERNET MESSAGE ACCESS PROTOCOL - VERSION 4rev1
|
|
- draft-crispin-imapv-15.txt
|
|
|
|
Not yet implemented :
|
|
|
|
- draft-crispin-imapv-20.txt
|
|
|
|
2.1.2/ Dependencies
|
|
|
|
- tools/
|
|
|
|
2.1.3/ Files descriptions
|
|
|
|
description of header files :
|
|
mailimap.[ch] -- functions that implements each IMAP4rev1 command
|
|
mailimap_helper.[ch] -- helper interface for the previous functions
|
|
mailimap_types.[ch] -- definition of types and constructors for these
|
|
types
|
|
mailimap_types_helper.[ch] -- contains function definitions that will help
|
|
to create data necessary to use IMAP4rev1 module
|
|
mailimap_socket.[ch] -- provides a function to connect to an
|
|
IMAP4rev1 server over TCP
|
|
mailimap_ssl.[ch] -- provides a function to connect to an
|
|
IMAP4rev1 server over TLS layer
|
|
|
|
2.1.4/ Interface
|
|
|
|
Include for this module is mailimap.h and includes all other headers.
|
|
|
|
|
|
The interface of IMAP4rev1 is documented in the following files :
|
|
|
|
mailimap.h
|
|
mailimap_types.h
|
|
mailimap_types_helper.h
|
|
|
|
|
|
2.2/ POP3 - Post Office Protocol - Version 3
|
|
--------------------------------------------
|
|
|
|
Each command of the POP3 Standard (RFC 1939 and RFC 2449) is implemented
|
|
in the POP3 module. Directory pop3/.
|
|
|
|
2.1.1/ References
|
|
|
|
- RFC 1939 - Post Office Protocol - Version 3
|
|
- RFC 2449 - POP3 Extension Mechanism (CAPA)
|
|
|
|
Not yet implemented :
|
|
|
|
- RFC 1734 - POP3 AUTHentication command
|
|
|
|
2.1.2/ Dependencies
|
|
|
|
- tools/
|
|
|
|
2.2.3/ Files descriptions
|
|
|
|
mailpop3.[ch] -- functions that implements each POP3 command
|
|
mailpop3_helper.[ch] -- helper interface for the previous functions
|
|
mailpop3_socket.[ch] -- provides a function to connect to a
|
|
POP3 server over TCP
|
|
mailpop3_ssl.[ch] -- provides a function to connect to a
|
|
POP3 server over TLS layer
|
|
|
|
2.2.4/ Interface
|
|
|
|
Include for this module is mailpop3.h and includes all other headers.
|
|
|
|
There is not yet documentation for POP3 module.
|
|
|
|
|
|
2.3/ NNTP - Network News Transfer Protocol
|
|
------------------------------------------
|
|
|
|
Each command of the NNTP Standard (RFC 977 and RFC 2980) is implemented
|
|
in the NNTP module. Directory nntp/.
|
|
|
|
2.3.1/ References
|
|
|
|
- RFC 977 - Network News Transfer Protocol
|
|
- RFC 2980 - Common NNTP Extensions
|
|
|
|
Not yet implemented :
|
|
|
|
- RFC 1036 - Standard for Interchange of USENET Messages
|
|
- son of RFC 1036 : FTP://zoo.toronto.edu/pub/news.txt.Z
|
|
|
|
2.3.2/ Dependencies
|
|
|
|
- tools/
|
|
|
|
2.3.3/ Files descriptions
|
|
|
|
newsnntp.[ch] -- functions that implements each NNTP command
|
|
newsnntp_socket.[ch] -- provides a function to connect to a
|
|
NNTP server over TCP
|
|
newsnntp_ssl.[ch] -- provides a function to connect to a
|
|
POP3 server over TLS layer
|
|
|
|
2.3.4/ Interface
|
|
|
|
Include for this module is newsnntp.h and includes all other headers.
|
|
|
|
There is not yet documentation for NNTP module.
|
|
|
|
|
|
2.4/ mbox
|
|
---------
|
|
|
|
The mbox module provides a set of functions to manipulate mbox mailboxes.
|
|
These functions make a safe lock on the mailbox they work with.
|
|
This module will assign to each message a unique message identifier
|
|
so that we can work with message numbers in mbox files without other
|
|
programs interfer.
|
|
Directory mbox/.
|
|
|
|
2.4.1/ References
|
|
|
|
- http://wp.netscape.com/eng/mozilla/2.0/relnotes/demo/content-length.html
|
|
- http://www.qmail.org/qmail-manual-html/man5/mbox.html
|
|
|
|
2.4.2/ Dependencies
|
|
|
|
- tools/
|
|
- imf/
|
|
|
|
2.5.3/ Specific to libEtPan!
|
|
|
|
- "X-LibEtPan-UID" header
|
|
|
|
2.5.4/ Files descriptions
|
|
|
|
mailmbox.[ch] -- functions to manipulate mbox mailboxes.
|
|
mailmbox_parse.[ch] -- this module is in charge of parsing the
|
|
mbox file content
|
|
mailmbox_types.[ch] -- definition of types and constructors for these
|
|
types
|
|
|
|
2.4.5/ Interface
|
|
|
|
Include for this module is mailmbox.h and includes all other headers.
|
|
|
|
There is not yet documentation for mbox module.
|
|
|
|
|
|
2.5/ MH
|
|
-------
|
|
|
|
The MH module provides a set of functions to manipulate MH mailboxes.
|
|
Directory mh/.
|
|
|
|
2.5.1/ References
|
|
|
|
- almost none
|
|
|
|
2.5.2/ Dependencies
|
|
|
|
- tools/
|
|
|
|
2.5.3/ Files descriptions
|
|
|
|
mailmh.[ch] -- functions to manipulate MH mailboxes.
|
|
|
|
|
|
2.5.4/ Interface
|
|
|
|
Include for this module is mailmh.h.
|
|
|
|
There is not yet documentation for MH module.
|
|
|
|
|
|
2.6/ IMF - Internet Message Format
|
|
----------------------------------
|
|
|
|
The IMF module provides functions to parse data given in RFC 2822
|
|
format (Internet Message Format).
|
|
Directory imf/.
|
|
|
|
2.6.1/ References
|
|
|
|
- RFC 2822 - Internet Message Format (Not entirely implemented)
|
|
- RFC 2076 - Common Internet Message Headers
|
|
|
|
Not yet implemented :
|
|
|
|
- RFC 2298 - An Extensible Message Format
|
|
for Message Disposition Notifications
|
|
|
|
2.6.2/ Dependencies
|
|
|
|
- tools/
|
|
|
|
2.6.3/ Files descriptions
|
|
|
|
mailimf.[ch] -- functions to parse RFC 2822 messages.
|
|
mailimf_types.[ch] -- definition of types and constructors for these
|
|
types
|
|
mailimf_types_helper.[ch] -- contains function definitions that will help
|
|
to create data necessary to use IMF module.
|
|
mailimf_write.[ch] -- functions that output RFC 2822 messages or
|
|
sub-part of the messages in a (FILE *).
|
|
|
|
2.6.4/ Interface
|
|
|
|
Include for this module is mailimf.h and includes all other headers.
|
|
|
|
The interface of IMAP4rev1 is documented in the following files :
|
|
|
|
mailimf.h
|
|
mailimf_types.h
|
|
mailimf_types_helper.h
|
|
mailimf_write.h
|
|
|
|
|
|
2.7/ MIME - Multipurpose Internet Mail Extensions
|
|
-------------------------------------------------
|
|
|
|
The MIME module provides functions to parse structure of MIME messages.
|
|
Directory mime/.
|
|
|
|
2.7.1/ References
|
|
|
|
- RFC 2045 - Multipurpose Internet Mail Extensions (MIME) Part One: Format of
|
|
Internet Message Bodies.
|
|
- RFC 2047 - MIME (Multipurpose Internet Mail Extensions) Part Three: Message
|
|
Header Extensions for Non-ASCII Text.
|
|
- RFC 2183 - Communicating Presentation Information in Internet Messages:
|
|
The Content-Disposition Header Field
|
|
|
|
Not implemented :
|
|
|
|
- RFC 2046 - Multipurpose Internet Mail Extensions (MIME) Part Two: Media
|
|
Types.
|
|
|
|
2.7.2/ Dependencies
|
|
|
|
- tools/
|
|
- imf/
|
|
|
|
2.7.3/ Files descriptions
|
|
|
|
mailmime.[ch] -- functions to parse the MIME fields (RFC 2045).
|
|
mailmime_content.[ch] -- functions to parse the MIME message. You get
|
|
the different parts and you can decode them.
|
|
mailmime_decode.[ch] -- functions to parse the MIME-encoded fields.
|
|
mailmime_disposition.[ch] -- functions to parse the Content-Disposition field
|
|
(RFC 2183)
|
|
mailmime_types.[ch] -- definition of types and constructors for these
|
|
types
|
|
mailmime_types_helper.[ch] -- contains function definitions that will help
|
|
to create data necessary to use MIME module.
|
|
mailmime_write.[ch] -- functions that output MIME messages or
|
|
sub-part of the messages in a (FILE *).
|
|
|
|
2.7.4/ Interface
|
|
|
|
Include for this module is mailmime.h and includes all other headers.
|
|
|
|
There is not yet documentation for MIME module.
|
|
|
|
|
|
2.8/ SMTP - Simple Mail Transfer Protocol
|
|
-----------------------------------------
|
|
|
|
Each command of the SMTP Standard (RFC 2821 and RFC 1891) is implemented
|
|
in the SMTP module. Directory smtp/.
|
|
|
|
2.8.1/ References
|
|
|
|
- RFC 2821 - Simple Mail Transfer Protocol (Not entirely implemented)
|
|
- RFC 1891 - SMTP Service Extension for Delivery Status Notifications
|
|
|
|
2.8.2/ Depencencies
|
|
|
|
- tools/
|
|
|
|
2.8.3/ Files descriptions
|
|
|
|
mailsmtp.[ch] -- functions that implements each SMTP command
|
|
mailsmtp_helper.[ch] -- functions to get an easier use of SMTP module
|
|
mailsmtp_socket.[ch] -- provides a function to connect to a
|
|
SMTP server over TCP
|
|
mailsmtp_ssl.[ch] -- provides a function to connect to a
|
|
SMTP server over TLS layer
|
|
mailsmtp_types.h -- definition of types
|
|
|
|
2.8.4/ Interface
|
|
|
|
Include for this module is mailsmtp.h and includes all other headers.
|
|
|
|
There is not yet documentation for MIME module.
|
|
|
|
|
|
2.9/ Miscellaneous
|
|
|
|
2.9.1/ References
|
|
|
|
- RFC 2234 - Augmented BNF for Syntax Specifications: ABNF
|
|
- RFC 2595 - Using TLS with IMAP, POP3 and ACAP
|
|
|
|
2.9.2/ Tools
|
|
|
|
tools/ directory contains some tools functions and useful data structures.
|
|
|
|
alloc.h -- a wrapper on malloc()
|
|
carray.[ch] -- an array, that grows automatically when elements
|
|
are added.
|
|
charconv.[ch] -- character set converter. For example, it will
|
|
translate an iso-8859-1 string to an utf-8 string.
|
|
chash.[ch] -- a hash table which keys can be anything
|
|
cinthash.[ch] -- a hash table which keys are integers
|
|
(should be removed and replaced with chash)
|
|
clist.[ch] -- a double-linked list
|
|
connect.[ch] -- easy interface to connect a TCP server
|
|
hmac_md5.h
|
|
md5.[ch]
|
|
md5global.h -- MD5 calculation
|
|
mail.h -- some constants
|
|
maildb_helper.[ch] -- wrappers to DB 2.x 3.x or 4.x
|
|
maillock.[ch] -- safely lock a given file
|
|
mailstream.[ch] -- stream interface - buffered reading and writing
|
|
on files/socket/SSL connection
|
|
mailstream_helper.[ch] -- useful functions for stream
|
|
(for example: read a line)
|
|
mailstream_low.[ch] -- driver interface for a stream
|
|
mailstream_socket.[ch] -- stream driver for file descriptors (includes socket)
|
|
mailstream_ssl.[ch] -- stream driver for SSL connection
|
|
mailstream_types.h -- data structure definition
|
|
mapping.[ch] -- map parts of files in memory (no more used)
|
|
mmapstring.[ch] -- a string, that grows automatically when data
|
|
are added.
|
|
|
|
|
|
3/ Higher-level
|
|
---------------
|
|
|
|
The higher level will allow us to query folder informations or to get
|
|
messages information or content.
|
|
|
|
There is four kinds of identities :
|
|
- storage
|
|
- folders
|
|
- session
|
|
- messages
|
|
|
|
In the higher-level interface, you manipulate data types from IMF and
|
|
MIME module, plus additionnal data types of higher-level.
|
|
|
|
|
|
3.1/ Objects
|
|
------------
|
|
|
|
3.1.1/ Storage
|
|
|
|
A storage (struct mail_storage) represents whether a server or
|
|
a main path, It can be an IMAP server, the root path of a MH or a mbox file.
|
|
|
|
|
|
3.1.2/ Folders
|
|
|
|
A folder can be created from a storage.
|
|
Folders (struct mail_folder) are the mailboxes we can choose in the
|
|
server or as sub-folder of the main path.
|
|
|
|
Folders for IMAP are the IMAP mailboxes, for MH this is one of the
|
|
folder of the MH storage, for mbox, there is only one folder, the
|
|
mbox file content;
|
|
|
|
|
|
3.1.3/ Session
|
|
|
|
Storage and folders communicate with the lower-layer through the
|
|
mail session data structure.
|
|
|
|
A mail session (struct mailsession) is a mail access to a server
|
|
or a mail access in the local file system. It allow us to send commands
|
|
to the mail access.
|
|
|
|
A mail storage is using a mail session to communicate.
|
|
A folder folder also uses a mail session to get information or to send
|
|
information. It can be the same session or not, depdending of the
|
|
implementation.
|
|
|
|
|
|
3.1.4/ Messages
|
|
|
|
From a session, we can get a message (struct mailmessage) to read.
|
|
|
|
|
|
3.2/ Drivers
|
|
------------
|
|
|
|
For a mail access, three drivers exist.
|
|
One for storage, one for session, one for message.
|
|
Note that the folder access rely only on session driver.
|
|
|
|
|
|
3.2.1/ storage driver interface
|
|
|
|
mail_storage_driver is the driver structure for mail storage
|
|
|
|
- name is the name of the driver
|
|
|
|
- connect() connects the storage to the remote access or to
|
|
the path in the local filesystem.
|
|
|
|
- get_folder() can have two kinds of behaviour.
|
|
Either it creates a new session and independant from the session
|
|
used by the storage and select the given mailbox or
|
|
it selects the given mailbox in the current session.
|
|
It depends on the efficiency of the mail driver.
|
|
|
|
- free_data() frees the data created with mail_storage constructor.
|
|
|
|
a constructor for each kind of access has to be implemented.
|
|
|
|
|
|
3.2.2/ session driver interface
|
|
|
|
maildriver is the driver structure for mail sessions
|
|
|
|
- name is the name of the driver
|
|
|
|
- initialize() is the function that will initializes a data structure
|
|
specific to the driver, it returns a value that will be stored
|
|
in the field data of the session.
|
|
The field data of the session is the state of the session,
|
|
the internal data structure used by the driver.
|
|
It is called when creating the mailsession structure with
|
|
mailsession_new().
|
|
|
|
- uninitialize() frees the structure created with initialize()
|
|
|
|
- parameters() implements functions specific to the given mail access
|
|
|
|
- connect_stream() connects a stream to the session
|
|
|
|
- connect_path() notify a main path to the session
|
|
|
|
- starttls() changes the current stream to a TLS stream
|
|
|
|
- login() notifies the user and the password to authenticate to the
|
|
session
|
|
|
|
- logout() exits the session and closes the stream
|
|
|
|
- noop() does no operation on the session, but it can be
|
|
used to poll for the status of the connection.
|
|
|
|
- check_folder() makes a checkpoint of the session
|
|
|
|
- select_folder() selects a mailbox
|
|
|
|
- expunge_folder() deletes all messages marked \Deleted
|
|
|
|
- status_folder() queries the status of the folder
|
|
(number of messages, number of recent messages, number of
|
|
unseen messages)
|
|
|
|
- append_message() adds a RFC 2822 message to the current
|
|
given mailbox
|
|
|
|
- get_messages_list() returns the list of message numbers
|
|
of the current mailbox.
|
|
|
|
- get_envelopes_list() fills the parsed fields in the
|
|
mailmessage structures of the mail_envelopes_list.
|
|
|
|
- remove_message() removes the given message from the mailbox.
|
|
The message is permanently deleted.
|
|
|
|
- get_message returns a mailmessage structure that corresponds
|
|
to the given message number.
|
|
|
|
|
|
3.2.3/ message driver interface
|
|
|
|
mailmessage_driver is the driver structure to get information from messages.
|
|
|
|
- name is the name of the driver
|
|
|
|
- initialize() is the function that will initializes a data structure
|
|
specific to the driver, it returns a value that will be stored
|
|
in the field data of the mailsession.
|
|
The field data of the session is the state of the session,
|
|
the internal data structure used by the driver.
|
|
It is called when initializing the mailmessage structure with
|
|
mailmessage_init().
|
|
|
|
- uninitialize() frees the structure created with initialize().
|
|
It will be called by mailmessage_free().
|
|
|
|
- flush() will free from memory all temporary structures of the message
|
|
(for example, the MIME structure of the message).
|
|
|
|
- fetch_result_free() will free all strings resulted by fetch() or
|
|
any fetch_xxx() functions that returns a string.
|
|
|
|
- fetch() returns the content of the message (headers and text).
|
|
|
|
- fetch_header() returns the content of the headers.
|
|
|
|
- fetch_body() returns the message text (message content without headers)
|
|
|
|
- fetch_size() returns the size of the message content.
|
|
|
|
- get_bodystructure() returns the MIME structure of the message.
|
|
|
|
- fetch_section() returns the content of a given MIME part
|
|
|
|
- fetch_section_header() returns the header of the message
|
|
contained by the given MIME part.
|
|
|
|
- fetch_section_mime() returns the MIME headers of the
|
|
given MIME part.
|
|
|
|
- fetch_section_body() returns the text (if this is a message, this is the
|
|
message content without headers) of the given MIME part.
|
|
|
|
- fetch_envelope() returns a mailimf_fields structure, with a list of
|
|
fields chosen by the driver.
|
|
|
|
- get_flags() returns a the flags related to the message.
|
|
When you want to get flags of a message, you have to make sure to
|
|
call get_flags() at least once before using directly message->flags.
|
|
|
|
|
|
3.3/ Higher level interface
|
|
---------------------------
|
|
|
|
3.3.1/ Files descriptions
|
|
|
|
generic_cache.[ch] -- functions that implements cache and
|
|
flags storing mechanism
|
|
imapdriver.[ch] -- IMAP driver for session
|
|
imapdriver_cached.[ch] -- IMAP driver for session, using cache,
|
|
IMAP already has flags.
|
|
imapdriver_cached_message.[ch] -- IMAP driver for message, using cache
|
|
IMAP already has flags.
|
|
imapdriver_message.[ch] -- IMAP driver for message
|
|
imapdriver_types.[ch] -- tools function for IMAP driver (types
|
|
conversion from IMAP module).
|
|
imapstorage.[ch] -- IMAP driver for storage
|
|
imfcache.[ch] -- implements cache for parsed fields
|
|
libetpan.h -- includes all necessary header files to
|
|
use libEtPan!
|
|
maildriver.[ch] -- wrappers to calls to the session driver
|
|
maildriver_tools.[ch] -- default implementation for drivers,
|
|
when the driver does not parse the
|
|
messages.
|
|
maildriver_types.[ch] -- data types declaration and constructors
|
|
maildriver_types_helper.[ch] -- easy data creation
|
|
mailmessage.[ch] -- wrappers to calls to the message driver
|
|
mailstorage.[ch] -- storage creation, calls to the storage
|
|
driver and implementation of folders.
|
|
mailstorage_tools.[ch] -- tools for storage (connection)
|
|
mailthread.[ch] -- threading: collection of the mails
|
|
into a treee
|
|
mboxdriver.[ch] -- mbox driver for session
|
|
mboxdriver_cached.[ch] -- mbox driver for session, using flags
|
|
and cache
|
|
mboxdriver_cached_message.[ch] -- mbox driver for message, using flags
|
|
and cache
|
|
mboxdriver_message.[ch] -- mbox driver for message
|
|
mboxdriver_tools.[ch] -- mbox driver common functions
|
|
mboxstorage.[ch] -- mbox driver for storage
|
|
mhdriver.[ch] -- MH driver for session
|
|
mhdriver_cached.[ch] -- MH driver for session, using flags
|
|
and cache
|
|
mhdriver_cached_message.[ch] -- MH driver for message, using flags
|
|
and cache.
|
|
mhdriver_message.[ch] -- MH driver for message
|
|
mhdriver_tools.[ch] -- MH driver common functions
|
|
mhstorage.[ch] -- MH driver for storage
|
|
nntpdriver.[ch] -- NNTP driver for session
|
|
nntpdriver_cached.[ch] -- NNTP driver for session, using flags
|
|
and cache
|
|
nntpdriver_cached_message.[ch] -- NNTP driver for message, using flags
|
|
and cache
|
|
nntpdriver_message.[ch] -- NNTP driver for message
|
|
nntpdriver_tools.[ch] -- NNTP driver common functions
|
|
nntpstorage.[ch] -- NNTP driver for storage
|
|
pop3driver.[ch] -- POP3 driver for session
|
|
pop3driver_cached.[ch] -- POP3 driver for session, using flags
|
|
and cache
|
|
pop3driver_cached_message.[ch] -- POP3 driver for message, using flags
|
|
and cache
|
|
pop3driver_message.[ch] -- POP3 driver for message
|
|
pop3driver_tools.[ch] -- POP3 driver common functions
|
|
pop3storage.[ch] -- POP3 driver for storage
|
|
|
|
|
|
3.3.2/ Interfaces
|
|
|
|
Include for this module is libetpan.h and includes all other headers.
|
|
|
|
|
|
The interface of higher layer is documented in the following files :
|
|
|
|
maildriver.h
|
|
maildriver_types.h
|
|
maildriver_types_helper.h
|
|
mailmessage.h
|
|
mailstorage.h
|
|
mailstorage_types.[h]
|
|
mailthread.h
|
|
|
|
|
|
4/ Architecture
|
|
---------------
|
|
|
|
(see layer.fig)
|
|
|
|
|
|
5/ Example of use
|
|
-----------------
|
|
|
|
You can find some example in tests/
|
|
|
|
|
|
6/ Constraints
|
|
--------------
|
|
|
|
- libEtPan! must run on a system where mmap() is available.
|
|
|
|
- for mbox particularly, libEtPan! make assumption on the fact that a
|
|
file can be entirely mapped into memory. But if you don't read
|
|
mailboxes of 1 Go, it should be fine.
|
|
|
|
|
|
|