Merge 0.10->trunk
authorKim Alvefur <zash@zash.se>
Mon, 22 Feb 2016 14:24:20 +0000 (15:24 +0100)
committerKim Alvefur <zash@zash.se>
Mon, 22 Feb 2016 14:24:20 +0000 (15:24 +0100)
core/usermanager.lua
plugins/mod_debug_sql.lua [new file with mode: 0644]
plugins/mod_storage_sql.lua
tests/test.lua
tests/test_util_random.lua [new file with mode: 0644]
util/sql.lua

index 0d8d7f91a125b6ccc671f10d888778714e2555e4..d5132662b08a9b9fb404de2b0682704e88bbefcc 100644 (file)
@@ -81,6 +81,7 @@ local function set_password(username, password, host)
 end
 
 local function user_exists(username, host)
+       if hosts[host].sessions[username] then return true; end
        return hosts[host].users.user_exists(username);
 end
 
diff --git a/plugins/mod_debug_sql.lua b/plugins/mod_debug_sql.lua
new file mode 100644 (file)
index 0000000..7bbbbd8
--- /dev/null
@@ -0,0 +1,25 @@
+-- Enables SQL query logging
+--
+-- luacheck: ignore 213/uri
+
+local engines = module:shared("/*/sql/connections");
+
+for uri, engine in pairs(engines) do
+       engine:debug(true);
+end
+
+setmetatable(engines, {
+       __newindex = function (t, uri, engine)
+               engine:debug(true);
+               rawset(t, uri, engine);
+       end
+});
+
+function module.unload()
+       setmetatable(engines, nil);
+       for uri, engine in pairs(engines) do
+               engine:debug(false);
+       end
+end
+
+
index 50d34a23c15cea615489c4140e9fea8f9a0acd58..bf3c1c7bd127756d2a641fd937709f4bf400d542 100644 (file)
@@ -235,12 +235,12 @@ local function archive_where_id_range(query, args, where)
        local args_len = #args
        -- Before or after specific item, exclusive
        if query.after then  -- keys better be unique!
-               where[#where+1] = "`sort_id` > (SELECT `sort_id` FROM `prosodyarchive` WHERE `key` = ? AND `host` = ? AND `user` = ? AND `store` = ? LIMIT 1)"
+               where[#where+1] = "`sort_id` > COALESCE((SELECT `sort_id` FROM `prosodyarchive` WHERE `key` = ? AND `host` = ? AND `user` = ? AND `store` = ? LIMIT 1), 0)"
                args[args_len+1], args[args_len+2], args[args_len+3], args[args_len+4] = query.after, args[1], args[2], args[3];
                args_len = args_len + 4
        end
        if query.before then
-               where[#where+1] = "`sort_id` < (SELECT `sort_id` FROM `prosodyarchive` WHERE `key` = ? AND `host` = ? AND `user` = ? AND `store` = ? LIMIT 1)"
+               where[#where+1] = "`sort_id` < COALESCE((SELECT `sort_id` FROM `prosodyarchive` WHERE `key` = ? AND `host` = ? AND `user` = ? AND `store` = ? LIMIT 1), (SELECT MAX(`sort_id`)+1 FROM `prosodyarchive`))"
                args[args_len+1], args[args_len+2], args[args_len+3], args[args_len+4] = query.before, args[1], args[2], args[3];
        end
 end
@@ -275,7 +275,6 @@ function archive_store:find(username, query)
                end
 
                sql_query = sql_query:format(t_concat(where, " AND "), query.reverse and "DESC" or "ASC", query.limit and " LIMIT ?" or "");
-               module:log("debug", sql_query);
                return engine:select(sql_query, unpack(args));
        end);
        if not ok then return ok, result end
@@ -301,7 +300,6 @@ function archive_store:delete(username, query)
                archive_where(query, args, where);
                archive_where_id_range(query, args, where);
                sql_query = sql_query:format(t_concat(where, " AND "));
-               module:log("debug", sql_query);
                return engine:delete(sql_query, unpack(args));
        end);
 end
@@ -453,7 +451,7 @@ function module.load()
        local params = normalize_params(module:get_option("sql", default_params));
        engine = engines[sql.db2uri(params)];
        if not engine then
-               module:log("info", "Creating new engine");
+               module:log("debug", "Creating new engine");
                engine = sql:create_engine(params, function (engine)
                        if module:get_option("sql_manage_tables", true) then
                                -- Automatically create table, ignore failure (table probably already exists)
index 4863c4e70aa18b68aafc2aa4b6d1812fc37ccad4..0fcc49073983eb96c96411ccee835ee9d4128d68 100644 (file)
@@ -23,6 +23,7 @@ function run_all_tests()
        dotest "util.cache"
        dotest "util.throttle"
        dotest "util.uuid"
+       dotest "util.random"
 
        dosingletest("test_sasl.lua", "latin1toutf8");
        dosingletest("test_utf8.lua", "valid");
diff --git a/tests/test_util_random.lua b/tests/test_util_random.lua
new file mode 100644 (file)
index 0000000..79572ef
--- /dev/null
@@ -0,0 +1,10 @@
+-- Makes no attempt at testing how random the bytes are,
+-- just that it returns the number of bytes requested
+
+function bytes(bytes)
+       assert_is(bytes(16));
+
+       for i = 1, 255 do
+               assert_equal(i, #bytes(i));
+       end
+end
index 2d5e17743a6a90f448499804330741924b5caad5..b4d1453724716d838a9d3d714ef1e4ab2effa9f5 100644 (file)
@@ -147,6 +147,11 @@ local result_mt = { __index = {
        rowcount = function(self) return self.__stmt:rowcount(); end;
 } };
 
+local function debugquery(where, sql, ...)
+       local i = 0; local a = {...}
+       log("debug", "[%s] %s", where, sql:gsub("%?", function () i = i + 1; local v = a[i]; if type(v) == "string" then v = ("%q"):format(v); end return tostring(v); end));
+end
+
 function engine:execute_query(sql, ...)
        if self.params.driver == "PostgreSQL" then
                sql = sql:gsub("`", "\"");
@@ -172,6 +177,26 @@ engine.insert = engine.execute_update;
 engine.select = engine.execute_query;
 engine.delete = engine.execute_update;
 engine.update = engine.execute_update;
+local function debugwrap(name, f)
+       return function (self, sql, ...)
+               debugquery(name, sql, ...)
+               return f(self, sql, ...)
+       end
+end
+function engine:debug(enable)
+       self._debug = enable;
+       if enable then
+               engine.insert = debugwrap("insert", engine.execute_update);
+               engine.select = debugwrap("select", engine.execute_query);
+               engine.delete = debugwrap("delete", engine.execute_update);
+               engine.update = debugwrap("update", engine.execute_update);
+       else
+               engine.insert = engine.execute_update;
+               engine.select = engine.execute_query;
+               engine.delete = engine.execute_update;
+               engine.update = engine.execute_update;
+       end
+end
 function engine:_transaction(func, ...)
        if not self.conn then
                local ok, err = self:connect();
@@ -221,7 +246,9 @@ function engine:_create_index(index)
        if index.unique then
                sql = sql:gsub("^CREATE", "CREATE UNIQUE");
        end
-       --print(sql);
+       if self._debug then
+               debugquery("create", sql);
+       end
        return self:execute(sql);
 end
 function engine:_create_table(table)
@@ -252,6 +279,9 @@ function engine:_create_table(table)
        elseif self.params.driver == "MySQL" then
                sql = sql:gsub(";$", (" CHARACTER SET '%s' COLLATE '%s_bin';"):format(self.charset, self.charset));
        end
+       if self._debug then
+               debugquery("create", sql);
+       end
        local success,err = self:execute(sql);
        if not success then return success,err; end
        for i,v in ipairs(table.__table__) do