Comparison

mod_auth_sql/mod_auth_sql.lua @ 399:4e0d36941ba1

mod_auth_sql: More cleanup.
author Waqas Hussain <waqas20@gmail.com>
date Wed, 10 Aug 2011 05:30:08 +0500
parent 398:fdd4f5ab029a
child 455:52f2188ec47d
comparison
equal deleted inserted replaced
398:fdd4f5ab029a 399:4e0d36941ba1
1 -- Simple SQL Authentication module for Prosody IM 1 -- Simple SQL Authentication module for Prosody IM
2 -- Copyright (C) 2011 Tomasz Sterna <tomek@xiaoka.com> 2 -- Copyright (C) 2011 Tomasz Sterna <tomek@xiaoka.com>
3 -- Copyright (C) 2011 Waqas Hussain <waqas20@gmail.com>
3 -- 4 --
4 5
5 local log = require "util.logger".init("auth_sql"); 6 local log = require "util.logger".init("auth_sql");
6 local new_sasl = require "util.sasl".new; 7 local new_sasl = require "util.sasl".new;
7 local nodeprep = require "util.encodings".stringprep.nodeprep; 8 local nodeprep = require "util.encodings".stringprep.nodeprep;
68 if not ok then return nil, err; end 69 if not ok then return nil, err; end
69 70
70 return stmt; 71 return stmt;
71 end 72 end
72 73
74 local function get_password(username)
75 local stmt, err = getsql("SELECT `password` FROM `authreg` WHERE `username`=? AND `realm`=?", username, module.host);
76 if stmt then
77 for row in stmt:rows(true) do
78 return row.password;
79 end
80 end
81 end
82
73 83
74 provider = { name = "sql" }; 84 provider = { name = "sql" };
75 85
76 function provider.test_password(username, password) 86 function provider.test_password(username, password)
77 local stmt, err = getsql("SELECT `username` FROM `authreg` WHERE `username`=? AND `password`=? AND `realm`=?", 87 return password and get_password(username) == password;
78 username, password, module.host);
79
80 if not stmt then return nil, err; end
81
82 for row in stmt:rows(true) do
83 return true;
84 end
85 end 88 end
86
87 function provider.get_password(username) 89 function provider.get_password(username)
88 local stmt, err = getsql("SELECT `password` FROM `authreg` WHERE `username`=? AND `realm`=?", 90 return get_password(username);
89 username, module.host);
90
91 if not stmt then return nil, err; end
92
93 for row in stmt:rows(true) do
94 return row.password;
95 end
96 end 91 end
97
98 function provider.set_password(username, password) 92 function provider.set_password(username, password)
99 return nil, "Setting password is not supported."; 93 return nil, "Setting password is not supported.";
100 end 94 end
101
102 function provider.user_exists(username) 95 function provider.user_exists(username)
103 local stmt, err = getsql("SELECT `username` FROM `authreg` WHERE `username`=? AND `realm`=?", 96 return get_password(username) and true;
104 username, module.host);
105
106 if not stmt then return nil, err; end
107
108 for row in stmt:rows(true) do
109 return true;
110 end
111 end 97 end
112
113 function provider.create_user(username, password) 98 function provider.create_user(username, password)
114 return nil, "Account creation/modification not supported."; 99 return nil, "Account creation/modification not supported.";
115 end 100 end
116
117 function provider.get_sasl_handler() 101 function provider.get_sasl_handler()
118 local profile = { 102 local profile = {
119 plain = function(sasl, username, realm) 103 plain = function(sasl, username, realm)
120 local prepped_username = nodeprep(username); 104 local prepped_username = nodeprep(username);
121 if not prepped_username then 105 if not prepped_username then
122 module:log("debug", "NODEprep failed on username: %s", username); 106 module:log("debug", "NODEprep failed on username: %s", username);
123 return "", nil; 107 return "", nil;
124 end 108 end
125 local password = provider.get_password(prepped_username); 109 local password = get_password(prepped_username);
126 if not password then return "", nil; end 110 if not password then return "", nil; end
127 return password, true; 111 return password, true;
128 end 112 end
129 }; 113 };
130 return new_sasl(module.host, profile); 114 return new_sasl(module.host, profile);