diff options
author | Marco Cirillo <maranda@lightwitch.org> | 2013-04-01 23:44:28 +0000 |
---|---|---|
committer | Marco Cirillo <maranda@lightwitch.org> | 2013-04-01 23:44:28 +0000 |
commit | 85dcb700331dd4ad338b6fc449e385c30756e657 (patch) | |
tree | 9282bd448c104f21cffcd60bcd413648cf09c6e8 | |
parent | 70370a142a00d8630d55554f320810f7d066583c (diff) | |
download | prosody-85dcb700331dd4ad338b6fc449e385c30756e657.tar.gz prosody-85dcb700331dd4ad338b6fc449e385c30756e657.zip |
moduleapi: have get_host_items wrap on get_items from modulemanager, also add has_{feature/identity} to the API.
-rw-r--r-- | core/moduleapi.lua | 32 |
1 files changed, 15 insertions, 17 deletions
diff --git a/core/moduleapi.lua b/core/moduleapi.lua index f9701471..de900bf0 100644 --- a/core/moduleapi.lua +++ b/core/moduleapi.lua @@ -62,6 +62,20 @@ end function api:add_extension(data) self:add_item("extension", data); end +function api:has_feature(xmlns) + for _, feature in ipairs(self:get_host_items("feature")) do + if feature == xmlns then return true; end + end + return false; +end +function api:has_identity(category, type, name) + for _, id in ipairs(self:get_host_items("identity")) do + if id.category == category and id.type == type and id.name == name then + return true; + end + end + return false; +end function api:fire_event(...) return (hosts[self.host] or prosody).events.fire_event(...); @@ -271,23 +285,7 @@ function api:remove_item(key, value) end function api:get_host_items(key) - local result = {}; - for mod_name, module in pairs(modulemanager.get_modules(self.host)) do - module = module.module; - if module.items then - for _, item in ipairs(module.items[key] or NULL) do - t_insert(result, item); - end - end - end - for mod_name, module in pairs(modulemanager.get_modules("*")) do - module = module.module; - if module.items then - for _, item in ipairs(module.items[key] or NULL) do - t_insert(result, item); - end - end - end + local result = modulemanager.get_items(key, self.host) or {}; return result; end |