Mercurial > prosody-modules
changeset 178:62f47a93b5b7
mod_archive: Now we can archive messages, even though not in organized way.
author | shinysky<shinysky1986(AT)gmail.com> |
---|---|
date | Mon, 14 Jun 2010 22:13:33 +0800 (2010-06-14) |
parents | bcd7dc51a5e3 |
children | af6143756a9e |
files | mod_archive/mod_archive.lua |
diffstat | 1 files changed, 22 insertions(+), 0 deletions(-) [+] |
line wrap: on
line diff
--- a/mod_archive/mod_archive.lua Mon Jun 14 12:26:25 2010 +0100 +++ b/mod_archive/mod_archive.lua Mon Jun 14 22:13:33 2010 +0800 @@ -7,6 +7,7 @@ local st = require "util.stanza"; local dm = require "util.datamanager"; +local jid = require "util.jid"; local PREFS_DIR = "archive_prefs"; local ARCHIVE_DIR = "archive"; @@ -28,6 +29,10 @@ dm.store(node, host, dir or PREFS_DIR, st.preserialize(data)); end +local function store_msg(data, node, host, dir) + dm.list_append(node, host, dir or ARCHIVE_DIR, st.preserialize(data)); +end + ------------------------------------------------------------ -- Preferences ------------------------------------------------------------ @@ -242,10 +247,27 @@ return true; end +------------------------------------------------------------ +-- Message Handler +------------------------------------------------------------ local function msg_handler(data) module:log("debug", "-- Enter msg_handler()"); local origin, stanza = data.origin, data.stanza; + local body = stanza:child_with_name("body"); module:log("debug", "-- msg:\n%s", tostring(stanza)); + if body then + module:log("debug", "-- msg body:\n%s", tostring(body)); + -- module:log("debug", "-- msg body text:\n%s", body:get_text()); + local from_node, from_host = jid.split(stanza.attr.from); + local to_node, to_host = jid.split(stanza.attr.to); + -- FIXME the format of collections + if from_host == "localhost" then -- FIXME only archive messages of users on this host + store_msg(stanza, from_node, from_host); + end + if to_host == "localhost" then + store_msg(stanza, to_node, to_host); + end + end return nil; end