quota-clone-plugin.c revision 02c335c23bf5fa225a467c19f2c063fb0dc7b8c3
/* Copyright (c) 2015-2016 Dovecot authors, see the included COPYING file */
#include "lib.h"
#include "module-context.h"
#include "dict.h"
#include "mail-storage-private.h"
#include "quota.h"
#include "quota-clone-plugin.h"
#define QUOTA_CLONE_USER_CONTEXT(obj) \
#define QUOTA_CLONE_CONTEXT(obj) \
struct quota_clone_user {
};
struct quota_clone_mailbox {
union mailbox_module_context module_ctx;
bool quota_changed;
bool quota_flushing;
};
{
struct quota_clone_user *quser =
struct dict_transaction_context *trans;
struct quota_root_iter *iter;
struct quota_root *root;
int ret;
/* we'll clone the first quota root */
/* no quota roots defined for this mailbox - ignore */
return;
}
/* update bytes */
if (ret < 0)
i_error("quota_clone_plugin: Failed to lookup current quota bytes");
else {
}
/* update messages */
if (ret < 0)
i_error("quota_clone_plugin: Failed to lookup current quota count");
else {
}
if (dict_transaction_commit(&trans) < 0)
i_error("quota_clone_plugin: Failed to commit dict update");
else
}
{
struct quota_clone_mailbox *qbox =
}
static int
{
struct quota_clone_mailbox *qbox =
}
static void
enum mailbox_sync_type sync_type)
{
if (sync_type == MAILBOX_SYNC_TYPE_EXPUNGE)
}
{
if (qbox->quota_flushing) {
/* recursing back from quota recalculation */
} else if (qbox->quota_changed) {
}
}
{
struct quota_clone_user *quser =
struct quota_clone_mailbox *qbox;
return;
v->copy = quota_clone_copy;
}
{
}
{
struct quota_clone_user *quser;
struct dict_settings dict_set;
i_error("The quota_clone_dict setting is missing from configuration");
return;
}
i_error("quota_clone_dict: Failed to initialize '%s': %s",
return;
}
}
static struct mail_storage_hooks quota_clone_mail_storage_hooks = {
};
{
}
void quota_clone_plugin_deinit(void)
{
}