mirror of
https://github.com/bjc/prosody.git
synced 2025-04-04 21:57:45 +03:00
mod_storage_sql: Implement archive summary API
This commit is contained in:
parent
582fa3f46f
commit
a32b5ceb45
1 changed files with 35 additions and 0 deletions
|
@ -419,6 +419,41 @@ function archive_store:find(username, query)
|
||||||
end, total;
|
end, total;
|
||||||
end
|
end
|
||||||
|
|
||||||
|
function archive_store:summary(username, query)
|
||||||
|
query = query or {};
|
||||||
|
local user,store = username,self.store;
|
||||||
|
local ok, result = engine:transaction(function()
|
||||||
|
local sql_query = [[
|
||||||
|
SELECT DISTINCT "with", COUNT(*)
|
||||||
|
FROM "prosodyarchive"
|
||||||
|
WHERE %s
|
||||||
|
GROUP BY "with"
|
||||||
|
ORDER BY "sort_id" %s%s;
|
||||||
|
]];
|
||||||
|
local args = { host, user or "", store, };
|
||||||
|
local where = { "\"host\" = ?", "\"user\" = ?", "\"store\" = ?", };
|
||||||
|
|
||||||
|
archive_where(query, args, where);
|
||||||
|
|
||||||
|
archive_where_id_range(query, args, where);
|
||||||
|
|
||||||
|
if query.limit then
|
||||||
|
args[#args+1] = query.limit;
|
||||||
|
end
|
||||||
|
|
||||||
|
sql_query = sql_query:format(t_concat(where, " AND "), query.reverse
|
||||||
|
and "DESC" or "ASC", query.limit and " LIMIT ?" or "");
|
||||||
|
return engine:select(sql_query, unpack(args));
|
||||||
|
end);
|
||||||
|
if not ok then return ok, result end
|
||||||
|
local summary = {};
|
||||||
|
for row in result do
|
||||||
|
local with, count = row[1], row[2];
|
||||||
|
summary[with] = count;
|
||||||
|
end
|
||||||
|
return summary;
|
||||||
|
end
|
||||||
|
|
||||||
function archive_store:delete(username, query)
|
function archive_store:delete(username, query)
|
||||||
query = query or {};
|
query = query or {};
|
||||||
local user,store = username,self.store;
|
local user,store = username,self.store;
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue