mailbox-list.h revision 697ff56bf3cdc9e7989ea2a70accf866b14b64d1
0N/A#ifndef MAILBOX_LIST_H
2846N/A#define MAILBOX_LIST_H
0N/A
0N/A#include "mail-error.h"
0N/A
0N/A#ifdef PATH_MAX
0N/A# define MAILBOX_LIST_NAME_MAX_LENGTH PATH_MAX
0N/A#else
0N/A# define MAILBOX_LIST_NAME_MAX_LENGTH 4096
0N/A#endif
0N/A
0N/Astruct fs;
0N/Astruct mail_namespace;
0N/Astruct mail_storage;
0N/Astruct mailbox_list;
0N/A
0N/Aenum mailbox_list_properties {
0N/A /* maildir_name must always be empty */
1472N/A MAILBOX_LIST_PROP_NO_MAILDIR_NAME = 0x01,
1472N/A /* alt directories not supported */
1472N/A MAILBOX_LIST_PROP_NO_ALT_DIR = 0x02,
0N/A /* no support for \noselect directories, only mailboxes */
0N/A MAILBOX_LIST_PROP_NO_NOSELECT = 0x04,
0N/A /* mail root directory isn't required */
1879N/A MAILBOX_LIST_PROP_NO_ROOT = 0x08,
1879N/A /* Automatically create mailbox directories when needed */
1879N/A MAILBOX_LIST_PROP_AUTOCREATE_DIRS = 0x10
0N/A};
0N/A
0N/Aenum mailbox_list_flags {
0N/A /* Mailboxes are files, not directories. */
0N/A MAILBOX_LIST_FLAG_MAILBOX_FILES = 0x01,
0N/A /* Namespace already has a mailbox list, don't assign this
0N/A mailbox list to it. */
0N/A MAILBOX_LIST_FLAG_SECONDARY = 0x02,
0N/A /* There are no mail files, only index and/or control files. */
0N/A MAILBOX_LIST_FLAG_NO_MAIL_FILES = 0x04
0N/A};
0N/A
0N/Aenum mailbox_info_flags {
0N/A MAILBOX_NOSELECT = 0x001,
0N/A MAILBOX_NONEXISTENT = 0x002,
0N/A MAILBOX_CHILDREN = 0x004,
0N/A MAILBOX_NOCHILDREN = 0x008,
0N/A MAILBOX_NOINFERIORS = 0x010,
0N/A MAILBOX_MARKED = 0x020,
0N/A MAILBOX_UNMARKED = 0x040,
0N/A MAILBOX_SUBSCRIBED = 0x080,
0N/A MAILBOX_CHILD_SUBSCRIBED = 0x100,
0N/A MAILBOX_CHILD_SPECIALUSE = 0x200,
0N/A
0N/A /* Internally used by lib-storage, use mailbox_info.special_use
0N/A to actually access these: */
0N/A MAILBOX_SPECIALUSE_ALL = 0x00010000,
0N/A MAILBOX_SPECIALUSE_ARCHIVE = 0x00020000,
0N/A MAILBOX_SPECIALUSE_DRAFTS = 0x00040000,
0N/A MAILBOX_SPECIALUSE_FLAGGED = 0x00080000,
0N/A MAILBOX_SPECIALUSE_JUNK = 0x00100000,
0N/A MAILBOX_SPECIALUSE_SENT = 0x00200000,
0N/A MAILBOX_SPECIALUSE_TRASH = 0x00400000,
0N/A MAILBOX_SPECIALUSE_IMPORTANT = 0x00800000,
0N/A
0N/A /* Internally used by lib-storage: */
0N/A MAILBOX_SELECT = 0x20000000,
0N/A MAILBOX_MATCHED = 0x40000000
0N/A};
0N/A
0N/Aenum mailbox_list_path_type {
0N/A /* Return directory's path (eg. ~/dbox/INBOX) */
0N/A MAILBOX_LIST_PATH_TYPE_DIR,
0N/A MAILBOX_LIST_PATH_TYPE_ALT_DIR,
0N/A /* Return mailbox path (eg. ~/dbox/INBOX/dbox-Mails) */
0N/A MAILBOX_LIST_PATH_TYPE_MAILBOX,
0N/A MAILBOX_LIST_PATH_TYPE_ALT_MAILBOX,
0N/A /* Return control directory */
0N/A MAILBOX_LIST_PATH_TYPE_CONTROL,
0N/A /* Return index directory ("" for in-memory) */
0N/A MAILBOX_LIST_PATH_TYPE_INDEX,
0N/A /* Return the private index directory (NULL if none) */
0N/A MAILBOX_LIST_PATH_TYPE_INDEX_PRIVATE
0N/A};
0N/A
0N/Aenum mailbox_list_file_type {
0N/A MAILBOX_LIST_FILE_TYPE_UNKNOWN = 0,
0N/A MAILBOX_LIST_FILE_TYPE_FILE,
0N/A MAILBOX_LIST_FILE_TYPE_DIR,
0N/A MAILBOX_LIST_FILE_TYPE_SYMLINK,
2846N/A MAILBOX_LIST_FILE_TYPE_OTHER
2846N/A};
2846N/A
2846N/Astruct mailbox_list_settings {
2846N/A const char *layout; /* FIXME: shouldn't be here */
2846N/A const char *root_dir;
2846N/A const char *index_dir;
2846N/A const char *index_pvt_dir;
2846N/A const char *control_dir;
2846N/A const char *alt_dir; /* FIXME: dbox-specific.. */
2846N/A
2846N/A const char *inbox_path;
2846N/A const char *subscription_fname;
0N/A /* If non-empty, it means that mails exist in a maildir_name
0N/A subdirectory. eg. if you have a directory containing directories:
0N/A
2846N/A mail/
2846N/A mail/foo/
2846N/A mail/foo/Maildir
2846N/A
2846N/A If mailbox_name is empty, you have mailboxes "mail", "mail/foo" and
2846N/A "mail/foo/Maildir".
2846N/A
2846N/A If mailbox_name is "Maildir", you have a non-selectable mailbox
2846N/A "mail" and a selectable mailbox "mail/foo". */
2846N/A const char *maildir_name;
2846N/A /* if set, store mailboxes under root_dir/mailbox_dir_name/.
2846N/A this setting contains either "" or "dir/". */
2846N/A const char *mailbox_dir_name;
0N/A
0N/A /* Encode "bad" characters in mailbox names as <escape_char><hex> */
0N/A char escape_char;
0N/A /* If mailbox name can't be changed reversibly to UTF-8 and back,
0N/A encode the problematic parts using <broken_char><hex> in the
0N/A user-visible UTF-8 name. The broken_char itself also has to be
0N/A encoded the same way. */
0N/A char broken_char;
0N/A /* Use UTF-8 mailbox names on filesystem instead of mUTF-7 */
0N/A bool utf8;
0N/A /* Don't check/create the alt-dir symlink. */
0N/A bool alt_dir_nocheck;
0N/A /* Use maildir_name also for index/control directories. This should
0N/A have been the default since the beginning, but for backwards
0N/A compatibility it had to be made an option. */
0N/A bool index_control_use_maildir_name;
0N/A};
0N/A
0N/Astruct mailbox_permissions {
0N/A /* The actual uid/gid of the mailbox */
0N/A uid_t file_uid;
0N/A gid_t file_gid;
0N/A
0N/A /* mode and GID to use for newly created files/dirs.
0N/A (gid_t)-1 is used if the default GID can be used. */
0N/A mode_t file_create_mode, dir_create_mode;
0N/A gid_t file_create_gid;
0N/A /* origin (e.g. path) where the file_create_gid was got from */
0N/A const char *file_create_gid_origin;
0N/A
0N/A bool gid_origin_is_mailbox_path;
0N/A bool mail_index_permissions_set;
0N/A};
0N/A
0N/A/* register all drivers */
0N/Avoid mailbox_list_register_all(void);
0N/A
0N/Avoid mailbox_list_register(const struct mailbox_list *list);
0N/Avoid mailbox_list_unregister(const struct mailbox_list *list);
0N/A
0N/Aconst struct mailbox_list *
0N/Amailbox_list_find_class(const char *driver);
0N/A
0N/A/* Returns 0 if ok, -1 if driver was unknown. */
0N/Aint mailbox_list_create(const char *driver, struct mail_namespace *ns,
0N/A const struct mailbox_list_settings *set,
0N/A enum mailbox_list_flags flags,
0N/A struct mailbox_list **list_r, const char **error_r);
0N/Avoid mailbox_list_destroy(struct mailbox_list **list);
0N/A
0N/Aconst char *
0N/Amailbox_list_get_driver_name(const struct mailbox_list *list) ATTR_PURE;
0N/Aconst struct mailbox_list_settings *
0N/Amailbox_list_get_settings(const struct mailbox_list *list) ATTR_PURE;
0N/Aenum mailbox_list_flags
0N/Amailbox_list_get_flags(const struct mailbox_list *list) ATTR_PURE;
0N/Astruct mail_namespace *
0N/Amailbox_list_get_namespace(const struct mailbox_list *list) ATTR_PURE;
0N/Astruct mail_user *
0N/Amailbox_list_get_user(const struct mailbox_list *list) ATTR_PURE;
0N/Aint mailbox_list_get_storage(struct mailbox_list **list, const char *vname,
0N/A struct mail_storage **storage_r);
0N/Avoid mailbox_list_get_default_storage(struct mailbox_list *list,
0N/A struct mail_storage **storage);
0N/Achar mailbox_list_get_hierarchy_sep(struct mailbox_list *list);
0N/A
0N/A/* Returns the mode and GID that should be used when creating new files and
0N/A directories to the specified mailbox. (gid_t)-1 is returned if it's not
0N/A necessary to change the default gid. */
0N/Avoid mailbox_list_get_permissions(struct mailbox_list *list, const char *name,
0N/A struct mailbox_permissions *permissions_r);
0N/A/* Like mailbox_list_get_permissions(), but for creating files/dirs to the
0N/A mail root directory (or even the root dir itself). */
0N/Avoid mailbox_list_get_root_permissions(struct mailbox_list *list,
0N/A struct mailbox_permissions *permissions_r);
1879N/A/* mkdir() a root directory of given type with proper permissions. The path can
1879N/A be either the root itself or point to a directory under the root. */
int mailbox_list_mkdir_root(struct mailbox_list *list, const char *path,
enum mailbox_list_path_type type);
/* Like mailbox_list_mkdir_root(), but don't log an error if it fails. */
int mailbox_list_try_mkdir_root(struct mailbox_list *list, const char *path,
enum mailbox_list_path_type type,
const char **error_r);
/* Call mailbox_list_mkdir_root() for index, unless the index root is the
same as mailbox root. Returns 1 if ok, 0 if there are no indexes, -1 if
error. Calling this multiple times does the check only once. */
int mailbox_list_mkdir_missing_index_root(struct mailbox_list *list);
/* Returns TRUE if name is ok, FALSE if it can't be safely passed to
mailbox_list_*() functions */
bool mailbox_list_is_valid_name(struct mailbox_list *list,
const char *name, const char **error_r);
const char *mailbox_list_get_storage_name(struct mailbox_list *list,
const char *vname);
const char *mailbox_list_get_vname(struct mailbox_list *list, const char *name);
/* Get path to specified type of files in mailbox. Returns -1 if an error
occurred (e.g. mailbox no longer exists), 0 if there are no files of this
type (in-memory index, no alt dir, storage with no files), 1 if path was
returned successfully. The path is set to NULL when returning -1/0. */
int mailbox_list_get_path(struct mailbox_list *list, const char *name,
enum mailbox_list_path_type type,
const char **path_r);
/* Get path to the root directory for files of specified type. Returns TRUE
if path was returned, FALSE if there are no files of this type. */
bool mailbox_list_get_root_path(struct mailbox_list *list,
enum mailbox_list_path_type type,
const char **path_r);
/* Like mailbox_list_get_root_path(), but assume that the root directory
exists (assert crash if not) */
const char *mailbox_list_get_root_forced(struct mailbox_list *list,
enum mailbox_list_path_type type);
/* Returns mailbox's change log, or NULL if it doesn't have one. */
struct mailbox_log *mailbox_list_get_changelog(struct mailbox_list *list);
/* Specify timestamp to use when writing mailbox changes to changelog.
The same timestamp is used until stamp is set to (time_t)-1, after which
current time is used */
void mailbox_list_set_changelog_timestamp(struct mailbox_list *list,
time_t stamp);
/* Returns a prefix that temporary files should use without conflicting
with the namespace. */
const char *mailbox_list_get_temp_prefix(struct mailbox_list *list);
/* Returns prefix that's common to all get_temp_prefix() calls.
Typically this returns either "temp." or ".temp.". */
const char *mailbox_list_get_global_temp_prefix(struct mailbox_list *list);
/* Subscribe/unsubscribe mailbox. There should be no error when
subscribing to already subscribed mailbox. Subscribing to
unexisting mailboxes is optional. */
int mailbox_list_set_subscribed(struct mailbox_list *list,
const char *name, bool set);
/* Delete a non-selectable mailbox. Fail if the mailbox is selectable. */
int mailbox_list_delete_dir(struct mailbox_list *list, const char *name);
/* Delete a symlinked mailbox. Fail if the mailbox isn't a symlink. */
int mailbox_list_delete_symlink(struct mailbox_list *list, const char *name);
/* Returns the error message of last occurred error. */
const char * ATTR_NOWARN_UNUSED_RESULT
mailbox_list_get_last_error(struct mailbox_list *list,
enum mail_error *error_r);
/* Create a fs based on the settings in the given mailbox_list. */
int mailbox_list_init_fs(struct mailbox_list *list, const char *driver,
const char *args, const char *root_dir,
struct fs **fs_r, const char **error_r);
/* Return mailbox_list that was used to create the fs via
mailbox_list_init_fs(). */
struct mailbox_list *mailbox_list_fs_get_list(struct fs *fs);
#endif