mirror of
https://github.com/bjc/prosody.git
synced 2025-04-04 05:37:39 +03:00
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:
parent
d3c559bcc8
commit
9d5e31fd48
3 changed files with 15 additions and 3 deletions
|
@ -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
|
||||
|
|
|
@ -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
|
||||
|
|
|
@ -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
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue