sdbox-storage.c revision eadbca0f2b78fcc36332678fee9ee08003df63de
/* Copyright (c) 2007-2011 Dovecot authors, see the included COPYING file */
#include "lib.h"
#include "master-service.h"
#include "mail-index-modseq.h"
#include "mail-search-build.h"
#include "mailbox-list-private.h"
#include "dbox-mail.h"
#include "dbox-save.h"
#include "sdbox-file.h"
#include "sdbox-sync.h"
#include "sdbox-storage.h"
extern struct mailbox sdbox_mailbox;
extern struct dbox_storage_vfuncs sdbox_dbox_storage_vfuncs;
static struct mail_storage *sdbox_storage_alloc(void)
{
struct sdbox_storage *storage;
}
static const char *
{
if (debug)
return path;
}
if (debug)
}
return NULL;
}
struct mailbox_list_settings *set)
{
else {
if (debug)
i_debug("sdbox: couldn't find root dir");
return FALSE;
}
}
/* NOTE: this check works for mdbox as well. we'll rely on the
autodetect ordering to catch mdbox before we get here. */
if (debug)
return FALSE;
}
if (debug)
return FALSE;
}
return TRUE;
}
static struct mailbox *
{
struct sdbox_mailbox *mbox;
struct index_mailbox_context *ibox;
/* dbox can't work without index files */
}
{
struct mail_index_view *view;
const void *data;
int ret;
if (data_size < SDBOX_INDEX_HEADER_MIN_SIZE &&
if (log_error) {
"sdbox %s: Invalid dbox header size",
}
ret = -1;
} else {
ret = 0;
}
return ret;
}
struct mail_index_transaction *trans,
const struct mailbox_update *update)
{
sizeof(new_hdr.mailbox_guid));
}
}
sizeof(mbox->mailbox_guid));
}
const struct mailbox_update *update,
struct mail_index_transaction *trans)
{
const struct mail_index_header *hdr;
}
else if (hdr->uid_validity != 0)
else {
/* set uidvalidity */
}
if (hdr->uid_validity != 0) {
/* UIDVALIDITY change requires index to be reset */
}
}
}
}
}
if (mail_index_transaction_commit(&new_trans) < 0) {
return -1;
}
}
return 0;
}
static const char *
{
return t_strdup_printf("-%s-%u",
}
{
struct sdbox_index_header hdr;
else
}
{
}
{
struct sdbox_index_header hdr;
if (dbox_mailbox_open(box) < 0)
return -1;
mbox->hdr_ext_id =
sizeof(struct sdbox_index_header), 0, 0);
/* wait for mailbox creation to initialize the index */
return 0;
}
/* wait for mailbox creation to initialize the index */
return 0;
}
/* it's possible that this mailbox is just now being created
by another process. lock it first and see if the header is
available then. */
struct mail_index_sync_ctx *sync_ctx;
struct mail_index_view *view;
struct mail_index_transaction *trans;
(void)mail_index_sync_commit(&sync_ctx);
}
/* regenerate it */
return -1;
}
sizeof(mbox->mailbox_guid));
return 0;
}
{
if (mbox->corrupted_rebuild_count != 0)
(void)sdbox_sync(mbox, 0);
}
static int
enum mailbox_metadata_items items,
struct mailbox_metadata *metadata_r)
{
return -1;
if ((items & MAILBOX_METADATA_GUID) != 0) {
sizeof(metadata_r->guid));
}
return 0;
}
static int
{
if (mailbox_open(box) < 0)
return -1;
}
}
struct mail_storage sdbox_storage = {
.class_flags = 0,
.v = {
NULL,
NULL,
}
};
struct mail_storage dbox_storage = {
.v = {
NULL,
NULL,
}
};
struct mailbox sdbox_mailbox = {
.v = {
NULL,
NULL,
}
};
struct dbox_storage_vfuncs sdbox_dbox_storage_vfuncs = {
};