Software /
code /
prosody
File
core/offlinemanager.lua @ 2089:fdd7280c4621
s2smanager: Queue db:verify unless we already sent a db:result (if we had then it can could a dialback deadlock). Also remove some redundant code which could cause a db:result to be sent while still negotiating features (e.g. TLS) and break things. Collectively these fix a 'random' s2s failure (usually with ejabberd for some reason) - resulting in an 'unbound prefix' XML error, or 'ssl handshake failure'. Was this commit message long enough? I think so.
author | Matthew Wild <mwild1@gmail.com> |
---|---|
date | Fri, 20 Nov 2009 04:39:54 +0000 |
parent | 1523:841d61be198f |
child | 2923:b7049746bd29 |
line wrap: on
line source
-- Prosody IM -- Copyright (C) 2008-2009 Matthew Wild -- Copyright (C) 2008-2009 Waqas Hussain -- -- This project is MIT/X11 licensed. Please see the -- COPYING file in the source package for more information. -- local datamanager = require "util.datamanager"; local st = require "util.stanza"; local datetime = require "util.datetime"; local ipairs = ipairs; module "offlinemanager" function store(node, host, stanza) stanza.attr.stamp = datetime.datetime(); stanza.attr.stamp_legacy = datetime.legacy(); return datamanager.list_append(node, host, "offline", st.preserialize(stanza)); end function load(node, host) local data = datamanager.list_load(node, host, "offline"); if not data then return; end for k, v in ipairs(data) do local stanza = st.deserialize(v); stanza:tag("delay", {xmlns = "urn:xmpp:delay", from = host, stamp = stanza.attr.stamp}):up(); -- XEP-0203 stanza:tag("x", {xmlns = "jabber:x:delay", from = host, stamp = stanza.attr.stamp_legacy}):up(); -- XEP-0091 (deprecated) stanza.attr.stamp, stanza.attr.stamp_legacy = nil, nil; data[k] = stanza; end return data; end function deleteAll(node, host) return datamanager.list_store(node, host, "offline", nil); end return _M;