commit
b2e0cf1433
32
init.lua
32
init.lua
|
@ -1,25 +1,25 @@
|
|||
|
||||
|
||||
|
||||
--[[
|
||||
Locked version of my travelnet that allow players to choose a destination out of a list
|
||||
Copyright (C) 2013 Sokomine
|
||||
Locked version of my travelnet that allow players to choose a destination out of a list
|
||||
Copyright (C) 2013 Sokomine
|
||||
|
||||
This program is free software: you can redistribute it and/or modify
|
||||
it under the terms of the GNU General Public License as published by
|
||||
the Free Software Foundation, either version 3 of the License, or
|
||||
(at your option) any later version.
|
||||
This program is free software: you can redistribute it and/or modify
|
||||
it under the terms of the GNU General Public License as published by
|
||||
the Free Software Foundation, either version 3 of the License, or
|
||||
(at your option) any later version.
|
||||
|
||||
This program is distributed in the hope that it will be useful,
|
||||
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
GNU General Public License for more details.
|
||||
This program is distributed in the hope that it will be useful,
|
||||
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
GNU General Public License for more details.
|
||||
|
||||
You should have received a copy of the GNU General Public License
|
||||
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||
You should have received a copy of the GNU General Public License
|
||||
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||
|
||||
Version: 1.0
|
||||
|
||||
Changelog:
|
||||
Version: 1.0
|
||||
|
||||
Changelog:
|
||||
--]]
|
||||
|
||||
|
||||
|
|
184
locked_doors.lua
184
locked_doors.lua
|
@ -5,15 +5,15 @@
|
|||
|
||||
locked_travelnet_doors_transform = function( pos, node, puncher, transform_into )
|
||||
|
||||
if( not( locks:lock_allow_use( pos, puncher ))) then
|
||||
minetest.chat_send_player( puncher:get_player_name(), "This door is locked. It can only be opened by its owner or people with a key that fits.");
|
||||
return;
|
||||
end
|
||||
if( not( locks:lock_allow_use( pos, puncher ))) then
|
||||
minetest.chat_send_player( puncher:get_player_name(), "This door is locked. It can only be opened by its owner or people with a key that fits.");
|
||||
return;
|
||||
end
|
||||
|
||||
local olddata = locks:get_lockdata( pos );
|
||||
local olddata = locks:get_lockdata( pos );
|
||||
|
||||
minetest.add_node(pos, {name = transform_into, param2 = node.param2})
|
||||
locks:set_lockdata( pos, olddata );
|
||||
minetest.add_node(pos, {name = transform_into, param2 = node.param2})
|
||||
locks:set_lockdata( pos, olddata );
|
||||
end
|
||||
|
||||
|
||||
|
@ -21,13 +21,13 @@ end
|
|||
minetest.register_node("locked_travelnet:elevator_door_steel_open", {
|
||||
description = "elevator door (open)",
|
||||
drawtype = "nodebox",
|
||||
-- top, bottom, side1, side2, inner, outer
|
||||
-- top, bottom, side1, side2, inner, outer
|
||||
tiles = {"default_stone.png"},
|
||||
paramtype = "light",
|
||||
paramtype2 = "facedir",
|
||||
is_ground_content = true,
|
||||
groups = {snappy=2,choppy=2,oddly_breakable_by_hand=2,not_in_creative_inventory=1},
|
||||
-- larger than one node but slightly smaller than a half node so that wallmounted torches pose no problem
|
||||
-- larger than one node but slightly smaller than a half node so that wallmounted torches pose no problem
|
||||
node_box = {
|
||||
type = "fixed",
|
||||
fixed = {
|
||||
|
@ -42,35 +42,35 @@ minetest.register_node("locked_travelnet:elevator_door_steel_open", {
|
|||
},
|
||||
},
|
||||
drop = "locked_travelnet:elevator_door_steel_closed",
|
||||
on_rightclick = function(pos, node, puncher)
|
||||
on_rightclick = function(pos, node, puncher)
|
||||
|
||||
locked_travelnet_doors_transform( pos, node, puncher, "locked_travelnet:elevator_door_steel_closed" );
|
||||
end,
|
||||
locked_travelnet_doors_transform( pos, node, puncher, "locked_travelnet:elevator_door_steel_closed" );
|
||||
end,
|
||||
|
||||
on_construct = function(pos)
|
||||
locks:lock_init( pos,
|
||||
"size[8,2]"..
|
||||
"field[0.3,0.6;6,0.7;locks_sent_lock_command;Locked door. Type /help for help:;]"..
|
||||
"button_exit[6.3,1.2;1.7,0.7;locks_sent_input;Proceed]" );
|
||||
end,
|
||||
on_construct = function(pos)
|
||||
locks:lock_init( pos,
|
||||
"size[8,2]"..
|
||||
"field[0.3,0.6;6,0.7;locks_sent_lock_command;Locked door. Type /help for help:;]"..
|
||||
"button_exit[6.3,1.2;1.7,0.7;locks_sent_input;Proceed]" );
|
||||
end,
|
||||
|
||||
after_place_node = function(pos, placer, itemstack)
|
||||
locks:lock_set_owner( pos, placer, "Shared locked door" );
|
||||
end,
|
||||
after_place_node = function(pos, placer, itemstack)
|
||||
locks:lock_set_owner( pos, placer, "Shared locked door" );
|
||||
end,
|
||||
|
||||
on_receive_fields = function(pos, formname, fields, sender)
|
||||
locks:lock_handle_input( pos, formname, fields, sender );
|
||||
end,
|
||||
on_receive_fields = function(pos, formname, fields, sender)
|
||||
locks:lock_handle_input( pos, formname, fields, sender );
|
||||
end,
|
||||
|
||||
can_dig = function(pos,player)
|
||||
return locks:lock_allow_dig( pos, player );
|
||||
end,
|
||||
can_dig = function(pos,player)
|
||||
return locks:lock_allow_dig( pos, player );
|
||||
end,
|
||||
})
|
||||
|
||||
minetest.register_node("locked_travelnet:elevator_door_steel_closed", {
|
||||
description = "elevator door (closed)",
|
||||
drawtype = "nodebox",
|
||||
-- top, bottom, side1, side2, inner, outer
|
||||
-- top, bottom, side1, side2, inner, outer
|
||||
tiles = {"default_stone.png"},
|
||||
paramtype = "light",
|
||||
paramtype2 = "facedir",
|
||||
|
@ -89,27 +89,27 @@ minetest.register_node("locked_travelnet:elevator_door_steel_closed", {
|
|||
{-0.5, -0.5, 0.4, 0.5, 1.5, 0.5},
|
||||
},
|
||||
},
|
||||
on_rightclick = function(pos, node, puncher)
|
||||
locked_travelnet_doors_transform( pos, node, puncher, "locked_travelnet:elevator_door_steel_open" );
|
||||
end,
|
||||
on_construct = function(pos)
|
||||
locks:lock_init( pos,
|
||||
"size[8,2]"..
|
||||
"field[0.3,0.6;6,0.7;locks_sent_lock_command;Locked door. Type /help for help:;]"..
|
||||
"button_exit[6.3,1.2;1.7,0.7;locks_sent_input;Proceed]" );
|
||||
end,
|
||||
on_rightclick = function(pos, node, puncher)
|
||||
locked_travelnet_doors_transform( pos, node, puncher, "locked_travelnet:elevator_door_steel_open" );
|
||||
end,
|
||||
on_construct = function(pos)
|
||||
locks:lock_init( pos,
|
||||
"size[8,2]"..
|
||||
"field[0.3,0.6;6,0.7;locks_sent_lock_command;Locked door. Type /help for help:;]"..
|
||||
"button_exit[6.3,1.2;1.7,0.7;locks_sent_input;Proceed]" );
|
||||
end,
|
||||
|
||||
after_place_node = function(pos, placer, itemstack)
|
||||
locks:lock_set_owner( pos, placer, "Shared locked door" );
|
||||
end,
|
||||
after_place_node = function(pos, placer, itemstack)
|
||||
locks:lock_set_owner( pos, placer, "Shared locked door" );
|
||||
end,
|
||||
|
||||
on_receive_fields = function(pos, formname, fields, sender)
|
||||
locks:lock_handle_input( pos, formname, fields, sender );
|
||||
end,
|
||||
on_receive_fields = function(pos, formname, fields, sender)
|
||||
locks:lock_handle_input( pos, formname, fields, sender );
|
||||
end,
|
||||
|
||||
can_dig = function(pos,player)
|
||||
return locks:lock_allow_dig( pos, player );
|
||||
end,
|
||||
can_dig = function(pos,player)
|
||||
return locks:lock_allow_dig( pos, player );
|
||||
end,
|
||||
})
|
||||
|
||||
|
||||
|
@ -118,13 +118,13 @@ minetest.register_node("locked_travelnet:elevator_door_steel_closed", {
|
|||
minetest.register_node("locked_travelnet:elevator_door_glass_open", {
|
||||
description = "elevator door (open)",
|
||||
drawtype = "nodebox",
|
||||
-- top, bottom, side1, side2, inner, outer
|
||||
-- top, bottom, side1, side2, inner, outer
|
||||
tiles = {"travelnet_elevator_door_glass.png"},
|
||||
paramtype = "light",
|
||||
paramtype2 = "facedir",
|
||||
is_ground_content = true,
|
||||
groups = {snappy=2,choppy=2,oddly_breakable_by_hand=2,not_in_creative_inventory=1},
|
||||
-- larger than one node but slightly smaller than a half node so that wallmounted torches pose no problem
|
||||
-- larger than one node but slightly smaller than a half node so that wallmounted torches pose no problem
|
||||
node_box = {
|
||||
type = "fixed",
|
||||
fixed = {
|
||||
|
@ -139,33 +139,33 @@ minetest.register_node("locked_travelnet:elevator_door_glass_open", {
|
|||
},
|
||||
},
|
||||
drop = "locked_travelnet:elevator_door_glass_closed",
|
||||
on_rightclick = function(pos, node, puncher)
|
||||
locked_travelnet_doors_transform( pos, node, puncher, "locked_travelnet:elevator_door_glass_closed" );
|
||||
end,
|
||||
on_construct = function(pos)
|
||||
locks:lock_init( pos,
|
||||
"size[8,2]"..
|
||||
"field[0.3,0.6;6,0.7;locks_sent_lock_command;Locked door. Type /help for help:;]"..
|
||||
"button_exit[6.3,1.2;1.7,0.7;locks_sent_input;Proceed]" );
|
||||
end,
|
||||
on_rightclick = function(pos, node, puncher)
|
||||
locked_travelnet_doors_transform( pos, node, puncher, "locked_travelnet:elevator_door_glass_closed" );
|
||||
end,
|
||||
on_construct = function(pos)
|
||||
locks:lock_init( pos,
|
||||
"size[8,2]"..
|
||||
"field[0.3,0.6;6,0.7;locks_sent_lock_command;Locked door. Type /help for help:;]"..
|
||||
"button_exit[6.3,1.2;1.7,0.7;locks_sent_input;Proceed]" );
|
||||
end,
|
||||
|
||||
after_place_node = function(pos, placer, itemstack)
|
||||
locks:lock_set_owner( pos, placer, "Shared locked door" );
|
||||
end,
|
||||
after_place_node = function(pos, placer, itemstack)
|
||||
locks:lock_set_owner( pos, placer, "Shared locked door" );
|
||||
end,
|
||||
|
||||
on_receive_fields = function(pos, formname, fields, sender)
|
||||
locks:lock_handle_input( pos, formname, fields, sender );
|
||||
end,
|
||||
on_receive_fields = function(pos, formname, fields, sender)
|
||||
locks:lock_handle_input( pos, formname, fields, sender );
|
||||
end,
|
||||
|
||||
can_dig = function(pos,player)
|
||||
return locks:lock_allow_dig( pos, player );
|
||||
end,
|
||||
can_dig = function(pos,player)
|
||||
return locks:lock_allow_dig( pos, player );
|
||||
end,
|
||||
})
|
||||
|
||||
minetest.register_node("locked_travelnet:elevator_door_glass_closed", {
|
||||
description = "elevator door (closed)",
|
||||
drawtype = "nodebox",
|
||||
-- top, bottom, side1, side2, inner, outer
|
||||
-- top, bottom, side1, side2, inner, outer
|
||||
tiles = {"travelnet_elevator_door_glass.png"},
|
||||
paramtype = "light",
|
||||
paramtype2 = "facedir",
|
||||
|
@ -184,40 +184,40 @@ minetest.register_node("locked_travelnet:elevator_door_glass_closed", {
|
|||
{-0.5, -0.5, 0.4, 0.5, 1.5, 0.5},
|
||||
},
|
||||
},
|
||||
on_rightclick = function(pos, node, puncher)
|
||||
locked_travelnet_doors_transform( pos, node, puncher, "locked_travelnet:elevator_door_glass_open" );
|
||||
end,
|
||||
on_construct = function(pos)
|
||||
locks:lock_init( pos,
|
||||
"size[8,2]"..
|
||||
"field[0.3,0.6;6,0.7;locks_sent_lock_command;Locked door. Type /help for help:;]"..
|
||||
"button_exit[6.3,1.2;1.7,0.7;locks_sent_input;Proceed]" );
|
||||
end,
|
||||
on_rightclick = function(pos, node, puncher)
|
||||
locked_travelnet_doors_transform( pos, node, puncher, "locked_travelnet:elevator_door_glass_open" );
|
||||
end,
|
||||
on_construct = function(pos)
|
||||
locks:lock_init( pos,
|
||||
"size[8,2]"..
|
||||
"field[0.3,0.6;6,0.7;locks_sent_lock_command;Locked door. Type /help for help:;]"..
|
||||
"button_exit[6.3,1.2;1.7,0.7;locks_sent_input;Proceed]" );
|
||||
end,
|
||||
|
||||
after_place_node = function(pos, placer, itemstack)
|
||||
locks:lock_set_owner( pos, placer, "Shared locked door" );
|
||||
end,
|
||||
after_place_node = function(pos, placer, itemstack)
|
||||
locks:lock_set_owner( pos, placer, "Shared locked door" );
|
||||
end,
|
||||
|
||||
on_receive_fields = function(pos, formname, fields, sender)
|
||||
locks:lock_handle_input( pos, formname, fields, sender );
|
||||
end,
|
||||
on_receive_fields = function(pos, formname, fields, sender)
|
||||
locks:lock_handle_input( pos, formname, fields, sender );
|
||||
end,
|
||||
|
||||
can_dig = function(pos,player)
|
||||
return locks:lock_allow_dig( pos, player );
|
||||
end,
|
||||
can_dig = function(pos,player)
|
||||
return locks:lock_allow_dig( pos, player );
|
||||
end,
|
||||
})
|
||||
|
||||
minetest.register_craft({
|
||||
output = "locked_travelnet:elevator_door_glass_closed",
|
||||
recipe = {{'travelnet:elevator_door_glass_closed','locks:lock'},
|
||||
}
|
||||
output = "locked_travelnet:elevator_door_glass_closed",
|
||||
recipe = {{'travelnet:elevator_door_glass_closed','locks:lock'},
|
||||
}
|
||||
})
|
||||
|
||||
minetest.register_craft({
|
||||
output = "locked_travelnet:elevator_door_steel_closed",
|
||||
recipe = {
|
||||
{'travelnet:elevator_door_steel_closed','locks:lock'},
|
||||
}
|
||||
output = "locked_travelnet:elevator_door_steel_closed",
|
||||
recipe = {
|
||||
{'travelnet:elevator_door_steel_closed','locks:lock'},
|
||||
}
|
||||
})
|
||||
|
||||
|
||||
|
|
|
@ -3,182 +3,178 @@
|
|||
-- Autor: Sokomine
|
||||
|
||||
minetest.register_node("locked_travelnet:elevator", {
|
||||
description = "Shared locked elevator",
|
||||
description = "Shared locked elevator",
|
||||
|
||||
drawtype = "nodebox",
|
||||
sunlight_propagates = true,
|
||||
paramtype = 'light',
|
||||
paramtype2 = "facedir",
|
||||
drawtype = "nodebox",
|
||||
sunlight_propagates = true,
|
||||
paramtype = 'light',
|
||||
paramtype2 = "facedir",
|
||||
|
||||
selection_box = {
|
||||
type = "fixed",
|
||||
fixed = { -0.5, -0.5, -0.5, 0.5, 1.5, 0.5 }
|
||||
},
|
||||
selection_box = {
|
||||
type = "fixed",
|
||||
fixed = { -0.5, -0.5, -0.5, 0.5, 1.5, 0.5 }
|
||||
},
|
||||
|
||||
node_box = {
|
||||
type = "fixed",
|
||||
fixed = {
|
||||
node_box = {
|
||||
type = "fixed",
|
||||
fixed = {
|
||||
{ 0.48, -0.5,-0.5, 0.5, 0.5, 0.5},
|
||||
{-0.5 , -0.5, 0.48, 0.48, 0.5, 0.5},
|
||||
{-0.5, -0.5,-0.5 ,-0.48, 0.5, 0.5},
|
||||
|
||||
{ 0.48, -0.5,-0.5, 0.5, 0.5, 0.5},
|
||||
{-0.5 , -0.5, 0.48, 0.48, 0.5, 0.5},
|
||||
{-0.5, -0.5,-0.5 ,-0.48, 0.5, 0.5},
|
||||
|
||||
--groundplate to stand on
|
||||
{ -0.5,-0.5,-0.5,0.5,-0.48, 0.5},
|
||||
},
|
||||
},
|
||||
--groundplate to stand on
|
||||
{ -0.5,-0.5,-0.5,0.5,-0.48, 0.5},
|
||||
},
|
||||
},
|
||||
|
||||
|
||||
tiles = {
|
||||
tiles = {
|
||||
"travelnet_elevator_inside_floor.png", -- view from top
|
||||
"default_stone.png", -- view from bottom
|
||||
"travelnet_elevator_inside_bottom.png", -- left side
|
||||
"travelnet_elevator_inside_bottom.png", -- right side
|
||||
"travelnet_elevator_inside_bottom.png", -- front view
|
||||
"travelnet_elevator_inside_bottom.png", -- backward view
|
||||
},
|
||||
inventory_image = "travelnet_elevator_inv.png",
|
||||
wield_image = "travelnet_elevator_wield.png",
|
||||
|
||||
"travelnet_elevator_inside_floor.png", -- view from top
|
||||
"default_stone.png", -- view from bottom
|
||||
"travelnet_elevator_inside_bottom.png", -- left side
|
||||
"travelnet_elevator_inside_bottom.png", -- right side
|
||||
"travelnet_elevator_inside_bottom.png", -- front view
|
||||
"travelnet_elevator_inside_bottom.png", -- backward view
|
||||
},
|
||||
inventory_image = "travelnet_elevator_inv.png",
|
||||
wield_image = "travelnet_elevator_wield.png",
|
||||
|
||||
groups = {}, --cracky=1,choppy=1,snappy=1},
|
||||
groups = {}, --cracky=1,choppy=1,snappy=1},
|
||||
|
||||
|
||||
light_source = 10,
|
||||
light_source = 10,
|
||||
|
||||
on_construct = function(pos)
|
||||
local meta = minetest.get_meta(pos)
|
||||
--- prepare the lock of the travelnet
|
||||
locks:lock_init( pos,
|
||||
"size[12,10]"..
|
||||
"field[0.3,5.6;6,0.7;station_name;Name of this station:;]"..
|
||||
-- "button_exit[6.3,6.2;1.7,0.7;station_set;Store]"..
|
||||
"button_exit[8.0,0.0;2.2,0.7;station_dig;Remove station]"..
|
||||
"field[0.3,3.0;6,0.7;locks_sent_lock_command;Locked travelnet. Type /help for help:;]"..
|
||||
"button_exit[6.3,3.2;1.7,0.7;locks_sent_input;Store]" );
|
||||
end,
|
||||
on_construct = function(pos)
|
||||
local meta = minetest.get_meta(pos)
|
||||
--- prepare the lock of the travelnet
|
||||
locks:lock_init( pos,
|
||||
"size[12,10]"..
|
||||
"field[0.3,5.6;6,0.7;station_name;Name of this station:;]"..
|
||||
-- "button_exit[6.3,6.2;1.7,0.7;station_set;Store]"..
|
||||
"button_exit[8.0,0.0;2.2,0.7;station_dig;Remove station]"..
|
||||
"field[0.3,3.0;6,0.7;locks_sent_lock_command;Locked travelnet. Type /help for help:;]"..
|
||||
"button_exit[6.3,3.2;1.7,0.7;locks_sent_input;Store]" );
|
||||
end,
|
||||
|
||||
after_place_node = function(pos, placer, itemstack)
|
||||
local meta = minetest.get_meta(pos);
|
||||
meta:set_string("infotext", "Elevator (unconfigured)");
|
||||
meta:set_string("station_name", "");
|
||||
meta:set_string("station_network","");
|
||||
meta:set_string("owner", placer:get_player_name() );
|
||||
-- request initinal data
|
||||
after_place_node = function(pos, placer, itemstack)
|
||||
local meta = minetest.get_meta(pos);
|
||||
meta:set_string("infotext", "Elevator (unconfigured)");
|
||||
meta:set_string("station_name", "");
|
||||
meta:set_string("station_network","");
|
||||
meta:set_string("owner", placer:get_player_name() );
|
||||
-- request initinal data
|
||||
|
||||
local p = {x=pos.x, y=pos.y+1, z=pos.z}
|
||||
local p2 = minetest.dir_to_facedir(placer:get_look_dir())
|
||||
minetest.add_node(p, {name="locked_travelnet:elevator_top", paramtype2="facedir", param2=p2})
|
||||
local p = {x=pos.x, y=pos.y+1, z=pos.z}
|
||||
local p2 = minetest.dir_to_facedir(placer:get_look_dir())
|
||||
minetest.add_node(p, {name="locked_travelnet:elevator_top", paramtype2="facedir", param2=p2})
|
||||
|
||||
locks:lock_set_owner( pos, placer, "Shared locked elevator" );
|
||||
end,
|
||||
locks:lock_set_owner( pos, placer, "Shared locked elevator" );
|
||||
end,
|
||||
|
||||
on_receive_fields = function(pos, formname, fields, sender)
|
||||
on_receive_fields = function(pos, formname, fields, sender)
|
||||
-- abort if no input has been sent
|
||||
if fields.quit then return end
|
||||
|
||||
-- abort if no input has been sent
|
||||
if( fields.quit ) then
|
||||
return;
|
||||
end
|
||||
-- if the user already has the right to use this and did input text
|
||||
if (
|
||||
not fields.locks_sent_lock_command
|
||||
or fields.locks_sent_lock_command == ""
|
||||
)
|
||||
and locks:lock_allow_use( pos, sender )
|
||||
then
|
||||
travelnet.on_receive_fields( pos, formname, fields, sender );
|
||||
|
||||
-- if the user already has the right to use this and did input text
|
||||
if( (not(fields.locks_sent_lock_command)
|
||||
or fields.locks_sent_lock_command=="")
|
||||
and locks:lock_allow_use( pos, sender )) then
|
||||
-- a command for the lock?
|
||||
else
|
||||
locks:lock_handle_input( pos, formname, fields, sender );
|
||||
end
|
||||
end,
|
||||
|
||||
travelnet.on_receive_fields( pos, formname, fields, sender );
|
||||
on_punch = function(pos, node, puncher)
|
||||
travelnet.update_formspec(pos, puncher:get_player_name())
|
||||
end,
|
||||
|
||||
-- a command for the lock?
|
||||
else
|
||||
locks:lock_handle_input( pos, formname, fields, sender );
|
||||
end
|
||||
end,
|
||||
can_dig = function( pos, player )
|
||||
if not locks:lock_allow_dig( pos, player ) then
|
||||
return false
|
||||
end
|
||||
return travelnet.can_dig( pos, player, 'elevator' )
|
||||
end,
|
||||
|
||||
on_punch = function(pos, node, puncher)
|
||||
travelnet.update_formspec(pos, puncher:get_player_name())
|
||||
end,
|
||||
after_dig_node = function(pos, oldnode, oldmetadata, digger)
|
||||
travelnet.remove_box( pos, oldnode, oldmetadata, digger )
|
||||
end,
|
||||
|
||||
can_dig = function( pos, player )
|
||||
if( not(locks:lock_allow_dig( pos, player ))) then
|
||||
return false;
|
||||
end
|
||||
return travelnet.can_dig( pos, player, 'elevator' )
|
||||
end,
|
||||
-- taken from VanessaEs homedecor fridge
|
||||
on_place = function(itemstack, placer, pointed_thing)
|
||||
local pos = pointed_thing.above;
|
||||
local node = minetest.get_node({x=pos.x, y=pos.y+1, z=pos.z});
|
||||
local def = minetest.registered_nodes[node.name]
|
||||
-- leftover elevator_top nodes can be removed by placing a new elevator underneath
|
||||
if not def or not def.buildable_to then
|
||||
minetest.chat_send_player( placer:get_player_name(), 'Not enough vertical space to place the travelnet box!' )
|
||||
return
|
||||
end
|
||||
return minetest.item_place(itemstack, placer, pointed_thing)
|
||||
end,
|
||||
|
||||
after_dig_node = function(pos, oldnode, oldmetadata, digger)
|
||||
travelnet.remove_box( pos, oldnode, oldmetadata, digger )
|
||||
end,
|
||||
|
||||
-- taken from VanessaEs homedecor fridge
|
||||
on_place = function(itemstack, placer, pointed_thing)
|
||||
local pos = pointed_thing.above;
|
||||
local node = minetest.get_node({x=pos.x, y=pos.y+1, z=pos.z});
|
||||
local def = minetest.registered_nodes[node.name]
|
||||
-- leftover elevator_top nodes can be removed by placing a new elevator underneath
|
||||
if not def or not def.buildable_to then
|
||||
minetest.chat_send_player( placer:get_player_name(), 'Not enough vertical space to place the travelnet box!' )
|
||||
return;
|
||||
end
|
||||
return minetest.item_place(itemstack, placer, pointed_thing);
|
||||
end,
|
||||
|
||||
on_destruct = function(pos)
|
||||
local p = {x=pos.x, y=pos.y+1, z=pos.z}
|
||||
minetest.remove_node(p)
|
||||
end
|
||||
on_destruct = function(pos)
|
||||
local p = {x=pos.x, y=pos.y+1, z=pos.z}
|
||||
minetest.remove_node(p)
|
||||
end
|
||||
})
|
||||
|
||||
minetest.register_node("locked_travelnet:elevator_top", {
|
||||
description = "Elevator Top",
|
||||
description = "Elevator Top",
|
||||
|
||||
drawtype = "nodebox",
|
||||
sunlight_propagates = true,
|
||||
paramtype = 'light',
|
||||
paramtype2 = "facedir",
|
||||
drawtype = "nodebox",
|
||||
sunlight_propagates = true,
|
||||
paramtype = 'light',
|
||||
paramtype2 = "facedir",
|
||||
|
||||
selection_box = {
|
||||
type = "fixed",
|
||||
fixed = { 0, 0, 0, 0, 0, 0 }
|
||||
-- fixed = { -0.5, -0.5, -0.5, 0.5, 0.5, 0.5 }
|
||||
},
|
||||
selection_box = {
|
||||
type = "fixed",
|
||||
fixed = { 0, 0, 0, 0, 0, 0 }
|
||||
-- fixed = { -0.5, -0.5, -0.5, 0.5, 0.5, 0.5 }
|
||||
},
|
||||
|
||||
node_box = {
|
||||
type = "fixed",
|
||||
fixed = {
|
||||
node_box = {
|
||||
type = "fixed",
|
||||
fixed = {
|
||||
|
||||
{ 0.48, -0.5,-0.5, 0.5, 0.5, 0.5},
|
||||
{-0.5 , -0.5, 0.48, 0.48, 0.5, 0.5},
|
||||
{-0.5, -0.5,-0.5 ,-0.48, 0.5, 0.5},
|
||||
{ 0.48, -0.5,-0.5, 0.5, 0.5, 0.5},
|
||||
{-0.5 , -0.5, 0.48, 0.48, 0.5, 0.5},
|
||||
{-0.5, -0.5,-0.5 ,-0.48, 0.5, 0.5},
|
||||
|
||||
--top ceiling
|
||||
{ -0.5, 0.48,-0.5,0.5, 0.5, 0.5},
|
||||
},
|
||||
},
|
||||
--top ceiling
|
||||
{ -0.5, 0.48,-0.5,0.5, 0.5, 0.5},
|
||||
},
|
||||
},
|
||||
|
||||
|
||||
tiles = {
|
||||
tiles = {
|
||||
"default_stone.png", -- view from top
|
||||
"travelnet_elevator_inside_ceiling.png", -- view from bottom
|
||||
"travelnet_elevator_inside_top_control.png", -- left side
|
||||
"travelnet_elevator_inside_top.png", -- right side
|
||||
"travelnet_elevator_inside_top.png", -- front view
|
||||
"travelnet_elevator_inside_top.png", -- backward view
|
||||
},
|
||||
inventory_image = "travelnet_elevator_inv.png",
|
||||
wield_image = "travelnet_elevator_wield.png",
|
||||
|
||||
"default_stone.png", -- view from top
|
||||
"travelnet_elevator_inside_ceiling.png", -- view from bottom
|
||||
"travelnet_elevator_inside_top_control.png", -- left side
|
||||
"travelnet_elevator_inside_top.png", -- right side
|
||||
"travelnet_elevator_inside_top.png", -- front view
|
||||
"travelnet_elevator_inside_top.png", -- backward view
|
||||
},
|
||||
inventory_image = "travelnet_elevator_inv.png",
|
||||
wield_image = "travelnet_elevator_wield.png",
|
||||
light_source = 10,
|
||||
|
||||
light_source = 10,
|
||||
|
||||
groups = {}, --cracky=1,choppy=1,snappy=1,not_in_creative_inventory=1},
|
||||
groups = {}, --cracky=1,choppy=1,snappy=1,not_in_creative_inventory=1},
|
||||
})
|
||||
|
||||
|
||||
|
||||
minetest.register_craft({
|
||||
output = 'locked_travelnet:elevator',
|
||||
recipe = {
|
||||
{ 'travelnet:elevator', 'locks:lock' },
|
||||
},
|
||||
output = 'locked_travelnet:elevator',
|
||||
recipe = {
|
||||
{ 'travelnet:elevator', 'locks:lock' },
|
||||
},
|
||||
})
|
||||
|
||||
print( "[Mod] locked_travelnet: loading locked_travelnet:elevator");
|
||||
|
|
|
@ -1,17 +1,18 @@
|
|||
-- contains the node definition for a general travelnet that can be used by anyone
|
||||
-- further travelnets can only be installed by the owner or by people with the travelnet_attach priv
|
||||
-- digging of such a travelnet is limited to the owner and to people with the travelnet_remove priv (useful for admins to clean up)
|
||||
-- further travelnets can only be installed by the owner or by people with the travelnet_attach priv
|
||||
-- digging of such a travelnet is limited to the owner and to people with the travelnet_remove priv (useful for admins to clean up)
|
||||
-- (this can be overrided in config.lua)
|
||||
-- Autor: Sokomine
|
||||
local S = minetest.get_translator("travelnet")
|
||||
|
||||
|
||||
local locked_forms = {}
|
||||
local function on_interact(pos, _, player)
|
||||
if not locks:lock_allow_use( pos, player ) then
|
||||
return false
|
||||
end
|
||||
locked_forms[player:get_player_name()] = true
|
||||
|
||||
local meta = minetest.get_meta(pos)
|
||||
local unconfiged = travelnet.is_falsey_string(meta:get_string("station_name", ""))
|
||||
if unconfiged then return end
|
||||
local legacy_formspec = meta:get_string("formspec")
|
||||
if not travelnet.is_falsey_string(legacy_formspec) then
|
||||
meta:set_string("formspec", "")
|
||||
|
@ -21,130 +22,172 @@ local function on_interact(pos, _, player)
|
|||
travelnet.show_current_formspec(pos, meta, player_name)
|
||||
end
|
||||
|
||||
local original_end_input = travelnet.actions.end_input
|
||||
function travelnet.actions.end_input(_, _, player)
|
||||
locked_forms[player:get_player_name()] = nil
|
||||
return original_end_input(_, _, player)
|
||||
end
|
||||
|
||||
local original_primary_formspec = travelnet.formspecs.primary
|
||||
function travelnet.formspecs.primary(options, player_name)
|
||||
if locked_forms[player_name] then
|
||||
options.height = 11.5
|
||||
return original_primary_formspec(options, player_name)..
|
||||
"field[0.3,11;6,0.7;locks_sent_lock_command;"..S("Locked travelnet. Type /help for help:")..";]"..
|
||||
locks.get_authorize_button(10,10.5)..
|
||||
locks.get_config_button(11,10.5)
|
||||
else
|
||||
return original_primary_formspec(options, player_name)
|
||||
end
|
||||
end
|
||||
|
||||
local original_edit_formspec = travelnet.formspecs.edit_travelnet
|
||||
function travelnet.formspecs.edit_travelnet(options, player_name)
|
||||
if locked_forms[player_name] then
|
||||
return ([[
|
||||
size[12,10]
|
||||
field[0.3,5.6;6,0.7;station_name;%s:;%s]
|
||||
field[0.3,6.6;6,0.7;station_network;%s;%s]
|
||||
field[0.3,7.6;6,0.7;owner;%s;%s]
|
||||
button[8.0,0.0;2.2,0.7;station_dig;%s]
|
||||
field[0.3,3.0;6,0.7;locks_sent_lock_command;%s;]
|
||||
button[6.3,3.2;1.7,0.7;station_set;%s]
|
||||
]]):format(
|
||||
S("Name of this station"),
|
||||
minetest.formspec_escape(options.station_name or ""),
|
||||
S("Assign to Network:"),
|
||||
travelnet.is_falsey_string(options.station_network)
|
||||
and "net1"
|
||||
or options.station_network,
|
||||
S("Owned by:"),
|
||||
minetest.formspec_escape(options.owner_name or ""),
|
||||
S("Remove station"),
|
||||
S("Locked travelnet. Type /help for help:"),
|
||||
S("Save")
|
||||
)..
|
||||
locks.get_authorize_button(6, 0)..
|
||||
locks.get_config_button(7, 0)
|
||||
else
|
||||
return original_edit_formspec(options, player_name)
|
||||
end
|
||||
end
|
||||
|
||||
local original_on_receive_fields = travelnet.on_receive_fields
|
||||
function travelnet.on_receive_fields(pos, formname, fields, player)
|
||||
local player_name = player:get_player_name()
|
||||
if locked_forms[player_name] then
|
||||
if not travelnet.is_falsey_string(fields.locks_sent_lock_command) or fields.locks_config or fields.locks_authorize then
|
||||
locked_forms[player_name] = nil
|
||||
return locks:lock_handle_input( pos, formname, fields, player )
|
||||
elseif locks:lock_allow_use( pos, player ) then
|
||||
return original_on_receive_fields( pos, formname, fields, player )
|
||||
end
|
||||
else
|
||||
return original_on_receive_fields( pos, formname, fields, player )
|
||||
end
|
||||
end
|
||||
|
||||
minetest.register_node("locked_travelnet:travelnet", {
|
||||
|
||||
description = "Shared locked travelnet box",
|
||||
description = "Shared locked travelnet box",
|
||||
|
||||
drawtype = "nodebox",
|
||||
sunlight_propagates = true,
|
||||
paramtype = 'light',
|
||||
paramtype2 = "facedir",
|
||||
drawtype = "nodebox",
|
||||
sunlight_propagates = true,
|
||||
paramtype = 'light',
|
||||
paramtype2 = "facedir",
|
||||
|
||||
selection_box = {
|
||||
type = "fixed",
|
||||
fixed = { -0.5, -0.5, -0.5, 0.5, 1.5, 0.5 }
|
||||
},
|
||||
selection_box = {
|
||||
type = "fixed",
|
||||
fixed = { -0.5, -0.5, -0.5, 0.5, 1.5, 0.5 }
|
||||
},
|
||||
|
||||
node_box = {
|
||||
type = "fixed",
|
||||
fixed = {
|
||||
node_box = {
|
||||
type = "fixed",
|
||||
fixed = {
|
||||
{ 0.45, -0.5,-0.5, 0.5, 1.45, 0.5},
|
||||
{-0.5 , -0.5, 0.45, 0.45, 1.45, 0.5},
|
||||
{-0.5, -0.5,-0.5 ,-0.45, 1.45, 0.5},
|
||||
|
||||
{ 0.45, -0.5,-0.5, 0.5, 1.45, 0.5},
|
||||
{-0.5 , -0.5, 0.45, 0.45, 1.45, 0.5},
|
||||
{-0.5, -0.5,-0.5 ,-0.45, 1.45, 0.5},
|
||||
--groundplate to stand on
|
||||
{ -0.5,-0.5,-0.5,0.5,-0.45, 0.5},
|
||||
--roof
|
||||
{ -0.5, 1.45,-0.5,0.5, 1.5, 0.5},
|
||||
},
|
||||
},
|
||||
|
||||
--groundplate to stand on
|
||||
{ -0.5,-0.5,-0.5,0.5,-0.45, 0.5},
|
||||
--roof
|
||||
{ -0.5, 1.45,-0.5,0.5, 1.5, 0.5},
|
||||
tiles = {
|
||||
"default_clay.png", -- view from top
|
||||
"default_clay.png", -- view from bottom
|
||||
"locked_travelnet_travelnet_side_lock.png", -- left side
|
||||
"locked_travelnet_travelnet_side_lock.png", -- right side
|
||||
"locked_travelnet_travelnet_back_lock.png", -- front view
|
||||
"locked_travelnet_travelnet_front_lock.png", -- backward view
|
||||
},
|
||||
inventory_image = "locked_travelnet_lock_inv.png",
|
||||
|
||||
},
|
||||
},
|
||||
groups = {travelnet=1},
|
||||
|
||||
tiles = {
|
||||
"default_clay.png", -- view from top
|
||||
"default_clay.png", -- view from bottom
|
||||
"locked_travelnet_travelnet_side_lock.png", -- left side
|
||||
"locked_travelnet_travelnet_side_lock.png", -- right side
|
||||
"locked_travelnet_travelnet_back_lock.png", -- front view
|
||||
"locked_travelnet_travelnet_front_lock.png", -- backward view
|
||||
},
|
||||
inventory_image = "locked_travelnet_lock_inv.png",
|
||||
light_source = 10,
|
||||
|
||||
groups = {travelnet=1}, --cracky=1,choppy=1,snappy=1},
|
||||
on_construct = function(pos)
|
||||
local meta = minetest.get_meta(pos)
|
||||
--- prepare the lock of the travelnet
|
||||
locks:lock_init( pos, "" )
|
||||
meta:set_string("formspec", "")
|
||||
end,
|
||||
|
||||
light_source = 10,
|
||||
after_place_node = function(pos, placer, itemstack)
|
||||
local meta = minetest.get_meta(pos);
|
||||
meta:set_string("infotext", "Travelnet-box (unconfigured)");
|
||||
meta:set_string("station_name", "");
|
||||
meta:set_string("station_network", "");
|
||||
meta:set_string("owner", placer:get_player_name() );
|
||||
-- request initinal data
|
||||
locks:lock_set_owner( pos, placer, "Shared locked travelnet" );
|
||||
local top_pos = vector.add({x=0,y=1,z=0}, pos)
|
||||
minetest.set_node(top_pos, {name="travelnet:hidden_top"})
|
||||
end,
|
||||
|
||||
on_construct = function(pos)
|
||||
local meta = minetest.get_meta(pos)
|
||||
--- prepare the lock of the travelnet
|
||||
locks:lock_init( pos,
|
||||
"size[12,10]"..
|
||||
"field[0.3,5.6;6,0.7;station_name;Name of this station:;]"..
|
||||
"field[0.3,6.6;6,0.7;station_network;Assign to Network:;]"..
|
||||
"field[0.3,7.6;6,0.7;owner_name;(optional) owned by:;]"..
|
||||
"button[8.0,0.0;2.2,0.7;station_dig;Remove station]"..
|
||||
-- "button_exit[6.3,6.2;1.7,0.7;station_set;Store]"..
|
||||
"field[0.3,3.0;6,0.7;locks_sent_lock_command;Locked travelnet. Type /help for help:;]"..
|
||||
"button[6.3,3.2;1.7,0.7;locks_sent_input;Store]" );
|
||||
end,
|
||||
on_receive_fields = travelnet.on_receive_fields,
|
||||
|
||||
after_place_node = function(pos, placer, itemstack)
|
||||
local meta = minetest.get_meta(pos);
|
||||
meta:set_string("infotext", "Travelnet-box (unconfigured)");
|
||||
meta:set_string("station_name", "");
|
||||
meta:set_string("station_network","");
|
||||
meta:set_string("owner", placer:get_player_name() );
|
||||
-- request initinal data
|
||||
locks:lock_set_owner( pos, placer, "Shared locked travelnet" );
|
||||
local top_pos = vector.add({x=0,y=1,z=0}, pos)
|
||||
minetest.set_node(top_pos, {name="travelnet:hidden_top"})
|
||||
end,
|
||||
on_punch = on_interact,
|
||||
on_rightclick = on_interact,
|
||||
|
||||
on_receive_fields = function(pos, formname, fields, sender)
|
||||
if not travelnet.is_falsey_string(fields.locks_sent_lock_command) then
|
||||
locks:lock_handle_input( pos, formname, fields, sender )
|
||||
elseif locks:lock_allow_use( pos, sender ) then
|
||||
if not fields.quit then
|
||||
local meta = minetest.get_meta(pos)
|
||||
meta:set_string("formspec", "")
|
||||
end
|
||||
can_dig = function( pos, player )
|
||||
if not locks:lock_allow_dig( pos, player ) then
|
||||
return false
|
||||
end
|
||||
|
||||
travelnet.on_receive_fields( pos, formname, fields, sender );
|
||||
end
|
||||
end,
|
||||
return travelnet.can_dig( pos, player, 'travelnet box' )
|
||||
end,
|
||||
|
||||
on_punch = on_interact,
|
||||
on_rightclick = on_interact,
|
||||
|
||||
can_dig = function( pos, player )
|
||||
|
||||
if( not(locks:lock_allow_dig( pos, player ))) then
|
||||
return false;
|
||||
end
|
||||
|
||||
return travelnet.can_dig( pos, player, 'travelnet box' )
|
||||
end,
|
||||
|
||||
after_dig_node = function(pos, oldnode, oldmetadata, digger)
|
||||
travelnet.remove_box( pos, oldnode, oldmetadata, digger )
|
||||
end,
|
||||
|
||||
-- taken from VanessaEs homedecor fridge
|
||||
on_place = function(itemstack, placer, pointed_thing)
|
||||
|
||||
local pos = pointed_thing.above;
|
||||
local node = minetest.get_node({x=pos.x, y=pos.y+1, z=pos.z})
|
||||
local def = minetest.registered_nodes[node.name]
|
||||
if (not def or not def.buildable_to) and node.name ~= "travelnet:hidden_top" then
|
||||
minetest.chat_send_player( placer:get_player_name(), 'Not enough vertical space to place the travelnet box!' )
|
||||
return;
|
||||
end
|
||||
return minetest.item_place(itemstack, placer, pointed_thing);
|
||||
end,
|
||||
after_dig_node = function (pos, oldnode, oldmetadata, digger)
|
||||
travelnet.remove_box( pos, oldnode, oldmetadata, digger )
|
||||
end,
|
||||
|
||||
-- taken from VanessaEs homedecor fridge
|
||||
on_place = function (itemstack, placer, pointed_thing)
|
||||
local pos = pointed_thing.above;
|
||||
local node = minetest.get_node({x=pos.x, y=pos.y+1, z=pos.z})
|
||||
local def = minetest.registered_nodes[node.name]
|
||||
if (not def or not def.buildable_to) and node.name ~= "travelnet:hidden_top" then
|
||||
minetest.chat_send_player( placer:get_player_name(), 'Not enough vertical space to place the travelnet box!' )
|
||||
return
|
||||
end
|
||||
return minetest.item_place(itemstack, placer, pointed_thing);
|
||||
end,
|
||||
})
|
||||
|
||||
|
||||
minetest.register_craft({
|
||||
output = 'locked_travelnet:travelnet',
|
||||
recipe = {
|
||||
{ 'travelnet:travelnet', 'locks:lock' },
|
||||
},
|
||||
output = 'locked_travelnet:travelnet',
|
||||
recipe = {
|
||||
{ 'travelnet:travelnet', 'locks:lock' },
|
||||
},
|
||||
})
|
||||
|
||||
if minetest.global_exists("mesecon") and mesecon.register_mvps_stopper then
|
||||
mesecon.register_mvps_stopper('locked_travelnet:travelnet')
|
||||
mesecon.register_mvps_stopper('locked_travelnet:travelnet')
|
||||
end
|
||||
|
||||
print( "[Mod] locked_travelnet: loading locked_travelnet:travelnet");
|
||||
|
|
Loading…
Reference in New Issue