mirror of
https://github.com/minetest/minetest_game.git
synced 2025-01-24 22:30:18 +01:00
Beds: priv/griefing fixes.
- disallow placing beds in protected areas
- fix rotation of beds(broken after 41c2b2ae
)
- allow using others' beds, but don't change spawn location
Fixes #953. #943 isn't something I think was ever implemented, and
this does a fair job of addressing the main concern (spawning in
others' houses)
This commit is contained in:
parent
b57dd0f9b2
commit
da0cc7f6f6
@ -44,22 +44,41 @@ function beds.register_bed(name, def)
|
|||||||
fixed = def.selectionbox,
|
fixed = def.selectionbox,
|
||||||
},
|
},
|
||||||
|
|
||||||
after_place_node = function(pos, placer, itemstack)
|
on_place = function(itemstack, placer, pointed_thing)
|
||||||
local n = minetest.get_node_or_nil(pos)
|
local under = pointed_thing.under
|
||||||
if not n or not n.param2 then
|
local pos
|
||||||
minetest.remove_node(pos)
|
if minetest.registered_items[minetest.get_node(under).name].buildable_to then
|
||||||
return true
|
pos = under
|
||||||
|
else
|
||||||
|
pos = pointed_thing.above
|
||||||
end
|
end
|
||||||
local dir = minetest.facedir_to_dir(n.param2)
|
|
||||||
local p = vector.add(pos, dir)
|
if minetest.is_protected(pos, placer:get_player_name()) and
|
||||||
local n2 = minetest.get_node_or_nil(p)
|
not minetest.check_player_privs(placer, "protection_bypass") then
|
||||||
local def = n2 and minetest.registered_items[n2.name]
|
minetest.record_protection_violation(pos, placer:get_player_name())
|
||||||
if not def or not def.buildable_to then
|
return itemstack
|
||||||
minetest.remove_node(pos)
|
|
||||||
return true
|
|
||||||
end
|
end
|
||||||
minetest.set_node(p, {name = n.name:gsub("%_bottom", "_top"), param2 = n.param2})
|
|
||||||
return false
|
local dir = minetest.dir_to_facedir(placer:get_look_dir())
|
||||||
|
local botpos = vector.add(pos, minetest.facedir_to_dir(dir))
|
||||||
|
|
||||||
|
if minetest.is_protected(botpos, placer:get_player_name()) and
|
||||||
|
not minetest.check_player_privs(placer, "protection_bypass") then
|
||||||
|
minetest.record_protection_violation(botpos, placer:get_player_name())
|
||||||
|
return itemstack
|
||||||
|
end
|
||||||
|
|
||||||
|
if not minetest.registered_nodes[minetest.get_node(botpos).name].buildable_to then
|
||||||
|
return itemstack
|
||||||
|
end
|
||||||
|
|
||||||
|
minetest.set_node(pos, {name = name .. "_bottom", param2 = dir})
|
||||||
|
minetest.set_node(botpos, {name = name .. "_top", param2 = dir})
|
||||||
|
|
||||||
|
if not minetest.setting_getbool("creative_mode") then
|
||||||
|
itemstack:take_item()
|
||||||
|
end
|
||||||
|
return itemstack
|
||||||
end,
|
end,
|
||||||
|
|
||||||
on_destruct = function(pos)
|
on_destruct = function(pos)
|
||||||
@ -96,9 +115,10 @@ function beds.register_bed(name, def)
|
|||||||
return false
|
return false
|
||||||
end
|
end
|
||||||
node.param2 = new_param2
|
node.param2 = new_param2
|
||||||
minetest.swap_node(pos, node)
|
-- do not remove_node here - it will trigger destroy_bed()
|
||||||
minetest.remove_node(p)
|
minetest.set_node(p, {name = "air"})
|
||||||
minetest.set_node(newp, {name = node.name:gsub("%_bottom", "_top"), param2 = new_param2})
|
minetest.set_node(pos, node)
|
||||||
|
minetest.set_node(newp, {name = name .. "_top", param2 = new_param2})
|
||||||
return true
|
return true
|
||||||
end,
|
end,
|
||||||
})
|
})
|
||||||
|
@ -18,8 +18,8 @@ function beds.read_spawns()
|
|||||||
repeat
|
repeat
|
||||||
local x = input:read("*n")
|
local x = input:read("*n")
|
||||||
if x == nil then
|
if x == nil then
|
||||||
break
|
break
|
||||||
end
|
end
|
||||||
local y = input:read("*n")
|
local y = input:read("*n")
|
||||||
local z = input:read("*n")
|
local z = input:read("*n")
|
||||||
local name = input:read("*l")
|
local name = input:read("*l")
|
||||||
@ -52,7 +52,10 @@ function beds.set_spawns()
|
|||||||
for name,_ in pairs(beds.player) do
|
for name,_ in pairs(beds.player) do
|
||||||
local player = minetest.get_player_by_name(name)
|
local player = minetest.get_player_by_name(name)
|
||||||
local p = player:getpos()
|
local p = player:getpos()
|
||||||
beds.spawn[name] = p
|
-- but don't change spawn location if borrowing a bed
|
||||||
|
if not minetest.is_protected(p, name) then
|
||||||
|
beds.spawn[name] = p
|
||||||
|
end
|
||||||
end
|
end
|
||||||
beds.save_spawns()
|
beds.save_spawns()
|
||||||
end
|
end
|
||||||
|
Loading…
Reference in New Issue
Block a user