mirror of
https://github.com/bjc/prosody.git
synced 2025-04-03 21:27:38 +03:00
usermanager, mod_auth_*: Add get_account_info() returning creation/update time
This is useful for a number of things. For example, listing users that need to rotate their passwords after some event. It also provides a safer way for code to determine that a user password has changed without needing to set a handler for the password change event (which is a more fragile approach).
This commit is contained in:
parent
af339f0e66
commit
4db3d15723
3 changed files with 35 additions and 2 deletions
|
@ -86,11 +86,21 @@ function provider.set_password(username, password)
|
|||
account.server_key = server_key_hex
|
||||
|
||||
account.password = nil;
|
||||
account.updated = os.time();
|
||||
return accounts:set(username, account);
|
||||
end
|
||||
return nil, "Account not available.";
|
||||
end
|
||||
|
||||
function provider.get_account_info(username)
|
||||
local account = accounts:get(username);
|
||||
if not account then return nil, "Account not available"; end
|
||||
return {
|
||||
created = account.created;
|
||||
password_updated = account.updated;
|
||||
};
|
||||
end
|
||||
|
||||
function provider.user_exists(username)
|
||||
local account = accounts:get(username);
|
||||
if not account then
|
||||
|
@ -115,9 +125,11 @@ function provider.create_user(username, password)
|
|||
end
|
||||
local stored_key_hex = to_hex(stored_key);
|
||||
local server_key_hex = to_hex(server_key);
|
||||
local now = os.time();
|
||||
return accounts:set(username, {
|
||||
stored_key = stored_key_hex, server_key = server_key_hex,
|
||||
salt = salt, iteration_count = default_iteration_count
|
||||
salt = salt, iteration_count = default_iteration_count,
|
||||
created = now, updated = now;
|
||||
});
|
||||
end
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue