mirror of
https://github.com/minetest-mods/xban2.git
synced 2025-06-30 15:30:24 +02:00
Compare commits
10 Commits
new_auth
...
nalc-1.2.0
Author | SHA1 | Date | |
---|---|---|---|
1faa658651 | |||
d2cda4f73a | |||
72a99b2b18 | |||
37cdbf014e | |||
e937f5ff67 | |||
43acd1c620 | |||
58e77ad16c | |||
af26ae75bd | |||
8fde3c240f | |||
d200b342e9 |
@ -104,3 +104,9 @@ the supported import plugins at the time of writing:
|
||||
* `v2`: Old format used by xban (`players.iplist.v2`).
|
||||
|
||||
**Example:** `/xban_dbi minetest`
|
||||
|
||||
### `xban_cleanup`
|
||||
|
||||
Removes all non-banned entries from the xban db.
|
||||
|
||||
**Usage:** `/xban_cleanup`
|
||||
|
5
gui.lua
5
gui.lua
@ -61,7 +61,8 @@ local function make_fs(name)
|
||||
"size[16,12]",
|
||||
"label[0,-.1;Filter]",
|
||||
"field[1.5,0;12.8,1;filter;;"..ESC(filter).."]",
|
||||
"button[14,-.3;2,1;search;Search]",
|
||||
"field_close_on_enter[filter;false]",
|
||||
"button[14,-.3;2,1;search_submit;Search]",
|
||||
}
|
||||
local fsn = #fs
|
||||
fsn=fsn+1 fs[fsn] = format("textlist[0,.8;4,9.3;player;%s;%d;0]",
|
||||
@ -122,7 +123,7 @@ minetest.register_on_player_receive_fields(function(player, formname, fields)
|
||||
end
|
||||
return
|
||||
end
|
||||
if fields.search then
|
||||
if fields.search_submit or fields.filter then
|
||||
local filter = fields.filter or ""
|
||||
state.filter = filter
|
||||
state.list = make_list(filter)
|
||||
|
39
init.lua
39
init.lua
@ -40,6 +40,14 @@ local function parse_time(t) --> secs
|
||||
return secs
|
||||
end
|
||||
|
||||
local function concat_keys(t, sep)
|
||||
local keys = {}
|
||||
for k, _ in pairs(t) do
|
||||
keys[#keys + 1] = k
|
||||
end
|
||||
return table.concat(keys, sep)
|
||||
end
|
||||
|
||||
function xban.find_entry(player, create) --> entry, index
|
||||
for index, e in ipairs(db) do
|
||||
for name in pairs(e.names) do
|
||||
@ -111,7 +119,7 @@ function xban.ban_player(player, source, expires, reason) --> bool, err
|
||||
end
|
||||
ACTION("%s bans %s until %s for reason: %s", source, player,
|
||||
date, reason)
|
||||
ACTION("Banned Names/IPs: %s", table.concat(e.names, ", "))
|
||||
ACTION("Banned Names/IPs: %s", concat_keys(e.names, ", "))
|
||||
return true
|
||||
end
|
||||
|
||||
@ -131,7 +139,7 @@ function xban.unban_player(player, source) --> bool, err
|
||||
e.expires = nil
|
||||
e.time = nil
|
||||
ACTION("%s unbans %s", source, player)
|
||||
ACTION("Unbanned Names/IPs: %s", table.concat(e.names, ", "))
|
||||
ACTION("Unbanned Names/IPs: %s", concat_keys(e.names, ", "))
|
||||
return true
|
||||
end
|
||||
|
||||
@ -314,6 +322,7 @@ minetest.register_chatcommand("xban_wl", {
|
||||
end,
|
||||
})
|
||||
|
||||
|
||||
local function check_temp_bans()
|
||||
minetest.after(60, check_temp_bans)
|
||||
local to_rm = { }
|
||||
@ -374,6 +383,30 @@ local function load_db()
|
||||
end
|
||||
end
|
||||
|
||||
minetest.register_chatcommand("xban_cleanup", {
|
||||
description = "Removes all non-banned entries from the xban db",
|
||||
privs = { server=true },
|
||||
func = function(name, params)
|
||||
local old_count = #db
|
||||
|
||||
local i = 1
|
||||
while i <= #db do
|
||||
if not db[i].banned then
|
||||
-- not banned, remove from db
|
||||
table.remove(db, i)
|
||||
else
|
||||
-- banned, hold entry back
|
||||
i = i + 1
|
||||
end
|
||||
end
|
||||
|
||||
-- save immediately
|
||||
save_db()
|
||||
|
||||
return true, "Removed " .. (old_count - #db) .. " entries, new db entry-count: " .. #db
|
||||
end,
|
||||
})
|
||||
|
||||
minetest.register_on_shutdown(save_db)
|
||||
minetest.after(SAVE_INTERVAL, save_db)
|
||||
load_db()
|
||||
@ -383,3 +416,5 @@ minetest.after(1, check_temp_bans)
|
||||
|
||||
dofile(xban.MP.."/dbimport.lua")
|
||||
dofile(xban.MP.."/gui.lua")
|
||||
|
||||
minetest.log("action", "[xban2] loaded.")
|
||||
|
Reference in New Issue
Block a user