GNU Mailutils |
|
General-Purpose Mail Package |
Official GNU Software |
GNU imap4d
supports a notion of namespaces defined
in RFC 2342. A namespace can be regarded as a list of entities,
defining locations to which the user has certain access rights. Each
entity includes the prefix, under which the mailboxes can be
found, hierarchy delimiter, a character used to delimit parts of
a path to a mailbox, and a directory on the file system on the
server, which actually holds the mailboxes. Among these three values,
only first two are visible to the client using the IMAP
‘NAMESPACE’ command.
There are three namespaces:
A namespace that is within the personal scope of the authenticated user on a particular connection. The user has all permissions on this namespace.
By default, this namespace contains a single prefix:
prefix: "" delimiter: / directory: home directory of the user
A namespace that consists of mailboxes from the “Personal Namespaces”
of other users. The user can read and list mailboxes from this
namespace. However, he is not allowed to use ‘%’ and ‘*’
wildcards with LIST
command, that is he can access a
mailbox only if he knows exactly its location.
By default, this namespace is empty.
A namespace that consists of mailboxes that are intended to be shared amongst users and do not exist within a user’s Personal Namespace. The user has all permissions on this namespace.
By default, this namespace is empty.
The default values ensure that each user is able to see or otherwise access mailboxes residing in the directories other than his own home.
These defaults can be changed using the namespace
block
statement:
namespace name { mailbox-mode mode; prefix pfx { directory path; delimiter chr; mailbox-type type; } }
The name argument to the namespace
statement declares
which namespace is being configured. Allowed values are:
‘personal’, ‘other’, and ‘shared’.
The mailbox-mode
statement configures the file mode for the
mailboxes created within that namespace (provided that the directory
permissions allow the user to create mailboxes). The mode
argument is a comma-delimited list of symbolic mode settings, similar
to that used by chmod
. Each setting begins with a
letter ‘g’, which means set mode bits for file group, or
‘o’, which means set mode bits for other users (note, that there
is no ‘u’ specifier, since user ownership of his mailbox cannot
be changed). This letter is followed by an ‘=’ (or ‘+’), and
a list of modes to be set. This list can contain only two letters:
‘r’ to set read permission, and ‘w’ to set write permission.
For example, the following statement sets read and write permissions for the group:
mailbox-mode g=rw;
The prefix
statement configures available prefixes and
determines their mappings to the server’s file system. The pfx
argument defines the prefix which will be visible to the IMAP client.
The directory
statement defines the directory in the file
system to which pfx is mapped. Exactly one directory
statement must be present in each prefix
block. The
inerpretation of its argument depends on the namespace in which it
occurs.
When used in the ‘namespace shared’ block, the argument to this statement is interpreted verbatim, as an absolute pathname.
When used in ‘namespace personal’ the argument to
directory
statement can contain references to the following
variables (see Configuration Variables):
Login name of the user.
Home directory of the user.
For example, the following statement maps the default personal namespace to the directory ‘imap’ in the user’s home directory:
namespace personal { prefix ""; directory "$home/imap"; }
If the ‘directory’ statement is used within the ‘namespace other’ block, its value can contain the ‘$user’ and ‘$home’ variables as well, but their meaning is different. For the ‘other’ namespace, the ‘$user’ variable is expanded to the part of the actual reference contained between the prefix and first hierarchy delimiter (or the end of the reference, if no delimiter occurs to the right of the prefix). Correspondingly, ‘$home’ expands to the home directory of that user. Consider, for example, the following statement:
namespace other { prefix "~"; directory "/var/imap/$user"; }
If the client issues the following statement:
1 LIST "~smith" "%"
then ‘$user’ will expand to the string ‘smith’ and the server will look for all mailboxes in the directory /var/imap/smith.
The delimiter
statement defines the folder hierarchy delimiter
for that prefix. It is optional, the default value being ‘"/"’.
The mailbox-type
statement declares the type of the mailboxes
within that prefix. If present, its argument must be a valid mailbox
type (e.g. ‘mailbox’, ‘maildir’, or ‘mh’). The IMAP
LIST
command will display only mailboxes of that type. The
CREATE
command will create mailboxes of that type.
In the absence of the mailbox-type
statement, the IMAP
LIST
command will display mailboxes of any type supported by
Mailutils. The type of newly-created mailboxes is then determined by
the mailbox-type
statement (see mailbox-type).
Any number of prefix
blocks can be present.
Consider, for example, the following configuration:
namespace personal { prefix "" { directory "$home/mailfolder"; } prefix "#MH:" { directory "$home/Mail"; delimiter "/"; mailbox-type "mh"; } }
It defines the personal namespace containing two prefixes. The empty prefix is mapped to the directory mailfolder in the home directory of the currently authenticated user. Any type of mailboxes is supported within that prefix.
The prefix ‘#MH:’ is mapped to the directory Mail in the home directory of the user, and is limited to contain only mailboxes in MH format.
Note that if the prefixes ‘""’ is not defined in the personal namespace, the following default will be automatically created:
prefix "" { directory "$home"; }
This document was generated on January 3, 2025 using makeinfo.
Verbatim copying and distribution of this entire article is permitted in any medium, provided this notice is preserved.