/usr/include/dovecot/mailbox-list-index.h is in dovecot-dev 1:2.2.22-1ubuntu2.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 | #ifndef MAILBOX_LIST_INDEX_H
#define MAILBOX_LIST_INDEX_H
/* Mailbox list index basically contains:
Header contains ID => name mapping. The name isn't the full mailbox name,
but rather each hierarchy level has its own ID and name. For example a
mailbox name "foo/bar" (with '/' as separator) would have separate IDs for
"foo" and "bar" names.
The records contain { parent_uid, uid, name_id } field that can be used to
build the whole mailbox tree. parent_uid=0 means root, otherwise it's the
parent node's uid.
Each record also contains GUID for each selectable mailbox. If a mailbox
is recreated using the same name, its GUID also changes. Note however that
the UID doesn't change, because the UID refers to the mailbox name, not to
the mailbox itself.
The records may contain also extensions for allowing mailbox_get_status()
to return values directly from the mailbox list index. Storage backends
may also add their own extensions to figure out if a record is up to date.
*/
#include "module-context.h"
#include "mail-types.h"
#include "mail-storage.h"
#include "mailbox-list-private.h"
#include <sys/time.h>
#define MAILBOX_LIST_INDEX_HIERARHCY_SEP '~'
#define MAILBOX_LIST_INDEX_PREFIX "dovecot.list.index"
#define INDEX_LIST_CONTEXT(obj) \
MODULE_CONTEXT(obj, mailbox_list_index_module)
struct mail_index_view;
struct mailbox_index_vsize;
/* stored in mail_index_record.flags: */
enum mailbox_list_index_flags {
MAILBOX_LIST_INDEX_FLAG_NONEXISTENT = MAIL_DELETED,
MAILBOX_LIST_INDEX_FLAG_NOSELECT = MAIL_DRAFT,
MAILBOX_LIST_INDEX_FLAG_NOINFERIORS = MAIL_ANSWERED,
/* set during syncing for mailboxes that still exist */
MAILBOX_LIST_INDEX_FLAG_SYNC_EXISTS = MAIL_FLAGGED
};
struct mailbox_list_index_header {
uint8_t refresh_flag;
/* array of { uint32_t id; char name[]; } */
};
struct mailbox_list_index_record {
/* points to given id in header */
uint32_t name_id;
/* parent mailbox's UID, 0 = root */
uint32_t parent_uid;
/* the following fields are temporarily zero while unknown,
also permanently zero for \NoSelect and \Nonexistent mailboxes: */
guid_128_t guid;
uint32_t uid_validity;
};
struct mailbox_list_index_msgs_record {
uint32_t messages;
uint32_t unseen;
uint32_t recent;
uint32_t uidnext;
};
struct mailbox_list_index_node {
struct mailbox_list_index_node *parent;
struct mailbox_list_index_node *next;
struct mailbox_list_index_node *children;
uint32_t name_id, uid;
enum mailbox_list_index_flags flags;
const char *name;
};
struct mailbox_list_index {
union mailbox_list_module_context module_ctx;
const char *path;
struct mail_index *index;
uint32_t ext_id, msgs_ext_id, hmodseq_ext_id, subs_hdr_ext_id;
uint32_t vsize_ext_id, first_saved_ext_id;
struct timeval last_refresh_timeval;
pool_t mailbox_pool;
/* uin32_t id => name */
HASH_TABLE(void *, char *) mailbox_names;
uint32_t highest_name_id;
struct mailbox_list_index_sync_context *sync_ctx;
uint32_t sync_log_file_seq;
uoff_t sync_log_file_offset;
uint32_t sync_stamp;
struct timeout *to_refresh;
/* uint32_t uid => node */
HASH_TABLE(void *, struct mailbox_list_index_node *) mailbox_hash;
struct mailbox_list_index_node *mailbox_tree;
unsigned int pending_init:1;
unsigned int opened:1;
unsigned int syncing:1;
unsigned int updating_status:1;
unsigned int has_backing_store:1;
unsigned int index_last_check_changed:1;
};
struct mailbox_list_index_iterate_context {
struct mailbox_list_iterate_context ctx;
struct mailbox_list_iterate_context *backend_ctx;
pool_t mailbox_pool;
struct mailbox_info info;
pool_t info_pool;
unsigned int parent_len;
string_t *path;
struct mailbox_list_index_node *next_node;
unsigned int failed:1;
};
extern MODULE_CONTEXT_DEFINE(mailbox_list_index_module,
&mailbox_list_module_register);
void mailbox_list_index_set_index_error(struct mailbox_list *list);
struct mailbox_list_index_node *
mailbox_list_index_lookup(struct mailbox_list *list, const char *name);
struct mailbox_list_index_node *
mailbox_list_index_lookup_uid(struct mailbox_list_index *ilist, uint32_t uid);
void mailbox_list_index_node_get_path(const struct mailbox_list_index_node *node,
char sep, string_t *str);
void mailbox_list_index_node_unlink(struct mailbox_list_index *ilist,
struct mailbox_list_index_node *node);
int mailbox_list_index_index_open(struct mailbox_list *list);
bool mailbox_list_index_need_refresh(struct mailbox_list_index *ilist,
struct mail_index_view *view);
/* Refresh the index, but only if it hasn't been refreshed "recently"
(= within this same ioloop run) */
int mailbox_list_index_refresh(struct mailbox_list *list);
/* Refresh the index regardless of when the last refresh was done. */
int mailbox_list_index_refresh_force(struct mailbox_list *list);
void mailbox_list_index_refresh_later(struct mailbox_list *list);
struct mailbox_list_index_node *
mailbox_list_index_node_find_sibling(struct mailbox_list_index_node *node,
const char *name);
void mailbox_list_index_reset(struct mailbox_list_index *ilist);
int mailbox_list_index_parse(struct mailbox_list *list,
struct mail_index_view *view, bool force);
struct mailbox_list_iterate_context *
mailbox_list_index_iter_init(struct mailbox_list *list,
const char *const *patterns,
enum mailbox_list_iter_flags flags);
const struct mailbox_info *
mailbox_list_index_iter_next(struct mailbox_list_iterate_context *ctx);
int mailbox_list_index_iter_deinit(struct mailbox_list_iterate_context *ctx);
bool mailbox_list_index_status(struct mailbox_list *list,
struct mail_index_view *view,
uint32_t seq, enum mailbox_status_items items,
struct mailbox_status *status_r,
uint8_t *mailbox_guid,
struct mailbox_index_vsize *vsize_r);
void mailbox_list_index_status_set_info_flags(struct mailbox *box, uint32_t uid,
enum mailbox_info_flags *flags);
void mailbox_list_index_update_mailbox_index(struct mailbox *box,
const struct mailbox_update *update);
int mailbox_list_index_notify_init(struct mailbox_list *list,
enum mailbox_list_notify_event mask,
struct mailbox_list_notify **notify_r);
void mailbox_list_index_notify_deinit(struct mailbox_list_notify *notify);
int mailbox_list_index_notify_next(struct mailbox_list_notify *notify,
const struct mailbox_list_notify_rec **rec_r);
void mailbox_list_index_notify_wait(struct mailbox_list_notify *notify,
void (*callback)(void *context),
void *context);
void mailbox_list_index_status_init_mailbox(struct mailbox *box);
void mailbox_list_index_backend_init_mailbox(struct mailbox *box);
void mailbox_list_index_status_init_finish(struct mailbox_list *list);
#endif
|