},
{
name = "builder",
- privs = {creative = true, worldedit = true, areas = true},
+ privs = {creative = true, areas = true},
color = "#EE6E00",
- tag = "[BUILDER]",
+ tag = "[Builder]",
},
{
name = "helper",
- privs = {kick = true, noclip = true, settime = true, give = true, teleport = true},
+ privs = {kick = true, noclip = true, settime = true, give = true, teleport = true, watch = true},
color = "#EBEE00",
- tag = "[HELPER]",
+ tag = "[Helper]",
},
{
name = "moderator",
- privs = {ban = true, bring = true, invhack = true, vanish = true, protection_bypass = true},
+ privs = {ban = true, bring = true, invhack = true, vanish = true, protection_bypass = true, worldedit = true},
color = "#001FFF",
- tag = "[MODERATOR]",
+ tag = "[Moderator]",
},
{
- name = "admin",
+ name = "developer",
privs = {server = true, privs = true},
+ color = "#900A00",
+ tag = "[Developer]",
+ },
+ {
+ name = "admin",
+ privs = {},
color = "#FF2D8D",
- tag = "[ADMIN]",
+ tag = "[Admin]",
},
}
-function elidragon.load_legacy_ranks()
- local file = io.open(minetest.get_worldpath() .. "/ranks.json", "r")
- if file then
- local ranks = minetest.parse_json(file:read())
- file:close()
- return ranks
- end
-end
-
-elidragon.savedata.ranks = elidragon.savedata.ranks or elidragon.load_legacy_ranks() or {}
+local s = minetest.get_mod_storage()
+local deferred = minetest.deserialize(s:get_string("deferred_rank_changes"))
-function elidragon.get_rank(name)
- return elidragon.get_rank_by_name(elidragon.savedata.ranks[name] or "player")
+function elidragon.get_rank(player)
+ local rank = player:get_meta():get_string("elidragon:rank")
+ if not rank or rank == "" then rank = "player" end
+ return elidragon.get_rank_by_name(rank)
end
function elidragon.get_rank_by_name(rankname)
- for _, rank in pairs(elidragon.ranks) do
+ for i, rank in pairs(elidragon.ranks) do
if rank.name == rankname then
- return rank
+ return rank, i
end
end
end
-function elidragon.get_player_name(name, color, brackets)
- local rank = elidragon.get_rank(name)
+function elidragon.get_player_name(player, color, brackets)
+ local rank = elidragon.get_rank(player)
local rank_tag = rank.tag
if color then
rank_tag = minetest.colorize(rank.color, rank_tag)
if not brackets then
brackets = {"",""}
end
- return rank_tag .. brackets[1] .. name .. brackets[2] .. " "
+ return rank_tag .. brackets[1] .. player:get_player_name() .. brackets[2] .. " "
+end
+
+function elidragon.update_nametag(player)
+ player:set_nametag_attributes({color = elidragon.get_rank(player).color})
end
minetest.register_on_joinplayer(function(player)
- local name = player:get_player_name()
- minetest.chat_send_all(elidragon.get_player_name(name, true) .. "has joined the Server.")
+ minetest.chat_send_all(elidragon.get_player_name(player, true) .. "has joined the Server.")
if irc and irc.connected and irc.config.send_join_part then
- irc.say(elidragon.get_player_name(name) .. "has joined the Server.")
+ irc.say(elidragon.get_player_name(player) .. "has joined the Server.")
end
- player:set_nametag_attributes({color = elidragon.get_rank(name).color})
+ elidragon.update_nametag(player)
end)
minetest.register_on_leaveplayer(function(player)
- local name = player:get_player_name()
- minetest.chat_send_all(elidragon.get_player_name(name, true) .. "has left the Server.")
+ minetest.chat_send_all(elidragon.get_player_name(player, true) .. "has left the Server.")
if irc and irc.connected and irc.config.send_join_part then
- irc.say(elidragon.get_player_name(name) .. "has left the Server.")
+ irc.say(elidragon.get_player_name(player) .. "has left the Server.")
end
end)
minetest.register_on_chat_message(function(name, message)
- minetest.chat_send_all(elidragon.get_player_name(name, true, {"<", ">"}) .. message)
+ local player = minetest.get_player_by_name(name)
+ if not player or not minetest.check_player_privs(name, {shout = true}) then return end
+ minetest.chat_send_all(elidragon.get_player_name(player, true, {"<", ">"}) .. message)
if irc and irc.connected and irc.joined_players[name] then
- irc.say(elidragon.get_player_name(name, false, {"<", ">"}) .. message)
+ irc.say(elidragon.get_player_name(player, false, {"<", ">"}) .. message)
end
return true
end)
minetest.register_chatcommand("rank", {
params = "<player> <rank>",
- description = "Set a player's rank (admin|moderator|helper|builder|vip|player)",
+ description = "Set a player's rank (admin|developer|moderator|helper|builder|vip|player)",
privs = {privs = true},
func = function(name, param)
- local target = param:split(" ")[1]
- local rank = param:split(" ")[2]
- local target_ref = minetest.get_player_by_name(name)
- local rank_ref = elidragon.get_rank_by_name(rank)
- if not rank_ref then
- minetest.chat_send_player(name, "Invalid Rank: " .. rank)
- else
- elidragon.savedata.ranks[target] = rank
+ local set_rank = function()
local privs = {}
for _, r in pairs(elidragon.ranks) do
for k, v in pairs(r.privs) do
end
minetest.set_player_privs(target, privs)
minetest.chat_send_all(target .. " is now a " .. minetest.colorize(rank_ref.color, rank_ref.name))
- if target_ref then
- target_ref:set_nametag_attributes({color = rank_ref.color})
- end
+ end
+
+ local target = param:split(" ")[1] or ""
+ local rank = param:split(" ")[2] or ""
+ local target_ref = minetest.get_player_by_name(target)
+ local rank_ref = elidragon.get_rank_by_name(rank)
+ if not rank_ref then
+ return false, "Invalid Rank: " .. rank
+ elseif not target_ref then
+ deferred[target] = rank
+ set_rank()
+ else
+ target_ref:get_meta():set_string("elidragon:rank", rank)
+ set_rank()
+ elidragon.update_nametag(target_ref)
end
end,
})
+
+minetest.register_on_joinplayer(function(player)
+ local name = player:get_player_name()
+ if deferred[name] then
+ player:get_meta():set_string("elidragon:rank", deferred[name])
+ elidragon.update_nametag(player)
+ deferred[name] = nil
+ end
+end)
+
+minetest.register_on_shutdown(function()
+ s:set_string("deferred_rank_changes", minetest.serialize(deferred))
+end)