Quota Clone Plugin

New in version v2.2.17.

Quota clone plugin is useful when you want to store everybody’s current quota usage to a database, but you don’t want to use the database as the authoritative quota database. For example you might want to access everybody’s quota via Redis (or with SQL database, Redis is example here), but you don’t store the Redis database permanently so it could become empty once in a while. In this case you can use e.g. dict-file or count as the authoritative quota database and make a copy of the quota usage to Redis. From Redis you could then once in a while gather everybody’s current quota usage and send it to yet another place (e.g. for statistics handling).

Every time quota is updated, the value is updated to the cloned dict. There are race conditions with it so the quota may not always be 100% correct. The old value is always replaced with the new one though (not just incremented/decremented) so the cloned quota is never too much wrong.

The keys that are written to:

  • priv/quota/storage - storage usage in bytes
  • priv/quota/messages - count of messages

Configuration

mail_plugins = $mail_plugins quota quota_clone
plugin {
  quota_clone_dict = redis:host=127.0.0.1:port=6379
}

More complex example using SQL:

dict {
  mysql = mysql:/etc/dovecot/dovecot-dict-sql.conf.ext
}

plugin {
   quota_clone_dict = proxy::mysql
}