# HG changeset patch # User Matthew Wild # Date 1276115060 -3600 # Node ID 032b81731f0fde1f82ad175193dfaf0c372f6f3f # Parent 382f70627ff96cd32b6e9be86f911b5b6a6067cd usermanager: Handle checking for global admins on behalf of providers diff -r 382f70627ff9 -r 032b81731f0f core/usermanager.lua --- a/core/usermanager.lua Wed Jun 09 22:20:53 2010 +0500 +++ b/core/usermanager.lua Wed Jun 09 21:24:20 2010 +0100 @@ -90,20 +90,25 @@ end function is_admin(jid, host) + local is_admin; if host and host ~= "*" then - return hosts[host].users.is_admin(jid); - else -- Test only whether this JID is a global admin + is_admin = hosts[host].users.is_admin(jid); + end + if not is_admin then -- Test only whether this JID is a global admin local admins = config.get("*", "core", "admins"); if type(admins) == "table" then jid = jid_bare(jid); for _,admin in ipairs(admins) do - if admin == jid then return true; end + if admin == jid then + is_admin = true; + break; + end end elseif admins then log("error", "Option 'admins' for host '%s' is not a table", host); end - return nil; end + return is_admin; end return _M;