aboutsummaryrefslogtreecommitdiffstats
path: root/util/sasl/external.lua
diff options
context:
space:
mode:
authorKim Alvefur <zash@zash.se>2013-06-13 18:20:49 +0200
committerKim Alvefur <zash@zash.se>2013-06-13 18:20:49 +0200
commit216b3a3df35f3631e0955870c2e97ac466e064ed (patch)
tree6edb8cb27a0121e8bb7ff3194d9194ec6b058583 /util/sasl/external.lua
parent1f4a227deefac1dc3e714428ecf16ec9306ad63f (diff)
downloadprosody-216b3a3df35f3631e0955870c2e97ac466e064ed.tar.gz
prosody-216b3a3df35f3631e0955870c2e97ac466e064ed.zip
util.sasl.external: Add SASL EXTERNAL mechanism
Diffstat (limited to 'util/sasl/external.lua')
-rw-r--r--util/sasl/external.lua25
1 files changed, 25 insertions, 0 deletions
diff --git a/util/sasl/external.lua b/util/sasl/external.lua
new file mode 100644
index 00000000..4c5c4343
--- /dev/null
+++ b/util/sasl/external.lua
@@ -0,0 +1,25 @@
+local saslprep = require "util.encodings".stringprep.saslprep;
+
+module "sasl.external"
+
+local function external(self, message)
+ message = saslprep(message);
+ local state
+ self.username, state = self.profile.external(message);
+
+ if state == false then
+ return "failure", "account-disabled";
+ elseif state == nil then
+ return "failure", "not-authorized";
+ elseif state == "expired" then
+ return "false", "credentials-expired";
+ end
+
+ return "success";
+end
+
+function init(registerMechanism)
+ registerMechanism("EXTERNAL", {"external"}, external);
+end
+
+return _M;