Appendices
Indices
gnu Mailutils contains a series of useful mail clients, servers, and libraries. These are the primary mail utilities of the GNU system. Specifically, this package contains a POP3 server, an IMAP4 server, and a Sieve mail filter. It also provides a POSIX `mailx' client, and a collection of other tools. The central library is capable of accessing different mailbox formats and mailers as well as off of local or remote POP3 and IMAP4 servers.
This software is part of the GNU Project and belongs to the Free Software Foundation. All libraries are licensed using the GNU LGPL. The documentation is licensed under the GNU FDL, and everything else is licensed using the GNU GPL.
This package started off to try and handle large mailbox files more gracefully then current POP3 servers did. While it handles this task, it also allows you to support a variety of different mailbox formats without any real effort on your part. Also, if a new format is added at a later date, your program will support that new format automatically as soon as it is compiled against the new library.
gnu Mailutils provides a set of programs for handling the e-mail.
There are some command line options that are used so often that it is inconvenient to specify them in the command line each time you run a Mailutils utility. The configuration files provide a way to add default command line arguments without having to type them in the command line. Upon startup, each Mailutils utility scans and processes the contents of the three startup files, none of which are required to exist:
mailutils.rc, found in your your system configuration directory (usually /etc or /usr/local/etc).
Usually ~/.mailutils, unless ~/.mailutils is a directory, in which case ~/.mailutils/mailutils is used.
Usually ~/.mu.programrc, unless ~/.mailutils is a directory, in which case ~/.mailutils/programrc is used (where program means the program name).
These files have simple line-oriented syntax. Comments begin with the pound sign (‘#’) and extend through the end of the line 1. Very long lines may be split across several lines by escaping final newline with a backslash (‘\’) character.
In the non-program-specific configuration files, any configuration line must start with a tag. In the program-specific configuration file the tag must not be present, all options are for that specific program.
A tag is either a name of a particular Mailutils utility or option group, prefixed with colon (‘:’). The command line options common for several Mailutils programs are divided into option groups or capabilities, e.g. the options --mail-spool and --lock-flags form group ‘mailbox’. These groups are discussed in detail below.
When processing the non-program-specific configuration files, a Mailutils utility selects those lines whose tag is either the name of that utility or the name of the option group supported by it. In the program-specific configuration file, all lines are selected. For each line found, its tag (if present) is stripped away, and the rest of the line is split up into words. These words are regarded as command line options and are inserted to the program arguments before any options from the command line. Thus the options from .mailutils take precedence over those from mailutils.rc, and the options from the command line take precedence over those from all three configuration files.
The word splitting occurs at whitespace characters and is similar to that performed by the shell. If an option must contain embedded whitespace, it should be enclosed in a pair of quotes (either double or single quotes).
Each program understands the following informational options:
Option group ‘mailbox’ consists of options used to specify the location of the mail spool, and the locking strategy.
This option group overrides the default mailer URL (sendmail:).
Option group ‘address’ consists of options used to specify how to qualify email addresses.
An unqualified address (one without an @) is qualified by appending
@defaultdomain. defaultdomain is the return of
gethostname()
, or the result of gethostbyname()
on the return
of gethostname()
(if the DNS lookup is successful).
If the email address of the current user is needed, either the address set by --email-addr is returned, or the current uid is looked up in the user database, and qualified with the defaultdomain.
These options control the authorization and authentication module lists. For a description of authentication concepts, refer to See authentication.
The following options exist in this group if the package was configured with --enable-sql option. They take effect only if the ‘sql’ module is used in authentication and/or authorization.
mailutils
was compiled with support for several
sql drivers.
If this option is omitted, mailutils
will use the first
available sql driver.
These options control TLS/SSL encryption in imap4d and pop3d daemons.
The following options comprise this group:
The following configuration file specifies that all Mailutils programs should use /var/spool/mail as a local mailspool directory. Programs performing authentication will use pam service ‘mailutils’. All programs, except imap4d will issue log messages via ‘mail’ facility, imap4d will use facility ‘local1’.
:mailbox --mail-spool /var/spool/mail :auth --authentication pam --pam-service mailutils :logging --log-facility mail imap4d --daemon=20 --timeout=1800 --log-facility local1
Some mail utilities provide access to their services only after verifying that the user is actually the person he is claiming to be. Such programs are, for example, pop3d and imap4d. The process of the verification is broken down into two stages: authorization and authentication. In authorization stage the program retrieves the information about a particular user. In authentication stage, this information is compared against the user-supplied credentials. Only if both stages succeed is the user allowed to use the service.
A set of modules is involved in performing each stage. For example, the authorization stage can retrieve the user description from various sources: system database, sql database, virtual domain table, etc. Each module is responsible for retrieving the description from a particular source of information. The modules are arranged in a module list. The modules from the list are invoked in turn, until either a one of them succeeds or the list is exhausted. In latter case the authorization fails. Otherwise the data returned by the succeeded module are used in authentication.
Similarly, authentication may be performed in several ways. The authentication modules are also grouped in a list. Each module is tried in turn until either a module succeeds, in which case the authentication succeeds, or the end of the list is reached.
We represent the module lists as column-separated lists of module names. For example, the authorization list
system:sql:virtdomains
means that first the system user database (/etc/password) is searched for a description of a user in question. If the search fails, the sql database is searched. Finally, if it also fails, the search is performed in the virtual domain database.
Note, that some authentication and/or authorization modules may be disabled when configuring the package before compilation. The names of the disabled modules are nevertheless available for use in runtime configuration options, but they represent a “fail-only” functionality, e.g. if the package was compiled without sql support then the module ‘sql’ in the above example will always fail, thus passing the execution on to the next module.
The modules available for use in authorization list are:
The modules available for use in authentication list are:
Unless overridden by --authentication command line option, the list of authentication modules is:
generic:system:pam:sql
Unless overridden by --authorization command line option, the list of authorization modules is:
system:sql:virtdomains
GNU mailutils provides two commands for listing messages in a mailbox. These are from and frm.
The frm command outputs a header information of
the selected messages in a mailbox. By default, frm reads the
user's system mailbox and outputs the contents of From
and
Subject
headers for each message. If a folder is specified in
the command line, the program reads that folder rather than the default
mailbox.
The program uses following option groups: See mailbox.
The following command line options alter the behavior of the program:
From
Subject
pair.
To
header to the output. The output field
order is then: To
From
Subject
.
The from utility displays sender and subject of each message in a mailbox. By default, it reads the user's system mailbox. If the program is given a single argument, it is interpreted as a user name whose mailbox is to be read. Obviously, permissions are required to access that user's mailbox, so such invocations may be used only by superuser.
Option -f (--file) instructs the program to read the given mailbox.
The full list of options, supported by from follows:
From:
header is examined.
Mail is an enhanced version of standard /bin/mail program. As well as its predecessor, it can be used either in sending mode or in reading mode. Mail enters sending mode when one or more email addresses were specified in this command line. In this mode the program waits until user finishes composing the message, then attempts to send it to the specified addresses and exits. See Composing Mail, for a detailed description of this behavior.
If the command line contained no email addresses, mail switches to reading mode. In this mode it allows to read and manipulate the contents of a mailbox. The URL of the mailbox to operate upon is taken from the argument of --file command line option. If it is not specified, the user's system mailbox is assumed. For more detail, see Reading Mail.
General usage of mail program is:
mail [option...] [address...]
If [address...] part is present, mail switches to mail sending mode, otherwise it operates in mail reading mode.
The program uses following option groups: See mailbox.
Mail understands following command line options:
print * quit
mail -f/spool_path/user
with spool_path being the full path to your mailspool directory
(/var/spool/mail or /var/mail on most systems).
Many mail commands such as print and delete can be given a message list to operate upon. Wherever the message list is omitted, the command operates on the current message.
The message list in its simplest form is one of:
In its complex form, the message list is a comma or whitespace-separated list of message specifiers. A message specifier is one of
[header:]/string/
It selects all messages that contain header field header
matching given regexp. If the variable regexp
is set,
the string is assumed to be a POSIX regexp. Otherwise, a
header is considered to match string if the latter constitutes
a substring of the former (comparison is case-insensitive).
If header: part is omitted, it is assumed to be ‘Subject:’.
:/string/
It selects all messages whose body matches the string. The matching rules are the same as described under “Header match”.
A message specifier can be followed by message part specifier, enclosed in a pair of brackets. A message part specifier controls which part of a message should be operated upon. It is meaningful only for multipart messages. A message part specifier is a comma or whitespace - separated list of part numbers or ranges. Each part number can in turn be message part specifier, thus allowing for operating upon multiply-encoded messages.
The following are the examples of valid message lists:
You can compose the message by simply typing the contents of it, line
by line. But usually this is not enough, you would need to edit
your text, to quote some messages, etc. Mail provides these
capabilities through compose escapes. The compose escapes
are single-character commands, preceded by special escape character,
which defaults to ‘~’. The combination escape character + command
is recognized as a compose escape only if it occurs at the beginning of
a line. If the escape character must appear at the beginning of a
line, enter it twice.
The actual escape character may be changed by setting the value of
escape
mail variable (see Mail Variables).
There are several commands allowing you to quit the compose mode.
Typing the end-of-file character (‘C-D’) on a line alone finishes
compose mode and sends the message to its destination. The ‘C-D’
character looses its special meaning if ignoreeof
mail variable
is set.
If mail variable dot
is set, typing dot (‘.’) on a line
alone achieves the same effect as ‘C-D’ above.
Finally, using ‘~.’ escape always quits compose mode and sends out the composed message.
To abort composing of a message without sending it, type interrupt
character (by default, ‘C-C’) twice. This behavior is disabled
when mail variable ignore
is set. In this case, you can use
‘~x’ escape to achieve the same effect.
The ‘~?’ escape prints on screen a brief summary of the available compose escapes. Please note, that ‘~h’ escape prompts for changing the header values, and does not give help.
If you are not satisfied with the message as it is, you can edit it
using a text editor specified either by EDITOR
or by
VISUAL
environment variables. The ‘~e’ uses the former,
and ‘~v’ uses the latter.
By default both escapes allow you to edit only the body of the
message. However, if the editheaders
variable is set,
mail will load into the editor the complete text of
the message with headers included, thus allowing you to change
the headers as well.
To add new addresses to the list of message recipients, use ‘~t’ command, e.g.:
~t name1@domain.net name2
To add addresses to Cc
or Bcc
, use ‘~c’ or ‘~b’
escapes respectively.
To change the Subject
header, use ‘~s’ escape, e.g.:
~s "Re: your message"
Finally, to edit all headers, type ‘~h’ escape. This will present
you with the values of To
, Cc
, Bcc
, and
Subject
headers allowing to edit them with normal text editing
commands.
If you are sending mail from within mail command mode, you can enclose the contents of any message sent to you by using ‘~m’ or ‘~M’ commands. Typing ‘~m’ alone will enclose the contents of the current message, typing ‘~m 12’ will enclose the contents of message #12 and so on.
The ‘~m’ uses retained and ignored lists when enclosing headers, the ‘~M’ encloses all header fields.
In both cases, the contents of indentprefix
mail variable is
prepended to each line enclosed.
To append the contents of file filename to the message, type
~r filename
or
~< filename
The ‘~d’ escape is a shorthand for
~r dead.letter
The ‘~p’ escape types the contents of the message entered so far, including headers, on your terminal. You can save the message to an arbitrary file using ‘~w’ escape. It takes the filename as its argument.
To save you the effort of typing your signature at the end of each
message, you can use ‘~a’ or ‘~A’ escapes. If your signature
occupies one line only, save it to the variable sign
and use
‘~a’ escape to insert it. Otherwise, if it is longer than one
line, save it to a file, store the name of this file in the
variable Sign
, and use ‘~A’ escape to insert it into
the message.
Sometimes it is necessary to view the contents of another message, while composing. These two escapes allow it. Both take the message list as their argument. If they are used without argument, the contents of the current message is printed. The difference between ‘~f’ and ‘~F’ is that the former uses ignored and retained lists to select headers to be displayed, whereas the latter prints all headers.
The ‘~i’ escape enters the value of the named mail variable into the body of the message being composed.
You can execute a mail command from within compose mode using ‘~:’ or ‘~-’ escapes. For example, typing
~: from :t
will display the from lines of all tagged messages. Note, that executing
mail-sending commands from within the compose mode is not allowed.
An attempt to execute such a command will result in diagnostic message
“Command not allowed in an escape sequence” being displayed.
Also, when starting compose mode immediately from the shell
(e.g. running ‘mail address@domain’), most mail commands are
meaningless, since there is no mailbox to operate upon. In this case,
the only commands that can reasonably be used are: alias
,
unalias
, alternate
, set
, and unset
.
The ‘~!’ escape executes specified command and returns you to mail compose mode without altering your message. When used without arguments, it starts your login shell. The ‘~|’ escape pipes the message composed so far through the given shell command and replaces the message with the output the command produced. If the command produced no output, mail assumes that something went wrong and retains the old contents of your message.
To read messages from a given mailbox, use one of the following ways of invoking mail:
mail
mail --file
mail --file=
path_to_mailboxmail --user=
userPlease note, that usual mailbox permissions won't allow you to use the last variant of invocation, unless you are a super-user. Similarly, the last but one variant is also greatly affected by the permissions the target mailbox has.
Unless you have started mail with --norc command line option, it will read the contents of the system-wide configuration file. Then it reads the contents of user configuration file, if any. For detailed description of these files, see Mail Configuration Files. After this initial setup, mail displays the first page of header lines and enters interactive mode. In interactive mode, mail displays its prompt (‘?’, if not set otherwise) and executes the commands the user enters.
Following commands quit the program:
delete
are removed.
The program exits to the Shell, unless saving the mailbox fails, in
which case user can escape with the exit command.
Typing EOF (‘C-D’) alone is equivalent to ‘quit’.
Following commands can be used during the session to request online help:
quit
command has been issued.
If mailbox is omitted, the command prints the current mailbox
name followed by the summary information regarding it, e.g.:
& fold "/var/spool/mail/gray": 23 messages 22 unread |
To control which headers in the message should be displayed, mail keeps two lists: a retained header list and an ignored header list. If retained header list is not empty, only the header fields listed in it are displayed when printing the message. Otherwise, if ignored header list is not empty, only the headers not listed in this list are displayed. The uppercase variants of message-displaying commands can be used to print all the headers.
The following commands modify and display the contents of both lists.
headers
command. When arg is ‘.’, it is generally equivalent to
headers
. When arg is omitted or is ‘+’, the next
pageful of headers is displayed. If arg is ‘-’, the
previous pageful of headers is displayed. The latter two forms
of z
command may also take a numerical argument meaning the
number of pages to skip before displaying the headers. For
example:
& z +2
will skip two pages of messages before displaying the header summary.
folder
variable.
& summary "/var/spool/mail/gray": 23 messages 22 unread |
crt
determines the minimum number of lines the body of the message must
contain in order to be piped through pager command specified
by environment variable PAGER
. If crt
is set to a numeric
value, this value is taken as the minimum number of lines. Otherwise,
if crt
is set without a value then the height of the terminal
screen is used to compute the threshold. The number of lines on
screen is controlled by screen
variable.
decode
command decodes and prints
out specified message parts. E.g.
& decode 15[2] +--------------------------------------- | Message=15[2] | Type=message/delivery-status | encoding=7bit +--------------------------------------- Content-Type: message/delivery-status ... |
toplines
and
defaults to five.
cmd
is set,
the value of this variable is used as a command name.
& untag :t
delete
command.
quit
command these
messages will be deleted from the mailbox. Until the end of current
session the deleted messages can be referred to in message lists using
:d notation.
delete
command, unless the variable
keepsave
is set.
save
, but the file to append messages to is named after the
sender of the first message in msglist. For example:
& from 14 15 U 14 smith@noldor.org Fri Jun 30 18:11 14/358 The Save c U 15 gray@noldor.org Fri Jun 30 18:30 8/245 Re: The Sa & Save 14 15 "smith" 22/603 |
i.e., 22 lines (603 characters) have been appended to the file “smith”.
If the file does not exist, it is created.
save
, except that only message body (without the
header) is saved.
Save
, except that only message body (without the
header) is saved.
quit
command. This is the default action for
all read messages, unless you have variable hold
set.
save
, except that saved messages are not marked for
deletion.
Save
, except that saved messages are not marked for
deletion.
These command allow to edit messages in a mailbox. Please note,
that modified messages currently do not replace original ones. i.e.
you have to save them explicitly using your editor's save
command if you do not want the effects of your editing to be lost.
EDITOR
environment variable.
VISUAL
environment variable.
reply
, except that the composed message is sent only to
originators of the specified messages.
Notice, that setting mail variable flipr
(see Mail Variables) swaps the meanings of the two above commands,
so that reply
sends the message to the sender and all
recipients of the message, whereas Reply
sends it to
originators only.
followup
, but reply message is sent only to
originators of messages in msglist.
To determine the sender of the message mail uses the list of sender fields (see Controlling Sender Fields). The first field from this list is looked up in message headers. If it is found and contains a valid email address, this address is used as the sender address. If not, the second field is searched and so on. This process continues until a field is found in the headers, or the sender field list is exhausted, whichever happens first.
If the previous step did not determine the sender address, the address from SMTP envelope is used.
Let's illustrate this. Suppose your mailbox contains the following:
U 1 block@helsingor.org Fri Jun 30 18:30 8/245 Re: The Sa & Print 1 From: Antonius Block <block@helsingor.org> To: Smeden Plog <plog@helsingor.org> Date: Tue, 27 Apr 2004 13:23:41 +0300 Reply-To: <root@helsingor.org> Subject: News Hi |
Now, you issue the following commands:
& sender mail-followup-to reply-to from & reply To: <root@helsingor.org> Subject: Re: News |
As you see, the value of Reply-To
field was taken as the
sender address.
Now, let's try the following command sequence:
# Clear the sender list & nosender # Set new sender list & sender From
Now, the From
address will be taken:
& reply To: Antonius Block <block@helsingor.org> Subject: Re: News |
Commands sender
and nosender
are used to manipulate
the contents of the sender field list.
If the command sender
is used without arguments, it displays
the contents of the sender field list. If arguments are given,
each argument is appended to the sender field list. For example:
& sender Sender address is obtained from the envelope & sender mail-followup-to reply-to & sender mail-followup-to reply-to & sender from & sender mail-followup-to reply-to from |
Command nosender
is used to remove items from the sender
field list:
& sender mail-followup-to reply-to from & nosender reply-to & sender mail-followup-to from |
When used without arguments, this command clears the list:
& nosender Sender address is obtained from the envelope |
The incorporate
(inc
) command incorporates newly arrived
messages to the displayed list of messages. This is done automatically
before returning to mail command prompt if the variable
autoinc
is set.
To run arbitrary shell command from mail command prompt, use
shell
(sh
) command. If no arguments are specified, the
command starts the user login shell. Otherwise, it uses its first
argument as a file name to execute and all subsequent arguments are
passed as positional parameters to this command. The shell
command can also be spelled as !
.
The ‘#’ character introduces an end-of-line comment. All characters until and including the end of line are ignored.
The ‘echo’ (‘ec’) command prints its arguments to stdout.
The command ‘source filename’ reads commands from the named file. Its minimal abbreviation is ‘so’.
The mail variables may be set using ‘set’ (‘se’) command. The command takes a list of assignments. The syntax of an assignment is
True
value.
False
value.
Example:
& set askcc nocrt indentprefix="> "
This statement sets askcc
to True
, crt
to
False
, and indentprefix
to “> ”.
To unset mail variables use ‘unset’(‘uns’) command. The command takes a list of variable names to unset.
Example: To undo the effect of the previous example, do:
& unset askcc crt indentprefix
Shell environment may be modified using ‘setenv’ (‘sete’) command. The command takes a list of assignments. The syntax of an assignment is:
The conditional statement allows to execute a set of mail commands depending on the mode the mail program is in. The conditional statement is:
if cond ... else ... endif
where ‘...’ represents the set of commands to be executed in each branch of the statement. cond can be one of the following:
The conditional statements can be nested to arbitrary depth. The minimal abbreviations for ‘if’, ‘else’ and ‘endif’ commands are ‘i’, ‘el’ and ‘en’.
Example:
if t set crt prompt="& " else unset prompt endif if s alt gray@farlep.net gray@mirddin.farlep.net set
Following variables control the behavior of gnu mail:
appenddeadletter
True
, the contents of canceled letter is
appended to the user's dead.letter file. Otherwise it overwrites
its contents.
askbcc
True
the user will be prompted to enter Bcc
field before composing the message.
askcc
True
the user will be prompted to enter Cc
field before composing the message.
asksub
True
the user will be prompted to enter Subject
field before composing the message.
autoinc
autoprint
bang
!
in arguments to !
command is replaced with the last executed command.
datefield
Date:
header field, converted to
localtime. Notice, that for messages lacking this field mail
will fall back to using SMTP envelope.
charset
LC_ALL
environment
variable. Otherwise, its value is taken as the name of the charset.
cmd
pipe
.
columns
COLUMNS
is used.
This variable contains the number of columns on terminal screen.
crt
crt
determines the minimum number of lines the body
of the message must contain in order to be piped through pager command
specified by environment variable PAGER
. If crt
is set
to a numeric value, this value is taken as the threshold. Otherwise,
if crt
is set without a value, then the height of the terminal
screen is used to compute the threshold. The number of lines on
screen is controlled by screen
variable.
decode-fallback
dot
True
, causes mail to interpret a period alone on a line as the
terminator of a message you are sending.
emptystart
editheaders
~e
and ~v
escapes, thus allowing you to customize
the headers.
escape
flipr
flipr
if set swaps the meanings of reply
and Reply
commands (see Replying).
folder
header
headers
command automatically after entering
interactive mode.
hold
True
, the read or saved messages will be stored in
user's mailbox ($HOME/mbox). Otherwise, they will be held in
system mailbox also. This option is in effect only when operating
upon user's system mailbox.
ignore
True
, mail will ignore keyboard interrupts
when composing messages. Otherwise an interrupt will be taken as a
signal to abort composing.
ignoreeof
indentprefix
~m
tilde escape for indenting quoted messages.
inplacealiases
If set, mail will expand aliases in the address header field
before entering send mode (see Composing Mail). By default, the
address header fields are left intact while composing, the alias
expansion takes place immediately before sending message.
keepsave
mailx
Cc
and Bcc
addresses after composing the body.
The default behavior is to ask for these values before composing
the body.
metamail
decode
command. If
it is unset, decode
will not attempt any interpretation
of the content of message parts. Otherwise, if metamail
is set to true
, decode
will use internal metamail
support to interpret message parts. Finally, if metamail
is assigned a string, this string is treated as command line of
the external metamail command which will be used to
display parts of a multipart message. For example:
# Disable MIME interpretation: set nometamail # Enable built-in MIME support: set metamail # Use external program to display MIME parts: set metamail="metamail -m mail -p"
mimenoask
set mimenoask=text/*,image/jpeg
will disable prompting before displaying any textual files, no
matter what their subtype is, and before displaying files with
type ‘image/jpeg’.
metoo
mode
outfolder
save
,
write
, etc. commands will be stored. When unset, current
directory is assumed.
page
True
, the pipe
command will emit a linefeed
character after printing each message.
prompt
quit
rc
record
recursivealiases
When set, mail will expand aliases recursively.
regex
True
enables use of regular expressions in
‘/.../’ message specifications.
replyprefix
replyregex
Subject
header of the message matches this
expression, the value of replyprefix
will not be prepended to
it before replying. The expression should be a POSIX extended regular
expression. The comparison is case-insensitive.
For example, to recognize usual English, Polish, Norwegian and German reply subject styles, use:
set replyregex="^(re|odp|aw|ang)(\\[[0-9]+\\])?:[[:blank:]]"
(Notice the quoting of backslash characters).
save
appenddeadletter
.
screen
LINES
is used.
This variable contains the number of lines on terminal screen.
sendmail
Sign
~A
escape.
sign
~a
escape. Use
Sign
variable, if your signature occupies more than one line.
showto
To:
addresses
instead of From:
for all messages that come from the user that
invoked the program.
subject
asksub
is
off.
toplines
top
and Top
commands.
verbose
xmailer
X-Mailer: mail (GNU Mailutils 1.0)
Upon startup, mail reads the contents of the two command files: the system-wide configuration file, and the user's configuration file. Each line read from these files is processed like a usual mail command.
When run with --norc (-N) option, mail does not read the contents of system-wide configuration file. The user's file, if it exists, is always processed.
The user's configuration file is located in the user's home directory and is named .mailrc. The location and name of the system-wide configuration file is determined when configuring the package via --with-mail-rc option. It defaults to sysconfdir/mail.rc.
Messages prints on standard output the number of messages contained in each folder specified in command line. If no folders are specified, it operates upon user's system mailbox. For each folder, the following output line is produced:
Number of messages in folder: number
where folder represents the folder name, number represents the number of messages.
The program uses following option groups: See mailbox.
The program accepts following command line options:
The purpose of movemail, as its name implies, is to move mail from one location to another. For example, the following invocation:
movemail /var/mail/smith INBOX
moves messages from file /var/mail/smith to file INBOX.
You will probably never have to run this program manually. It is
intended as a replacement for movemail from GNU Emacs. The
movemail program is run by Emacs Rmail
module. See Rmail, for detailed
description of Rmail
interface.
Mailutils version of movemail is completely
backward-compatible with its Emacs predecessor, so it should run
flawlessly with older versions of Emacs. Emacs version 21.4, which is
being developed at the time of this writing, will contain improved
Rmail
interface for work with mailutils movemail.
This subsection discusses movemail options from the point of
view of an Emacs Rmail
user.
To set various options to movemail from Rmail
, use
rmail-movemail-flags
variable, or ‘Rmail Movemail Flags’
section from the menu.
Some POP servers return messages in reversed order. To fix the order, use -p option or its synonym --reverse.
If the remote server supports TLS encryption, use --tls to instruct movemail to initiate encrypted connection.
Quite a few options control how movemail handles mail locking (a way of preventing simultaneous access to the source mailbox). By default, before accessing mailbox file, movemail will first see if the file named file.lock (so called lock file) exists. If so, it will assume that the mailbox is being used by another program and will sleep one second. If file.lock file disappears after this wait period, the program will proceed. Otherwise, it will repeat this action ten times. If after ten wait periods the lock file does not disappear, movemail gives up and exits.
If the lock file does not exist, movemail will create it, thereby indicating to other programs that the mailbox is being used, and will proceed to copying messages to the destination file. When finished, movemail closes the mailbox and removes the lock file.
Several options control this behavior. To change the default sleep period use --lock-retry-timeout. Its argument is the timeout value in seconds.
To change number of retries, use --lock-retry-count. For
example, setting rmail-movemail-flags
to
--lock-retry-timeout=2 --lock-retry-count=5
instructs movemail to make five attempts to acquire the lock file, with two-second intervals between the attempts.
You may also force movemail to remove the lock file if it is older than a given amount of time (a so called stale lock file). To do so, use the following option:
--lock-expire-timeout=seconds
The --lock-expire-timeout sets the number of seconds after which a lock file is considered stale.
There are special programs that can be used to lock and unlock mailboxes. A common example of such programs is dotlock. If you wish to use such external locking program instead of the default mailutils locking mechanism, use option --external-locker. Argument to this option specifies the full name of the external program to use.
movemail [option...] inbox destfile [remote-password]
The first argument, inbox, is the url (see URL) of the source mailbox. The second argument, destfile, traditionally means destination file, i.e. the UNIX mailbox to copy messages to. However, mailutils movemail extends the meaning of this parameter. You may actually specify any valid url as destfile parameter.2. Finally, optional third argument is a traditional way of specifying user passwords for remote (POP or IMAP) mailboxes.
Following is the summary of available command line options:
The program, readmsg, extracts with the selection argument messages from a mailbox. Selection can be specify by:
readmsg 1 3 0
extracts three messages from the folder: the first, the third, and the last.
readmsg staff meeting
extracts the message which contains the words “staff meeting.” Note that it will not match a message containing “Staff Meeting” - the matching is case sensitive. Normally only the first message which matches the pattern will be printed.
Sieve is a language for filtering e-mail messages at time of final delivery, described in RFC 3028. gnu Mailutils provides two implementations of this language: a stand-alone sieve interpreter and a sieve translator and filter. The following sections describe these utilities in detail.
Sieve interpreter sieve allows to apply Sieve scripts to an arbitrary number of mailboxes. gnu sieve implements a superset of the Sieve language as described in RFC 3028. See Sieve Language, for a description of the Sieve language. See GNU Extensions, for a discussion of differences between the gnu implementation of Sieve and its standard.
The sieve invocation syntax is:
sieve [options] script
where script denotes the filename of the sieve program to parse, and options is one or more of the following:
‘g’ | Enable main parser traces
|
‘T’ | Enable mailutil traces
|
‘P’ | Trace network protocols
|
‘t’ | Enable sieve trace
|
‘i’ | Trace the program instructions
|
reject
and
redirect
actions. By default, the user email address is deduced
from the user name and the full name of the machine where sieve is
executed.
Apart from these, sieve understands the options from the
following groups: sieve
, mailbox
, mailer
,
logging
.
The default behavior of sieve is to remain silent about anything except errors. However, it is sometimes necessary to see which actions are executed and on which messages. This is particularly useful when debugging the sieve scripts. The --verbose (-v) option outputs log of every action executed.
Option --debug allows to produce even more detailed debugging information. This option takes an argument specifying the debugging level to be enabled. The argument can consist of the following letters:
mailutils
library.
Note, that there should be no whitespace between the short variant of the option (-d), and its argument. Similarly, when using long option (--debug), its argument must be preceded by equal sign.
If the argument to --debug is omitted, it defaults to ‘TPt’.
Option --dump produces the disassembled dump of the compiled sieve program.
By default sieve output all diagnostics on standard error and verbose logs on standard output. This behaviour is changed when --log-facility is given in the command line (see logging). This option causes sieve to output its diagnostics to the given syslog facility.
The basic set of sieve actions, tests and comparators may be extended
using loadable extensions. Usual require
mechanism is used for
that.
When processing arguments for require
statement, sieve
uses the following algorithm:
#searchpath
directive.
The value of LTDL_LIBRARY_PATH and LD_LIBRARY_PATH must be a colon-separated list of absolute directories, for example, ‘"/usr/lib/mypkg:/lib/foo"’.
In any of these directories, sieve first attempts to find and load the given filename. If this fails, it tries to append the following suffixes to the file name:
source for the required action NAME is not available
A Sieve to Scheme Translator sieve.scm translates a given Sieve script into an equivalent Scheme program and optionally executes it. The program itself is written in Scheme and requires presence of Guile 1.4 on the system. For more information on Guile refer to Overview.
The Scheme programs produced by sieve.scm can be used with guimb or mail.local.
Guimb is for mailboxes what awk is for text files. It processes mailboxes, applying the user-supplied scheme procedures to each of them in turn and saves the resulting output in mailbox format.
The program uses following option groups: See mailbox.
The Scheme program or expression to be executed is passed to guimb via the following options:
The above switches stop further argument processing, and pass all
remaining arguments as the value of (command-line)
.
If the remaining arguments must be processed by guimb itself, use following options:
You can specify both of them. In this case, the file is read first, then expr is executed. You may still pass any additional arguments to the script using --guile-arg option.
There are four basic ways of passing mailboxes to guimb.
guimb [
options] [
mailbox...]
guimb [
options] --mailbox
defmboxguimb [
options] --mailbox
defmbox mailbox [
mailbox...]
guimb [
options] --user
username [
mailbox...]
If no mailboxes are specified in the command line, guimb reads and processes the system mailbox of the current user.
Sometimes it is necessary to pass some command line options to the scheme procedure. There are three ways of doing so.
When using --source (-s) or --code (-c) options, all the rest of the command line following the option's argument is passed to Scheme program verbatim. This allows for making guimb scripts executable by the shell. If your system supports ‘#!’ magic at the start of scripts, add the following two lines to the beginning of your script to allow for its immediate execution:
#! /usr/local/bin/guimb -s !#
(replace ‘/usr/local/bin/’ with the actual path to the guimb).
Otherwise, if you use --file or --expression options, the additional arguments may be passed to the Scheme program -g (--guile-arg) command line option. For example:
guimb --guile-arg -opt --guile-arg 24 --file progfile
In this example, the scheme procedure will see the following command line:
progfile -opt 24
Finally, if there are many arguments to be passed to Scheme, it is more convenient to enclose them in -{ and -} escapes:
guimb -{ -opt 24 -} --file progfile
This is a short summary of the command line options available to guimb.
mail.local reads the standard input up to an end-of-file and appends the received data to the local mailboxes.
General usage of mail.local program is:
mail.local [option...] recipient [recipient ...]
If recipient part is present is a FQDN, mail.local will attempt to deliver to a virtual host.
The program uses following option groups: See mailbox, See auth, See logging, See sieve.
This option is available only if the package has been configured to
use Guile extension language.
MU_DEBUG_TRACE
).
MU_DEBUG_PROT
)
MU_SIEVE_DEBUG_TRACE
)
The digits in the range ‘0’ – ‘9’ used in flags set
mail.local debugging level.
This section explains how to invoke mail.local from configuration files of various Mail Transport Agents.
All examples in this section suppose that mail.local must receive following command line switches:
-s %h/.filter.scm -q /etc/mail/userquota
The mail.local must be invoked from the local mailer definition in the sendmail.cf file. It must have the following flags set ‘lswS’, meaning the mailer is local, the quote characters should be stripped off the address before invoking the mailer, the user must have a valid account on this machine and the userid should not be reset before calling the mailer. Additionally, ‘fn’ flags may be specified to allow mail.local to generate usual ‘From ’ envelope instead of the one supplied by sendmail.
If you wish to use mail.local with SQL authentication, you may wish to remove the ‘w’ flag, since in that case the user is not required to have a valid account on the machine that runs sendmail.
Here is an example of mailer definition in sendmail.cf
Mlocal, P=/usr/local/libexec/mail.local, F=lsDFMAw5:/|@qSPfhn9, S=EnvFromL/HdrFromL, R=EnvToL/HdrToL, T=DNS/RFC822/X-Unix, A=mail $u
To define local mailer in ‘mc’ source file, it will suffice to set:
define(`LOCAL_MAILER_PATH', `/usr/local/libexec/mail.local') define(`LOCAL_MAILER_ARGS', `mail $u')
Using mail.local with Exim is quite straightforward. The following example illustrates the definition of appropriate transport and director in exim.conf:
# transport mail_local_pipe: driver = pipe command = /usr/local/libexec/mail.local $local_part return_path_add delivery_date_add envelope_to_add # director mail_local: driver = localuser transport = mail_local_pipe
Sometimes it is necessary to limit the maximum size of a user's mailbox. Such maximum size is called mailbox quota for this user.
When delivering a message, mail.local first cheks if the mailbox quota is specified for the recipient. If so, mail.local computes the difference between the quota value and the actual size of the recipient's mailbox. This difference represents the maximum size of the message the receipient's mailbox is able to accomodate. Let's call it msize. Depending on its value, mail.local takes decision on whether to deliver the message. There are three possible cases:
user: mailbox quota exceeded for this recipient
user: message would exceed maximum mailbox size for this recipient
Version 1.0 of gnu mailutils is able to retrieve mailbox quotas from a dbm or sql database.
To use the dbm quota database, your copy of mailutils
must
be compiled with dbm support (one of --with-gdbm,
--with-db2, --with-ndbm, --with-dbm options
to configure
). Examine the of
mail.local --show-config-options if not sure.
The quota database should have the following structure:
A special value ‘NONE’ means no mailbox size limitation for this user.
Here is an example of a valid quota database
# Default quota value: DEFAULT 5mb # Following users have unlimited mailbox size root NONE smith NONE # Rest of users plog 26214400 karin 10mB
To use the dbm database, specify its full name using -q
or ‘--quota-db’ in the invocation of mail.local. For
example, in sendmail .mc
file:
define(`LOCAL_MAILER_PATH', `/usr/local/libexec/mail.local') define(`LOCAL_MAILER_ARGS', `mail -q /etc/mail/quota.db $u')
Option --quota-query allows to specify a special query to retrieve the quota from the database. Currently (as of mailutils version 1.0) it is assumed that this table can be accessed using the same credentials as sql authentication tables (See daemon, for the detailed discussion of --sql- options).
For example, suppose you have the following quota table:
create table mailbox_quota ( user_name varchar(32) binary not null, quota int, unique (user_name) );
To retrieve the quota for user %u
you may then use the
following query:
SELECT quota FROM mailbox_quota WHERE user_name='%u'
There is no special provisions for specifying group quotas, similar to
‘DEFAULT’ in dbm databases. This is because group quotas can
easily be implemented using sql language. Mail.local
always uses the first tuple from the set returned by mailbox quota
query. So, you may add a special entry to the mailbox_quota
table that would keep the group quota. For the following discussion,
it is important that the user_name
column for this entry be
lexicographically less than any other user name in the table. Let's
suppose the group quota name is ‘00DEFAULT’. Then the following
query:
SELECT quota FROM mailbox_quota WHERE user_name IN ('%u','00DEFAULT') ORDER BY user_name DESC
will return two tuples if user %u
is found in
mailbox_quota
. Due to ORDER
statement, the first tuple
will contain the quota for the user, which will be used by
mail.local. On the other hand, if user name %u
is not
present in the table, the above query will return a single tuple
containing the group quota.
To summarize this, here is a working mailutils.rc entry for mail.local:
:mail.local \ --sql-db MAILAUTH \ --sql-host some.host.net \ --sql-user mail.local \ --sql-passwd guessme \ --quota-query "SELECT quota \ FROM mailbox_quota \ WHERE user_name IN ('%u','00DEFAULT') \ ORDER BY user_name DESC"
For each file given in its command line, mimeview attempts to autodetect its type and invoke an appropriate file viewer.
To detect the file type, mimeview uses mime.types
file. This file is a part of Common UNIX Printing System, see
man mime.types
for the description of its syntax. [FIXME:
provide an xref to CUPS]. By default mimeview searches for
mime.types in $prefix/etc/cups/3, however its exact location can be specified
at runtime as well (see --mimetypes below).
Once file MIME type is successfully determined, mimeview
consults mailcap files in order to determine how to display
the file. It does so essentially in the same manner as
metamail utility, i.e., it scans all files specified
in METAMAIL
environment variable until it finds an entry
describing the desired file format or until the list of files is
exhausted. If METAMAIL
variable is not set, mimeview
uses the following default path instead:
$HOME/.mailcap:/usr/local/etc/mailcap:\ /usr/etc/mailcap:/etc/mailcap:\ /etc/mail/mailcap:/usr/public/lib/mailcap
The following table summarizes options specific for mimeview:
--no-ask='text/*,image/jpeg'
will disable prompting before displaying any textual files, no matter what their subtype is, and before displaying files with type ‘image/jpeg’.
Notice, that when the long form is used, its argument
must be separated from the option by a single equal sign, as shown
in the example above. When the short form (-a) is used, its argument
must follow the option immediately, without any intervening whitespace,
e.g. -a'text/*').
mailcap
files.
If flags are not given, the default ‘9’ is assumed.
command
field is not executed. Instead
mimeview will execute the command specified in
the print
field. If there is nothing in the print field,
the mailcap entry is ignored and the search continues for a matching
mailcap entry that does have a print
field.
Notice, that unlike in metamail -h, this option does not force mimeview to send the output to the printer daemon.
When used with --metamail option, this option passes -h flag to the invocation of metamail.
By default mimeview behaves as if given
--no-interactive option whenever its standard input is not
a tty device.
The pop3d daemon implements the Post Office Protocol Version 3 server.
pop3d has two operation modes:
pop3 stream tcp nowait root /usr/local/sbin/pop3d pop3d
This is the default operation mode.
The program uses following option groups: See mailbox, See daemon, See logging, See auth.
gnu imap4d is a daemon implementing imap4 rev1 protocol for accessing and handling electronic mail messages on a server. It can be run either as a standalone program or from inetd.conf file.
gnu imap4d supports a notion of namespaces defined in RFC 2342. A namespace is a set of directories upon which the user has certain permissions. It should be understood that these permissions apply only if the underlying filesystem allows them.
The three namespaces supported by imap4d are:
By default, imap4d starts with the following namespaces:
Note, that this means that by default, a user won't be able to see or otherwise access mailboxes residing in the directories other than his own home.
To change these defaults, use --shared-namespace and --other-namespace options.
imap4d may run either in standalone or in inetd operation modes. When run in “standalone” mode, the server disconnects from the terminal and runs as a daemon, forking a child for each new connection.
The “inetd” mode allows to start the server from /etc/inetd.conf file. This is the default operation mode.
imap4 stream tcp nowait root /usr/local/sbin/imap4d imap4d
The program uses following option groups: See mailbox, See daemon, See logging, See auth.
umask
value. The default value for mode is ‘700’
(‘drwx------’ in ls
terms).
Comsatd is the server which receives reports of incoming mail and notifies users, wishing to get this service. It can be started either from inetd.conf or as a standalone daemon.
Comsatd uses following option groups: See mailbox, See daemon, See logging.
comsat dgram udp wait root /usr/sbin/comsatd \ comsatd -c /etc/comsat.conf
This is the default operation mode.
The configuration parameters for comsatd are kept in a single configuration file. The file uses line-oriented format: each line contains a single statement. Comments are introduced with the ‘#’ sign and empty lines are ignored. You can specify the configuration file to use by using -c or --config command line switch.
The configuration file statements can logically be subdivided into General Settings, Security Settings and Access Control Lists. The following sections address each of these statement group in detail.
These statements control the general behavior of the comsat daemon:
These statements control the way comsatd fights possible flooding attacks.
Access control lists determine from which addresses comsatd will receive mail notification messages.
The access control lists are introduced in configuration file using keyword ‘acl’. General format for an ACL rule is
acl action netlist
Here, action specifies the action to be taken when a request arrives from one of the networks, listed in netlist. There are two possible actions: ‘allow’ and ‘deny’.
The netlist is a whitespace-separated list of network numbers. Each network number may be specified in one of the following forms:
Upon receiving a notification message, comsatd compares its source address against each ACL rule in the order of their appearance in the configuration file. The first rule that matches the packet determines whether the message will be processed or rejected. If no matching rule was found, the default rule applies. Currently, default rule is
acl allow any
If you don't need such behavior, specify the default rule explicitly. For example, the common use would be:
acl allow 127.0.0.1 acl deny any
which makes comsatd receive the notification messages from localhost only.
By default, when a notification arrives, comsatd prints subject, from headers and the first five lines from the new message to the user's tty. The user is allowed to change this behavior by using his own configuration file. This file should be located in the user's home directory and should be named .biffrc. It must be owned by the user and have its permissions bits set to 0600. (Please note, that the use of per-user configuration files may be disabled, by specifying ‘allow-biffrc no’ in the main configuration file, see see Configuring comsatd).
The .biffrc file consists of a series of statements. Each statement occupies one line and defines an action to be taken upon arrival of a new mail. Very long lines may be split using ‘\’ as the last character on the line. As usual, comments may be introduced with ‘#’ character.
The actions specified in .biffrc file are executed in turn. The following actions are defined:
In the description above, string denotes any sequence of characters. This sequence must be enclosed in a pair of double-quotes, if it contains whitespace characters. The ‘\’ character inside a string starts a C escape sequence. Following meta-characters may be used in strings:
Dump to the user's terminal the contents of ‘From’ and ‘Subject’ headers followed by at most 5 lines of message body.
echo "Mail to \a$u@$h\a\n---\n\ From: $H{from}\n\ Subject: $H{Subject}\n\ ---\n\ $B(,5)\ ---\n"
Produce a bell, then pop up the xmessage window on display :0.0 with the text formatted in the same manner as in the previous example.
beep exec /usr/X11R6/bin/xmessage \ -display :0.0 -timeout 10 "Mail to $u@$h \n---\n\ From: $H{from}\n\ Subject: $H{Subject}\n\ ---\n\ $B(,5)\ ---\n"
The primary aim of this implementation is to provide an interface between Mailutils and Emacs using mh-e module.
To use Mailutils MH with Emacs, add the following line to your site-start.el or .emacs file:
(load "mailutils-mh")
For the information about the current state of Mailutils MH implementation please refer to file mh/TODO in the Mailutils distribution directory.
[FIXME]
Decodes the input string str as per RFC 2047. Useful in printing ‘From:’, ‘To:’ and ‘Subject:’ headers.
Notice that, unlike the similar NMH function,
decode
checks the value of the global profile variableCharset
(see Charset variable) to determine the charset to output the result in. If this variable is not set,decode
returns its argument without any change. If this variable is set toauto
,decode
tries to determine the charset name from the setting of LC_ALL environment variable. Otherwise, the value ofCharset
is taken to be the name of the character set.
The function removes any leading whitespace and eventual ‘Re:’ prefix from its argument. Useful for creating subjects in reply messages:
%<{subject}Subject: Re: %(unre{subject})\\n%>
Sets the regular expression used to recognize reply messages. The argument r should be a POSIX extended regular expression. Matching is case insensitive.
For example, the following invocation
%(reply_regex ^\(re|aw|ang|odp\)\(\\[[0-9]+\\]\)?:[[:blank:]])corresponds to English ‘Re’, Polish ‘Odp’, Norwegian ‘Aw’ or German ‘Ang’, optionally followed by a number in brackets, followed by colon and any amount of whitespace. Notice proper quoting of the regex metacharacters.
See also
Reply-Regex
(see Reply-Regex variable) andisreply
(see isreply MH function) below.
If str is not given, the value of ‘Subject:’ header is taken.
The function returns true if its argument matches the “reply subject” regular expression. This expression is set via the global profile variable
Reply-Regex
(see Reply-Regex variable) or via the format functionreply_regex
.This function is useful for creating ‘Subject:’ headers in reply messages. For example, consider the following construction:
%<{subject}%(lit)%<(isreply)%?\ (profile reply-prefix)%(concat)%|%(concat Re:)%>\ %(concat{subject})%(printhdr Subject: )\n%>If the ‘Subject:’ header already contained reply prefix, this construct leaves it unchanged. Otherwise it prepends to it the value of
Reply-Prefix
profile variable, or, if it is unset, the string ‘Re:’.This expression is used in default replcomps and replgroupcomps files.
This function returns true if the given element is present in the recipient mask (as modified by --cc or --nocc options) and false otherwise. It is used in default formats for repl and comp, e.g.:
%(lit)%<(rcpt to)%(formataddr{to})%>Notice that this means that usual replcomps file will be ignoring --cc and --nocc options, unless it has been modified as shown above.
Prints the value of string register, prefixed by str. The output is formatted as a RFC 822 header, i.e. it is split at whitespace characters nearest to the width boundary and each subsequent segment is prefixed with horizontal tabulation.
Generates the value for ‘In-reply-to:’ header according to RFC 2822.
Generates the value for ‘References:’ header according to RFC 2822.
Controls the character set in which the components decoded via the
decode
(see decode function) format function should be output.
Keeps the regular expression used to recognize reply messages. The argument should be a POSIX extended regular expression. Matching is case insensitive.
For more information, please see See reply_regex function.
The --recurse option instructs the utility to recursively expand the digest.
The --length option can be used to set the minimal encapsulation
boundary length for RFC 934 digests. Default length is 1,
i.e. encountering one dash immediately following a newline triggers
digest decoding. It is OK for messages that follow RFC 934
specification. However, many user agents do not precisely follow it,
in particular, they often do not escape lines starting with a dash by
‘- ’ sequence. Mailman is one of such agents. To cope
with such digests you can set encapsulation boundary length to a higher
value. For example, bounce --length=8 has been found to be
sufficient for most Mailman-generated digests.
ignores
contains more than one component name
it must be enclosed in double-quotes. Dangling equal sign is an error,
to set a string variable to the empty value assign it an empty string, e.g.:
overflowtext=""
(see the supplied mhl.format file).
Ineractive prompting is not yet implemented.
moreproc
variable. Standard mhn in this case used to print ‘don't
know how to display content’ diagnostic.
The default behaviour is to pipe the content to the standard input
of the mhn-show-type[/subtype] command. This is altered to using a
temporary file if the command contains %f
or %F
escapes.
Content-Disposition
header contains ‘filename=’,
and mhn is invoked with --auto switch, it
transforms the file name into the absolute notation and uses it only
if it lies below the current mhn-storage directory. Standard
mhn only requires that the file name do not begin with ‘/’.
Before saving a message part, GNU mhn checks if the file already exists. If so, it asks whether the user wishes to rewrite it. This behaviour is disabled when --quiet option was given.
use
command.
Mailutils rmm does not delete any messages. Standard rmm in this case deletes all messages preceeding the non-existent one.
rmmproc
profile component is not used.
pick --component field --pattern string
New command line option --cflags allows to control the type of regular expressions used. The option must occur right before --pattern or --component option (or one of its aliases, like --cc, --from, etc.)
The argument to this option is a string of type specifications:
B | Use basic regular expressions
|
E | Use extended regular expressions
|
I | Ignore case
|
C | Case sensitive
|
Default is ‘EI’.
The flags remain in effect until the next occurrence of --cflags option.
Sample usage:
pick --cflag BC --subject '*a string'
The date comparison options (--before and --after accept date specifications in a wide variety of formats, e.g.:
pick --after 20030301 pick --after 2003-03-01 pick --after 01-mar-2003 pick --after 2003-mar-01 pick --before '1 year ago' etc...
Any number of --datefield, --textfield and --numfield options may be given, thus allowing to build sort criteria of arbitrary complexity.
The order of --.*field options sets the ordering priority. This differs from the behaviour of the standard sortm, which always orders datefield-major, textfield-minor.
Apart from sorting the mailfolder the following actions may be specified:
This program is designed for developers wishing to link their programs against libmailbox. It allows to examine the particulars of the current build of Mailutils and to get the command line parameters necessary for compiling and linking an application with Mailutils libraries.
When invoked with the option --compile, or its short form -c, mailutils-config prints the flags that must be given to the compiler for compiling the program using Mailutils functions. An example usage:
cc -omyprog.o `mailutils-config --compile` myprog.c
The --link, or its short form -l prints to the standard output the loader flags necessary to link a program against Mailutils libraries.
When invoked without arguments, it produces the flags necessary to link against the basic library of Mailutils: libmailbox. Arguments may be given that alter this behavior. These are:
mbox
format library.
mh
format library.
maildir
format library.
imap
format library.
pop
format library.
The order of arguments does not matter.
For example, if you wrote a program myprog.c that uses standard unix mailbox format, mh format and the Guile interface, then you would link it with the following command:
cc -omyprog myprog.o `mailutils-config --link mbox mh guile`
The --info, or -i retrieves the options (flags) used when building Mailutils. It may be used with or without arguments.
When used without arguments, it prints the list of all build flags, e.g.:
$ mailutils-config --info VERSION=0.4.1 USE_LIBPAM HAVE_LIBLTDL WITH_GDBM WITH_GNUTLS WITH_GSASL WITH_GUILE WITH_PTHREAD WITH_READLINE HAVE_MYSQL ENABLE_VIRTUAL_DOMAINS ENABLE_IMAP ENABLE_POP ENABLE_MH ENABLE_MAILDIR ENABLE_SMTP ENABLE_SENDMAIL
This option also accepts any number of arguments. When these are given, each argument is treated as a name of a build flag. Mailutils-config checks if such a flag was defined and prints its full name if so. It exits with zero code if all the flags given on the command line are defined. Otherwise, it exits with code of 1.
The comparison of the flag names is case-insensitive. The arguments given need not include the leading prefix (i.e. the characters up to and including the first underscore character).
Given the previous example, the invocation
$ mailutils --info readline use_libpam pop
will produce the following output:
WITH_READLINE USE_LIBPAM ENABLE_POP
and will exit with a zero status.
The following command:
$ mailutils --info readline gssapi pop
will exit with status 1, and will print:
WITH_READLINE ENABLE_POP
since WITH_GSSAPI
flag is not defined.
The flags and their meanings are:
Wherever the mail is and whatever format it is stored in, it is operated upon using the same set of functions. To unified the C API, gnu Mailutils offers a heteroclite set of objects that work in aggregation to do operations on emails. Each object does a specific task and delegates non-related tasks to others. The object comes alive by specifying a URL parameter when created, it will indicate the storage format or protocol (POP3, IMAP4, MH, MAILDIR, etc ..).
mu_folder_t mu_url_t -/var/mail- +- .. ->+-------------------+ +-->+------------+ ( alain *-)-+ | | mu_url_t *-|---+ | port | ---------- | | |-------------------| | hostname | ( jakob *-)-+--+ | mu_auth_t *-|---+ | file | ---------- | |-------------------| | | ... | ( jeff *-)-+ | mu_stream_t | | +------------+ ---------- | |-------------------| | ( shaleh*-)-+ | ..... | | mu_auth_t ---------- |-------------------| +-->+-------------+ +---|-* mu_mailbox_t[] | | mu_ticket_t | mu_mailbox_t | +-------------------+ +-------------+ +-------------------+ | mu_locker_t *--|-------------+ |-------------------| | | mu_url_t | | mu_locker_t |-------------------| +-------->+---------+ | mu_stream_t | | lock | |-------------------| | unlock | | mu_message_t[] *-|-------+ +---------+ +-------------------+ | mu_envelope_t | +-------->+-----------+ mu_message_t | | | date | +-------------------+<------+ | | from | | mu_envelope_t *-|------------------+ | to | |-------------------| mu_header_t +-----------+ | mu_header_t *-|------------>+-----------------+ |-------------------| | mu_stream_t | | mu_body_t *-|----+ +-----------------+ +-------------------+ | mu_body_t +-->+-----------------+ | mu_stream_t | +-----------------+
As an example, here is a simplified version of from
command. It
lists the ‘From’ and ‘Subject’ headers of every mail in a mailbox.
#include <stdio.h> #include <stdlib.h> #include <string.h> #include <unistd.h> #include <mailutils/mailutils.h> int main (int argc, const char **argv) { char *from; char *subject; mu_mailbox_t mbox; size_t msgno, total = 0; int status; /* Register the formats. */ mu_register_all_mbox_formats (); status = mu_mailbox_create_default (&mbox, argv[1]); if (status != 0) { mu_error ("mu_mailbox_create: %s", mu_strerror (status)); exit (EXIT_FAILURE); } status = mu_mailbox_open (mbox, MU_STREAM_READ); if (status != 0) { mu_error ("mu_mailbox_open: %s", mu_strerror (status)); exit (EXIT_FAILURE); } mu_mailbox_messages_count (mbox, &total); for (msgno = 1; msgno <= total; msgno++) { mu_message_t msg; mu_header_t hdr; if ((status = mu_mailbox_get_message (mbox, msgno, &msg)) != 0 || (status = mu_message_get_header (msg, &hdr)) != 0) { mu_error ("Error message: %s", mu_strerror (status)); exit (EXIT_FAILURE); } if (mu_header_aget_value (hdr, MU_HEADER_FROM, &from)) from = strdup ("(NO FROM)"); if (mu_header_aget_value (hdr, MU_HEADER_SUBJECT, &subject)) subject = strdup ("(NO SUBJECT)"); printf ("%s\t%s\n", from, subject); free (from); free (subject); } status = mu_mailbox_close (mbox); if (status != 0) { mu_error ("mu_mailbox_close: %s", mu_strerror (status)); exit (EXIT_FAILURE); } mu_mailbox_destroy (&mbox); return 0; }
Here is a sample output produced by this program:
% ./sfrom pop://alain@localhost Passwd: xxxx Jim Meyering <meyering@foo.org> fetish(shellutils) beta François Pinard <pinard@bar.org> recode new alpha ... |
/* Prefix
mu_folder_is reserved. */
#include <mailutils/folder.h>
mu_folder_t mu_url_t -/var/mail- +---//--->/-------------------\ +-->/-----------\ ( alain *-)-+ | | mu_url_t *-|---+ | port | ---------- | | |-------------------+ | hostname | ( jakob *-)-+--+ | mu_observer_t *-| | file | ---------- | |-------------------+ | ... | ( jeff *-)-+ | mu_stream_t | \-----------/ ---------- | |-------------------| ( sean *-)-+ | mu_auth_t | ---------- |-------------------| | mu_mailbox_t(1) | |-------------------| | mu_mailbox_t(2) | | ...... | | mu_mailbox_t(n) | \-----------------/
Data structures:
struct mu_list_response { int type; int separator; char *name; };
/* Prefix
mu_mailbox_is reserved. */
#include <mailutils/mailbox.h>
The
mu_mailbox_t
object is used to hold information and it is an opaque data structure to the user. Functions are provided to retrieve information from the data structure.
mu_mailbox_t mu_url_t -/var/mail- +---//--->/------------------\ +-->/-----------\ ( alain ) | | mu_url_t *-|---+ | port | ---------- | |------------------+ | hostname | ( jakob *-)----+ | mu_observer_t *-| | file | ---------- |------------------+ | ... | ( jeff ) | mu_stream_t | \-----------/ ---------- |------------------| ( sean ) | mu_locker_t | ---------- |------------------| | mu_message_t(1) | |------------------| | mu_message_t(2) | | ...... | | mu_message_t(n) | \------------------/
The function
mu_mailbox_create
allocates and initializes mbox. The concrete mailbox type instantiate is based on the scheme of the url name.The return value is
0
on success and a code number on error conditions:
MU_ERR_OUT_PTR_NULL
- The pointer mbox supplied is
NULL
.MU_ERR_NO_HANDLER
- The url name supplied is invalid or not supported.
EINVAL
ENOMEM
- Not enough memory to allocate resources.
Create a mailbox with
mu_mailbox_create()
based on the environment variable MAIL or the string formed by _PATH_MAILDIR/user" or LOGNAME if user is null,
Destroys and releases resources held by mbox.
A connection is open, if no stream was provided, a stream is created based on the mbox type. The flag can be OR'ed. See
stream_create()
for flag's description.The return value is
0
on success and a code number on error conditions:
EAGAIN
EINPROGRESS
- Operation in progress.
EBUSY
- Resource busy.
MU_ERROR_INVALID_PARAMETER
- mbox is
NULL
or flag is invalid.ENOMEM
- Not enough memory.
The stream attach to mbox is closed.
The return value is
0
on success and a code number on error conditions:
MU_ERROR_INVALID_PARAMETER
- mbox is
NULL
.
Get the folder.
The return value is
0
on success and a code number on error conditions:
MU_ERROR_INVALID_PARAMETER
- mbox is
NULL
.
Give the uid validity of mbox.
The return value is
0
on success and a code number on error conditions:
MU_ERROR_INVALID_PARAMETER
- mbox is
NULL
.
Give the next predicted uid for mbox.
The return value is
0
on success and a code number on error conditions:
MU_ERROR_INVALID_PARAMETER
- mbox is
NULL
.
Retrieve message number msgno, message is allocated and initialized.
The return value is
0
on success and a code number on error conditions:
MU_ERROR_INVALID_PARAMETER
- mbox is
NULL
or msgno is invalid.ENOMEM
- Not enough memory.
The message is appended to the mailbox mbox.
The return value is
0
on success and a code number on error conditions:
MU_ERROR_INVALID_PARAMETER
- mbox is
NULL
or message is invalid.
Give the number of messages in mbox.
The return value is
0
on success and a code number on error conditions:
MU_ERROR_INVALID_PARAMETER
- mbox is
NULL
.
Give the number of recent messages in mbox.
The return value is
0
on success and a code number on error conditions:
MU_ERROR_INVALID_PARAMETER
- mbox is
NULL
.
Give the number of first unseen message in mbox.
The return value is
0
on success and a code number on error conditions:
MU_ERROR_INVALID_PARAMETER
- mbox is
NULL
.
All messages marked for deletion are removed.
The return value is
0
on success and a code number on error conditions:
MU_ERROR_INVALID_PARAMETER
- mbox is
NULL
.
Gives the mbox size.
The return value is
0
on success and a code number on error conditions:
MU_ERROR_INVALID_PARAMETER
- mbox is
NULL
.
Scan the mailbox for new messages starting at message msgno.
The return value is
0
on success and a code number on error conditions:
MU_ERROR_INVALID_PARAMETER
- mbox is
NULL
.ENOMEM
- Not enough memory.
The mailbox stream is put in stream.
The return value is
0
on success and a code number on error conditions:
MU_ERROR_INVALID_PARAMETER
- mbox is invalid or stream is
NULL
.
Set the stream connection to use for the mailbox.
The return value is
0
on success and a code number on error conditions:
MU_ERROR_INVALID_PARAMETER
- mbox or stream is
NULL
.
Get the mu_locker_t object.
The return value is
0
on success and a code number on error conditions:
MU_ERROR_INVALID_PARAMETER
- mbox is
NULL
.
Set the type of locking done by the mbox.
The return value is
0
on success and a code number on error conditions:
MU_ERROR_INVALID_PARAMETER
- mbox is
NULL
.
Get the property object. The return value is
0
on success and a code number on error conditions:
MU_ERROR_INVALID_PARAMETER
- mbox is
NULL
.ENOMEM
Gives the constructed url.
The return value is
0
on success and a code number on error conditions:
MU_ERROR_INVALID_PARAMETER
- mbox is
NULL
.
Get a debug object. The return value is
0
on success and a code number on error conditions:
MU_ERROR_INVALID_PARAMETER
- mbox is
NULL
.ENOMEM
Get the observable object.
The return value is
0
on success and a code number on error conditions:
MU_ERROR_INVALID_PARAMETER
- mbox is
NULL
.ENOMEM
- Not enough memory.
/* Prefix
mu_mailer_is reserved. */
#include <mailutils/mailer.h>
If from is not
NULL
, it must contain a single fully qualified RFC2822 email address which will be used as the envelope from address. This is the address to which delivery status notifications are sent, so it never matters what it is set to until it really matters. This is equivalent to Sendmail's -f flag.The default for from is provided by the specific mailer.
If to is not
NULL
, then the message will be sent to the list of addresses that it specifies.The default for to is to use the contents of the standard "To:", "Cc:", and "Bcc:" fields, this is equivalent to Sendmail's -t flag.
Some possible use cases the API must support are:
mu_mailer_send_message(mailer, msg, NULL, NULL)
To:
or Apparently-To:
header will be added if non is present (for RFC compliance)
mu_mailer_send_message(mailer, msg, from, to)
Resent-[To,From,...]
mu_mailer_send_message(mailer, msg, NULL, to)
mu_mailer_deliver(mailer, msg, address_t("<>"), to)
Don't want mail loops, so the null but valid SMTP address of ‘<>’ is the envelope From.
/sbin/sendmail isn't always Sendmail... Sometimes it's a Sendmail-compatible wrapper, so assume /sbin/sendmail understands only a recipient list, -f and -oi, these seem to be pretty basic. Cross fingers.
Pipe to "/sbin/sendmail -oi [-f from] [to...]", supplying -f if there was a from, and supplying the recipient list from the to (if there is no recipient list, assume it will read the message contents for the recipients).
Caution: since the stdout
and stderr
of Sendmail
is closed, we have no way of ever giving feedback on failure. Also, what
should the return code be from mu_mailer_send_message()
when Sendmail
returns ‘1’? ‘1’ maps to EPERM
, which is less than
descriptive!
This mailer does not canonicalize the message. This must be done before sending the message, or it may be assumed that the MTA will do so.
It does blind out the Bcc: header before sending, though.
Caution: Mutt always puts the recipient addresses on the command line, even Bcc: ones, do we strip the Bcc: before forwarding with SMTP?
An address that has no domain is not and RFC822 email address. What do I do with them? Should the user of the API be responsible for determining what is mean by email to "John" means? Or should the be able to configure Sendmail to decide globally what this means. If so, we can pass the address to Sendmail, but we have to decide for SMTP! So, right now these addresses are rejected. This could be changed.
/* Prefix
mu_message_is reserved. */
#include <mailutils/message.h>
The mu_message_t
object is a convenient way to manipulate messages. It
encapsulates the envelope_t
, the header_t
and the body_t
.
mailbox_t ---------- mu_message_t (message[1]) +------>+--------------------+ ---------- | | mu_envelope_t | (message[2]) | |--------------------| ---------- | | mu_header_t | (message[3])--------+ |--------------------| ---------- | mu_body_t | (message[n]) |--------------------| ---------- | mu_attribute_t | |--------------------| | mu_stream_t | +--------------------+
The resources allocate for msg are freed.
Set *multi to non-zero value if msg is multi-part.
/* Prefix
mu_envelope_is reserved. */
#include <mailutils/envelope.h>
Get the address that this message was reportedly received from. This would be the "mail from" argument if the message was delivered or received via SMTP, for example.
Primarily for internal use. The implementation of
mu_envelope_t
depends on the mailbox type, this allows the function which actually gets the sender to be set by the creator of anmu_envelope_t
.
Get the date that the message was delivered to the mailbox, in something close to ANSI
ctime()
format: Mon Jul 05 13:08:27 1999.
Primarily for internal use. The implementation of
mu_envelope_t
depends on the mailbox type, this allows the function which actually gets the date to be set by the creator of anmu_envelope_t
.
/* Prefix
mu_header_is reserved. */
#include <mailutils/header.h>
So far we plan support for RFC822 and plan for RFC1522. With RFC1522 non-ASCII characters will be encoded.
Initialize a hdr to a supported type. If blurb is not
NULL
, it is parsed.
The resources allocated for hdr are freed.
Some basic macros are already provided for RFC822.
MU_HEADER_UNIX_FROM
- From
MU_HEADER_RETURN_PATH
- Return-Path
MU_HEADER_RECEIVED
- Received
MU_HEADER_DATE
- Date
MU_HEADER_FROM
- From
MU_HEADER_SENDER
- Sender
MU_HEADER_RESENT_FROM
- Resent-From
MU_HEADER_SUBJECT
- Subject
MU_HEADER_SENDER
- Sender
MU_HEADER_RESENT_SENDER
- Resent-SENDER
MU_HEADER_TO
- To
MU_HEADER_RESENT_TO
- Resent-To
MU_HEADER_CC
- Cc
MU_HEADER_RESENT_CC
- Resent-Cc
MU_HEADER_BCC
- Bcc
MU_HEADER_RESENT_BCC
- Resent-Bcc
MU_HEADER_REPLY_TO
- Reply-To
MU_HEADER_RESENT_REPLY_TO
- Resent-Reply-To
MU_HEADER_MESSAGE_ID
- Message-ID
MU_HEADER_RESENT_MESSAGE_ID
- Resent-Message-ID
MU_HEADER_IN_REPLY_TO
- In-Reply-To
MU_HEADER_REFERENCE
- Reference
MU_HEADER_REFERENCES
- References
MU_HEADER_ENCRYPTED
- Encrypted
MU_HEADER_PRECEDENCE
- Precedence
MU_HEADER_STATUS
- Status
MU_HEADER_CONTENT_LENGTH
- Content-Length
MU_HEADER_CONTENT_LANGUAGE
- Content-Language
MU_HEADER_CONTENT_TRANSFER_ENCODING
- Content-transfer-encoding
MU_HEADER_CONTENT_ID
- Content-ID
MU_HEADER_CONTENT_TYPE
- Content-Type
MU_HEADER_CONTENT_DESCRIPTION
- Content-Description
MU_HEADER_CONTENT_DISPOSITION
- Content-Disposition
MU_HEADER_CONTENT_MD5
- Content-MD5
MU_HEADER_MIME_VERSION
- MIME-Version
MU_HEADER_X_UIDL
- X-UIDL
MU_HEADER_X_UID
- X-UID
MU_HEADER_X_IMAPBASE
- X-IMAPbase
MU_HEADER_ENV_SENDER
- X-Envelope-Sender
MU_HEADER_ENV_DATE
- X-Envelope-Date
MU_HEADER_FCC
- Fcc
MU_HEADER_DELIVERY_DATE
- Delivery-date
MU_HEADER_ENVELOPE_TO
- Envelope-to
Value of field-name fn is returned in buffer fv of size len. The number of bytes written is put in n.
The value is allocated.
/* Prefix
mu_body_is reserved. */
#include <mailutils/body.h>
/* Prefix
mu_attribute_is reserved. */
#include <mailutils/attribute.h>
#include <mailutils/stream.h>
These generic flags are interpreted as appropriate to the specific streams.
MU_STREAM_READ
MU_STREAM_WRITE
MU_STREAM_RDWR
MU_STREAM_APPEND
MU_STREAM_CREAT
MU_STREAM_NONBLOCK
MU_STREAM_NO_CHECK
MU_STREAM_SEEKABLE
MU_STREAM_NO_CLOSE
MU_STREAM_ALLOW_LINKS
If
MU_STREAM_NO_CLOSE
is specified,fclose()
will not be called on stdio when the stream is closed.
Used to implement a new kind of stream.
MU_STREAM_STATE_OPEN
- Last action was
mu_stream_open
.MU_STREAM_STATE_READ
- Last action was
mu_stream_read
ormu_stream_readline
.MU_STREAM_STATE_WRITE
- Last action was
mu_stream_write
.MU_STREAM_STATE_CLOSE
- Last action was
mu_stream_close
.
An example using mu_tcp_stream_create()
to make a simple web client:
/* This is an example program to illustrate the use of stream functions. It connects to a remote HTTP server and prints the contents of its index page */ #include <stdio.h> #include <stdlib.h> #include <string.h> #include <errno.h> #include <unistd.h> #include <sys/time.h> #include <mailutils/mailutils.h> char wbuf[1024]; char rbuf[1024]; size_t io_timeout = 3; size_t io_attempts = 3; int http_stream_wait (mu_stream_t stream, int flags, size_t *attempt) { int rc; int oflags = flags; struct timeval tv; while (*attempt < io_attempts) { tv.tv_sec = io_timeout; tv.tv_usec = 0; rc = mu_stream_wait (stream, &oflags, &tv); switch (rc) { case 0: if (flags & oflags) return 0; /* FALLTHROUGH */ case EAGAIN: case EINPROGRESS: ++*attempt; continue; default: return rc; } } return ETIMEDOUT; } int main (int argc, char **argv) { int ret, off = 0; mu_stream_t stream; size_t nb, size; size_t attempt; char *url = "www.gnu.org"; if (argc > 3) { fprintf (stderr, "usage: %s [hostname [url]]\n", argv[0]); exit (1); } if (argc > 1) url = argv[1]; snprintf (wbuf, sizeof wbuf, "GET %s HTTP/1.0\r\n\r\n", argc == 3 ? argv[2] : "/"); ret = mu_tcp_stream_create (&stream, url, 80, MU_STREAM_NONBLOCK); if (ret != 0) { mu_error ("mu_tcp_stream_create: %s", mu_strerror (ret)); exit (EXIT_FAILURE); } for (attempt = 0; (ret = mu_stream_open (stream)); ) { if ((ret == EAGAIN || ret == EINPROGRESS) && attempt < io_attempts) { ret = http_stream_wait(stream, MU_STREAM_READY_WR, &attempt); if (ret == 0) continue; } mu_error ("mu_stream_open: %s", mu_strerror (ret)); exit (EXIT_FAILURE); } for (attempt = 0, size = strlen (wbuf); size > 0; ) { ret = mu_stream_write (stream, wbuf + off, strlen (wbuf), 0, &nb); if (ret == 0) { if (nb == 0) { mu_error("mu_stream_write: wrote 0 bytes"); exit (EXIT_FAILURE); } off += nb; size -= nb; } else if (ret == EAGAIN) { if (attempt < io_attempts) { ret = http_stream_wait (stream, MU_STREAM_READY_WR, &attempt); if (ret) { mu_error ("http_wait failed: %s", mu_strerror (ret)); return -1; } continue; } else { mu_error ("mu_stream_write timed out"); exit (EXIT_FAILURE); } } else { mu_error ("mu_stream_write: %s", mu_strerror (ret)); exit (EXIT_FAILURE); } } attempt = 0; for (;;) { ret = mu_stream_read (stream, rbuf, sizeof (rbuf), 0, &nb); if (ret == 0) { if (nb == 0) break; write (1, rbuf, nb); } else if (ret == EAGAIN) { if (attempt < io_attempts) { ret = http_stream_wait (stream, MU_STREAM_READY_RD, &attempt); if (ret) { mu_error ("http_stream_wait failed: %s", mu_strerror (ret)); exit (EXIT_FAILURE); } } else { mu_error ("mu_stream_read: %s", mu_strerror (ret)); exit (EXIT_FAILURE); } } } ret = mu_stream_close (stream); if (ret != 0) { mu_error ("mu_stream_close: %s", mu_strerror (ret)); exit (EXIT_FAILURE); } mu_stream_destroy (&stream, NULL); exit (EXIT_SUCCESS); }
/* Prefix
mu_iterator_is reserved. */
#include <mailutils/iterator.h>
/* Prefixes
mu_authority_,
mu_ticket_, and
mu_wicket_are reserved. */
#include <mailutils/auth.h>
There are many ways to authenticate to a server. To be flexible the
authentication process is provided by three objects mu_authority_t
,
mu_ticket_t
, and mu_wicket_t
. The mu_authority_t
can implement
different protocol like APOP, MD5-AUTH, One Time Passwd, etc. By default
if a mailbox does not understand or know how to authenticate it falls back
to user/passwd authentication. The mu_ticket_t
is a way for
Mailboxes and Mailers provide a way to authenticate when the URL does not
contain enough information. The default action is to call the function
mu_authority_authenticate()
which will get the user and passwd
if not set, this function can be overridden by a custom method.
A simple example of an authenticate function:
#include <stdio.h> #include <string.h> #include <mailutils/auth.h> int my_authenticate (auth_t auth, char **user, char **passwd) { char u[128] = ""; char p[128] = ""; /* prompt the user name */ printf ("User: "); fflush (stdout); fgets (u, sizeof (u), stdin); u[strlen (u) - 1] = '\0'; /* nuke the trailing NL */ /* prompt the passwd */ printf ("Passwd: "); fflush (stdout); echo_off (); fgets (p, sizeof(p), stdin); echo_on (); p[strlen (p) - 1] = '\0'; /* duplicate */ *user = strdup (u); *passwd = strdup (p); return 0; }
/* Prefix
address_is reserved. */
#include <mailutils/address.h>
The Internet address format is defined in RFC 822. RFC 822 has been updated, and is now superceeded by RFC 2822, which makes some corrections and clarifications. References to RFC 822 here apply equally to RFC 2822.
The RFC 822 format is more flexible than many people realize, here is a quick summary of the syntax this parser implements, see RFC 822 for the details. ‘[]’ pairs mean "optional", ‘/’ means "one or the other", and double-quoted characters are literals.
addr-spec = local-part "@" domain mailbox = addr-spec ["(" display-name ")"] / [display-name] "<" [route] addr-spec ">" mailbox-list = mailbox ["," mailbox-list] group = display-name ":" [mailbox-list] ";" address = mailbox / group / unix-mbox address-list = address ["," address-list]
Unix-mbox is a non-standard extension meant to deal with the common practice of using user names as addresses in mail utilities. It allows addresses such as "root" to be parsed correctly. These are not valid internet email addresses, they must be qualified before use.
Several address functions have a set of common arguments with consistent semantics, these are described here to avoid repetition.
Since an address-list may contain multiple addresses, they are accessed by a one-based index number, no. The index is one-based because pop, imap, and other message stores commonly use one-based counts to access messages and attributes of messages.
If len is greater than 0
it is the length of the buffer
buf, and as much of the component as possible will be copied
into the buffer. The buffer will be NULL
terminated.
The size of a particular component may be queried by providing 0
for the len of the buffer, in which case the buffer is optional.
In this case, if n is provided *n is assigned the length of
the component string.
The
mu_address_t
object is used to hold information about a parsed RFC822 address list, and is an opaque data structure to the user. Functions are provided to retrieve information about an address in the address list.
This function allocates and initializes addr by parsing the RFC822 address-list string.
The return value is
0
on success and a code number on error conditions:
EINVAL
- Invalid usage, usually a required argument was
NULL
.ENOMEM
- Not enough memory to allocate resources.
ENOENT
- Invalid RFC822 syntax, parsing failed.
This function allocates and initializes addr by parsing the array of pointers to RFC822 address-lists in sv. If len is
-1
, then sv must beNULL
terminated in the fashion of argv, otherwise len is the length of the array.The return value is
0
on success and a code number on error conditions:
EINVAL
- Invalid usage, usually a required argument was
NULL
.ENOMEM
- Not enough memory to allocate resources.
ENOENT
- Invalid RFC822 syntax, parsing failed.
Accesses the noth email address component of the address list. This address is the plain email address, correctly quoted, suitable for using in an smtp dialog, for example, or as the address part of a contact book entry.
Note that the entry may be valid, but be a group name. In this case success is returned, but the length of the address is
0
.The return value is
0
on success and a code number on error conditions:
EINVAL
- Invalid usage, usually a required argument was
NULL
.ENOENT
- The index no is outside of the range of available addresses.
Accesses the local-part of an email addr-spec extracted while parsing the noth email address.
The return value is
0
on success and a code number on error conditions:
EINVAL
- Invalid usage, usually a required argument was
NULL
.ENOENT
- The index no is outside of the range of available addresses.
Accesses the domain of an email addr-spec extracted while parsing the noth email address. This will be
0
length for a unix-mbox.The return value is
0
on success and a code number on error conditions:
EINVAL
- Invalid usage, usually a required argument was
NULL
.ENOENT
- The index no is outside of the range of available addresses.
Accesses the display-name describing the noth email address. This display-name is optional, so may not be present. If it is not present, but there is an RFC822 comment after the address, that comment will be returned as the personal phrase, as this is a common usage of the comment even though it is not defined in the internet mail standard.
A group is a kind of a special case. It has a display-name, followed by an optional mailbox-list. The display-name will be allocated an address all it's own, but all the other elements (local-part, domain, etc.) will be zero-length. So "a group: ;" is valid, will have a count of 1, but
mu_address_get_email()
, and all the rest, will return zero-length output.The return value is
0
on success and a code number on error conditions:
EINVAL
- Invalid usage, usually a required argument was
NULL
.ENOENT
- The index no is outside of the range of available addresses.
Accesses the comments extracted while parsing the noth email address. These comments have no defined meaning, and are not currently collected.
The return value is
0
on success and a code number on error conditions:
EINVAL
- Invalid usage, usually a required argument was
NULL
.ENOENT
- The index no is outside of the range of available addresses.
Accesses the route of an email addr-spec extracted while parsing the noth email address. This is a rarely used RFC822 address syntax, but is legal in SMTP as well. The entire route is returned as a string, those wishing to parse it should look at mailutils/parse822.h.
The return value is
0
on success and a code number on error conditions:
EINVAL
- Invalid usage, usually a required argument was
NULL
.ENOENT
- The index no is outside of the range of available addresses.
As above, but mallocs the email address, if present, and write a pointer to it into bufp. bufp will be
NULL
if there is no email address to return.The return value is
0
on success and a code number on error conditions:
EINVAL
- Invalid usage, usually a required argument was
NULL
.ENOENT
- The index no is outside of the range of available addresses.
Sets *yes to
1
if this address is just the name of a group,0
otherwise. This is faster than checking if the address has a non-zero length personal, and a zero-length local_part and domain.yes can be
NULL
, though that doesn't serve much purpose other than determining that no refers to an address.Currently, there is no way to determine the end of the group.
The return value is
0
on success and a code number on error conditions:
EINVAL
- Invalid usage, usually a required argument was
NULL
.ENOENT
- The index no is outside of the range of available addresses.
Returns the entire address list as a single RFC822 formatted address list.
The return value is
0
on success and a code number on error conditions:
EINVAL
- Invalid usage, usually a required argument was
NULL
.ENOMEM
- Not enough memory to allocate resources.
Returns a count of the addresses in the address list.
If addr is
NULL
, the count is0
. If count is notNULL
, the count will be written to *count.The return value is
0
.
#include <stdio.h> #include <string.h> #include <errno.h> #include <mailutils/address.h> #include <mailutils/errno.h> #include <mailutils/mutil.h> #define EPARSE MU_ERR_NOENT static int parse (const char *str) { size_t no = 0; size_t pcount = 0; int status; char buf[BUFSIZ]; mu_address_t address = NULL; mu_set_user_email_domain ("localhost"); status = mu_address_create (&address, str); mu_address_get_count (address, &pcount); if (status) { printf ("%s=> error %s\n\n", str, mu_errname (status)); return 0; } else { printf ("%s=> pcount %lu\n", str, (unsigned long) pcount); } for (no = 1; no <= pcount; no++) { size_t got = 0; int isgroup; mu_address_is_group (address, no, &isgroup); printf ("%lu ", (unsigned long) no); if (isgroup) { mu_address_get_personal (address, no, buf, sizeof (buf), &got); printf ("group <%s>\n", buf); } else { mu_address_get_email (address, no, buf, sizeof (buf), 0); printf ("email <%s>\n", buf); } mu_address_get_personal (address, no, buf, sizeof (buf), &got); if (got && !isgroup) printf (" personal <%s>\n", buf); mu_address_get_comments (address, no, buf, sizeof (buf), &got); if (got) printf (" comments <%s>\n", buf); mu_address_get_local_part (address, no, buf, sizeof (buf), &got); if (got) { printf (" local-part <%s>", buf); mu_address_get_domain (address, no, buf, sizeof (buf), &got); if (got) printf (" domain <%s>", buf); printf ("\n"); } mu_address_get_route (address, no, buf, sizeof (buf), &got); if (got) printf (" route <%s>\n", buf); } mu_address_destroy (&address); printf ("\n"); return 0; } static int parseinput (void) { char buf[BUFSIZ]; while (fgets (buf, sizeof (buf), stdin) != 0) { buf[strlen (buf) - 1] = 0; parse (buf); } return 0; } int main (int argc, const char *argv[]) { argc = 1; if (!argv[argc]) return parseinput (); for (; argv[argc]; argc++) { if (strcmp (argv[argc], "-") == 0) parseinput (); else parse (argv[argc]); } return 0; }
/* Prefix
mu_locker_is reserved. */
#include <mailutils/locker.h>
A flags of 0 means that the default will be used.
Time is measured in seconds.
A mailbox or a mailer can be described in a URL, the string will contain the
necessary information to initialize mailbox_t
, or mailer_t
properly.
The POP URL scheme contains a POP server, optional port number and the authentication mechanism. The general form is
<pop://[
user[;AUTH=
auth]@]
host[:
port]
> or <pop://[
user[:
passwd]@]
host[:
port]
>
If :port is omitted the default value is 110. Different forms of authentication can be specified with ;AUTH=type. The special string ;AUTH=* indicates that the client will use a default scheme base on the capability of the server.
<pop://obelix@gaulois.org
> <pop://asterix;AUTH=*@france.com
> <pop://falbala;AUTH=+APOP@france.com
> <pop://obelix;AUTH=+APOP@village.gaulois.org:2000
> <pop://obelix:menhir@village.gaulois.org:2000
>
For more complete information see RFC 2368.
The IMAP URL scheme contains an IMAP server, optional port number and the authentication mechanism. The general form is
<imap://[
user[;AUTH=
type]]@
host[:
port][/
mailbox]
> or <imap://[
user[:
passwd]]@
host[:
port][/
mailbox]
>
If :port is omitted the default value is 143. Different forms of authentication can be specified with ;AUTH=type. The special string ;AUTH=* indicates that the client will use a default scheme base on the capability of the server.
<imap://obelix@imap.gaulois.org
> <imap://asterix;AUTH=*@imap.france.com
> <imap://asterix:potion@imap.france.com
>
For more complete information see RFC 2192.
Local folder should be handle by this URL. It is preferable to let the mailbox recognize the type of mailbox and take the appropriate action.
<file://
path> <file://var/mail/user
> <file://home/obelix/Mail
>
For MMDF, MH local mailboxes URLs are provided, but it is preferable to
use <file://
path> and let the library figure out which one.
<mmdf://
path> <mh://
path>
After setting a mailer, <mailto:
> is used to tell the mailer where
and to whom the message is for.
<mailto://
hostname>
Mailto can be used to generate short messages, for example to subscribe to mailing lists.
<mailto://bug-mailutils@gnu.org?body=subscribe
> <mailto://bug-mailutils@gnu.org?Subject=hello&body=subscribe
>
For more complete information see RFC 2368.
Helper functions are provided to retrieve and set the URL fields.
Create the url data structure, but do not parse it.
Parses the url, after calling this the get functions can be called.
The syntax, condensed from RFC 1738, and extended with the ;auth= of RFC 2384 (for POP) and RFC 2192 (for IMAP) is:
url = scheme ":" [ "//" [ user [ ( ":" password ) | ( ";auth=" auth ) ] "@" ] host [ ":" port ] [ ( "/" urlpath ) | ( "?" query ) ] ]This is a generalized URL syntax, and may not be exactly appropriate for any particular scheme.
Decodes an RFC 1738 encoded string, returning the decoded string in allocated memory. If the string is not encoded, this degenerates to a
strdup()
.
#include <stdlib.h> #include <stdio.h> #include <string.h> #include <mailutils/errno.h> #include <mailutils/url.h> int main () { char str[1024]; char buffer[1024]; long port = 0; int len = sizeof (buffer); mu_url_t u = NULL; while (fgets (str, sizeof (str), stdin) != NULL) { int rc; str[strlen (str) - 1] = '\0'; /* chop newline */ if (strspn (str, " \t") == strlen (str)) continue; /* skip empty lines */ if ((rc = mu_url_create (&u, str)) != 0) { fprintf (stderr, "mu_url_create %s ERROR: [%d] %s", str, rc, mu_strerror (rc)); exit (1); } if ((rc = mu_url_parse (u)) != 0) { printf ("%s => FAILED: [%d] %s\n", str, rc, mu_strerror (rc)); continue; } printf ("%s => SUCCESS\n", str); mu_url_get_scheme (u, buffer, len, NULL); printf ("\tscheme <%s>\n", buffer); mu_url_get_user (u, buffer, len, NULL); printf ("\tuser <%s>\n", buffer); mu_url_get_passwd (u, buffer, len, NULL); printf ("\tpasswd <%s>\n", buffer); mu_url_get_auth (u, buffer, len, NULL); printf ("\tauth <%s>\n", buffer); mu_url_get_host (u, buffer, len, NULL); printf ("\thost <%s>\n", buffer); mu_url_get_port (u, &port); printf ("\tport %ld\n", port); mu_url_get_path (u, buffer, len, NULL); printf ("\tpath <%s>\n", buffer); mu_url_get_query (u, buffer, len, NULL); printf ("\tquery <%s>\n", buffer); mu_url_destroy (&u); } return 0; }
/* Prefix
mu_parse822_is reserved. */
#include <mailutils/parse822.h>
/* Prefix
mu_mailcap_is reserved. */
#include <mailutils/mailcap.h>
The standard RFC 1524 (A User Agent Configuration Mechanism) suggests a file format to be used to inform a mail user agent about facilities for handling mail in various format. The configuration file is known also as mailcap and it is tipically found in UNIX platforms, a example of /etc/mailcap:
application/pgp; gpg < %s | metamail; needsterminal; \ test=test %{encapsulation}=entity ; copiousoutput
A mailcap file consits of a set of mailcap entries per line, lines beginning with ‘#’ are considered comments and ignored. Long mailcap entry may be continued on multiple lines if each line ends with a backslash character ‘\’, the multiline will be considered a single mailcap entry. The overall format in BNF:
Mailcap-File = *mailcap-line Mailcap-Line = comment | mailcap-entry Comment = newline | "#" * char newline Newline = <newline as defined by OS convention>
Each mailcap entry consists of a number of fields, separated by semi-colons. The first two filds are required and must occur in the secified order, the remaining fields are optional.
Mailcap-Entry = typefield ";" view-command ";" *[ ";" field ]
The
mu_mailcap_t
andmu_mailcap_entry_t
objects are used to hold information and it is an opaque data structure to the user. Functions are provided to retrieve information from the data structure.
mu_mailcap_t mu_mailcap_entry_t -/etc/mailcap- +--->/------------------------\ +-->/------------------\ ( alain ) | mu_mailcap_entry[0]*--|--+ | typefield | | mu_mailcap_entry[1] | | view-command | | ..... | | field[0] | | mu_mailcap_entry[n] | | ..... | \------------------------/ | field[n] | \------------------/
#include <stdlib.h> #include <stdio.h> #include <mailutils/mailcap.h> #include <mailutils/stream.h> #include <mailutils/error.h> int main (int argc, char **argv) { mu_stream_t stream = NULL; int status = 0; char *file = argc == 1 ? "/etc/mailcap" : argv[1]; mu_mailcap_t mailcap = NULL; status = mu_file_stream_create (&stream, file, MU_STREAM_READ); if (status) { mu_error ("cannot create file stream %s: %s", file, mu_strerror (status)); exit (1); } status = mu_stream_open (stream); if (status) { mu_error ("cannot open file stream %s: %s", file, mu_strerror (status)); exit (1); } status = mu_mailcap_create (&mailcap, stream); if (status == 0) { int i; size_t count = 0; char buffer[256]; mu_mailcap_entries_count (mailcap, &count); for (i = 1; i <= count; i++) { size_t j; mu_mailcap_entry_t entry = NULL; size_t fields_count = 0; printf ("entry[%d]\n", i); mu_mailcap_get_entry (mailcap, i, &entry); /* typefield. */ mu_mailcap_entry_get_typefield (entry, buffer, sizeof (buffer), NULL); printf ("\ttypefield: %s\n", buffer); /* view-command. */ mu_mailcap_entry_get_viewcommand (entry, buffer, sizeof (buffer), NULL); printf ("\tview-command: %s\n", buffer); /* fields. */ mu_mailcap_entry_fields_count (entry, &fields_count); for (j = 1; j <= fields_count; j++) { int status = mu_mailcap_entry_get_field (entry, j, buffer, sizeof (buffer), NULL); if (status) { mu_error ("cannot retrieve field %lu: %s", (unsigned long) j, mu_strerror (status)); break; } printf ("\tfields[%d]: %s\n", j, buffer); } printf ("\n"); } mu_mailcap_destroy (&mailcap); } return 0; }
The function allocates, parses the buffer from the stream and initializes mailcap. The return value is
0
on success and a code number on error conditions:
MU_ERROR_INVALID_PARAMETER
- mailcap is
NULL
or stream is invalid.
Release any resources from the mailcap object.
The function returns the number of entries found in the mailcap. The return value is
0
on success and a code number on error conditions:
EINVAL
- mailcap or count is
NULL
.
Returns in entry the mailcap entry of no.
The function returns the number of fields found in the entry. The return value is
0
on success and a code number on error conditions:
EINVAL
- entry or count is
NULL
.
Helper function saving in buffer, the argument of "compose" field.
Helper function saving in buffer, the argument of "composetyped" field.
Helper function saving in buffer, the argument of "edit" field.
Helper function saving in buffer, the argument of "textualnewlines" field.
Helper function saving in buffer, the argument of "test" field.
Helper function saving in buffer, the argument of "x11-bitmap" field.
Helper function saving in buffer, the argument of "description" field.
Helper function saving in buffer, the argument of "nametemplate" field.
Helper function saving in buffer, the argument of "notes" field.
Helper function. Returns *on != 0 if the flag
needsterminal
is in the record.
Helper function. Returns *on != 0 if the flag copiousoutput is in the record.
The functions from libmailbox library get user information from the system user database. The library libmuauth extends this functionality, allowing libmailbox functions to obtain information about a user from several places, like sql database, etc. The method used is described in detail in authentication. This chapter contains a very succinct description of the underlying library mechanism.
This is a pointer to authentication or authorization data. It is defined as follows:
typedef int (*mu_auth_fp) (struct mu_auth_data **return_data, void *key, void *func_data, void *call_data);Its arguments are:
- return_data
- Upon successful return authorization handler leaves in this memory location a pointer to the filled
mu_auth_data
structure with the user's information.For authentication handlers this argument is always
NULL
and should be ignored.- key
- The search key value. Its actual type depends upon type of the handler.
For authorization handlers it is
const char*
if the handler is called bymu_get_auth_by_name()
anduid_t *
if it is called bymu_get_auth_by_uid()
.For authentication handlers it is always
struct mu_auth_data*
representing the user's data obtained by a previous call to amu_get_auth_by_...
function.- func_data
- Any data associated with this handler.
- call_data
- Any call specific data. This argument is not used at the moment.
The
mu_auth_data
is used to return the information about the user. It is similar to systemstruct passwd
, except that it is more mailutils-specific. Its definition is:struct mu_auth_data { /* These are from struct passwd */ char *name; /* user name */ char *passwd; /* user password */ uid_t uid; /* user id */ gid_t gid; /* group id */ char *gecos; /* real name */ char *dir; /* home directory */ char *shell; /* shell program */ /* */ char *mailbox; /* Path to the user's system mailbox */ int change_uid; /* Should the uid be changed? */ };
The
mu_auth_module
structure contains full information about a libmuauth module. It is declared as follows:struct mu_auth_module { char *name; /* Module name */ struct argp *argp; /* Corresponding argp structure */ mu_auth_fp authenticate; /* Authentication function ... */ void *authenticate_data; /* ... and its specific data */ mu_auth_fp auth_by_name; /* Get user info by user name */ void *auth_by_name_data; /* ... and its specific data */ mu_auth_fp auth_by_uid; /* Get user info by user id */ void *auth_by_uid_data; /* ... and its specific data */ };
This function registers the command line capability “auth”. It must be called after registering libmuauth modules and before calling
mu_agrp_parse()
. If an error occurs, this function prints diagnostic message and aborts the program.
This macro registers all default modules and calls
mu_auth_init()
.
Create a
mu_auth_data
structure and initialize it with the given values. Returns 0 on success and 1 otherwise.
Free the
mu_auth_data
structure allocated by a call tomu_auth_data_alloc()
.
Register the module defined by the mod argument.
The list is expected to contain
mu_auth_fp
pointers. Each of them is dereferenced and executed until either the list is exhausted or any of the functions returns non-zero, whichever occurs first. The return_data and key arguments are passed as the first two parameters to the function (see the definition ofmu_auth_fp
, notice the footnote), thecall_data
is passed as its last parameter.The function returns 0 if none of the functions from
list
succeeded, i.e. returned non-zero value. Otherwise it returns the return code from the succeeded function.
Search the information about given user by its username. Similar to system's
getpwnam
call).
Search the information about given user by its uid. Similar to system's
getpwuid
call).
Authenticate the user whose data are in auth_data using password pass. Return 0 if the user is authenticated.
The “not-supported” module. Always returns
ENOSYS
.
This module is always registered even if libmuauth is not linked. It performs usual authentication using system user database (/etc/password et al.)
This module is always registered even if libmuauth is not linked. Both its authorization handlers are
mu_auth_nosupport
. Its authentication handler computes the MD5 or DES hash over the supplied password with the seed taken frompasswd
member of its key argument. Then it compares the obtained hash with thepasswd
member itself and returns 1 if both strings match.
Implements PAM authentication. Both authorization handlers are
mu_auth_nosupport()
.
Implements authentication and authorization via MySQL database. The credentials for accessing the database are taken from global variables
sql_host
,sql_port
,sql_user
,sql_passwd
andsql_db
. The SQL queries for retrieving user information from global variablessql_getpwnam_query
andsql_getpwuid_query
. The variablesql_getpass_query
keeps the query used for retrieving user's password. See auth, for information on command line options used to set these variables.
Implements
mu_get_auth_by_name
method using virtual mail domains. Neithermu_get_auth_by_uid
normu_authenticate
is implemented. This module must be used together withgeneric
module.
To link your program against libmuauth, obtain loader arguments by running mailutils-config as follows:
mailutils-config --link auth
See mailutils-config, for more information about this utility.
Here is a sample Makefile fragment:
MU_LDFLAGS=`mailutils-config --link auth` MU_INCLUDES=`mailutils-config --include` myprog: myprog.c $(CC) -omyprog $(CFLAGS) $(MU_INCLUDES) myprog.c $(MU_LDFLAGS)
If your program will be using only default modules provided by the
library, then it will suffice to call
MU_AUTH_REGISTER_ALL_MODULES()
somewhere near the start of
your program. As an example, consider the following code fragment
(it is taken from the imap4d daemon):
int main (int argc, char **argv) { struct group *gr; int status = EXIT_SUCCESS; state = STATE_NONAUTH; /* Starting state in non-auth. */ MU_AUTH_REGISTER_ALL_MODULES (); mu_argp_parse (&argp, &argc, &argv, 0, imap4d_capa, NULL, &daemon_param); ...
Otherwise, if your program will use it's own modules, first register
them with mu_auth_register_module
and then call
mu_auth_init()
, e.g.:
struct mu_auth_module radius_module = { ... }; struct mu_auth_module ext_module = { ... }; int main (int argc, char **argv) { mu_auth_register_module (&radius_module); mu_auth_register_module (&ext_module); mu_auth_init (); ...
These two approaches may be combined, allowing you to use both your modules and the ones provided by Mailutils. Consider the example below:
int main (int argc, char **argv) { mu_auth_register_module (&radius_module); mu_auth_register_module (&ext_module); MU_AUTH_REGISTER_ALL_MODULES (); ... }
The library libmu_scm provides an interface between Mailutils and Guile, allowing to access the Mailutils functionality from a Scheme program. For more information about Guile, refer to Overview. For information about Scheme programming language, See Top.
Functions Provided by libmu_scm
Using libmu_scm
Return personal part of the numth email address from address.
Return comment part of the numth email address from address.
Return email part of the numth email address from address.
Return domain part of the numth email address from address.
Return local part of the numth email address from address.
Deduce user's email address from his username. If name is omitted, current username is assumed
If url is given, sets it as a name of the user's mail directory. Returns the current value of the mail directory.
If url is given, sets it as a name of the user's folder directory. Returns the current value of the folder directory.
Opens the mailbox specified by url. mode is a string, consisting of the characters described below, giving the access mode for the mailbox
mode Meaning r Open for reading. w Open for writing. a Open for appending to the end of the mailbox. c Create the mailbox if it does not exist.
Returns a port associated with the contents of the mbox. mode is a string defining operation mode of the stream. It may contain any of the two characters: ‘r’ for reading, ‘w’ for writing.
Retrieve from message #msgno from the mailbox mbox.
Sets new value to the header header of the message mesg. If header is already present in the message its value is replaced with the suplied one iff the optional replace is #t. Otherwise, a new header is created and appended.
Returns email address of the sender of the message mesg.
Returns value of the header header from the message mesg.
Returns the list of headers in the message mesg. Optional argument headers gives a list of header names to restrict return value to.
Set the headers in the message mesg from list list is a list of conses (cons HEADER VALUE). The function sets these headers in the message mesg. Optional parameter replace specifies whether the new header values should replace the headers already present in the message.
Mark the message mesg as deleted. Optional argument flag allows to toggle deletion mark. The message is deleted if it is
#t
and undeleted if it is#f
Return value of the attribute flag of the message mesg.
Set the attribute flag of the message mesg. If optional value is #f, the attribute is unset.
Return the value of the user attribute flag from the message mesg.
Set the given user attribute flag in the message mesg. If optional argumen value is ‘#f’, the attribute is unset.
Returns a port associated with the given mesg. mode is a string defining operation mode of the stream. It may contain any of the two characters: ‘r’ for reading, ‘w’ for writing. If optional argument full is specified, it should be a boolean value. If it is ‘#t’ then the returned port will allow access to any part of the message (including headers). If it is
#f
then the port accesses only the message body (the default).
Returns number of parts in a multipart MIME message. Returns
#f
if the argument is not a multipart message.
Returns part #part from a multipart MIME message mesg.
Sends the message mesg. Optional mailer overrides default mailer settings in mu-mailer. Optional from and to give sender and recever addresses.
Creates a new MIME object. Both arguments are optional. flags specifies the type of the object to create (‘0’ is a reasonable value). mesg gives the message to create the MIME object from.
Opens a connection to the system logger for Guile program. ident, option and facility have the same meaning as in openlog(3)
Registers desired mailutils formats. Any number of arguments can be given. Each argument must be one of the following strings:
Argument Meaning ‘mbox’ Regular UNIX mbox format ‘mh’ MH mailbox format ‘maildir’ Maildir mailbox format ‘pop’ POP mailbox format ‘imap’ IMAP mailbox format ‘sendmail’ sendmail mailer format ‘smtp’ SMTP mailer format If called without arguments, the function registers all available formats
Return the error message corresponding to err, which must be an integer value.
If you plan to link your program directly to libguile, it will probably make sense to link libmu_scm directly as well. The arguments to the program loader may be obtained by running
mailutils-config --link guile
See mailutils-config, for more information about this utility.
Here is a sample Makefile fragment:
MU_LDFLAGS=`mailutils-config --link guile` MU_INCLUDES=`mailutils-config --include` myprog: myprog.c $(CC) -omyprog $(CFLAGS) $(MU_INCLUDES) myprog.c $(MU_LDFLAGS)
Dynamic linking is the preferred method of using libmu_scm. It uses Guile “use-modules” mechanism. An interface module mailutils.scm is provided in order to facilitate using this method. This module is installed in the package data directory (by default it is prefix/share/mailutils). A sample use of this module is:
(set! %load-path (list "/usr/local/share/mailutils")) (use-modules (mailutils)) # Now you may use mailutils functions: (let ((mb (mu-mailbox-open "/var/spool/mail/gray" "r"))) ...
Note, that you should explicitly modify the %load-path
before calling use-modules
, otherwise Guile will not be able to
find mailutils.scm.
Libsieve
is gnu implementation of the mail filtering
language Sieve. The library is built around a Sieve Machine — an
abstract computer constructed specially to handle mail filtering tasks.
This computer has two registers: program counter and numeric accumulator;
a runtime stack of unlimited depth and the code segment. A set of
functions is provided for creating and destroying instances of Sieve
Machine, manipulating its internal data, compiling and executing a
sieve program.
The following is a typical scenario of using libsieve
:
mu_sieve_compile
function is called to translate
the Sieve source into an equivalent program executable by the
Machine
keep
are marked with the delete
flag. Thus, running mailbox_expunge
upon the mailbox finishes
the job, leaving in the mailbox only those messages that were preserved
by the filter.
The following sections describe in detail the functions from the Sieve Library.
This is an opaque data type representing a pointer to an instance of sieve machine. The
sieve_machine_t
keeps all information necessary for compiling and executing the script.It is created by
sieve_machine_create()
and destroyed bysieve_machine_destroy()
. The functions for manipulating this data type are described in Manipulating the Sieve Machine.
This enumeration keeps the possible types of sieve data. These are:
SVT_VOID
- No datatype.
SVT_NUMBER
- Numeric type.
SVT_STRING
- Character string.
SVT_STRING_LIST
- A
mu_list_t
. Each item in this list represents a character string.SVT_TAG
- A sieve tag. See
mu_sieve_runtime_tag_t
below.SVT_IDENT
- A character string representing an identifier.
SVT_VALUE_LIST
- A
mu_list_t
. Each item in this list is ofmu_sieve_value_t
type.SVT_POINTER
- An opaque pointer.
The
mu_sieve_value_t
keeps an instance of sieve data. It is defined as follows:typedef struct { mu_sieve_data_type type; /* Type of the data */ union { char *string; /* String value or identifier */ size_t number; /* Numeric value */ mu_list_t list; /* List value */ mu_sieve_runtime_tag_t *tag; /* Tag value */ void *ptr; /* Pointer value */ } v; } mu_sieve_value_t;Depending on the value of
type
member, following members of the unionv
keep the actual value:
SVT_VOID
- Never appears.
SVT_NUMBER
- The numeric value is kept in
number
member.SVT_STRING
- The string is kept in
string
member.SVT_STRING_LIST
SVT_VALUE_LIST
- The list itself is pointed to by
list
memberSVT_TAG
- The tag value is pointed to by
tag
member.SVT_IDENT
- The
string
member points to the identifier name.SVT_POINTER
- The data are pointed to by
ptr
member.
This structure represents a definition of a tagged (optional) argument to a sieve action or test. It is defined as follows:
typedef struct { char *name; /* Tag name */ mu_sieve_data_type argtype; /* Type of tag argument. */ } mu_sieve_tag_def_t;The
name
member points to the tag's name without leading colon. Theargtype
is set toSVT_VOID
if the tag does not take argument, or to the type of the argument otherwise.
This structure represents the tagged (optional) argument at a runtime. It is defined as:
struct mu_sieve_runtime_tag { char *tag; /* Tag name */ mu_sieve_value_t *arg; /* Tag argument (if any) */ };The
arg
member isNULL
if the tag does not take an argument.
Objects of this type represent a location in the Sieve source file:
typedef struct { const char *source_file; size_t source_line; } mu_sieve_locus_t;
This is a pointer to function handler for a sieve action or test. It is defined as follows:
typedef int (*mu_sieve_handler_t) (mu_sieve_machine_t mach, mu_list_t args, mu_list_t tags);The arguments to the handler have the following meaning:
- mach
- Sieve machine being processed.
- args
- A list of required arguments to the handler
- tags
- A list of optional arguments (tags).
A pointer to a diagnostic output function. It is defined as follows:
typedef int (*mu_sieve_printf_t) (void *data, const char *fmt, va_list ap);
- data
- A pointer to application specific data. These data are passed as second argument to
mu_sieve_machine_init()
.- fmt
- Printf-like format string.
- ap
- Other arguments.
This data type is declared as follows:
typedef int (*mu_sieve_parse_error_t) (void *data, const char *filename, int lineno, const char *fmt, va_list ap);It is used to declare error handlers for parsing errors. The application-specific data are passed in the data argument. Arguments filename and line indicate the location of the error in the source text, while fmt and ap give verbose description of the error.
A pointer to the application-specific logging function:
typedef void (*mu_sieve_action_log_t) (void *data, const mu_sieve_locus_t *locus, size_t msgno, mu_message_t msg, const char *action, const char *fmt, va_list ap);
- data
- Application-specific data.
- locus
- Location in the Sieve source file.
- script
- Name of the sieve script being executed.
- msgno
- Ordinal number of the message in mailbox, if appropriate. When execution is started using
sieve_message()
, this argument is zero.- msg
- The message this action is executed upon.
- action
- The name of the action.
- fmt
- var
- These two arguments give the detailed description of the action.
typedef int (*mu_sieve_relcmp_t) (int, int); typedef int (*mu_sieve_relcmpn_t) (size_t, size_t);
typedef int (*mu_sieve_comparator_t) (const char *, const char *);A pointer to the comparator handler function. The function compares its two operands and returns 1 if they are equal, and 0 otherwise. Notice, that the sense of the return value is inverted in comparison with most standard libc functions like
stcmp()
, etc.
typedef int (*mu_sieve_retrieve_t) (void *item, void *data, int idx, char **pval);A pointer to generic retriever function. See description of
mu_sieve_vlist_compare()
for details of its usage.
typedef void (*mu_sieve_destructor_t) (void *data);A pointer to destructor function. The function frees any resources associated with
data
. See the description ofmu_sieve_machine_add_destructor()
for more information.
typedef int (*mu_sieve_tag_checker_t) (const char *name, mu_list_t tags, mu_list_t args)A pointer to tag checker function. The purpose of the function is to perform compilation-time consistency test on tags. Its arguments are:
- name
- Name of the test or action whose tags are being checked.
- tags
- A list of
mu_sieve_runtime_tag_t
representing tags.- args
- A list of
mu_sieve_value_t
representing required arguments to name.The function is allowed to make any changes in tags and args. It should return 0 if the syntax is correct and non-zero otherwise. It is responsible for issuing the diagnostics in the latter case. [FIXME: describe how to do that]
This subsection describes functions used to create an instance of the sieve machine, read or alter its internal fields and destroy it.
The
mu_sieve_machine_init()
function creates an instance of a sieve machine. A pointer to the instance itself is returned in the argument mach. The user-specific data to be associated with the new machine are passed in data argument. The function returns 0 on success, non-zero error code otherwise,
This function destroys the instance of sieve machine pointed to by mach parameter. After execution of
mu_sieve_machine_destroy()
pmach containsNULL
. The destructors registered withmu_sieve_machine_add_destructor()
are executed in lifo order.
This function registers a destructor function dest. The purpose of the destructor is to free any resources associated with the item ptr. The destructor function takes a single argument — a pointer to the data being destroyed. All registered destructors are called in reverse order upon execution of
mu_sieve_machine_destroy()
. Here's a short example of the use of this function:static void free_regex (void *data) { regfree ((regex_t*)data); } int match_part_checker (const char *name, list_t tags, list_t args) { regex_t *regex; /* Initialise the regex: */ regex = mu_sieve_malloc (mach, sizeof (*regex)); /* Make sure it will be freed when necessary */ mu_sieve_machine_add_destructor (sieve_machine, free_regex, regex); . . . }
This function returns the application-specific data associated with the instance of sieve machine. See
mu_sieve_machine_init()
.
This function returns the current message.
This function returns the current message number in the mailbox. If there are no mailbox, i.e. the execution of the sieve code is started with
mu_sieve_message
, this function returns 1.
Returns the debug level set for this instance of sieve machine.
Returns the authentication ticket for this machine.
Returns the locus in the Sieve source file corresponding to the code pointer where the Sieve machine currently is.
This function returns the daemon email associated with this instance of sieve machine. The daemon email is an email address used in envelope from addresses of automatic reply messages. By default its local part is ‘<MAILER-DAEMON>’ and the domain part is the machine name.
This function sets the error printer function for the machine. If it is not set, the default error printer will be used. It is defined as follows:
int _sieve_default_error_printer (void *unused, const char *fmt, va_list ap) { return mu_verror (fmt, ap); }
This function sets the parse error printer function for the machine. If it is not set, the default parse error printer will be used. It is defined as follows:
int _sieve_default_parse_error (void *unused, const char *filename, int lineno, const char *fmt, va_list ap) { if (filename) fprintf (stderr, "%s:%d: ", filename, lineno); vfprintf (stderr, fmt, ap); fprintf (stderr, "\n"); return 0; }
This function sets the debug printer function for the machine. If it is not set, the default debug printer is
NULL
which means no debugging information will be displayed.
This function sets the debug level for the given instance of sieve machine. The dbg argument is the
mu_debug_t
object to be used with mailutils library, the level argument specifies the debugging level for the sieve library itself. It is a bitwise or of the following values:
MU_SIEVE_DEBUG_TRACE
- Trace the execution of the sieve script.
MU_SIEVE_DEBUG_INSTR
- Print the sieve machine instructions as they are executed.
MU_SIEVE_DEBUG_DISAS
- Dump the disassembled code of the sieve machine. Do not run it.
MU_SIEVE_DRY_RUN
- Do not executed the actions, only show what would have been done.
This function sets the logger function. By default the logger function is
NULL
, which means that the executed actions are not logged.
This function sets the authentication ticket to be used with this machine.
This function sets the mailer. The default mailer is
"sendmail:"
.
This functions sets the daemon email for
reject
andredirect
actions.
The
mu_sieve_is_dry_run()
returns 1 if the machine is in dry run state, i.e. it will only log the actions that would have been executed without actually executing them. The dry run state is set by callingmu_sieve_set_debug_level()
if its last argument has theMU_SIEVE_DRY_RUN
bit set.
Returns the string representation for the given sieve data type. The return value is a pointer to a static constant string.
Format and output an error message using error printer of the machine mach.
Format and output a debug message using debug printer of the machine mach.
Log a sieve action using logger function associated with the machine mach.
Immediately abort the execution of the script.
Find a register object describing the test name. Returns
NULL
if no such test exists.
Find a register object describing the action name. Returns
NULL
if no such action exists.
The following functions act as their libc counterparts. The allocated
memory is associated with the mach argument and is automatically
freed upon the call to mu_sieve_machine_destroy (
mach)
.
Allocates size bytes and returns a pointer to the allocated memory.
This function returns a pointer to a new string which is a duplicate of the string str.
Changes the size of the memory block pointed to by ptr to size bytes. The contents will be unchanged to the minimum of the old and new sizes; newly allocated memory will be uninitialized. If ptr is
NULL
, the call is equivalent tomu_sieve_malloc(
mach,
size)
; if size is equal to zero, the call is equivalent tomu_sieve_mfree(
ptr)
. Unless ptr isNULL
, it must have been returned by an earlier call tomu_sieve_malloc()
ormu_sieve_mrealloc()
.
mu_sieve_mfree()
frees the memory space pointed to by ptr and detaches it from the destructor list of mach. The ptr must have been returned by a previous call tomu_sieve_malloc()
ormu_sieve_mrealloc()
. Otherwise, or ifmu_sieve_mfree(
ptr)
has already been called before, undefined behaviour occurs.If ptr is
NULL
, no operation is performed.
Compile the sieve script from the file name.
Execute the code from the given instance of sieve machine mach over each message in the mailbox mbox.
Execute the code from the given instance of sieve machine mach over the message.
Dump the disassembled code of the sieve machine mach.
This section contains an example of how to write external loadable commands for gnu libsieve.
/* This is an example on how to write extension tests for GNU sieve. It provides test "numaddr". Syntax: numaddr [":over" / ":under"] <header-names: string-list> <limit: number> The "numaddr" test counts Internet addresses in structured headers that contain addresses. It returns true if the total number of addresses satisfies the requested relation: If the argument is ":over" and the number of addresses is greater than the number provided, the test is true; otherwise, it is false. If the argument is ":under" and the number of addresses is less than the number provided, the test is true; otherwise, it is false. If the argument is empty, ":over" is assumed. */ #ifdef HAVE_CONFIG_H # include <config.h> #endif #include <stdlib.h> #include <mailutils/libsieve.h> struct val_ctr { /* Data passed to the counter function */ mu_header_t hdr; /* Headers of the current message */ size_t limit; /* Limit for the number of addresses */ size_t count; /* Number of addresses counted so far */ }; /* Count addresses in a single header value. Input: ITEM is the name of the header to scan. DATA is a pointer to the val_ctr structure Return value: non-zero if the limit on the number of addresses has been reached. */ static int _count_items (void *item, void *data) { char *name = item; struct val_ctr *vp = data; char *val; mu_address_t addr; size_t count = 0; if (mu_header_aget_value (vp->hdr, name, &val)) return 0; if (mu_address_create (&addr, val) == 0) { mu_address_get_count (addr, &count); mu_address_destroy (&addr); vp->count += count; } free (val); return vp->count >= vp->limit; } /* Handler for the numaddr test */ static int numaddr_test (mu_sieve_machine_t mach, mu_list_t args, mu_list_t tags) { mu_sieve_value_t *h, *v; struct val_ctr vc; int rc; if (mu_sieve_get_debug_level (mach) & MU_SIEVE_DEBUG_TRACE) { mu_sieve_locus_t locus; mu_sieve_get_locus (mach, &locus); mu_sieve_debug (mach, "%s:%lu: NUMADDR\n", locus.source_file, (unsigned long) locus.source_line); } /* Retrieve required arguments: */ /* First argument: list of header names */ h = mu_sieve_value_get (args, 0); if (!h) { mu_sieve_error (mach, "numaddr: can't get argument 1"); mu_sieve_abort (mach); } /* Second argument: Limit on the number of addresses */ v = mu_sieve_value_get (args, 1); if (!v) { mu_sieve_error (mach, "numaddr: can't get argument 2"); mu_sieve_abort (mach); } /* Fill in the val_ctr structure */ mu_message_get_header (mu_sieve_get_message (mach), &vc.hdr); vc.count = 0; vc.limit = v->v.number; /* Count the addresses */ rc = mu_sieve_vlist_do (h, _count_items, &vc); /* Here rc >= 1 iff the counted number of addresses is greater or equal to vc.limit. If `:under' tag was given we reverse the return value */ if (mu_sieve_tag_lookup (tags, "under", NULL)) rc = !rc; return rc; } /* Syntactic definitions for the numaddr test */ /* Required arguments: */ static mu_sieve_data_type numaddr_req_args[] = { SVT_STRING_LIST, SVT_NUMBER, SVT_VOID }; /* Tagged arguments: */ static mu_sieve_tag_def_t numaddr_tags[] = { { "over", SVT_VOID }, { "under", SVT_VOID }, { NULL } }; static mu_sieve_tag_group_t numaddr_tag_groups[] = { { numaddr_tags, NULL }, { NULL } }; /* Initialization function. It is the only function exported from this module. */ int SIEVE_EXPORT(numaddr,init) (mu_sieve_machine_t mach) { return mu_sieve_register_test (mach, "numaddr", numaddr_test, numaddr_req_args, numaddr_tag_groups, 1); }
The input language understood by the gnu Sieve Library is a superset of the Sieve language as described in RFC 3028.
Comments are semantically equivalent to whitespace and can be used anyplace that whitespace is (with one exception in multi-line strings, as described below).
There are two kinds of comments: hash comments, that begin with a ‘#’ character that is not contained within a string and continue until the next newline, and C-style or bracketed comments, that are delimited by ‘/*’ and ‘*/’ tokens. The bracketed comments may span multiple lines. E.g.:
if size :over 100K { # this is a comment discard; } if size :over 100K { /* this is a comment this is still a comment */ discard /* this is a comment again */ ; }
Like in C, bracketed comments do not nest.
The basic lexical entities are identifiers and literals.
An identifier is a sequence of letters, digits and underscores, started
with a letter or underscore. For example, header
and
check_822_again
are valid identifiers, whereas 1st
is not.
A special form of identifier is tag: it is an identifier prefixed
with a colon (‘:’), e.g.: :comparator
.
A literal is a data that is not executed, merely evaluated “as is”, to be used as arguments to commands. There are four kinds of literals:
Numbers are given as ordinary unsigned decimal numbers. An optional suffix may be used to indicate a multiple of a power of two. The suffixes are: ‘K’ specifying “kibi-”, or 1,024 (2^10) times the value of the number; ‘M’ specifying “mebi-”, or 1,048,576 (2^20) times the value of the number; and ‘G’ specifying “tebi-”, or 1,073,741,824 (2^30) times the value of the number.
The numbers have 32 bits of magnitude.
A string is any sequence of characters enclosed in double quotes (‘"’). A string cannot contain newlines and double quote characters. This limitation will disappear in future releases.
A multiline string is used to represent large blocks of text
with embedded newlines and special characters. It starts with the
keyword text:
followed by a newline and ends with a dot
(‘.’) on a newline by itself. Any characters between these two
markers are taken verbatim. For example:
text: ** This is an authomatic response from my message ** ** filtering program. ** I can not attend your message right now. However it will be saved, and I will read it as soon as I am back. Regards, Fred .
Notice that a hashed comment or whitespace may occur between
text:
and the newline. However, when used inside the multiline
string a hash sign looses its special meaning (except in one case, see
below) and is taken as is, as well as bracketed comment delimiters.
In other words, no comments are allowed within a multiline string. E.g.:
text: # This is a comment Sample text # This line is taken verbatim /* And this line too */ .
The only exception to this rule is that preprocessor include
statement is expanded as usual when found within a multiline string
(see Preprocessor), e.g.:
text: #include <myresponse.txt> .
This results in the contents of file myresponse.txt being read and interpreted as the contents of the multiline string.
GNU libsieve extends the described syntax as follows. If the keyword
text:
is immediately followed by a dash (‘-’), then all
leading tab characters are stripped from input lines and the line
containing delimiter (‘.’). This allows multiline strings within
scripts to be indented in a natural fashion.
Furthermore, if the text:
(optionally followed by ‘-’) is
immediately followed by a word, this word will be used as ending
delimiter of multiline string instead of the default dot. For
example:
if header "from" "me@example.com" { reject text:-EOT I do not accept messages from this address. . . EOT # Notice that this the multiline string ends here. # The single dots above will be part of it. ; }
A string list is a comma-delimited list of quoted strings, enclosed in a pair of square brackets, e.g.:
["me@example.com", "me00@landru.example.edu"]
For convenience, in any context where a list of strings is appropriate, a single string is allowed without being a member of a list: it is equivalent to a list with a single member. For example, the following two statements are equivalent:
exists "To"; exists ["To"];
Being designed for the sole purpose of filtering mail, Sieve has a very simple syntax.
The basic syntax element is a command. It is defined as follows:
command-name [tags] args
where command-name is an identifier representing the name of the command, tags is an optional list of optional or tagged arguments and args is a list of required or positional arguments.
Positional arguments are literals delimited with whitespace. They provide the command with the information necessary to its proper functioning. Each command has a fixed number of positional arguments. It is an error to supply more arguments to the command or to give it fewer arguments than it accepts.
Optional arguments allow to modify the behaviour of the command, like command line options in UNIX do. They are a list of tags (see Lexical Structure) separated by whitespace. An optional argument may have at most one parameter.
Each command understands a set of optional arguments. Supplying it tags that it does not understand results in an error.
For example, consider the following command
header :mime :comparator "i;octet" ["to", "from"] "bug-mailutils@gnu.org"
Here, given that header
takes two positional arguments:
header
is command name, the list ["to", "from"]
is first
positional argument and the string "bug-mailutils@gnu.org"
is second
positional argument. There are two optional arguments: :mime
and
:comparator
. The latter has a string "i;octet"
as its
parameter.
An action is a Sieve command that performs some operation over the message. Actions do the main job in any Sieve program. Syntactically, an action is a command terminated with semicolon, e.g.:
keep; fileinto "mbox";
gnu Sieve provides the full set of actions described in RFC 3028. It also allows to extend this set using loadable actions. See Actions, for detailed discussion of actions.
The only control flow statement Sieve has is “if” statement. In its simplest form it is:
if condition
{ ... }
The effect of this statement is that the sequence of actions between the
curly braces is executed only if the condition
evaluates to
true
.
A more elaborate form of this statement allows to execute two different sets of actions depending on whether the condition is true or not:
if condition
{ ... } else { ... }
The most advanced form of the “if” statement allows to select an action depending on what condition from the set of conditions is met.
ifcond1
{ ... } elsifcond2
{ ... } else { ... }
There may be any number of “elsif” branches in an “if” statement. However it may have at most one “else” branch. Notes for C programmers:
Here's an example of “if” statement:
if header :contains "from" "coyote" { discard; } elsif header :contains ["subject"] ["$$$"] { discard; } else { fileinto "INBOX"; }
The following section describes in detail conditions used in “if” statements.
Tests are Sieve commands that return boolean value. E.g. the test
header :contains "from" "coyote"
returns true only if the header “From” of the current message contains substring “coyote”.
The tests shipped with the gnu Sieve are described in Tests.
Condition is a Sieve expression that evaluates to true
or
false
. In its simplest form, condition is just a Sieve test.
To reverse the sense of a condition use keyword not
, e.g.:
not header :contains "from" "coyote"
The results of several conditions may be joined together by logical
and
and or
operations. The special form allof
takes several tests as its arguments and computes the logical and
of their results. Similarly, the form anyof
performs logical
or
over the results of its arguments. E.g.:
if anyof (not exists ["From", "Date"], header :contains "from" "fool@example.edu") { discard; }
The preprocessor statements are a gnu extension to the Sieve language.
The syntax for a preprocessor statement is similar to that used in
C
programming language, i.e.: a pound character (‘#’)
followed by a preprocessor directive and its arguments. Any amount of
whitespace can be inserted between the ‘#’ and the directive.
Currently implemented directives are include
and searchpath
.
The #include
directive reads in the contents of the given file.
The contents is “inserted” into the text being parsed starting at the
line where the directive appears. The directive takes two forms:
#include "
filename"
#include <
filename>"
If filename starts with a directory separator character (‘/’) both forms have the same effect.
The #searchpath
directive adds its argument to the list of
directories searched for loadable modules. It has the same effect
as -L command line switch used by gnu sieve utility
(see sieve group).
Syntax: require string; require string-list;
The require statement informs the parser that a script makes use of a certain extension. Multiple capabilities can be declared using the second form of the statement. The actual handling of a capability name depends on its suffix.
If the name starts with ‘comparator-’, it is understood as a request to use the specified comparator. The comparator name consists of the characters following the suffix.
If the name starts with ‘test-’, it means a request to use the given test. The test name consists of the characters following the suffix.
Otherwise, the capability is understood as a name of an action to be used.
The require
statement, if present, must be used before any other
statement that is using the required capability. As an extension, the gnu
sieve allows the require
and any other statements to be
interspersed.
By default the following actions and comparators are always required:
Example:
require ["fileinto", "reject"]; require "fileinto"; require "comparator-i;ascii-numeric";
When processing arguments for require
statement, gnu libsieve
uses the following algorithm:
#searchpath
directive.
The value of LTDL_LIBRARY_PATH and LD_LIBRARY_PATH must be a colon-separated list of absolute directories, for example, ‘"/usr/lib/mypkg:/lib/foo"’.
In any of these directories, libsieve first attempts to find and load the given filename. If this fails, it tries to append the following suffixes to the file name:
source for the required action NAME is not available
gnu libsieve supports the following built-in comparators:
i;octet
i;ascii-casemap
i;ascii-numeric
This section describes the built-in tests supported by gnu libsieve. In the discussion below the following macro-notations are used:
:is
:is
match type describes an absolute match; if the contents of
the first string are absolutely the same as the contents of the
second string, they match. Only the string “frobnitzm” is the string
“frobnitzm”. The null key “:is” and only “:is” the null value.
This is the default match-type.
:contains
:contains
match type describes a substring match. If the value
argument contains the key argument as a substring, the match is true.
For instance, the string “frobnitzm” contains “frob” and “nit”, but
not “fbm”. The null key “” is contained in all values.
:matches
:matches
version specifies a wildcard match using the
characters ‘*’ and ‘?’. ‘*’ matches zero or more
characters, and ‘?’ matches a single character. ‘?’ and
‘*’ may be escaped as ‘\\?’ and ‘\\*’ in strings to match
against themselves. The first backslash escapes the second backslash;
together, they escape the ‘*’.
:regex
:regex
version specifies a match using POSIX Extended Regular
Expressions.
:value
relation:value
match type does a relational comparison between
strings. Valid values for relation are:
:count
relation:comparator "comparator-name"
It instructs sieve to use the given comparator with the test. If comparator-name is not one of ‘i;octet’, ‘i;ascii-casemap’ it must be required prior to using it. For example:
require "comparator-i;ascii-numeric"; if header :comparator "i;ascii-numeric" :is "X-Num" "10" { ...
:all
:localpart
:domain
Notice, that match-type modifiers interact with
comparators. Some comparators are not suitable for matching with
:contains
or :matches
. If this occurs, sieve issues
an appropriate error message. For example, the statement:
if header :matches :comparator "i;ascii-numeric"
would result in the following error message:
comparator `i;ascii-numeric' is incompatible with match type `:matches' in call to `header'
Tagged arguments:
Required arguments:
- address-part
- Selects the address part to compare. Default is the whole email address (
:all
).- comparator
- Specifies the comparator to be used instead of the default
i;ascii-casemap
.- match-type
- Specifies the match type to be used instead of the default
:is
.The
- header-names
- A list of header names.
- key-list
- A list of address values.
address
test matches Internet addresses in structured headers that contain addresses. It returnstrue
if any header contains any key in the specified part of the address, as modified by comparator and match-type optional arguments.This test returns
true
if any combination of the header-names and key-list arguments match.The
address
primitive never acts on the phrase part of an email address, nor on comments within that address. Use theheader
test instead. It also never acts on group names, although it does act on the addresses within the group construct.Example:
if address :is :all "from" "tim@example.com" { discard; }
The
size
test deals with the size of a message. The required argument number represents the size of the message in bytes. It may be suffixed with the following quantifiers:
- ‘k’
- ‘K’
- The number is expressed in kilobytes.
- ‘m’
- ‘M’
- The number is expressed in megabytes.
- ‘g’
- ‘G’
- The number is expressed in gigabytes.
If the tagged argument is ‘:over’, and the size of the message is greater than number, the test is true; otherwise, it is false.
If the argument is ‘:under’, and the size of the message is less than the number, the test is true; otherwise, it is false.
Otherwise, the test is true only if the size of the message equals exactly number. This is a gnu extension.
The size of a message is defined to be the number of octets from the initial header until the last character in the message body.
Tagged arguments:
Required arguments:
- address-part
- Selects the address part to compare. Default is the whole email address (
:all
).- comparator
- Specifies the comparator to be used instead of the default
i;ascii-casemap
.- match-type
- Specifies the match type to be used instead of the default
:is
.The
- envelope-parts
- A list of envelope parts to operate upon.
- key-list
- A list of address values.
envelope
test is true if the specified part of the smtp envelope matches the specified key.If the envelope-part strings is (case insensitive) ‘from’, then matching occurs against the FROM address used in the SMTP MAIL command.
Notice, that due to the limitations imposed by smtp envelope structure the use of any other values in envelope-parts header is meaningless.
Required arguments:
- header-names
- List of message header names.
Theexists
test istrue
if the headers listed in header-names argument exist within the message. All of the headers must exist or the test is false.The following example throws out mail that doesn't have a From header and a Date header:
if not exists ["From","Date"] { discard; }
Tagged arguments:
- comparator
- Specifies the comparator to be used instead of the default
i;ascii-casemap
.- match-type
- Specifies the match type to be used instead of the default
:is
.- :mime
- This tag instructs
header
to search through the mime headers in multipart messages as well.Required arguments:
- header-names
- A list of header names.
- key-list
- A list of header values.
Theheader
test evaluates to true if any header name matches any key. The type of match is specified by the optional match argument, which defaults to ":is" if not explicitly given.The test returns
true
if any combination of the header-names and key-list arguments match.If a header listed in header-names exists, it contains the null key (‘""’). However, if the named header is not present, it does not contain the null key. So if a message contained the header
X-Caffeine: C8H10N4O2these tests on that header evaluate as follows:header :is ["X-Caffeine"] [""] => false header :contains ["X-Caffeine"] [""] => true
This test is provided as an example of loadable extension tests. You must use ‘require "test-numaddr"’ statement before actually using it.
The
numaddr
test counts Internet addresses in structured headers that contain addresses. It returns true if the total number of addresses satisfies the requested relation.If the tagged argument is ‘:over’ and the number of addresses is greater than number, the test is true; otherwise, it is false.
If the tagged argument is ‘:under’ and the number of addresses is less than number, the test is true; otherwise, it is false.
If the tagged argument is not given, ‘:over’ is assumed.
The gnu libsieve supports the following default actions:
Among them the first three actions do not need to be explicitly required
by a require
statement, while the others do.
These actions are described in detail below.
The
stop
action ends all processing. If no actions have been executed, then thekeep
action is taken.
The effect of this action is to preserve the current message in the mailbox. This action is executed if no other action has been executed.
Discard
silently throws away the current message. No notification is returned to the sender, the message is deleted from the mailbox.Example:
if header :contains ["from"] ["idiot@example.edu"] { discard; }
Required arguments:
- folder
- A string representing the folder name
The
fileinto
action delivers the message into the specified folder.
The optional
reject
action refuses delivery of a message by sending back a message delivery notification to the sender. It resends the message to the sender, wrapping it in a “reject” form, noting that it was rejected by the recipient. The required argument reason is a string specifying the reason for rejecting the message.Example:
If the message contained
Date: Tue, 1 Apr 1997 09:06:31 -0800 (PST) From: coyote@desert.example.org To: roadrunner@acme.example.com Subject: I have a present for you I've got some great birdseed over here at my place. Want to buy it?
and the user's script contained:if header :contains "from" "coyote@desert.example.org" { reject "I am not taking mail from you, and I don't want your birdseed, either!"; }then the original sender <coyote@desert.example.org> would receive the following notification:
To: <coyote@desert.example.org> X-Authentication-Warning: roadrunner set sender using -f flag Content-Type: multipart/mixed; boundary=----- =_aaaaaaaaaa0 MIME-Version: 1.0 ----- =_aaaaaaaaaa0 The original message was received at Tue, 1 Apr 1997 09:07:15 -0800 from coyote@desert.example.org. Message was refused by recipient's mail filtering program. Reason given was as follows: I am not taking mail from you, and I don't want your birdseed, either! ----- =_aaaaaaaaaa0 Content-Type: message/delivery-status Reporting-UA: sieve; GNU Mailutils 0.1.3 Arrival-Date: Tue, 1 Apr 1997 09:07:15 -0800 Final-Recipient: RFC822; roadrunner@acme.example.com Action: deleted Disposition: automatic-action/MDN-sent-automatically;deleted Last-Attempt-Date: Tue, 1 Apr 1997 09:07:15 -0800 ----- =_aaaaaaaaaa0 Content-Type: message/rfc822 From: coyote@desert.example.org To: roadrunner@acme.example.com Subject: I have a present for you I've got some great birdseed over here at my place. Want to buy it? ----- =_aaaaaaaaaa0If the reason argument is rather long, the common approach is to use the combination of the
text:
and#include
keywords, e.g.:if header :mime :matches "Content-Type" [ "*application/msword;*", "*audio/x-midi*" ] { reject text: #include "nomsword.txt" . ; }
The
redirect
action is used to send the message to another user at a supplied address, as a mail forwarding feature does. This action makes no changes to the message body or existing headers, but it may add new headers. It also modifies the envelope recipient.The
redirect
command performs an MTA-style “forward” — that is, what you get from a .forward file usingsendmail
under unix. The address on the SMTP envelope is replaced with the one on theredirect
command and the message is sent back out. Notice, that it differs from the MUA-style forward, which creates a new message with a different sender and message ID, wrapping the old message in a new one.
This section summarizes the gnu extensions to the sieve language
GNU libsieve understands the following multiline string syntax:
text:[-][delimiter] .... delimiter
The meaning of optional flags is the same as in shell “here document” construct: the dash strips all leading tab characters from the string body, thus allowing it to be indented in a natural fashion; delimiter introduces the new end-of-text delimiter instead of the default dot. If delimiter starts with a backslash, no preprocessing will be performed within a string.
require
statement.
require
appears
after a command other than require
. The gnu sieve library allows
interspersing the require
and other statements. The only
requirement is that require
must occur before a statement that is
using the required capability (see Require Statement).
header
test
The header
takes an optional argument :mime
, meaning to
scan the headers from each part of a multipart message.
size
test
The size
test allows to omit the optional argument
(:over|:under). In this case exact equality is assumed.
envelope
test
The only value that can be meaningfully used as the first required
argument of an envelope
test is ‘from’. This limitation
may disappear from the subsequent releases.
Along with the usual :is
, :matches
and contains
matching type, gnu sieve library understands :regex
type. This
matching type toggles POSIX Extended Regular Expression matching.
Email bug reports to bug-mailutils@gnu.org. Be sure to include the word “mailutils” somewhere in the “Subject:” field.
As the purpose of bug reporting is to improve software, please be sure to include maximum information when reporting a bug. The information needed is:
The archives of bug-mailutils mailing list are available from http://mail.gnu.org/mailman/listinfo/bug-mailutils.
The two places to look for any news regarding gnu Mailutils are the Mailutils homepage at http://www.gnu.org/software/mailutils, and the project page at http://savannah.gnu.org/projects/mailutils.
The updated versions of this manual are available online from http://www.gnu.org/software/mailutils/manual.
In no particular order,
Copyright © 2000,2001,2002 Free Software Foundation, Inc. 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA Everyone is permitted to copy and distribute verbatim copies of this license document, but changing it is not allowed.
The purpose of this License is to make a manual, textbook, or other functional and useful document free in the sense of freedom: to assure everyone the effective freedom to copy and redistribute it, with or without modifying it, either commercially or noncommercially. Secondarily, this License preserves for the author and publisher a way to get credit for their work, while not being considered responsible for modifications made by others.
This License is a kind of “copyleft”, which means that derivative works of the document must themselves be free in the same sense. It complements the GNU General Public License, which is a copyleft license designed for free software.
We have designed this License in order to use it for manuals for free software, because free software needs free documentation: a free program should come with manuals providing the same freedoms that the software does. But this License is not limited to software manuals; it can be used for any textual work, regardless of subject matter or whether it is published as a printed book. We recommend this License principally for works whose purpose is instruction or reference.
This License applies to any manual or other work, in any medium, that contains a notice placed by the copyright holder saying it can be distributed under the terms of this License. Such a notice grants a world-wide, royalty-free license, unlimited in duration, to use that work under the conditions stated herein. The “Document”, below, refers to any such manual or work. Any member of the public is a licensee, and is addressed as “you”. You accept the license if you copy, modify or distribute the work in a way requiring permission under copyright law.
A “Modified Version” of the Document means any work containing the Document or a portion of it, either copied verbatim, or with modifications and/or translated into another language.
A “Secondary Section” is a named appendix or a front-matter section of the Document that deals exclusively with the relationship of the publishers or authors of the Document to the Document's overall subject (or to related matters) and contains nothing that could fall directly within that overall subject. (Thus, if the Document is in part a textbook of mathematics, a Secondary Section may not explain any mathematics.) The relationship could be a matter of historical connection with the subject or with related matters, or of legal, commercial, philosophical, ethical or political position regarding them.
The “Invariant Sections” are certain Secondary Sections whose titles are designated, as being those of Invariant Sections, in the notice that says that the Document is released under this License. If a section does not fit the above definition of Secondary then it is not allowed to be designated as Invariant. The Document may contain zero Invariant Sections. If the Document does not identify any Invariant Sections then there are none.
The “Cover Texts” are certain short passages of text that are listed, as Front-Cover Texts or Back-Cover Texts, in the notice that says that the Document is released under this License. A Front-Cover Text may be at most 5 words, and a Back-Cover Text may be at most 25 words.
A “Transparent” copy of the Document means a machine-readable copy, represented in a format whose specification is available to the general public, that is suitable for revising the document straightforwardly with generic text editors or (for images composed of pixels) generic paint programs or (for drawings) some widely available drawing editor, and that is suitable for input to text formatters or for automatic translation to a variety of formats suitable for input to text formatters. A copy made in an otherwise Transparent file format whose markup, or absence of markup, has been arranged to thwart or discourage subsequent modification by readers is not Transparent. An image format is not Transparent if used for any substantial amount of text. A copy that is not “Transparent” is called “Opaque”.
Examples of suitable formats for Transparent copies include plain ascii without markup, Texinfo input format, LaTeX input format, SGML or XML using a publicly available DTD, and standard-conforming simple HTML, PostScript or PDF designed for human modification. Examples of transparent image formats include PNG, XCF and JPG. Opaque formats include proprietary formats that can be read and edited only by proprietary word processors, SGML or XML for which the DTD and/or processing tools are not generally available, and the machine-generated HTML, PostScript or PDF produced by some word processors for output purposes only.
The “Title Page” means, for a printed book, the title page itself, plus such following pages as are needed to hold, legibly, the material this License requires to appear in the title page. For works in formats which do not have any title page as such, “Title Page” means the text near the most prominent appearance of the work's title, preceding the beginning of the body of the text.
A section “Entitled XYZ” means a named subunit of the Document whose title either is precisely XYZ or contains XYZ in parentheses following text that translates XYZ in another language. (Here XYZ stands for a specific section name mentioned below, such as “Acknowledgements”, “Dedications”, “Endorsements”, or “History”.) To “Preserve the Title” of such a section when you modify the Document means that it remains a section “Entitled XYZ” according to this definition.
The Document may include Warranty Disclaimers next to the notice which states that this License applies to the Document. These Warranty Disclaimers are considered to be included by reference in this License, but only as regards disclaiming warranties: any other implication that these Warranty Disclaimers may have is void and has no effect on the meaning of this License.
You may copy and distribute the Document in any medium, either commercially or noncommercially, provided that this License, the copyright notices, and the license notice saying this License applies to the Document are reproduced in all copies, and that you add no other conditions whatsoever to those of this License. You may not use technical measures to obstruct or control the reading or further copying of the copies you make or distribute. However, you may accept compensation in exchange for copies. If you distribute a large enough number of copies you must also follow the conditions in section 3.
You may also lend copies, under the same conditions stated above, and you may publicly display copies.
If you publish printed copies (or copies in media that commonly have printed covers) of the Document, numbering more than 100, and the Document's license notice requires Cover Texts, you must enclose the copies in covers that carry, clearly and legibly, all these Cover Texts: Front-Cover Texts on the front cover, and Back-Cover Texts on the back cover. Both covers must also clearly and legibly identify you as the publisher of these copies. The front cover must present the full title with all words of the title equally prominent and visible. You may add other material on the covers in addition. Copying with changes limited to the covers, as long as they preserve the title of the Document and satisfy these conditions, can be treated as verbatim copying in other respects.
If the required texts for either cover are too voluminous to fit legibly, you should put the first ones listed (as many as fit reasonably) on the actual cover, and continue the rest onto adjacent pages.
If you publish or distribute Opaque copies of the Document numbering more than 100, you must either include a machine-readable Transparent copy along with each Opaque copy, or state in or with each Opaque copy a computer-network location from which the general network-using public has access to download using public-standard network protocols a complete Transparent copy of the Document, free of added material. If you use the latter option, you must take reasonably prudent steps, when you begin distribution of Opaque copies in quantity, to ensure that this Transparent copy will remain thus accessible at the stated location until at least one year after the last time you distribute an Opaque copy (directly or through your agents or retailers) of that edition to the public.
It is requested, but not required, that you contact the authors of the Document well before redistributing any large number of copies, to give them a chance to provide you with an updated version of the Document.
You may copy and distribute a Modified Version of the Document under the conditions of sections 2 and 3 above, provided that you release the Modified Version under precisely this License, with the Modified Version filling the role of the Document, thus licensing distribution and modification of the Modified Version to whoever possesses a copy of it. In addition, you must do these things in the Modified Version:
If the Modified Version includes new front-matter sections or appendices that qualify as Secondary Sections and contain no material copied from the Document, you may at your option designate some or all of these sections as invariant. To do this, add their titles to the list of Invariant Sections in the Modified Version's license notice. These titles must be distinct from any other section titles.
You may add a section Entitled “Endorsements”, provided it contains nothing but endorsements of your Modified Version by various parties—for example, statements of peer review or that the text has been approved by an organization as the authoritative definition of a standard.
You may add a passage of up to five words as a Front-Cover Text, and a passage of up to 25 words as a Back-Cover Text, to the end of the list of Cover Texts in the Modified Version. Only one passage of Front-Cover Text and one of Back-Cover Text may be added by (or through arrangements made by) any one entity. If the Document already includes a cover text for the same cover, previously added by you or by arrangement made by the same entity you are acting on behalf of, you may not add another; but you may replace the old one, on explicit permission from the previous publisher that added the old one.
The author(s) and publisher(s) of the Document do not by this License give permission to use their names for publicity for or to assert or imply endorsement of any Modified Version.
You may combine the Document with other documents released under this License, under the terms defined in section 4 above for modified versions, provided that you include in the combination all of the Invariant Sections of all of the original documents, unmodified, and list them all as Invariant Sections of your combined work in its license notice, and that you preserve all their Warranty Disclaimers.
The combined work need only contain one copy of this License, and multiple identical Invariant Sections may be replaced with a single copy. If there are multiple Invariant Sections with the same name but different contents, make the title of each such section unique by adding at the end of it, in parentheses, the name of the original author or publisher of that section if known, or else a unique number. Make the same adjustment to the section titles in the list of Invariant Sections in the license notice of the combined work.
In the combination, you must combine any sections Entitled “History” in the various original documents, forming one section Entitled “History”; likewise combine any sections Entitled “Acknowledgements”, and any sections Entitled “Dedications”. You must delete all sections Entitled “Endorsements.”
You may make a collection consisting of the Document and other documents released under this License, and replace the individual copies of this License in the various documents with a single copy that is included in the collection, provided that you follow the rules of this License for verbatim copying of each of the documents in all other respects.
You may extract a single document from such a collection, and distribute it individually under this License, provided you insert a copy of this License into the extracted document, and follow this License in all other respects regarding verbatim copying of that document.
A compilation of the Document or its derivatives with other separate and independent documents or works, in or on a volume of a storage or distribution medium, is called an “aggregate” if the copyright resulting from the compilation is not used to limit the legal rights of the compilation's users beyond what the individual works permit. When the Document is included an aggregate, this License does not apply to the other works in the aggregate which are not themselves derivative works of the Document.
If the Cover Text requirement of section 3 is applicable to these copies of the Document, then if the Document is less than one half of the entire aggregate, the Document's Cover Texts may be placed on covers that bracket the Document within the aggregate, or the electronic equivalent of covers if the Document is in electronic form. Otherwise they must appear on printed covers that bracket the whole aggregate.
Translation is considered a kind of modification, so you may distribute translations of the Document under the terms of section 4. Replacing Invariant Sections with translations requires special permission from their copyright holders, but you may include translations of some or all Invariant Sections in addition to the original versions of these Invariant Sections. You may include a translation of this License, and all the license notices in the Document, and any Warranty Disclaimers, provided that you also include the original English version of this License and the original versions of those notices and disclaimers. In case of a disagreement between the translation and the original version of this License or a notice or disclaimer, the original version will prevail.
If a section in the Document is Entitled “Acknowledgements”, “Dedications”, or “History”, the requirement (section 4) to Preserve its Title (section 1) will typically require changing the actual title.
You may not copy, modify, sublicense, or distribute the Document except as expressly provided for under this License. Any other attempt to copy, modify, sublicense or distribute the Document is void, and will automatically terminate your rights under this License. However, parties who have received copies, or rights, from you under this License will not have their licenses terminated so long as such parties remain in full compliance.
The Free Software Foundation may publish new, revised versions of the GNU Free Documentation License from time to time. Such new versions will be similar in spirit to the present version, but may differ in detail to address new problems or concerns. See http://www.gnu.org/copyleft/.
Each version of the License is given a distinguishing version number. If the Document specifies that a particular numbered version of this License “or any later version” applies to it, you have the option of following the terms and conditions either of that specified version or of any later version that has been published (not as a draft) by the Free Software Foundation. If the Document does not specify a version number of this License, you may choose any version ever published (not as a draft) by the Free Software Foundation.
To use this License in a document you have written, include a copy of the License in the document and put the following copyright and license notices just after the title page:
Copyright (C) year your name. Permission is granted to copy, distribute and/or modify this document under the terms of the GNU Free Documentation License, Version 1.2 or any later version published by the Free Software Foundation; with no Invariant Sections, no Front-Cover Texts, and no Back-Cover Texts. A copy of the license is included in the section entitled ``GNU Free Documentation License''.
If you have Invariant Sections, Front-Cover Texts and Back-Cover Texts, replace the “with...Texts.” line with this:
with the Invariant Sections being list their titles, with the Front-Cover Texts being list, and with the Back-Cover Texts being list.
If you have Invariant Sections without Cover Texts, or some other combination of the three, merge those two alternatives to suit the situation.
If your document contains nontrivial examples of program code, we recommend releasing these examples in parallel under your choice of free software license, such as the GNU General Public License, to permit their use in free software.
This is an alphabetical list of all Mailutils functions.
address
: Testsconcat
: Format String Diffsdecode
: Format String Diffsdiscard
: Actionsenvelope
: Testsexists
: Testsfalse
: Testsfileinto
: Actionsheader
: Testsin_reply_to
: Format String Diffsint
: Streamisreply
: Format String Diffskeep
: Actionsmu-address-get-comments
: Address Functionsmu-address-get-count
: Address Functionsmu-address-get-domain
: Address Functionsmu-address-get-email
: Address Functionsmu-address-get-local
: Address Functionsmu-address-get-personal
: Address Functionsmu-body-read-line
: Message Functionsmu-body-write
: Message Functionsmu-closelog
: Logging Functionsmu-folder-directory
: Mailbox Functionsmu-logger
: Logging Functionsmu-mail-directory
: Mailbox Functionsmu-mailbox-append-message
: Mailbox Functionsmu-mailbox-close
: Mailbox Functionsmu-mailbox-expunge
: Mailbox Functionsmu-mailbox-get-message
: Mailbox Functionsmu-mailbox-get-port
: Mailbox Functionsmu-mailbox-get-url
: Mailbox Functionsmu-mailbox-messages-count
: Mailbox Functionsmu-mailbox-open
: Mailbox Functionsmu-message-copy
: Message Functionsmu-message-create
: Message Functionsmu-message-delete
: Message Functionsmu-message-destroy
: Message Functionsmu-message-get-body
: Message Functionsmu-message-get-flag
: Message Functionsmu-message-get-header
: Message Functionsmu-message-get-header-fields
: Message Functionsmu-message-get-lines
: Message Functionsmu-message-get-num-parts
: Message Functionsmu-message-get-part
: Message Functionsmu-message-get-port
: Message Functionsmu-message-get-sender
: Message Functionsmu-message-get-size
: Message Functionsmu-message-get-uid
: Message Functionsmu-message-get-user-flag
: Message Functionsmu-message-multipart?
: Message Functionsmu-message-send
: Message Functionsmu-message-set-flag
: Message Functionsmu-message-set-header
: Message Functionsmu-message-set-header-fields
: Message Functionsmu-message-set-user-flag
: Message Functionsmu-mime-add-part
: MIME Functionsmu-mime-create
: MIME Functionsmu-mime-get-message
: MIME Functionsmu-mime-get-num-parts
: MIME Functionsmu-mime-get-part
: MIME Functionsmu-mime-multipart?
: MIME Functionsmu-openlog
: Logging Functionsmu-register-format
: Other Functionsmu-strerror
: Other Functionsmu-username->email
: Address Functionsmu_address_aget_domain
: Addressmu_address_aget_email
: Addressmu_address_aget_local_part
: Addressmu_address_aget_personal
: Addressmu_address_contains_email
: Addressmu_address_create
: Addressmu_address_createv
: Addressmu_address_destroy
: Addressmu_address_format_string
: Addressmu_address_get_comments
: Addressmu_address_get_count
: Addressmu_address_get_domain
: Addressmu_address_get_email
: Addressmu_address_get_email_count
: Addressmu_address_get_group_count
: Addressmu_address_get_local_part
: Addressmu_address_get_nth
: Addressmu_address_get_personal
: Addressmu_address_get_route
: Addressmu_address_get_unix_mailbox_count
: Addressmu_address_is_group
: Addressmu_address_t
: Addressmu_address_to_string
: Addressmu_address_union
: Addressmu_attribute_clear_modified
: Attributemu_attribute_copy
: Attributemu_attribute_create
: Attributemu_attribute_destroy
: Attributemu_attribute_get_flags
: Attributemu_attribute_get_owner
: Attributemu_attribute_is_answered
: Attributemu_attribute_is_deleted
: Attributemu_attribute_is_draft
: Attributemu_attribute_is_equal
: Attributemu_attribute_is_flagged
: Attributemu_attribute_is_modified
: Attributemu_attribute_is_read
: Attributemu_attribute_is_recent
: Attributemu_attribute_is_seen
: Attributemu_attribute_is_userflag
: Attributemu_attribute_set_answered
: Attributemu_attribute_set_deleted
: Attributemu_attribute_set_draft
: Attributemu_attribute_set_flagged
: Attributemu_attribute_set_flags
: Attributemu_attribute_set_get_flags
: Attributemu_attribute_set_modified
: Attributemu_attribute_set_read
: Attributemu_attribute_set_recent
: Attributemu_attribute_set_seen
: Attributemu_attribute_set_set_flags
: Attributemu_attribute_set_unset_flags
: Attributemu_attribute_set_userflag
: Attributemu_attribute_to_string
: Attributemu_attribute_unset_answered
: Attributemu_attribute_unset_deleted
: Attributemu_attribute_unset_draft
: Attributemu_attribute_unset_flagged
: Attributemu_attribute_unset_flags
: Attributemu_attribute_unset_read
: Attributemu_attribute_unset_recent
: Attributemu_attribute_unset_seen
: Attributemu_attribute_unset_userflag
: Attributemu_auth_data
: Data Typesmu_auth_data_alloc
: Module Creation and Destructionmu_auth_data_free
: Module Creation and Destructionmu_auth_fp
: Data Typesmu_auth_init
: Initializing libmuauthmu_auth_module
: Data Typesmu_auth_nosupport
: Existing ModulesMU_AUTH_REGISTER_ALL_MODULES
: Initializing libmuauthmu_auth_register_module
: Module Creation and Destructionmu_auth_runlist
: Obtaining Authorization Informationmu_authenticate
: Obtaining Authorization Informationmu_authority_authenticate
: Authenticatormu_authority_create
: Authenticatormu_authority_create_null
: Authenticatormu_authority_destroy
: Authenticatormu_authority_get_owner
: Authenticatormu_authority_get_ticket
: Authenticatormu_authority_set_authenticate
: Authenticatormu_authority_set_ticket
: Authenticatormu_body_clear_modified
: Bodymu_body_create
: Bodymu_body_destroy
: Bodymu_body_get_filename
: Bodymu_body_get_owner
: Bodymu_body_get_stream
: Bodymu_body_is_modified
: Bodymu_body_lines
: Bodymu_body_set_lines
: Bodymu_body_set_size
: Bodymu_body_set_stream
: Bodymu_body_size
: Bodymu_decoder_stream_create
: Streammu_encoder_stream_create
: Streammu_envelope_create
: Envelopemu_envelope_date
: Envelopemu_envelope_destroy
: Envelopemu_envelope_get_owner
: Envelopemu_envelope_sender
: Envelopemu_envelope_set_date
: Envelopemu_envelope_set_sender
: Envelopemu_file_stream_create
: Streammu_filter_prog_stream_create
: Streammu_folder_close
: Foldermu_folder_create
: Foldermu_folder_delete
: Foldermu_folder_destroy
: Foldermu_folder_get_authority
: Foldermu_folder_get_debug
: Foldermu_folder_get_observable
: Foldermu_folder_get_stream
: Foldermu_folder_get_url
: Foldermu_folder_has_debug
: Foldermu_folder_list
: Foldermu_folder_lsub
: Foldermu_folder_open
: Foldermu_folder_rename
: Foldermu_folder_set_authority
: Foldermu_folder_set_debug
: Foldermu_folder_set_stream
: Foldermu_folder_set_url
: Foldermu_folder_subscribe
: Foldermu_folder_unsubscribe
: Foldermu_get_auth_by_name
: Obtaining Authorization Informationmu_get_auth_by_uid
: Obtaining Authorization Informationmu_header_aget_field_name
: Headersmu_header_aget_field_value
: Headersmu_header_aget_field_value_unfold
: Headersmu_header_aget_value
: Headersmu_header_aget_value_unfold
: Headersmu_header_clear_modified
: Headersmu_header_create
: Headersmu_header_destroy
: Headersmu_header_get_address
: Headersmu_header_get_field_count
: Headersmu_header_get_field_name
: Headersmu_header_get_field_value
: Headersmu_header_get_field_value_unfold
: Headersmu_header_get_owner
: Headersmu_header_get_stream
: Headersmu_header_get_value
: Headersmu_header_get_value_unfold
: Headersmu_header_is_modified
: Headersmu_header_lines
: Headersmu_header_set_fill
: Headersmu_header_set_get_fvalue
: Headersmu_header_set_get_value
: Headersmu_header_set_lines
: Headersmu_header_set_set_value
: Headersmu_header_set_size
: Headersmu_header_set_stream
: Headersmu_header_set_value
: Headersmu_header_size
: Headersmu_iterator_advance
: Iteratormu_iterator_attach
: Iteratormu_iterator_create
: Iteratormu_iterator_current
: Iteratormu_iterator_destroy
: Iteratormu_iterator_detach
: Iteratormu_iterator_dup
: Iteratormu_iterator_first
: Iteratormu_iterator_is_done
: Iteratormu_iterator_next
: Iteratormu_iterator_set_curitem_p
: Iteratormu_iterator_set_destroy
: Iteratormu_iterator_set_dup
: Iteratormu_iterator_set_finished_p
: Iteratormu_iterator_set_first
: Iteratormu_iterator_set_getitem
: Iteratormu_iterator_set_next
: Iteratormu_locker_create
: Lockermu_locker_destroy
: Lockermu_locker_get_expire_time
: Lockermu_locker_get_external
: Lockermu_locker_get_flags
: Lockermu_locker_get_retries
: Lockermu_locker_get_retry_sleep
: Lockermu_locker_lock
: Lockermu_locker_remove_lock
: Lockermu_locker_set_default_expire_timeout
: Lockermu_locker_set_default_external_program
: Lockermu_locker_set_default_flags
: Lockermu_locker_set_default_retry_count
: Lockermu_locker_set_default_retry_timeout
: Lockermu_locker_set_expire_time
: Lockermu_locker_set_external
: Lockermu_locker_set_flags
: Lockermu_locker_set_retries
: Lockermu_locker_set_retry_sleep
: Lockermu_locker_touchlock
: Lockermu_locker_unlock
: Lockermu_mailbox_append_message
: Mailboxmu_mailbox_close
: Mailboxmu_mailbox_create
: Mailboxmu_mailbox_create_default
: Mailboxmu_mailbox_destroy
: Mailboxmu_mailbox_expunge
: Mailboxmu_mailbox_flush
: Mailboxmu_mailbox_get_debug
: Mailboxmu_mailbox_get_folder
: Mailboxmu_mailbox_get_locker
: Mailboxmu_mailbox_get_message
: Mailboxmu_mailbox_get_observable
: Mailboxmu_mailbox_get_property
: Mailboxmu_mailbox_get_size
: Mailboxmu_mailbox_get_stream
: Mailboxmu_mailbox_get_url
: Mailboxmu_mailbox_has_debug
: Mailboxmu_mailbox_is_updated
: Mailboxmu_mailbox_lock
: Mailboxmu_mailbox_message_unseen
: Mailboxmu_mailbox_messages_count
: Mailboxmu_mailbox_messages_recent
: Mailboxmu_mailbox_open
: Mailboxmu_mailbox_save_attributes
: Mailboxmu_mailbox_scan
: Mailboxmu_mailbox_set_debug
: Mailboxmu_mailbox_set_folder
: Mailboxmu_mailbox_set_locker
: Mailboxmu_mailbox_set_stream
: Mailboxmu_mailbox_t
: Mailboxmu_mailbox_uidnext
: Mailboxmu_mailbox_uidvalidity
: Mailboxmu_mailbox_unlock
: Mailboxmu_mailcap_create
: Mailcapmu_mailcap_destroy
: Mailcapmu_mailcap_entries_count
: Mailcapmu_mailcap_entry_copiousoutput
: Mailcapmu_mailcap_entry_fields_count
: Mailcapmu_mailcap_entry_get_compose
: Mailcapmu_mailcap_entry_get_composetyped
: Mailcapmu_mailcap_entry_get_description
: Mailcapmu_mailcap_entry_get_edit
: Mailcapmu_mailcap_entry_get_field
: Mailcapmu_mailcap_entry_get_nametemplate
: Mailcapmu_mailcap_entry_get_notes
: Mailcapmu_mailcap_entry_get_test
: Mailcapmu_mailcap_entry_get_textualnewlines
: Mailcapmu_mailcap_entry_get_typefield
: Mailcapmu_mailcap_entry_get_value
: Mailcapmu_mailcap_entry_get_viewcommand
: Mailcapmu_mailcap_entry_get_x11bitmap
: Mailcapmu_mailcap_entry_needsterminal
: Mailcapmu_mailcap_get_entry
: Mailcapmu_mailcap_t
: Mailcapmu_mailer_check_from
: Mailermu_mailer_check_to
: Mailermu_mailer_close
: Mailermu_mailer_create
: Mailermu_mailer_destroy
: Mailermu_mailer_get_debug
: Mailermu_mailer_get_observable
: Mailermu_mailer_get_property
: Mailermu_mailer_get_stream
: Mailermu_mailer_get_url
: Mailermu_mailer_open
: Mailermu_mailer_send_message
: Mailermu_mailer_set_debug
: Mailermu_mailer_set_stream
: Mailermu_mapfile_stream_create
: Streammu_memory_stream_create
: Streammu_message_aget_attachment_name
: Messagemu_message_clear_modified
: Messagemu_message_create
: Messagemu_message_create_attachment
: Messagemu_message_create_copy
: Messagemu_message_destroy
: Messagemu_message_encapsulate
: Messagemu_message_get_attachment_name
: Messagemu_message_get_attribute
: Messagemu_message_get_body
: Messagemu_message_get_envelope
: Messagemu_message_get_header
: Messagemu_message_get_mailbox
: Messagemu_message_get_num_parts
: Messagemu_message_get_observable
: Messagemu_message_get_owner
: Messagemu_message_get_part
: Messagemu_message_get_stream
: Messagemu_message_get_uid
: Messagemu_message_get_uidl
: Messagemu_message_is_modified
: Messagemu_message_is_multipart
: Messagemu_message_lines
: Messagemu_message_ref
: Messagemu_message_save_attachment
: Messagemu_message_save_to_mailbox
: Messagemu_message_set_attribute
: Messagemu_message_set_body
: Messagemu_message_set_envelope
: Messagemu_message_set_get_num_parts
: Messagemu_message_set_get_part
: Messagemu_message_set_header
: Messagemu_message_set_is_multipart
: Messagemu_message_set_lines
: Messagemu_message_set_mailbox
: Messagemu_message_set_size
: Messagemu_message_set_stream
: Messagemu_message_set_uid
: Messagemu_message_set_uidl
: Messagemu_message_size
: Messagemu_message_unencapsulate
: Messagemu_parse822_addr_spec
: Parse822mu_parse822_address
: Parse822mu_parse822_address_list
: Parse822mu_parse822_atom
: Parse822mu_parse822_comment
: Parse822mu_parse822_d_text
: Parse822mu_parse822_date
: Parse822mu_parse822_date_time
: Parse822mu_parse822_day
: Parse822mu_parse822_digits
: Parse822mu_parse822_domain
: Parse822mu_parse822_domain_literal
: Parse822mu_parse822_domain_ref
: Parse822mu_parse822_field_body
: Parse822mu_parse822_field_name
: Parse822mu_parse822_group
: Parse822mu_parse822_is_atom_char
: Parse822mu_parse822_is_char
: Parse822mu_parse822_is_ctl
: Parse822mu_parse822_is_d_text
: Parse822mu_parse822_is_digit
: Parse822mu_parse822_is_htab
: Parse822mu_parse822_is_lwsp_char
: Parse822mu_parse822_is_q_text
: Parse822mu_parse822_is_smtp_q
: Parse822mu_parse822_is_space
: Parse822mu_parse822_is_special
: Parse822mu_parse822_local_part
: Parse822mu_parse822_mail_box
: Parse822mu_parse822_phrase
: Parse822mu_parse822_quote_local_part
: Parse822mu_parse822_quote_string
: Parse822mu_parse822_quoted_pair
: Parse822mu_parse822_quoted_string
: Parse822mu_parse822_route
: Parse822mu_parse822_route_addr
: Parse822mu_parse822_skip_comments
: Parse822mu_parse822_skip_crlf
: Parse822mu_parse822_skip_lwsp
: Parse822mu_parse822_skip_lwsp_char
: Parse822mu_parse822_skip_nl
: Parse822mu_parse822_special
: Parse822mu_parse822_sub_domain
: Parse822mu_parse822_time
: Parse822mu_parse822_unix_mbox
: Parse822mu_parse822_word
: Parse822mu_prog_stream_create
: Streammu_sieve_abort
: Logging and Diagnostic Functionsmu_sieve_action_log_t
: Sieve Data Typesmu_sieve_action_lookup
: Symbol Space Functionsmu_sieve_comparator_t
: Sieve Data Typesmu_sieve_compile
: Compiling and Executing the Scriptmu_sieve_data_type
: Sieve Data Typesmu_sieve_debug
: Logging and Diagnostic Functionsmu_sieve_destructor_t
: Sieve Data Typesmu_sieve_disass
: Compiling and Executing the Scriptmu_sieve_error
: Logging and Diagnostic Functionsmu_sieve_get_daemon_email
: Manipulating the Sieve Machinemu_sieve_get_data
: Manipulating the Sieve Machinemu_sieve_get_debug_level
: Manipulating the Sieve Machinemu_sieve_get_locus
: Manipulating the Sieve Machinemu_sieve_get_mailer
: Manipulating the Sieve Machinemu_sieve_get_message
: Manipulating the Sieve Machinemu_sieve_get_message_num
: Manipulating the Sieve Machinemu_sieve_get_ticket
: Manipulating the Sieve Machinemu_sieve_handler_t
: Sieve Data Typesmu_sieve_is_dry_run
: Manipulating the Sieve Machinemu_sieve_load_ext
: Symbol Space Functionsmu_sieve_locus_t
: Sieve Data Typesmu_sieve_log_action
: Logging and Diagnostic Functionsmu_sieve_machine_add_destructor
: Manipulating the Sieve Machinemu_sieve_machine_destroy
: Manipulating the Sieve Machinemu_sieve_machine_init
: Manipulating the Sieve Machinemu_sieve_mailbox
: Compiling and Executing the Scriptmu_sieve_malloc
: Memory Allocationmu_sieve_message
: Compiling and Executing the Scriptmu_sieve_mfree
: Memory Allocationmu_sieve_mrealloc
: Memory Allocationmu_sieve_mstrdup
: Memory Allocationmu_sieve_parse_error_t
: Sieve Data Typesmu_sieve_printf_t
: Sieve Data Typesmu_sieve_register_action
: Symbol Space Functionsmu_sieve_register_comparator
: Symbol Space Functionsmu_sieve_register_test
: Symbol Space Functionsmu_sieve_relcmp_t
: Sieve Data Typesmu_sieve_relcmpn_t
: Sieve Data Typesmu_sieve_retrieve_t
: Sieve Data Typesmu_sieve_runtime_tag_t
: Sieve Data Typesmu_sieve_set_daemon_email
: Manipulating the Sieve Machinemu_sieve_set_debug
: Manipulating the Sieve Machinemu_sieve_set_debug_level
: Manipulating the Sieve Machinemu_sieve_set_error
: Manipulating the Sieve Machinemu_sieve_set_logger
: Manipulating the Sieve Machinemu_sieve_set_mailer
: Manipulating the Sieve Machinemu_sieve_set_parse_error
: Manipulating the Sieve Machinemu_sieve_set_ticket
: Manipulating the Sieve Machinemu_sieve_tag_checker_t
: Sieve Data Typesmu_sieve_tag_def_t
: Sieve Data Typesmu_sieve_tag_lookup
: Symbol Space Functionsmu_sieve_test_lookup
: Symbol Space Functionsmu_sieve_type_str
: Manipulating the Sieve Machinemu_sieve_value_t
: Sieve Data Typesmu_stdio_stream_create
: StreamMU_STREAM_ALLOW_LINKS
: StreamMU_STREAM_APPEND
: Streammu_stream_close
: StreamMU_STREAM_CREAT
: Streammu_stream_create
: Streammu_stream_destroy
: Streammu_stream_flush
: Streammu_stream_get_fd
: Streammu_stream_get_fd2
: Streammu_stream_get_flags
: Streammu_stream_get_owner
: Streammu_stream_get_property
: Streammu_stream_get_state
: Streammu_stream_is_seekable
: StreamMU_STREAM_NO_CHECK
: StreamMU_STREAM_NO_CLOSE
: StreamMU_STREAM_NONBLOCK
: Streammu_stream_open
: StreamMU_STREAM_RDWR
: Streammu_stream_read
: StreamMU_STREAM_READ
: Streammu_stream_readline
: Streammu_stream_seek
: StreamMU_STREAM_SEEKABLE
: Streammu_stream_sequential_readline
: Streammu_stream_sequential_write
: Streammu_stream_set_close
: Streammu_stream_set_destroy
: Streammu_stream_set_fd
: Streammu_stream_set_flags
: Streammu_stream_set_flush
: Streammu_stream_set_open
: Streammu_stream_set_owner
: Streammu_stream_set_property
: Streammu_stream_set_read
: Streammu_stream_set_readline
: Streammu_stream_set_size
: Streammu_stream_set_strerror
: Streammu_stream_set_truncate
: Streammu_stream_set_write
: Streammu_stream_setbufsiz
: Streammu_stream_size
: Streammu_stream_strerror
: Streammu_stream_write
: StreamMU_STREAM_WRITE
: Streammu_tcp_stream_create
: Streammu_ticket_create
: Authenticatormu_ticket_destroy
: Authenticatormu_ticket_get_data
: Authenticatormu_ticket_get_owner
: Authenticatormu_ticket_pop
: Authenticatormu_ticket_set_data
: Authenticatormu_ticket_set_destroy
: Authenticatormu_ticket_set_pop
: Authenticatormu_url_create
: URLmu_url_decode
: URLmu_url_destroy
: URLmu_url_get_auth
: URLmu_url_get_host
: URLmu_url_get_passwd
: URLmu_url_get_path
: URLmu_url_get_port
: URLmu_url_get_query
: URLmu_url_get_scheme
: URLmu_url_get_user
: URLmu_url_is_same_host
: URLmu_url_is_same_path
: URLmu_url_is_same_port
: URLmu_url_is_same_scheme
: URLmu_url_is_same_user
: URLmu_url_is_scheme
: URLmu_url_is_ticket
: URLmu_url_parse
: URLmu_url_to_string
: URLmu_wicket_create
: Authenticatormu_wicket_destroy
: Authenticatormu_wicket_get_filename
: Authenticatormu_wicket_get_ticket
: Authenticatormu_wicket_set_filename
: Authenticatormu_wicket_set_ticket
: Authenticatornumaddr
: Testspackage
: Format String Diffspackage_string
: Format String Diffsprinthdr
: Format String Diffsrcpt
: Format String Diffsredirect
: Actionsreferences
: Format String Diffsreject
: Actionsreply_regex
: Format String Diffssieve_machine_t
: Sieve Data Typessize
: Testsstop
: Actionsstring_to_flags
: Attributetrue
: Testsunre
: Format String Diffsversion
: Format String Diffsappenddeadletter, mail variable
: Mail Variablesaskbcc, mail variable
: Mail Variablesaskcc, mail variable
: Mail Variablesasksub, mail variable
: Mail Variablesautoinc, mail variable
: Mail Variablesautoprint, mail variable
: Mail Variablesbang, mail variable
: Mail Variablescharset, mail variable
: Mail Variablescmd, mail variable
: Mail Variablescolumns, mail variable
: Mail Variablescrt, mail variable
: Mail Variablesdatefield, mail variable
: Mail Variablesdecode-fallback, mail variable
: Mail Variablesdot, mail variable
: Mail Variableseditheaders, mail variable
: Mail Variablesemptystart, mail variable
: Mail Variablesescape, mail variable
: Mail Variablesflipr, mail variable
: Mail Variablesfolder, mail variable
: Mail Variablesheader, mail variable
: Mail Variableshold, mail variable
: Mail Variablesignore, mail variable
: Mail Variablesignoreeof, mail variable
: Mail Variablesindentprefix, mail variable
: Mail Variableskeepsave, mail variable
: Mail Variablesmailx, mail variable
: Mail Variablesmetamail, mail variable
: Mail Variablesmetoo, mail variable
: Mail Variablesmimenoask, mail variable
: Mail Variablesmode, mail variable
: Mail Variablesmu_auth_generic_module
: Existing Modulesmu_auth_pam_module
: Existing Modulesmu_auth_sql_module
: Existing Modulesmu_auth_system_module
: Existing Modulesmu_auth_virtual_module
: Existing Modulesoutfolder, mail variable
: Mail Variablespage, mail variable
: Mail Variablesprompt, mail variable
: Mail Variablesquit, mail variable
: Mail Variablesrc, mail variable
: Mail Variablesrecord, mail variable
: Mail Variablesregex, mail variable
: Mail Variablesreplyprefix, mail variable
: Mail Variablesreplyregex, mail variable
: Mail Variablessave, mail variable
: Mail Variablesscreen, mail variable
: Mail Variablessendmail, mail variable
: Mail Variablesshowto, mail variable
: Mail Variablessign, mail variable
: Mail VariablesSign, mail variable
: Mail Variablesstring
: Profile Variable Diffssubject, mail variable
: Mail Variablestoplines, mail variable
: Mail Variablesverbose, mail variable
: Mail Variablesxmailer, mail variable
: Mail Variables!, mail command
: Shell Escapes=, mail command
: Displaying Information?, mail command
: Obtaining Online Helpalias, mail command
: Aliasingalternates, mail command
: Aliasingchdir, mail command
: Changing mailbox/directoryCopy, mail command
: Saving Messagescopy, mail command
: Saving Messagesdecode, mail command
: Displaying Messagesdelete, mail command
: Disposing of Messagesdiscard, mail command
: Controlling Header Displaydp, mail command
: Disposing of Messagesdt, mail command
: Disposing of Messagesecho, mail command
: Scriptingedit, mail command
: Editing Messageselse, mail command
: Scriptingendif, mail command
: Scriptingfile, mail command
: Changing mailbox/directoryfolder, mail command
: Changing mailbox/directoryfolders, mail command
: Displaying InformationFollowup, mail command
: Replyingfollowup, mail command
: Replyingfrom, mail command
: Displaying Informationgroup, mail command
: Aliasingheaders, mail command
: Displaying Informationhelp, mail command
: Obtaining Online Helphold, mail command
: Marking Messagesif, mail command
: Scriptingignore, mail command
: Controlling Header Displayincorporate, mail command
: Incorporating New Maillist, mail command
: Obtaining Online Helpmail, mail command
: Replyingmbox, mail command
: Saving Messagesnext, mail command
: Moving Within a Mailboxnosender, mail command
: Controlling Sender Fieldspipe, mail command
: Displaying Messagespreserve, mail command
: Marking Messagesprev, mail command
: Moving Within a MailboxPrint, mail command
: Displaying Messagesprint, mail command
: Displaying MessagesReply, mail command
: Replyingreply, mail command
: ReplyingRespond, mail command
: Replyingrespond, mail command
: Replyingretain, mail command
: Controlling Header DisplaySave, mail command
: Saving Messagessave, mail command
: Saving Messagessender, mail command
: Controlling Sender Fieldsset, mail command
: Scriptingshell, mail command
: Shell Escapessize, mail command
: Displaying Informationsource, mail command
: Scriptingsummary, mail command
: Displaying Informationtag, mail command
: Marking Messagestop, mail command
: Displaying Messagestouch, mail command
: Saving MessagesType, mail command
: Displaying Messagestype, mail command
: Displaying Messagesunalias, mail command
: Aliasingundelete, mail command
: Disposing of Messagesunset, mail command
: Scriptingversion, mail command
: Obtaining Online Helpvisual, mail command
: Editing Messageswarranty, mail command
: Obtaining Online HelpWrite, mail command
: Saving Messageswrite, mail command
: Saving Messagesz, mail command
: Displaying Information|, mail command
: Displaying Messages~!, mail escape
: Executing Shell Commands~-, mail escape
: Executing Other Mail Commands~., mail escape
: Quitting Compose Mode~:, mail escape
: Executing Other Mail Commands~?, mail escape
: Getting Help on Compose Escapes~A, mail escape
: Signing the Message~a, mail escape
: Signing the Message~e, mail escape
: Editing the Message~F, mail escape
: Printing Another Message~f, mail escape
: Printing Another Message~i, mail escape
: Inserting Value of a Mail Variable~M, mail escape
: Enclosing Another Message~m, mail escape
: Enclosing Another Message~p, mail escape
: Printing And Saving the Message~v, mail escape
: Editing the Message~w, mail escape
: Printing And Saving the Message~x, mail escape
: Quitting Compose Mode~|, mail escape
: Executing Shell Commandscomsatd
: comsatdfrm
: frm and fromfrom
: frm and fromguimb
: guimbimap4d
: imap4dmail
: mailmail.local
: mail.localmail.remote
: mail.remotemailutils-config
: mailutils-configmessages
: messagesmimeview
: mimeviewmovemail
: movemailpop3d
: pop3dreadmsg
: readmsgsieve
: sieveThis is a general index of all issues discussed in this manual
[1] If ‘#’ is not the first character on the line, it should be separated from the previous word by any amount of whitespace.
[2] Rmail does not use this feature
[3] The exact location is determined at configuration time by setting environment variable DEFAULT_CUPS_CONFDIR. On most sites running
./configure DEFAULT_CUPS_CONFDIR=/etc/cups
should be recommended.