diff options
author | sfan5 <sfan5@live.de> | 2017-12-06 17:32:49 +0100 |
---|---|---|
committer | SmallJoker <SmallJoker@users.noreply.github.com> | 2017-12-06 17:32:49 +0100 |
commit | 4edf08709010f721b099dfae3cab011acbdfb3ff (patch) | |
tree | 530b903ee81b672fe5a4dd9cfa7a00059b5c541a /builtin/game | |
parent | 2b5341c51864660bb1a434a520f7cca9ce3619e6 (diff) | |
download | minetest-4edf08709010f721b099dfae3cab011acbdfb3ff.tar.gz minetest-4edf08709010f721b099dfae3cab011acbdfb3ff.tar.bz2 minetest-4edf08709010f721b099dfae3cab011acbdfb3ff.zip |
Auth handler: Player deletion & Iterator (#6741)
* Add player deletion method to auth handler (fixes #6653)
* Support iterating over the auth database
There was no way to do this previously and a recent commit
broke doing this the "hacky" way by accessing `core.auth_table`.
Diffstat (limited to 'builtin/game')
-rw-r--r-- | builtin/game/auth.lua | 18 |
1 files changed, 18 insertions, 0 deletions
diff --git a/builtin/game/auth.lua b/builtin/game/auth.lua index 80b15e818..3d4d6b199 100644 --- a/builtin/game/auth.lua +++ b/builtin/game/auth.lua @@ -106,6 +106,16 @@ core.builtin_auth_handler = { } save_auth_file() end, + delete_auth = function(name) + assert(type(name) == "string") + if not auth_table[name] then + return false + end + core.log('info', "Built-in authentication handler deleting player '"..name.."'") + auth_table[name] = nil + save_auth_file() + return true + end, set_password = function(name, password) assert(type(name) == "string") assert(type(password) == "string") @@ -154,6 +164,13 @@ core.builtin_auth_handler = { assert(auth_table[name]).last_login = os.time() save_auth_file() end, + iterate = function() + local names = {} + for k in pairs(auth_table) do + names[k] = true + end + return pairs(names) + end, } core.register_on_prejoinplayer(function(name, ip) @@ -204,6 +221,7 @@ end core.set_player_password = auth_pass("set_password") core.set_player_privs = auth_pass("set_privileges") +core.remove_player_auth = auth_pass("delete_auth") core.auth_reload = auth_pass("reload") local record_login = auth_pass("record_login") |