diff options
author | Matthew Wild <mwild1@gmail.com> | 2022-07-12 13:14:47 +0100 |
---|---|---|
committer | Matthew Wild <mwild1@gmail.com> | 2022-07-12 13:14:47 +0100 |
commit | 4db3d1572390ce5b615282cb1112358d9e3ba892 (patch) | |
tree | 37bb45722201e08eb3e8a4ff1c88d27fbdd372ac /plugins/mod_auth_internal_hashed.lua | |
parent | af339f0e66480da6825fd655a5bf35e2824cfc00 (diff) | |
download | prosody-4db3d1572390ce5b615282cb1112358d9e3ba892.tar.gz prosody-4db3d1572390ce5b615282cb1112358d9e3ba892.zip |
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).
Diffstat (limited to 'plugins/mod_auth_internal_hashed.lua')
-rw-r--r-- | plugins/mod_auth_internal_hashed.lua | 14 |
1 files changed, 13 insertions, 1 deletions
diff --git a/plugins/mod_auth_internal_hashed.lua b/plugins/mod_auth_internal_hashed.lua index cf851eef..397d82e9 100644 --- a/plugins/mod_auth_internal_hashed.lua +++ b/plugins/mod_auth_internal_hashed.lua @@ -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 |