2013-05-19 18:43:04 +02:00
|
|
|
-- mods/default/tools.lua
|
|
|
|
|
|
|
|
-- The hand
|
|
|
|
minetest.register_item(":", {
|
|
|
|
type = "none",
|
|
|
|
wield_image = "wieldhand.png",
|
|
|
|
wield_scale = {x=1,y=1,z=2.5},
|
|
|
|
tool_capabilities = {
|
|
|
|
full_punch_interval = 0.9,
|
|
|
|
max_drop_level = 0,
|
|
|
|
groupcaps = {
|
|
|
|
crumbly = {times={[2]=3.00, [3]=0.70}, uses=0, maxlevel=1},
|
|
|
|
snappy = {times={[3]=0.40}, uses=0, maxlevel=1},
|
2013-09-29 00:02:38 +02:00
|
|
|
oddly_breakable_by_hand = {times={[1]=3.50,[2]=2.00,[3]=0.70}, uses=0}
|
2013-05-19 18:43:04 +02:00
|
|
|
},
|
|
|
|
damage_groups = {fleshy=1},
|
|
|
|
}
|
|
|
|
})
|
|
|
|
|
|
|
|
--
|
|
|
|
-- Picks
|
|
|
|
--
|
|
|
|
|
|
|
|
minetest.register_tool("default:pick_wood", {
|
|
|
|
description = "Wooden Pickaxe",
|
|
|
|
inventory_image = "default_tool_woodpick.png",
|
|
|
|
tool_capabilities = {
|
|
|
|
full_punch_interval = 1.2,
|
|
|
|
max_drop_level=0,
|
|
|
|
groupcaps={
|
|
|
|
cracky = {times={[3]=1.60}, uses=10, maxlevel=1},
|
|
|
|
},
|
|
|
|
damage_groups = {fleshy=2},
|
|
|
|
},
|
2016-10-24 20:34:00 +02:00
|
|
|
groups = {flammable = 2},
|
2016-01-22 22:04:38 -08:00
|
|
|
sound = {breaks = "default_tool_breaks"},
|
2013-05-19 18:43:04 +02:00
|
|
|
})
|
2016-01-22 22:04:38 -08:00
|
|
|
|
2013-05-19 18:43:04 +02:00
|
|
|
minetest.register_tool("default:pick_stone", {
|
|
|
|
description = "Stone Pickaxe",
|
|
|
|
inventory_image = "default_tool_stonepick.png",
|
|
|
|
tool_capabilities = {
|
|
|
|
full_punch_interval = 1.3,
|
|
|
|
max_drop_level=0,
|
|
|
|
groupcaps={
|
2014-11-30 08:08:45 +01:00
|
|
|
cracky = {times={[2]=2.0, [3]=1.00}, uses=20, maxlevel=1},
|
2013-05-19 18:43:04 +02:00
|
|
|
},
|
|
|
|
damage_groups = {fleshy=3},
|
|
|
|
},
|
2016-01-22 22:04:38 -08:00
|
|
|
sound = {breaks = "default_tool_breaks"},
|
2013-05-19 18:43:04 +02:00
|
|
|
})
|
2016-01-22 22:04:38 -08:00
|
|
|
|
2013-05-19 18:43:04 +02:00
|
|
|
minetest.register_tool("default:pick_steel", {
|
|
|
|
description = "Steel Pickaxe",
|
|
|
|
inventory_image = "default_tool_steelpick.png",
|
|
|
|
tool_capabilities = {
|
|
|
|
full_punch_interval = 1.0,
|
|
|
|
max_drop_level=1,
|
|
|
|
groupcaps={
|
|
|
|
cracky = {times={[1]=4.00, [2]=1.60, [3]=0.80}, uses=20, maxlevel=2},
|
|
|
|
},
|
|
|
|
damage_groups = {fleshy=4},
|
|
|
|
},
|
2016-01-22 22:04:38 -08:00
|
|
|
sound = {breaks = "default_tool_breaks"},
|
2013-05-19 18:43:04 +02:00
|
|
|
})
|
2016-01-22 22:04:38 -08:00
|
|
|
|
2013-05-19 18:43:04 +02:00
|
|
|
minetest.register_tool("default:pick_bronze", {
|
|
|
|
description = "Bronze Pickaxe",
|
|
|
|
inventory_image = "default_tool_bronzepick.png",
|
|
|
|
tool_capabilities = {
|
|
|
|
full_punch_interval = 1.0,
|
|
|
|
max_drop_level=1,
|
|
|
|
groupcaps={
|
|
|
|
cracky = {times={[1]=4.00, [2]=1.60, [3]=0.80}, uses=30, maxlevel=2},
|
|
|
|
},
|
|
|
|
damage_groups = {fleshy=4},
|
|
|
|
},
|
2016-01-22 22:04:38 -08:00
|
|
|
sound = {breaks = "default_tool_breaks"},
|
2013-05-19 18:43:04 +02:00
|
|
|
})
|
2016-01-22 22:04:38 -08:00
|
|
|
|
2013-05-19 18:43:04 +02:00
|
|
|
minetest.register_tool("default:pick_mese", {
|
|
|
|
description = "Mese Pickaxe",
|
|
|
|
inventory_image = "default_tool_mesepick.png",
|
|
|
|
tool_capabilities = {
|
|
|
|
full_punch_interval = 0.9,
|
|
|
|
max_drop_level=3,
|
|
|
|
groupcaps={
|
|
|
|
cracky = {times={[1]=2.4, [2]=1.2, [3]=0.60}, uses=20, maxlevel=3},
|
|
|
|
},
|
|
|
|
damage_groups = {fleshy=5},
|
|
|
|
},
|
2016-01-22 22:04:38 -08:00
|
|
|
sound = {breaks = "default_tool_breaks"},
|
2013-05-19 18:43:04 +02:00
|
|
|
})
|
2016-01-22 22:04:38 -08:00
|
|
|
|
2013-05-19 18:43:04 +02:00
|
|
|
minetest.register_tool("default:pick_diamond", {
|
|
|
|
description = "Diamond Pickaxe",
|
|
|
|
inventory_image = "default_tool_diamondpick.png",
|
|
|
|
tool_capabilities = {
|
|
|
|
full_punch_interval = 0.9,
|
|
|
|
max_drop_level=3,
|
|
|
|
groupcaps={
|
2016-05-31 18:02:13 +02:00
|
|
|
cracky = {times = {[1] = 2.25, [2] = 0.70, [3] = 0.55}, uses = 30, maxlevel= 3}
|
2013-05-19 18:43:04 +02:00
|
|
|
},
|
|
|
|
damage_groups = {fleshy=5},
|
|
|
|
},
|
2016-01-22 22:04:38 -08:00
|
|
|
sound = {breaks = "default_tool_breaks"},
|
2013-05-19 18:43:04 +02:00
|
|
|
})
|
|
|
|
|
|
|
|
--
|
|
|
|
-- Shovels
|
|
|
|
--
|
|
|
|
|
|
|
|
minetest.register_tool("default:shovel_wood", {
|
|
|
|
description = "Wooden Shovel",
|
|
|
|
inventory_image = "default_tool_woodshovel.png",
|
|
|
|
wield_image = "default_tool_woodshovel.png^[transformR90",
|
|
|
|
tool_capabilities = {
|
|
|
|
full_punch_interval = 1.2,
|
|
|
|
max_drop_level=0,
|
|
|
|
groupcaps={
|
|
|
|
crumbly = {times={[1]=3.00, [2]=1.60, [3]=0.60}, uses=10, maxlevel=1},
|
|
|
|
},
|
|
|
|
damage_groups = {fleshy=2},
|
|
|
|
},
|
2016-10-24 20:34:00 +02:00
|
|
|
groups = {flammable = 2},
|
2016-01-22 22:04:38 -08:00
|
|
|
sound = {breaks = "default_tool_breaks"},
|
2013-05-19 18:43:04 +02:00
|
|
|
})
|
2016-01-22 22:04:38 -08:00
|
|
|
|
2013-05-19 18:43:04 +02:00
|
|
|
minetest.register_tool("default:shovel_stone", {
|
|
|
|
description = "Stone Shovel",
|
|
|
|
inventory_image = "default_tool_stoneshovel.png",
|
|
|
|
wield_image = "default_tool_stoneshovel.png^[transformR90",
|
|
|
|
tool_capabilities = {
|
|
|
|
full_punch_interval = 1.4,
|
|
|
|
max_drop_level=0,
|
|
|
|
groupcaps={
|
|
|
|
crumbly = {times={[1]=1.80, [2]=1.20, [3]=0.50}, uses=20, maxlevel=1},
|
|
|
|
},
|
|
|
|
damage_groups = {fleshy=2},
|
|
|
|
},
|
2016-01-22 22:04:38 -08:00
|
|
|
sound = {breaks = "default_tool_breaks"},
|
2013-05-19 18:43:04 +02:00
|
|
|
})
|
2016-01-22 22:04:38 -08:00
|
|
|
|
2013-05-19 18:43:04 +02:00
|
|
|
minetest.register_tool("default:shovel_steel", {
|
|
|
|
description = "Steel Shovel",
|
|
|
|
inventory_image = "default_tool_steelshovel.png",
|
|
|
|
wield_image = "default_tool_steelshovel.png^[transformR90",
|
|
|
|
tool_capabilities = {
|
|
|
|
full_punch_interval = 1.1,
|
|
|
|
max_drop_level=1,
|
|
|
|
groupcaps={
|
|
|
|
crumbly = {times={[1]=1.50, [2]=0.90, [3]=0.40}, uses=30, maxlevel=2},
|
|
|
|
},
|
|
|
|
damage_groups = {fleshy=3},
|
|
|
|
},
|
2016-01-22 22:04:38 -08:00
|
|
|
sound = {breaks = "default_tool_breaks"},
|
2013-05-19 18:43:04 +02:00
|
|
|
})
|
2016-01-22 22:04:38 -08:00
|
|
|
|
2013-05-19 18:43:04 +02:00
|
|
|
minetest.register_tool("default:shovel_bronze", {
|
|
|
|
description = "Bronze Shovel",
|
|
|
|
inventory_image = "default_tool_bronzeshovel.png",
|
|
|
|
wield_image = "default_tool_bronzeshovel.png^[transformR90",
|
|
|
|
tool_capabilities = {
|
|
|
|
full_punch_interval = 1.1,
|
|
|
|
max_drop_level=1,
|
|
|
|
groupcaps={
|
|
|
|
crumbly = {times={[1]=1.50, [2]=0.90, [3]=0.40}, uses=40, maxlevel=2},
|
|
|
|
},
|
|
|
|
damage_groups = {fleshy=3},
|
|
|
|
},
|
2016-01-22 22:04:38 -08:00
|
|
|
sound = {breaks = "default_tool_breaks"},
|
2013-05-19 18:43:04 +02:00
|
|
|
})
|
2016-01-22 22:04:38 -08:00
|
|
|
|
2013-05-19 18:43:04 +02:00
|
|
|
minetest.register_tool("default:shovel_mese", {
|
|
|
|
description = "Mese Shovel",
|
|
|
|
inventory_image = "default_tool_meseshovel.png",
|
|
|
|
wield_image = "default_tool_meseshovel.png^[transformR90",
|
|
|
|
tool_capabilities = {
|
|
|
|
full_punch_interval = 1.0,
|
|
|
|
max_drop_level=3,
|
|
|
|
groupcaps={
|
|
|
|
crumbly = {times={[1]=1.20, [2]=0.60, [3]=0.30}, uses=20, maxlevel=3},
|
|
|
|
},
|
|
|
|
damage_groups = {fleshy=4},
|
|
|
|
},
|
2016-01-22 22:04:38 -08:00
|
|
|
sound = {breaks = "default_tool_breaks"},
|
2013-05-19 18:43:04 +02:00
|
|
|
})
|
2016-01-22 22:04:38 -08:00
|
|
|
|
2013-05-19 18:43:04 +02:00
|
|
|
minetest.register_tool("default:shovel_diamond", {
|
|
|
|
description = "Diamond Shovel",
|
|
|
|
inventory_image = "default_tool_diamondshovel.png",
|
|
|
|
wield_image = "default_tool_diamondshovel.png^[transformR90",
|
|
|
|
tool_capabilities = {
|
|
|
|
full_punch_interval = 1.0,
|
|
|
|
max_drop_level=1,
|
|
|
|
groupcaps={
|
|
|
|
crumbly = {times={[1]=1.10, [2]=0.50, [3]=0.30}, uses=30, maxlevel=3},
|
|
|
|
},
|
|
|
|
damage_groups = {fleshy=4},
|
|
|
|
},
|
2016-01-22 22:04:38 -08:00
|
|
|
sound = {breaks = "default_tool_breaks"},
|
2013-05-19 18:43:04 +02:00
|
|
|
})
|
|
|
|
|
|
|
|
--
|
|
|
|
-- Axes
|
|
|
|
--
|
|
|
|
|
|
|
|
minetest.register_tool("default:axe_wood", {
|
|
|
|
description = "Wooden Axe",
|
|
|
|
inventory_image = "default_tool_woodaxe.png",
|
|
|
|
tool_capabilities = {
|
|
|
|
full_punch_interval = 1.0,
|
|
|
|
max_drop_level=0,
|
|
|
|
groupcaps={
|
2014-11-30 08:08:45 +01:00
|
|
|
choppy = {times={[2]=3.00, [3]=1.60}, uses=10, maxlevel=1},
|
2013-05-19 18:43:04 +02:00
|
|
|
},
|
|
|
|
damage_groups = {fleshy=2},
|
|
|
|
},
|
2016-10-24 20:34:00 +02:00
|
|
|
groups = {flammable = 2},
|
2016-01-22 22:04:38 -08:00
|
|
|
sound = {breaks = "default_tool_breaks"},
|
2013-05-19 18:43:04 +02:00
|
|
|
})
|
2016-01-22 22:04:38 -08:00
|
|
|
|
2013-05-19 18:43:04 +02:00
|
|
|
minetest.register_tool("default:axe_stone", {
|
|
|
|
description = "Stone Axe",
|
|
|
|
inventory_image = "default_tool_stoneaxe.png",
|
|
|
|
tool_capabilities = {
|
|
|
|
full_punch_interval = 1.2,
|
|
|
|
max_drop_level=0,
|
|
|
|
groupcaps={
|
2014-11-30 08:08:45 +01:00
|
|
|
choppy={times={[1]=3.00, [2]=2.00, [3]=1.30}, uses=20, maxlevel=1},
|
2013-05-19 18:43:04 +02:00
|
|
|
},
|
|
|
|
damage_groups = {fleshy=3},
|
|
|
|
},
|
2016-01-22 22:04:38 -08:00
|
|
|
sound = {breaks = "default_tool_breaks"},
|
2013-05-19 18:43:04 +02:00
|
|
|
})
|
2016-01-22 22:04:38 -08:00
|
|
|
|
2013-05-19 18:43:04 +02:00
|
|
|
minetest.register_tool("default:axe_steel", {
|
|
|
|
description = "Steel Axe",
|
|
|
|
inventory_image = "default_tool_steelaxe.png",
|
|
|
|
tool_capabilities = {
|
|
|
|
full_punch_interval = 1.0,
|
|
|
|
max_drop_level=1,
|
|
|
|
groupcaps={
|
|
|
|
choppy={times={[1]=2.50, [2]=1.40, [3]=1.00}, uses=20, maxlevel=2},
|
|
|
|
},
|
|
|
|
damage_groups = {fleshy=4},
|
|
|
|
},
|
2016-01-22 22:04:38 -08:00
|
|
|
sound = {breaks = "default_tool_breaks"},
|
2013-05-19 18:43:04 +02:00
|
|
|
})
|
2016-01-22 22:04:38 -08:00
|
|
|
|
2013-05-19 18:43:04 +02:00
|
|
|
minetest.register_tool("default:axe_bronze", {
|
|
|
|
description = "Bronze Axe",
|
|
|
|
inventory_image = "default_tool_bronzeaxe.png",
|
|
|
|
tool_capabilities = {
|
|
|
|
full_punch_interval = 1.0,
|
|
|
|
max_drop_level=1,
|
|
|
|
groupcaps={
|
|
|
|
choppy={times={[1]=2.50, [2]=1.40, [3]=1.00}, uses=30, maxlevel=2},
|
|
|
|
},
|
|
|
|
damage_groups = {fleshy=4},
|
|
|
|
},
|
2016-01-22 22:04:38 -08:00
|
|
|
sound = {breaks = "default_tool_breaks"},
|
2013-05-19 18:43:04 +02:00
|
|
|
})
|
2016-01-22 22:04:38 -08:00
|
|
|
|
2013-05-19 18:43:04 +02:00
|
|
|
minetest.register_tool("default:axe_mese", {
|
|
|
|
description = "Mese Axe",
|
|
|
|
inventory_image = "default_tool_meseaxe.png",
|
|
|
|
tool_capabilities = {
|
|
|
|
full_punch_interval = 0.9,
|
|
|
|
max_drop_level=1,
|
|
|
|
groupcaps={
|
|
|
|
choppy={times={[1]=2.20, [2]=1.00, [3]=0.60}, uses=20, maxlevel=3},
|
|
|
|
},
|
|
|
|
damage_groups = {fleshy=6},
|
|
|
|
},
|
2016-01-22 22:04:38 -08:00
|
|
|
sound = {breaks = "default_tool_breaks"},
|
2013-05-19 18:43:04 +02:00
|
|
|
})
|
2016-01-22 22:04:38 -08:00
|
|
|
|
2013-05-19 18:43:04 +02:00
|
|
|
minetest.register_tool("default:axe_diamond", {
|
|
|
|
description = "Diamond Axe",
|
|
|
|
inventory_image = "default_tool_diamondaxe.png",
|
|
|
|
tool_capabilities = {
|
|
|
|
full_punch_interval = 0.9,
|
|
|
|
max_drop_level=1,
|
|
|
|
groupcaps={
|
|
|
|
choppy={times={[1]=2.10, [2]=0.90, [3]=0.50}, uses=30, maxlevel=2},
|
|
|
|
},
|
|
|
|
damage_groups = {fleshy=7},
|
|
|
|
},
|
2016-01-22 22:04:38 -08:00
|
|
|
sound = {breaks = "default_tool_breaks"},
|
2013-05-19 18:43:04 +02:00
|
|
|
})
|
|
|
|
|
|
|
|
--
|
|
|
|
-- Swords
|
|
|
|
--
|
|
|
|
|
|
|
|
minetest.register_tool("default:sword_wood", {
|
|
|
|
description = "Wooden Sword",
|
|
|
|
inventory_image = "default_tool_woodsword.png",
|
|
|
|
tool_capabilities = {
|
|
|
|
full_punch_interval = 1,
|
|
|
|
max_drop_level=0,
|
|
|
|
groupcaps={
|
|
|
|
snappy={times={[2]=1.6, [3]=0.40}, uses=10, maxlevel=1},
|
|
|
|
},
|
|
|
|
damage_groups = {fleshy=2},
|
2016-10-24 20:34:00 +02:00
|
|
|
},
|
|
|
|
groups = {flammable = 2},
|
2016-01-22 22:04:38 -08:00
|
|
|
sound = {breaks = "default_tool_breaks"},
|
2013-05-19 18:43:04 +02:00
|
|
|
})
|
2016-01-22 22:04:38 -08:00
|
|
|
|
2013-05-19 18:43:04 +02:00
|
|
|
minetest.register_tool("default:sword_stone", {
|
|
|
|
description = "Stone Sword",
|
|
|
|
inventory_image = "default_tool_stonesword.png",
|
|
|
|
tool_capabilities = {
|
|
|
|
full_punch_interval = 1.2,
|
|
|
|
max_drop_level=0,
|
|
|
|
groupcaps={
|
|
|
|
snappy={times={[2]=1.4, [3]=0.40}, uses=20, maxlevel=1},
|
|
|
|
},
|
|
|
|
damage_groups = {fleshy=4},
|
2016-01-22 22:04:38 -08:00
|
|
|
},
|
|
|
|
sound = {breaks = "default_tool_breaks"},
|
2013-05-19 18:43:04 +02:00
|
|
|
})
|
2016-01-22 22:04:38 -08:00
|
|
|
|
2013-05-19 18:43:04 +02:00
|
|
|
minetest.register_tool("default:sword_steel", {
|
|
|
|
description = "Steel Sword",
|
|
|
|
inventory_image = "default_tool_steelsword.png",
|
|
|
|
tool_capabilities = {
|
|
|
|
full_punch_interval = 0.8,
|
|
|
|
max_drop_level=1,
|
|
|
|
groupcaps={
|
|
|
|
snappy={times={[1]=2.5, [2]=1.20, [3]=0.35}, uses=30, maxlevel=2},
|
|
|
|
},
|
|
|
|
damage_groups = {fleshy=6},
|
2016-01-22 22:04:38 -08:00
|
|
|
},
|
|
|
|
sound = {breaks = "default_tool_breaks"},
|
2013-05-19 18:43:04 +02:00
|
|
|
})
|
2016-01-22 22:04:38 -08:00
|
|
|
|
2013-05-19 18:43:04 +02:00
|
|
|
minetest.register_tool("default:sword_bronze", {
|
|
|
|
description = "Bronze Sword",
|
|
|
|
inventory_image = "default_tool_bronzesword.png",
|
|
|
|
tool_capabilities = {
|
|
|
|
full_punch_interval = 0.8,
|
|
|
|
max_drop_level=1,
|
|
|
|
groupcaps={
|
|
|
|
snappy={times={[1]=2.5, [2]=1.20, [3]=0.35}, uses=40, maxlevel=2},
|
|
|
|
},
|
|
|
|
damage_groups = {fleshy=6},
|
2016-01-22 22:04:38 -08:00
|
|
|
},
|
|
|
|
sound = {breaks = "default_tool_breaks"},
|
2013-05-19 18:43:04 +02:00
|
|
|
})
|
2016-01-22 22:04:38 -08:00
|
|
|
|
2013-05-19 18:43:04 +02:00
|
|
|
minetest.register_tool("default:sword_mese", {
|
|
|
|
description = "Mese Sword",
|
|
|
|
inventory_image = "default_tool_mesesword.png",
|
|
|
|
tool_capabilities = {
|
|
|
|
full_punch_interval = 0.7,
|
|
|
|
max_drop_level=1,
|
|
|
|
groupcaps={
|
|
|
|
snappy={times={[1]=2.0, [2]=1.00, [3]=0.35}, uses=30, maxlevel=3},
|
|
|
|
},
|
|
|
|
damage_groups = {fleshy=7},
|
2016-01-22 22:04:38 -08:00
|
|
|
},
|
|
|
|
sound = {breaks = "default_tool_breaks"},
|
2013-05-19 18:43:04 +02:00
|
|
|
})
|
2016-01-22 22:04:38 -08:00
|
|
|
|
2013-05-19 18:43:04 +02:00
|
|
|
minetest.register_tool("default:sword_diamond", {
|
|
|
|
description = "Diamond Sword",
|
|
|
|
inventory_image = "default_tool_diamondsword.png",
|
|
|
|
tool_capabilities = {
|
|
|
|
full_punch_interval = 0.7,
|
|
|
|
max_drop_level=1,
|
|
|
|
groupcaps={
|
|
|
|
snappy={times={[1]=1.90, [2]=0.90, [3]=0.30}, uses=40, maxlevel=3},
|
|
|
|
},
|
|
|
|
damage_groups = {fleshy=8},
|
2016-01-22 22:04:38 -08:00
|
|
|
},
|
|
|
|
sound = {breaks = "default_tool_breaks"},
|
2013-05-19 18:43:04 +02:00
|
|
|
})
|
Keys: Allow easy sharing of access without commands
This code adds the key concept to minetest_game, and integrates it
with lockable nodes. Currently supported lockable items are the Steel
Door, the Steel Trapdoor, and the Locked Chest.
The goal of this modification is to introduce a fine-grained multi-
player permission system that is intuitive and usable without any
console or chat commands, and doesn't require extra privileges to
be granted or setup. Keys can also physically be conveyed to other
players, adding to gameplay and adding some personality that is
preferable to console commands or editing formspecs.
A skeleton key can be crafted with 1 gold ingot. Skeleton keys can
then be matched to a lockable node by right-clicking the skeleton
key on a lockable node, which changes the skeleton key to a "key".
Gold was chosen as it's currently a not-so very useful item, and
therefore it's likely that players have some, but aren't really
using it for any purpose.
This key can subsequently used by any player to open or access that
lockable node, including retrieving items from Locked Chests, or
putting items in them.
They key is programmed to fit only the particular locked node it is
programmed to. This is achieved by storing a secret value in both
key and locked node. If this secret value doesn't match, the key
will not open the locked node. This allows many keys to be created
for one chest or door, but a key will only fit one node ever. The
secrets are stored in node, and item meta for the key.
If a locked node is removed, all keys that opened it are no longer
valid. Even if a new door/chest is placed in exactly the same spot,
the old keys will no longer fit that node.
Keys can be smelted back in gold ingots if they are no longer useful.
The method of storing a secret in nodemeta and itemstackmeta is secure
as there is no way for the client to create new items on the server
with a particular secret metadata value. Even if you could possible
create such an itemstack on the client, the server does not ever read
itemstackmeta from a client package.
The patch adds an API that allows other nodes and nodes added by
mods to use the same keys as well. The method how to implement this
is described in game_api.txt. The mod should add 2 callbacks to it's
node definition. Example code is given.
Textures are from PixelBOX, thanks to Gambit.
2015-12-26 11:16:49 -08:00
|
|
|
|
|
|
|
minetest.register_tool("default:skeleton_key", {
|
|
|
|
description = "Skeleton Key",
|
|
|
|
inventory_image = "default_key_skeleton.png",
|
|
|
|
groups = {key = 1},
|
|
|
|
on_place = function(itemstack, placer, pointed_thing)
|
2017-02-11 16:23:43 -08:00
|
|
|
local under = pointed_thing.under
|
|
|
|
local node = minetest.get_node(under)
|
|
|
|
local def = minetest.registered_nodes[node.name]
|
|
|
|
if def and def.on_rightclick and
|
|
|
|
not (placer and placer:get_player_control().sneak) then
|
|
|
|
return def.on_rightclick(under, node, placer, itemstack,
|
|
|
|
pointed_thing) or itemstack
|
|
|
|
end
|
|
|
|
|
Keys: Allow easy sharing of access without commands
This code adds the key concept to minetest_game, and integrates it
with lockable nodes. Currently supported lockable items are the Steel
Door, the Steel Trapdoor, and the Locked Chest.
The goal of this modification is to introduce a fine-grained multi-
player permission system that is intuitive and usable without any
console or chat commands, and doesn't require extra privileges to
be granted or setup. Keys can also physically be conveyed to other
players, adding to gameplay and adding some personality that is
preferable to console commands or editing formspecs.
A skeleton key can be crafted with 1 gold ingot. Skeleton keys can
then be matched to a lockable node by right-clicking the skeleton
key on a lockable node, which changes the skeleton key to a "key".
Gold was chosen as it's currently a not-so very useful item, and
therefore it's likely that players have some, but aren't really
using it for any purpose.
This key can subsequently used by any player to open or access that
lockable node, including retrieving items from Locked Chests, or
putting items in them.
They key is programmed to fit only the particular locked node it is
programmed to. This is achieved by storing a secret value in both
key and locked node. If this secret value doesn't match, the key
will not open the locked node. This allows many keys to be created
for one chest or door, but a key will only fit one node ever. The
secrets are stored in node, and item meta for the key.
If a locked node is removed, all keys that opened it are no longer
valid. Even if a new door/chest is placed in exactly the same spot,
the old keys will no longer fit that node.
Keys can be smelted back in gold ingots if they are no longer useful.
The method of storing a secret in nodemeta and itemstackmeta is secure
as there is no way for the client to create new items on the server
with a particular secret metadata value. Even if you could possible
create such an itemstack on the client, the server does not ever read
itemstackmeta from a client package.
The patch adds an API that allows other nodes and nodes added by
mods to use the same keys as well. The method how to implement this
is described in game_api.txt. The mod should add 2 callbacks to it's
node definition. Example code is given.
Textures are from PixelBOX, thanks to Gambit.
2015-12-26 11:16:49 -08:00
|
|
|
if pointed_thing.type ~= "node" then
|
|
|
|
return itemstack
|
|
|
|
end
|
|
|
|
|
|
|
|
local pos = pointed_thing.under
|
2017-02-11 16:23:43 -08:00
|
|
|
node = minetest.get_node(pos)
|
Keys: Allow easy sharing of access without commands
This code adds the key concept to minetest_game, and integrates it
with lockable nodes. Currently supported lockable items are the Steel
Door, the Steel Trapdoor, and the Locked Chest.
The goal of this modification is to introduce a fine-grained multi-
player permission system that is intuitive and usable without any
console or chat commands, and doesn't require extra privileges to
be granted or setup. Keys can also physically be conveyed to other
players, adding to gameplay and adding some personality that is
preferable to console commands or editing formspecs.
A skeleton key can be crafted with 1 gold ingot. Skeleton keys can
then be matched to a lockable node by right-clicking the skeleton
key on a lockable node, which changes the skeleton key to a "key".
Gold was chosen as it's currently a not-so very useful item, and
therefore it's likely that players have some, but aren't really
using it for any purpose.
This key can subsequently used by any player to open or access that
lockable node, including retrieving items from Locked Chests, or
putting items in them.
They key is programmed to fit only the particular locked node it is
programmed to. This is achieved by storing a secret value in both
key and locked node. If this secret value doesn't match, the key
will not open the locked node. This allows many keys to be created
for one chest or door, but a key will only fit one node ever. The
secrets are stored in node, and item meta for the key.
If a locked node is removed, all keys that opened it are no longer
valid. Even if a new door/chest is placed in exactly the same spot,
the old keys will no longer fit that node.
Keys can be smelted back in gold ingots if they are no longer useful.
The method of storing a secret in nodemeta and itemstackmeta is secure
as there is no way for the client to create new items on the server
with a particular secret metadata value. Even if you could possible
create such an itemstack on the client, the server does not ever read
itemstackmeta from a client package.
The patch adds an API that allows other nodes and nodes added by
mods to use the same keys as well. The method how to implement this
is described in game_api.txt. The mod should add 2 callbacks to it's
node definition. Example code is given.
Textures are from PixelBOX, thanks to Gambit.
2015-12-26 11:16:49 -08:00
|
|
|
|
|
|
|
if not node then
|
|
|
|
return itemstack
|
|
|
|
end
|
|
|
|
|
|
|
|
local on_skeleton_key_use = minetest.registered_nodes[node.name].on_skeleton_key_use
|
|
|
|
if on_skeleton_key_use then
|
|
|
|
-- make a new key secret in case the node callback needs it
|
|
|
|
local random = math.random
|
|
|
|
local newsecret = string.format(
|
|
|
|
"%04x%04x%04x%04x",
|
|
|
|
random(2^16) - 1, random(2^16) - 1,
|
|
|
|
random(2^16) - 1, random(2^16) - 1)
|
|
|
|
|
|
|
|
local secret, _, _ = on_skeleton_key_use(pos, placer, newsecret)
|
|
|
|
|
|
|
|
if secret then
|
|
|
|
-- finish and return the new key
|
|
|
|
itemstack:take_item()
|
|
|
|
itemstack:add_item("default:key")
|
2017-02-26 09:24:12 -08:00
|
|
|
local meta = itemstack:get_meta()
|
|
|
|
meta:set_string("secret", secret)
|
|
|
|
meta:set_string("description", "Key to "..placer:get_player_name().."'s "
|
|
|
|
..minetest.registered_nodes[node.name].description)
|
Keys: Allow easy sharing of access without commands
This code adds the key concept to minetest_game, and integrates it
with lockable nodes. Currently supported lockable items are the Steel
Door, the Steel Trapdoor, and the Locked Chest.
The goal of this modification is to introduce a fine-grained multi-
player permission system that is intuitive and usable without any
console or chat commands, and doesn't require extra privileges to
be granted or setup. Keys can also physically be conveyed to other
players, adding to gameplay and adding some personality that is
preferable to console commands or editing formspecs.
A skeleton key can be crafted with 1 gold ingot. Skeleton keys can
then be matched to a lockable node by right-clicking the skeleton
key on a lockable node, which changes the skeleton key to a "key".
Gold was chosen as it's currently a not-so very useful item, and
therefore it's likely that players have some, but aren't really
using it for any purpose.
This key can subsequently used by any player to open or access that
lockable node, including retrieving items from Locked Chests, or
putting items in them.
They key is programmed to fit only the particular locked node it is
programmed to. This is achieved by storing a secret value in both
key and locked node. If this secret value doesn't match, the key
will not open the locked node. This allows many keys to be created
for one chest or door, but a key will only fit one node ever. The
secrets are stored in node, and item meta for the key.
If a locked node is removed, all keys that opened it are no longer
valid. Even if a new door/chest is placed in exactly the same spot,
the old keys will no longer fit that node.
Keys can be smelted back in gold ingots if they are no longer useful.
The method of storing a secret in nodemeta and itemstackmeta is secure
as there is no way for the client to create new items on the server
with a particular secret metadata value. Even if you could possible
create such an itemstack on the client, the server does not ever read
itemstackmeta from a client package.
The patch adds an API that allows other nodes and nodes added by
mods to use the same keys as well. The method how to implement this
is described in game_api.txt. The mod should add 2 callbacks to it's
node definition. Example code is given.
Textures are from PixelBOX, thanks to Gambit.
2015-12-26 11:16:49 -08:00
|
|
|
return itemstack
|
|
|
|
end
|
|
|
|
end
|
|
|
|
return nil
|
|
|
|
end
|
|
|
|
})
|
|
|
|
|
|
|
|
minetest.register_tool("default:key", {
|
|
|
|
description = "Key",
|
|
|
|
inventory_image = "default_key.png",
|
|
|
|
groups = {key = 1, not_in_creative_inventory = 1},
|
|
|
|
stack_max = 1,
|
|
|
|
on_place = function(itemstack, placer, pointed_thing)
|
2017-02-11 16:23:43 -08:00
|
|
|
local under = pointed_thing.under
|
|
|
|
local node = minetest.get_node(under)
|
|
|
|
local def = minetest.registered_nodes[node.name]
|
|
|
|
if def and def.on_rightclick and
|
|
|
|
not (placer and placer:get_player_control().sneak) then
|
|
|
|
return def.on_rightclick(under, node, placer, itemstack,
|
|
|
|
pointed_thing) or itemstack
|
|
|
|
end
|
Keys: Allow easy sharing of access without commands
This code adds the key concept to minetest_game, and integrates it
with lockable nodes. Currently supported lockable items are the Steel
Door, the Steel Trapdoor, and the Locked Chest.
The goal of this modification is to introduce a fine-grained multi-
player permission system that is intuitive and usable without any
console or chat commands, and doesn't require extra privileges to
be granted or setup. Keys can also physically be conveyed to other
players, adding to gameplay and adding some personality that is
preferable to console commands or editing formspecs.
A skeleton key can be crafted with 1 gold ingot. Skeleton keys can
then be matched to a lockable node by right-clicking the skeleton
key on a lockable node, which changes the skeleton key to a "key".
Gold was chosen as it's currently a not-so very useful item, and
therefore it's likely that players have some, but aren't really
using it for any purpose.
This key can subsequently used by any player to open or access that
lockable node, including retrieving items from Locked Chests, or
putting items in them.
They key is programmed to fit only the particular locked node it is
programmed to. This is achieved by storing a secret value in both
key and locked node. If this secret value doesn't match, the key
will not open the locked node. This allows many keys to be created
for one chest or door, but a key will only fit one node ever. The
secrets are stored in node, and item meta for the key.
If a locked node is removed, all keys that opened it are no longer
valid. Even if a new door/chest is placed in exactly the same spot,
the old keys will no longer fit that node.
Keys can be smelted back in gold ingots if they are no longer useful.
The method of storing a secret in nodemeta and itemstackmeta is secure
as there is no way for the client to create new items on the server
with a particular secret metadata value. Even if you could possible
create such an itemstack on the client, the server does not ever read
itemstackmeta from a client package.
The patch adds an API that allows other nodes and nodes added by
mods to use the same keys as well. The method how to implement this
is described in game_api.txt. The mod should add 2 callbacks to it's
node definition. Example code is given.
Textures are from PixelBOX, thanks to Gambit.
2015-12-26 11:16:49 -08:00
|
|
|
if pointed_thing.type ~= "node" then
|
|
|
|
return itemstack
|
|
|
|
end
|
|
|
|
|
|
|
|
local pos = pointed_thing.under
|
2017-02-11 16:23:43 -08:00
|
|
|
node = minetest.get_node(pos)
|
Keys: Allow easy sharing of access without commands
This code adds the key concept to minetest_game, and integrates it
with lockable nodes. Currently supported lockable items are the Steel
Door, the Steel Trapdoor, and the Locked Chest.
The goal of this modification is to introduce a fine-grained multi-
player permission system that is intuitive and usable without any
console or chat commands, and doesn't require extra privileges to
be granted or setup. Keys can also physically be conveyed to other
players, adding to gameplay and adding some personality that is
preferable to console commands or editing formspecs.
A skeleton key can be crafted with 1 gold ingot. Skeleton keys can
then be matched to a lockable node by right-clicking the skeleton
key on a lockable node, which changes the skeleton key to a "key".
Gold was chosen as it's currently a not-so very useful item, and
therefore it's likely that players have some, but aren't really
using it for any purpose.
This key can subsequently used by any player to open or access that
lockable node, including retrieving items from Locked Chests, or
putting items in them.
They key is programmed to fit only the particular locked node it is
programmed to. This is achieved by storing a secret value in both
key and locked node. If this secret value doesn't match, the key
will not open the locked node. This allows many keys to be created
for one chest or door, but a key will only fit one node ever. The
secrets are stored in node, and item meta for the key.
If a locked node is removed, all keys that opened it are no longer
valid. Even if a new door/chest is placed in exactly the same spot,
the old keys will no longer fit that node.
Keys can be smelted back in gold ingots if they are no longer useful.
The method of storing a secret in nodemeta and itemstackmeta is secure
as there is no way for the client to create new items on the server
with a particular secret metadata value. Even if you could possible
create such an itemstack on the client, the server does not ever read
itemstackmeta from a client package.
The patch adds an API that allows other nodes and nodes added by
mods to use the same keys as well. The method how to implement this
is described in game_api.txt. The mod should add 2 callbacks to it's
node definition. Example code is given.
Textures are from PixelBOX, thanks to Gambit.
2015-12-26 11:16:49 -08:00
|
|
|
|
|
|
|
if not node or node.name == "ignore" then
|
|
|
|
return itemstack
|
|
|
|
end
|
|
|
|
|
|
|
|
local ndef = minetest.registered_nodes[node.name]
|
|
|
|
if not ndef then
|
|
|
|
return itemstack
|
|
|
|
end
|
|
|
|
|
|
|
|
local on_key_use = ndef.on_key_use
|
|
|
|
if on_key_use then
|
|
|
|
on_key_use(pos, placer)
|
|
|
|
end
|
|
|
|
|
|
|
|
return nil
|
|
|
|
end
|
2013-05-19 18:43:04 +02:00
|
|
|
})
|