Diff

core/moduleapi.lua @ 4534:7a0a31c4f6c5

modulemanager, moduleapi: Replace hooks multitable with an event_handlers map stored in individual modules. Also adds module:hook_object_event() to hook events on any util.events compatible object.
author Matthew Wild <mwild1@gmail.com>
date Sun, 22 Jan 2012 18:49:11 +0000
parent 4531:c778ce7e3c78
child 4538:d0a89c1c43fd
line wrap: on
line diff
--- a/core/moduleapi.lua	Sun Jan 22 18:47:33 2012 +0000
+++ b/core/moduleapi.lua	Sun Jan 22 18:49:11 2012 +0000
@@ -66,14 +66,17 @@
 	return (hosts[self.host] or prosody).events.fire_event(...);
 end
 
+function api:hook_object_event(object, event, handler, priority)
+	self.event_handlers[handler] = { name = event, priority = priority, object = object };
+	return object.add_handler(event, handler, priority);
+end
+
 function api:hook(event, handler, priority)
-	hooks:set(self.host, self.name, event, handler, true);
-	(hosts[self.host] or prosody).events.add_handler(event, handler, priority);
+	return self:hook_object_event((hosts[self.host] or prosody).events, event, handler, priority);
 end
 
 function api:hook_global(event, handler, priority)
-	hooks:set("*", self.name, event, handler, true);
-	prosody.events.add_handler(event, handler, priority);
+	return self:hook_object_event(prosody.events, event, handler, priority);
 end
 
 function api:hook_stanza(xmlns, name, handler, priority)