mirror of
https://github.com/bjc/prosody.git
synced 2025-04-05 22:27:38 +03:00
Rename mod_defaultauth -> mod_auth_internal, mod_hashpassauth -> mod_auth_internal_hashed, and the providers to internal and internal_hashed respectively. Also no longer auto-load defaultauth, but instead auto-load the plugin selected for each host at startup based on the provider name.
This commit is contained in:
parent
c294b198d3
commit
3846f08f09
4 changed files with 12 additions and 6 deletions
|
@ -39,7 +39,7 @@ end
|
|||
|
||||
local array, set = require "util.array", require "util.set";
|
||||
|
||||
local autoload_modules = {"presence", "message", "iq", "defaultauth"};
|
||||
local autoload_modules = {"presence", "message", "iq"};
|
||||
|
||||
-- We need this to let modules access the real global namespace
|
||||
local _G = _G;
|
||||
|
|
|
@ -7,6 +7,7 @@
|
|||
--
|
||||
|
||||
local datamanager = require "util.datamanager";
|
||||
local modulemanager = require "core.modulemanager";
|
||||
local log = require "util.logger".init("usermanager");
|
||||
local type = type;
|
||||
local error = error;
|
||||
|
@ -22,6 +23,8 @@ local prosody = _G.prosody;
|
|||
|
||||
local setmetatable = setmetatable;
|
||||
|
||||
local default_provider = "internal";
|
||||
|
||||
module "usermanager"
|
||||
|
||||
function new_null_provider()
|
||||
|
@ -33,9 +36,8 @@ local function host_handler(host)
|
|||
local host_session = hosts[host];
|
||||
host_session.events.add_handler("item-added/auth-provider", function (event)
|
||||
local provider = event.item;
|
||||
if config.get(host, "core", "authentication") == nil and provider.name == "default" then
|
||||
host_session.users = provider;
|
||||
elseif config.get(host, "core", "authentication") == provider.name then
|
||||
local auth_provider = config.get(host, "core", "authentication") or default_provider;
|
||||
if provider.name == auth_provider then
|
||||
host_session.users = provider;
|
||||
end
|
||||
if host_session.users ~= nil and host_session.users.name ~= nil then
|
||||
|
@ -49,6 +51,10 @@ local function host_handler(host)
|
|||
end
|
||||
end);
|
||||
host_session.users = new_null_provider(); -- Start with the default usermanager provider
|
||||
local auth_provider = config.get(host, "core", "authentication") or default_provider;
|
||||
if auth_provider ~= "null" then
|
||||
modulemanager.load(host, "auth_"..auth_provider);
|
||||
end
|
||||
end;
|
||||
prosody.events.add_handler("host-activated", host_handler, 100);
|
||||
prosody.events.add_handler("component-activated", host_handler, 100);
|
||||
|
|
|
@ -23,7 +23,7 @@ local prosody = _G.prosody;
|
|||
local is_cyrus = usermanager.is_cyrus;
|
||||
|
||||
function new_default_provider(host)
|
||||
local provider = { name = "default" };
|
||||
local provider = { name = "internal" };
|
||||
log("debug", "initializing default authentication provider for host '%s'", host);
|
||||
|
||||
function provider.test_password(username, password)
|
|
@ -28,7 +28,7 @@ local is_cyrus = usermanager.is_cyrus;
|
|||
local iteration_count = 4096;
|
||||
|
||||
function new_hashpass_provider(host)
|
||||
local provider = { name = "hashpass" };
|
||||
local provider = { name = "internal_hashed" };
|
||||
log("debug", "initializing hashpass authentication provider for host '%s'", host);
|
||||
|
||||
function provider.test_password(username, password)
|
Loading…
Add table
Add a link
Reference in a new issue