Skip to content

Commit

Permalink
Check for area protection in buckets
Browse files Browse the repository at this point in the history
  • Loading branch information
Ekdohibs authored and ShadowNinja committed Dec 14, 2013
1 parent 64fdb49 commit e8bcfdc
Showing 1 changed file with 24 additions and 0 deletions.
24 changes: 24 additions & 0 deletions mods/bucket/init.lua
Expand Up @@ -18,6 +18,19 @@ minetest.register_craft({
bucket = {}
bucket.liquids = {}

local function check_protection(pos, name, text)
if minetest.is_protected(pos, name) then
minetest.log("action", name
.. " tried to " .. text
.. " at protected position "
.. minetest.pos_to_string(pos)
.. " with a bucket")
minetest.record_protection_violation(pos, name)
return true
end
return false
end

-- Register a new liquid
-- source = name of the source node
-- flowing = name of the flowing node
Expand Down Expand Up @@ -55,6 +68,11 @@ function bucket.register_liquid(source, flowing, itemname, inventory_image, name
end

local place_liquid = function(pos, node, source, flowing, fullness)
if check_protection(pos,
user:get_player_name(),
"place "..source) then
return
end
if math.floor(fullness/128) == 1 or (not minetest.setting_getbool("liquid_finite")) then
minetest.add_node(pos, {name=source, param2=fullness})
return
Expand Down Expand Up @@ -112,6 +130,12 @@ minetest.register_craftitem("bucket:bucket_empty", {
if liquiddef ~= nil and liquiddef.itemname ~= nil and (node.name == liquiddef.source or
(node.name == liquiddef.flowing and minetest.setting_getbool("liquid_finite"))) then

if check_protection(pointed_thing.under,
user:get_player_name(),
"take ".. node.name) then
return
end

minetest.add_node(pointed_thing.under, {name="air"})

if node.name == liquiddef.source then node.param2 = LIQUID_MAX end
Expand Down

0 comments on commit e8bcfdc

Please sign in to comment.