mail-namespace.h revision 0dffa25d211be541ee3c953b23566a1a990789df
#ifndef MAIL_NAMESPACE_H
#define MAIL_NAMESPACE_H
#include "mail-user.h"
struct mail_storage_callbacks;
enum mail_namespace_type {
MAIL_NAMESPACE_TYPE_PRIVATE = 0x01,
MAIL_NAMESPACE_TYPE_SHARED = 0x02,
MAIL_NAMESPACE_TYPE_PUBLIC = 0x04
#define MAIL_NAMESPACE_TYPE_MASK_ALL \
};
enum namespace_flags {
/* Namespace contains the user's INBOX mailbox. Normally only a single
namespace has this flag set, but when using alias_for for the INBOX
namespace the flag gets copied to the alias namespace as well */
NAMESPACE_FLAG_INBOX_USER = 0x01,
/* Namespace contains someone's INBOX. This is set for both user's
INBOX namespace and also for any other users' shared namespaces. */
NAMESPACE_FLAG_INBOX_ANY = 0x02,
/* Namespace is visible only by explicitly using its full prefix */
NAMESPACE_FLAG_HIDDEN = 0x04,
/* Namespace prefix is visible with LIST */
NAMESPACE_FLAG_LIST_PREFIX = 0x08,
/* Namespace prefix isn't visible with LIST, but child mailboxes are */
NAMESPACE_FLAG_LIST_CHILDREN = 0x10,
/* Namespace uses its own subscriptions. */
NAMESPACE_FLAG_SUBSCRIPTIONS = 0x20,
/* Namespace was created automatically (for shared mailboxes) */
NAMESPACE_FLAG_AUTOCREATED = 0x1000,
/* Namespace has at least some usable mailboxes. Autocreated namespaces
that don't have usable mailboxes may be removed automatically. */
NAMESPACE_FLAG_USABLE = 0x2000,
/* Automatically created namespace for a user that doesn't exist. */
NAMESPACE_FLAG_UNUSABLE = 0x4000,
/* Don't track quota for this namespace */
NAMESPACE_FLAG_NOQUOTA = 0x8000,
/* Don't enforce ACLs for this namespace */
NAMESPACE_FLAG_NOACL = 0x10000
};
struct mail_namespace {
/* Namespaces are sorted by their prefix length, "" comes first */
struct mail_namespace *next;
int refcount;
enum mail_namespace_type type;
enum namespace_flags flags;
char *prefix;
/* If non-NULL, this points to a namespace with identical mail location
and it should be considered as the primary way to access the
mailboxes. This allows for example FTS plugin to avoid duplicating
indexes for same mailboxes when they're accessed via different
namespaces. */
struct mail_namespace *alias_for;
/* alias_for->alias_chain_next starts each chain. The chain goes
through all namespaces that have the same alias_for. */
struct mail_namespace *alias_chain_next;
struct mailbox_list *list;
const struct mail_storage_settings *mail_set;
bool special_use_mailboxes:1;
bool destroyed:1;
};
/* Deinitialize all namespaces. mail_user_deinit() calls this automatically
for user's namespaces. */
/* Manually initialize namespaces one by one. */
struct mail_namespace_settings *ns_set,
struct mail_namespace_settings *unexpanded_ns_set,
const char **error_r);
/* Set storage callback functions to use in all namespaces. */
struct mail_storage_callbacks *callbacks,
void *context);
/* Add a new storage to namespace. */
struct mail_storage *storage);
/* Destroy a single namespace and remove it from user's namespaces list. */
/* Returns the default storage to use for newly created mailboxes. */
struct mail_storage *
/* Return namespace's hierarchy separator. */
/* Returns the hierarchy separator for mailboxes that are listed at root. */
/* Returns namespace based on the mailbox name's prefix. Note that there is
always a prefix="" namespace, so for this function NULL is never returned. */
struct mail_namespace *
/* Same as mail_namespace_find(), but if the namespace has alias_for set,
return that namespace instead and change mailbox name to be a valid
inside it. */
struct mail_namespace *
const char **mailbox);
/* Like mail_namespace_find(), but ignore hidden namespaces. */
struct mail_namespace *
const char *mailbox);
/* Like mail_namespace_find(), but find only from namespaces with
subscriptions=yes. */
struct mail_namespace *
const char *mailbox);
/* Like mail_namespace_find(), but find only from namespaces with
subscriptions=no. */
struct mail_namespace *
const char *mailbox);
/* Returns the INBOX namespace, or NULL if there is no such */
struct mail_namespace *
/* Find a namespace with given prefix. */
struct mail_namespace *
const char *prefix);
/* Like _find_prefix(), but ignore trailing separator */
struct mail_namespace *
const char *prefix);
/* Called internally by mailbox_list_create(). */
struct mailbox_list *list);
/* Returns TRUE if this is the root of a type=shared namespace that is actually
used for accessing shared users' mailboxes (as opposed to marking a
type=public namespace "wrong"). */
#endif