quota-clone-plugin.c revision 661998e2ccd772ad92a9d4a75cb712692a8c94b3
/* 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 {
bool quota_flushing;
};
struct quota_clone_mailbox {
union mailbox_module_context module_ctx;
bool quota_changed;
};
{
struct quota_clone_user *quser =
struct dict_transaction_context *trans;
struct quota_root_iter *iter;
struct quota_root *root;
const char *error;
/* we'll clone the first quota root */
/* no quota roots defined for this mailbox - ignore */
return;
}
/* get new values first */
&bytes_value, &limit) < 0) {
i_error("quota_clone_plugin: Failed to lookup current quota bytes");
return;
}
&count_value, &limit) < 0) {
i_error("quota_clone_plugin: Failed to lookup current quota count");
return;
}
/* then update them */
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)
}
{
struct quota_clone_user *quser =
if (quser->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)
{
}