mirror of
https://github.com/bjc/prosody.git
synced 2025-04-03 21:27:38 +03:00
mod_mam: Store archives with sub-second precision timestamps
Changes sub-second part of example timestamp to .5 in order to avoid floating point issues. Some clients use timestamps when ordering messages which can lead to messages having the same timestamp ending up in the wrong order. It would be better to preserve the order messages are sent in, which is the order they were stored in.
This commit is contained in:
parent
c85c18b03a
commit
e2807b035e
3 changed files with 10 additions and 10 deletions
|
@ -34,9 +34,9 @@ local rm_load_roster = require "core.rostermanager".load_roster;
|
|||
|
||||
local is_stanza = st.is_stanza;
|
||||
local tostring = tostring;
|
||||
local time_now = os.time;
|
||||
local time_now = require "util.time".now;
|
||||
local m_min = math.min;
|
||||
local timestamp, datestamp = import( "util.datetime", "datetime", "date");
|
||||
local timestamp, datestamp = import("util.datetime", "datetime", "date");
|
||||
local default_max_items, max_max_items = 20, module:get_option_number("max_archive_query_results", 50);
|
||||
local strip_tags = module:get_option_set("dont_archive_namespaces", { "http://jabber.org/protocol/chatstates" });
|
||||
|
||||
|
|
|
@ -45,8 +45,8 @@ Romeo sends:
|
|||
Romeo receives:
|
||||
<iq type="result" id="mamextmeta">
|
||||
<metadata xmlns="urn:xmpp:mam:2">
|
||||
<start timestamp="2008-08-22T21:09:04Z" xmlns="urn:xmpp:mam:2" id="{scansion:any}"/>
|
||||
<end timestamp="2008-08-22T21:09:04Z" xmlns="urn:xmpp:mam:2" id="{scansion:any}"/>
|
||||
<start timestamp="2008-08-22T21:09:04.500000Z" xmlns="urn:xmpp:mam:2" id="{scansion:any}"/>
|
||||
<end timestamp="2008-08-22T21:09:04.500000Z" xmlns="urn:xmpp:mam:2" id="{scansion:any}"/>
|
||||
</metadata>
|
||||
</iq>
|
||||
|
||||
|
@ -59,7 +59,7 @@ Romeo receives:
|
|||
<message to="${Romeo's full JID}">
|
||||
<result xmlns="urn:xmpp:mam:2" queryid="q1" id="{scansion:any}">
|
||||
<forwarded xmlns="urn:xmpp:forward:0">
|
||||
<delay stamp="2008-08-22T21:09:04Z" xmlns="urn:xmpp:delay"/>
|
||||
<delay stamp="2008-08-22T21:09:04.500000Z" xmlns="urn:xmpp:delay"/>
|
||||
<message to="someone@localhost" xmlns="jabber:client" type="chat" xml:lang="en" id="chat01" from="${Romeo's full JID}">
|
||||
<body>Hello</body>
|
||||
</message>
|
||||
|
@ -71,7 +71,7 @@ Romeo receives:
|
|||
<message to="${Romeo's full JID}">
|
||||
<result xmlns="urn:xmpp:mam:2" queryid="q1" id="{scansion:any}">
|
||||
<forwarded xmlns="urn:xmpp:forward:0">
|
||||
<delay stamp="2008-08-22T21:09:04Z" xmlns="urn:xmpp:delay"/>
|
||||
<delay stamp="2008-08-22T21:09:04.500000Z" xmlns="urn:xmpp:delay"/>
|
||||
<message to="someone@localhost" xmlns="jabber:client" type="chat" xml:lang="en" id="chat02" from="${Romeo's full JID}">
|
||||
<body>U there?</body>
|
||||
</message>
|
||||
|
@ -98,7 +98,7 @@ Romeo receives:
|
|||
<message to="${Romeo's full JID}">
|
||||
<result xmlns="urn:xmpp:mam:2" queryid="q1" id="{scansion:any}">
|
||||
<forwarded xmlns="urn:xmpp:forward:0">
|
||||
<delay stamp="2008-08-22T21:09:04Z" xmlns="urn:xmpp:delay"/>
|
||||
<delay stamp="2008-08-22T21:09:04.500000Z" xmlns="urn:xmpp:delay"/>
|
||||
<message to="someone@localhost" xmlns="jabber:client" type="chat" xml:lang="en" id="chat02" from="${Romeo's full JID}">
|
||||
<body>U there?</body>
|
||||
</message>
|
||||
|
@ -110,7 +110,7 @@ Romeo receives:
|
|||
<message to="${Romeo's full JID}">
|
||||
<result xmlns="urn:xmpp:mam:2" queryid="q1" id="{scansion:any}">
|
||||
<forwarded xmlns="urn:xmpp:forward:0">
|
||||
<delay stamp="2008-08-22T21:09:04Z" xmlns="urn:xmpp:delay"/>
|
||||
<delay stamp="2008-08-22T21:09:04.500000Z" xmlns="urn:xmpp:delay"/>
|
||||
<message to="someone@localhost" xmlns="jabber:client" type="chat" xml:lang="en" id="chat01" from="${Romeo's full JID}">
|
||||
<body>Hello</body>
|
||||
</message>
|
||||
|
|
|
@ -6,8 +6,8 @@ function _G.os.time()
|
|||
end
|
||||
package.preload["util.time"] = function ()
|
||||
return {
|
||||
now = function () return 1219439344.1; end;
|
||||
monotonic = function () return 0.1; end;
|
||||
now = function () return 1219439344.5; end;
|
||||
monotonic = function () return 0.5; end;
|
||||
}
|
||||
end
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue