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:
Matthew Wild 2022-07-12 13:14:47 +01:00
parent af339f0e66
commit 4db3d15723
3 changed files with 35 additions and 2 deletions

View file

@ -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