aboutsummaryrefslogtreecommitdiffstats
path: root/plugins/mod_message.lua
diff options
context:
space:
mode:
authorWaqas Hussain <waqas20@gmail.com>2009-05-30 17:36:05 +0500
committerWaqas Hussain <waqas20@gmail.com>2009-05-30 17:36:05 +0500
commit3761a13384d537f8530f67d956def14f14634723 (patch)
tree72b05be10da776b9059fcf837668f12a1fb50302 /plugins/mod_message.lua
parent777a395b47795ba460f31bca1f6ab786f49d56d0 (diff)
downloadprosody-3761a13384d537f8530f67d956def14f14634723.tar.gz
prosody-3761a13384d537f8530f67d956def14f14634723.zip
mod_message: Initial commit
Diffstat (limited to 'plugins/mod_message.lua')
-rw-r--r--plugins/mod_message.lua41
1 files changed, 41 insertions, 0 deletions
diff --git a/plugins/mod_message.lua b/plugins/mod_message.lua
new file mode 100644
index 00000000..a99287ab
--- /dev/null
+++ b/plugins/mod_message.lua
@@ -0,0 +1,41 @@
+
+local full_sessions = full_sessions;
+local bare_sessions = bare_sessions;
+
+local jid_bare = require "util.jid".bare;
+local user_exists = require "core.usermanager".user_exists;
+
+module:hook("message/full", function(data)
+ -- message to full JID recieved
+ local origin, stanza = data.origin, data.stanza;
+
+ local session = full_sessions[stanza.attr.to];
+ if session then
+ -- TODO fire post processing event
+ session.send(stanza);
+ return true;
+ else -- resource not online
+ -- TODO fire event to send to bare JID
+ end
+end);
+
+module:hook("message/bare", function(data)
+ -- message to bare JID recieved
+ local origin, stanza = data.origin, data.stanza;
+
+ local sessions = bare_sessoins[stanza.attr.to];
+ if sessions then sessions = sessions.sessions; end
+
+ if sessions then
+ -- some resources are online
+ -- TODO find top resources willing to accept this message
+ -- TODO then send them each the stanza
+ else
+ -- no resources are online
+ -- TODO check if the user exists
+ -- TODO if it doesn't, return an error reply
+ -- TODO otherwise, apply the default privacy list
+ -- TODO and store into offline storage
+ -- TODO or maybe the offline store can apply privacy lists
+ end
+end);