Merge pull request #5 from oversword/update

Update
master
Oversword 2022-02-20 20:47:07 +00:00 committed by GitHub
commit b2e0cf1433
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
4 changed files with 390 additions and 351 deletions

View File

@ -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:
--]]

View File

@ -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'},
}
})

View File

@ -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");

View File

@ -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");