diff options
author | Diego Martinez <kaeza@users.sf.net> | 2014-05-21 07:07:37 -0300 |
---|---|---|
committer | Diego Martinez <kaeza@users.sf.net> | 2014-05-21 07:07:37 -0300 |
commit | d47e87e390b018ac5510bb2143eb0e66f6bc2eeb (patch) | |
tree | 268699a2fcd923116452bf33bdf833893cc6f72f | |
parent | 51097eee6bb6179773e7df4c958c1dd80136ed42 (diff) |
Allow importing old databases.
Currently:
- Minetest (`ipban.txt')
- xban v1 (`players.iplist')
-rw-r--r-- | dbimport.lua | 37 | ||||
-rw-r--r-- | importers/minetest.lua | 29 | ||||
-rw-r--r-- | importers/v1.lua | 33 | ||||
-rw-r--r-- | init.lua | 8 |
4 files changed, 103 insertions, 4 deletions
diff --git a/dbimport.lua b/dbimport.lua new file mode 100644 index 0000000..22fef27 --- /dev/null +++ b/dbimport.lua @@ -0,0 +1,37 @@ + +xban.importers = { } + +dofile(xban.MP.."/importers/minetest.lua") +dofile(xban.MP.."/importers/v1.lua") + +minetest.register_chatcommand("xban_dbi", { + description = "Import old databases", + params = "<importer>", + privs = { server=true }, + func = function(name, params) + if params == "--list" then + local names = { } + for name in pairs(xban.importers) do + table.insert(names, name) + end + minetest.chat_send_player(name, + ("[xban] Known importers: %s"):format( + table.concat(names, ", "))) + return + elseif not xban.importers[params] then + minetest.chat_send_player(name, + ("[xban] Unknown importer `%s'"):format(params)) + minetest.chat_send_player(name, "[xban] Try `--list'") + return + end + local f = xban.importers[params] + local ok, err = f() + if ok then + minetest.chat_send_player(name, + "[xban] Import successfull") + else + minetest.chat_send_player(name, + ("[xban] Import failed: %s"):format(err)) + end + end, +}) diff --git a/importers/minetest.lua b/importers/minetest.lua new file mode 100644 index 0000000..e19c3c6 --- /dev/null +++ b/importers/minetest.lua @@ -0,0 +1,29 @@ + +function xban.importers.minetest() + local f, e = io.open(minetest.get_worldpath().."/ipban.txt") + if not f then + return false, "Unable to open `ipban.txt': "..e + end + for line in f:lines() do + local ip, name = line:match("([^|]+)%|(.+)") + if ip and name then + local entry + entry = xban.find_entry(ip, true) + entry.banned = true + entry.reason = "Banned in `ipban.txt'" + entry.names[name] = true + entry.names[ip] = true + entry.time = os.time() + entry.expires = nil + entry.source = "xban:importer_minetest" + table.insert(entry.record, { + source = entry.source, + reason = entry.reason, + time = entry.time, + expires = nil, + }) + end + end + f:close() + return true +end diff --git a/importers/v1.lua b/importers/v1.lua new file mode 100644 index 0000000..a3722c7 --- /dev/null +++ b/importers/v1.lua @@ -0,0 +1,33 @@ + +function xban.importers.v1() + local f, e = io.open(minetest.get_worldpath().."/players.iplist") + if not f then + return false, "Unable to open `players.iplist': "..e + end + for line in f:lines() do + local list = line:split("|") + if #list >= 2 then + local banned = (list[1]:sub(1, 1) == "!") + local entry + entry = xban.find_entry(list[1], true) + entry.banned = banned + for _, name in ipairs(list) do + entry.names[name] = true + end + if banned then + entry.reason = "Banned in `players.iplist'" + entry.time = os.time() + entry.expires = nil + entry.source = "xban:importer_v1" + table.insert(entry.record, { + source = entry.source, + reason = entry.reason, + time = entry.time, + expires = nil, + }) + end + end + end + f:close() + return true +end @@ -1,9 +1,7 @@ -xban = { } +xban = { MP = minetest.get_modpath(minetest.get_current_modname()) } -local MP = minetest.get_modpath(minetest.get_current_modname()) - -dofile(MP.."/serialize.lua") +dofile(xban.MP.."/serialize.lua") local db = { } local tempbans = { } @@ -262,3 +260,5 @@ minetest.register_on_shutdown(save_db) minetest.after(SAVE_INTERVAL, save_db) load_db() xban.db = db + +dofile(xban.MP.."/dbimport.lua") |