aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--core/modulemanager.lua8
-rw-r--r--plugins/mod_iq.lua33
-rw-r--r--plugins/mod_message.lua41
3 files changed, 82 insertions, 0 deletions
diff --git a/core/modulemanager.lua b/core/modulemanager.lua
index 57a44c29..901659f7 100644
--- a/core/modulemanager.lua
+++ b/core/modulemanager.lua
@@ -354,6 +354,14 @@ function api:fire_event(...)
return eventmanager.fire_event(...);
end
+function api:hook(event, handler)
+ if self.host ~= '*' then
+ hosts[self.host].events.add_handler(event, handler);
+ else
+ self:log("error", "Global module attempting to hook a host-specific event: %s", event);
+ end
+end
+
--------------------------------------------------------------------
local actions = {};
diff --git a/plugins/mod_iq.lua b/plugins/mod_iq.lua
new file mode 100644
index 00000000..e0c9813d
--- /dev/null
+++ b/plugins/mod_iq.lua
@@ -0,0 +1,33 @@
+
+local full_sessions = full_sessions;
+local bare_sessions = bare_sessions;
+
+module:hook("iq/full", function(data)
+ -- IQ 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 error reply
+ end
+end);
+
+module:hook("iq/bare", function(data)
+ -- IQ to bare JID recieved
+ local origin, stanza = data.origin, data.stanza;
+
+ -- TODO if not user exists, return an error
+ -- TODO fire post processing events
+ -- TODO fire event with the xmlns:tag of the child, or with the id of errors and results
+end);
+
+module:hook("iq/host", function(data)
+ -- IQ to a local host recieved
+ local origin, stanza = data.origin, data.stanza;
+
+ -- TODO fire event with the xmlns:tag of the child, or with the id of errors and results
+end);
diff --git a/plugins/mod_message.lua b/plugins/mod_message.lua
new file mode 100644
index 00000000..c0abe936
--- /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_sessions[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);