prevent csm tampering

This commit is contained in:
TenPlus1 2018-07-03 14:14:39 +01:00
parent 3331132a4b
commit dacab4f038
2 changed files with 23 additions and 14 deletions

@ -53,6 +53,7 @@ Change log:
- 2.3 - Localise many of the protector functions and tidy code. - 2.3 - Localise many of the protector functions and tidy code.
- 2.4 - Update to newer functions, Minetest 0.4.16 needed to run now. - 2.4 - Update to newer functions, Minetest 0.4.16 needed to run now.
- 2.5 - Added HUD text to show when player is inside a protected area (updates every 5 seconds) - 2.5 - Added HUD text to show when player is inside a protected area (updates every 5 seconds)
- 2.6 - Add protection against CSM tampering
Lucky Blocks: 10 Lucky Blocks: 10

@ -353,6 +353,9 @@ local check_overlap = function(itemstack, placer, pointed_thing)
end end
-- temporary pos store
local player_pos = {}
-- protection node -- protection node
minetest.register_node("protector:protect", { minetest.register_node("protector:protect", {
description = S("Protection Block") .. " (" .. S("USE for area check") .. ")", description = S("Protection Block") .. " (" .. S("USE for area check") .. ")",
@ -398,13 +401,14 @@ minetest.register_node("protector:protect", {
on_rightclick = function(pos, node, clicker, itemstack) on_rightclick = function(pos, node, clicker, itemstack)
local meta = minetest.get_meta(pos) local meta = minetest.get_meta(pos)
local name = clicker:get_player_name()
if meta if meta
and protector.can_dig(1, pos, clicker:get_player_name(), true, 1) then and protector.can_dig(1, pos, name, true, 1) then
minetest.show_formspec(clicker:get_player_name(), player_pos[name] = pos
"protector:node_" .. minetest.pos_to_string(pos),
protector_formspec(meta)) minetest.show_formspec(name, "protector:node", protector_formspec(meta))
end end
end, end,
@ -481,11 +485,14 @@ minetest.register_node("protector:protect2", {
on_rightclick = function(pos, node, clicker, itemstack) on_rightclick = function(pos, node, clicker, itemstack)
local meta = minetest.get_meta(pos) local meta = minetest.get_meta(pos)
local name = clicker:get_player_name()
if protector.can_dig(1, pos, clicker:get_player_name(), true, 1) then if meta
and protector.can_dig(1, pos, name, true, 1) then
minetest.show_formspec(clicker:get_player_name(), player_pos[name] = pos
"protector:node_" .. minetest.pos_to_string(pos), protector_formspec(meta))
minetest.show_formspec(name, "protector:node", protector_formspec(meta))
end end
end, end,
@ -523,14 +530,13 @@ minetest.register_craft({
-- check formspec buttons or when name entered -- check formspec buttons or when name entered
minetest.register_on_player_receive_fields(function(player, formname, fields) minetest.register_on_player_receive_fields(function(player, formname, fields)
-- protector formspec found if formname == "protector:node" then
if string.sub(formname, 0, string.len("protector:node_")) == "protector:node_" then
local pos_s = string.sub(formname, string.len("protector:node_") + 1) local name = player:get_player_name()
local pos = minetest.string_to_pos(pos_s) local pos = player_pos[name]
local meta = minetest.get_meta(pos) local meta = minetest.get_meta(pos)
if not meta then if not name or not pos or not meta then
return return
end end
@ -567,8 +573,10 @@ minetest.register_on_player_receive_fields(function(player, formname, fields)
end end
-- reset formspec until close button pressed -- reset formspec until close button pressed
if not fields.close_me then if not fields.close_me and not fields.quit then
minetest.show_formspec(player:get_player_name(), formname, protector_formspec(meta)) minetest.show_formspec(name, formname, protector_formspec(meta))
else
player_pos[name] = nil
end end
end end
end) end)