mod_storage_*: Also include timestmap of first message in :summary API

For completeness along with most recent timestamp. Might be nice to be
able to order by oldest unread message.
This commit is contained in:
Kim Alvefur 2019-08-23 01:15:44 +02:00
parent d3c559bcc8
commit 9d5e31fd48
3 changed files with 15 additions and 3 deletions

View file

@ -218,13 +218,18 @@ function archive:summary(username, query)
local iter, err = self:find(username, query)
if not iter then return iter, err; end
local counts = {};
local earliest = {};
local latest = {};
for _, _, when, with in iter do
counts[with] = (counts[with] or 0) + 1;
if earliest[with] == nil then
earliest[with] = when;
end
latest[with] = when;
end
return {
counts = counts;
earliest = earliest;
latest = latest;
};
end

View file

@ -171,13 +171,18 @@ function archive_store:summary(username, query)
local iter, err = self:find(username, query)
if not iter then return iter, err; end
local counts = {};
local earliest = {};
local latest = {};
for _, _, when, with in iter do
counts[with] = (counts[with] or 0) + 1;
if earliest[with] == nil then
earliest[with] = when;
end
latest[with] = when;
end
return {
counts = counts;
earliest = earliest;
latest = latest;
};
end

View file

@ -424,7 +424,7 @@ function archive_store:summary(username, query)
local user,store = username,self.store;
local ok, result = engine:transaction(function()
local sql_query = [[
SELECT DISTINCT "with", COUNT(*), MAX("when")
SELECT DISTINCT "with", COUNT(*), MIN("when"), MAX("when")
FROM "prosodyarchive"
WHERE %s
GROUP BY "with"
@ -447,14 +447,16 @@ function archive_store:summary(username, query)
end);
if not ok then return ok, result end
local counts = {};
local latest = {};
local earliest, latest = {}, {};
for row in result do
local with, count = row[1], row[2];
counts[with] = count;
latest[with] = row[3];
earliest[with] = row[3];
latest[with] = row[4];
end
return {
counts = counts;
earliest = earliest;
latest = latest;
};
end