diff options
author | Kim Alvefur <zash@zash.se> | 2019-02-25 15:48:28 +0100 |
---|---|---|
committer | Kim Alvefur <zash@zash.se> | 2019-02-25 15:48:28 +0100 |
commit | 582fa3f46f105fe55447d607dceb43b5ac61d440 (patch) | |
tree | 21f89ef04949ba04cad55d6d93b4e97b66709053 /plugins | |
parent | 3c50aa4902aada8eccbdd32f359a0cd6a52aceae (diff) | |
download | prosody-582fa3f46f105fe55447d607dceb43b5ac61d440.tar.gz prosody-582fa3f46f105fe55447d607dceb43b5ac61d440.zip |
mod_storage_internal: Implement a summary API returning message counts per contact
Diffstat (limited to 'plugins')
-rw-r--r-- | plugins/mod_storage_internal.lua | 10 |
1 files changed, 10 insertions, 0 deletions
diff --git a/plugins/mod_storage_internal.lua b/plugins/mod_storage_internal.lua index c87d01be..aa5c3c8a 100644 --- a/plugins/mod_storage_internal.lua +++ b/plugins/mod_storage_internal.lua @@ -196,6 +196,16 @@ function archive:dates(username) return array(items):pluck("when"):map(datetime.date):unique(); end +function archive:summary(username, query) + local iter, err = self:find(username, query) + if not iter then return iter, err; end + local summary = {}; + for _, _, _, with in iter do + summary[with] = (summary[with] or 0) + 1; + end + return summary; +end + function archive:delete(username, query) local cache_key = jid_join(username, host, self.store); if not query or next(query) == nil then |