diff options
author | Gabriel Pérez-Cerezo <gabriel@gpcf.eu> | 2020-10-10 23:35:44 +0200 |
---|---|---|
committer | Gabriel Pérez-Cerezo <gabriel@gpcf.eu> | 2020-10-10 23:35:44 +0200 |
commit | ad25fb61f76b88e27caa9d9bd9759c990c400a7f (patch) | |
tree | 7e6b81afb83b53dd5eb2cfa5f27f1e60c7a15b47 /webmail.lua | |
download | forks-modpack-ad25fb61f76b88e27caa9d9bd9759c990c400a7f.tar.gz forks-modpack-ad25fb61f76b88e27caa9d9bd9759c990c400a7f.tar.bz2 forks-modpack-ad25fb61f76b88e27caa9d9bd9759c990c400a7f.zip |
Squashed 'auth_export/' content from commit 77f7a30
git-subtree-dir: auth_export
git-subtree-split: 77f7a301678e6e4b121d0f4729594f5cb34d8c39
Diffstat (limited to 'webmail.lua')
-rw-r--r-- | webmail.lua | 53 |
1 files changed, 53 insertions, 0 deletions
diff --git a/webmail.lua b/webmail.lua new file mode 100644 index 0000000..5131adf --- /dev/null +++ b/webmail.lua @@ -0,0 +1,53 @@ +-- false per default +local has_xban2_mod = minetest.get_modpath("xban2") + +local MP = minetest.get_modpath(minetest.get_current_modname()) +local Channel = dofile(MP .. "/channel.lua") +local channel +-- auth request from webmail +local function auth_handler(auth) + local handler = minetest.get_auth_handler() + minetest.log("action", "[webmail] auth: " .. auth.name) + + local success = false + local banned = false + local message = "" + + if mail.webmail.disallow_banned_players and has_xban2_mod then + -- check xban db + local xbanentry = xban.find_entry(auth.name) + if xbanentry and xbanentry.banned then + banned = true + message = "Banned!" + end + end + + if not banned then + local entry = handler.get_auth(auth.name) + if entry and minetest.check_password_entry(auth.name, entry.password, auth.password) then + success = true + end + end + + channel.send({ + type = "auth", + data = { + name = auth.name, + success = success, + message = message + } + }) +end + + +function mail.webmail_init(http, url, key) + channel = Channel(http, url .. "/api/minetest/channel", { + extra_headers = { "webmailkey: " .. key } + }) + + channel.receive(function(data) + if data.type == "auth" then + auth_handler(data.data) + end + end) +end |