Software /
code /
prosody
Diff
core/moduleapi.lua @ 6639:3003d041c159
moduleapi: Experimental API for modules to measure the rate+duration of events
author | Matthew Wild <mwild1@gmail.com> |
---|---|
date | Tue, 28 Apr 2015 13:52:07 +0100 |
parent | 6556:74253c7beb9c |
child | 6640:859e9af53aa1 |
line wrap: on
line diff
--- a/core/moduleapi.lua Tue Apr 28 13:42:59 2015 +0100 +++ b/core/moduleapi.lua Tue Apr 28 13:52:07 2015 +0100 @@ -375,6 +375,25 @@ return measure(type, "/"..self.host.."/mod_"..self.name.."/"..name); end +function api:measure_object_event(events_object, event_name, stat_name) + local m = self:measure(stat_name or event_name, "duration"); + local function handler(handlers, event_name, event_data) + local finished = m(); + local ret = handlers(event_name, event_data); + finished(); + return ret; + end + return self:hook_object_event(events_object, event_name, handler); +end + +function api:measure_event(event_name, stat_name) + return self:hook_object_event((hosts[self.host] or prosody).events.wrappers, event_name, handler); +end + +function api:measure_global_event(event_name, stat_name) + return self:hook_object_event(prosody.events.wrappers, event_name, handler); +end + function api.init(mm) modulemanager = mm; return api;