]> git.lizzy.rs Git - elidragon.git/commitdiff
Revert "Change rank while player is offline"
authorHimbeerserverDE <himbeerserverde@gmail.com>
Tue, 27 Apr 2021 06:24:19 +0000 (08:24 +0200)
committerHimbeerserverDE <himbeerserverde@gmail.com>
Tue, 27 Apr 2021 06:24:19 +0000 (08:24 +0200)
This reverts commit 62d142a897ac533f4c23b3195bedbe9155345004.

ranks.lua

index 0274a25eb4da6b3ff23eef516e72c9ad94806581..53f2df89370081426e4ad7ab50496fbd5a78da9f 100755 (executable)
--- a/ranks.lua
+++ b/ranks.lua
@@ -43,8 +43,6 @@ elidragon.ranks = {
        },
 }
 
-local s = minetest.get_mod_storage()
-local deferred = minetest.deserialize(s:get_string("deferred_rank_changes"))
 
 function elidragon.get_rank(player)
     local rank = player:get_meta():get_string("elidragon:rank")
@@ -106,7 +104,16 @@ minetest.register_chatcommand("rank", {
        description = "Set a player's rank (admin|developer|moderator|helper|builder|vip|player)",
        privs = {privs = true},
        func = function(name, param)
-               local set_rank = function()
+               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
+                       return false, "Player not found"
+               else
+                       target_ref:get_meta():set_string("elidragon:rank", rank)
                        local privs = {}
                        for _, r in pairs(elidragon.ranks) do
                                for k, v in pairs(r.privs) do
@@ -118,34 +125,7 @@ minetest.register_chatcommand("rank", {
                        end
                        minetest.set_player_privs(target, privs)
                        minetest.chat_send_all(target .. " is now a " .. minetest.colorize(rank_ref.color, rank_ref.name))
-               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)