Allow sharing the button based on protection

Should be fully backwards compatible.
This commit is contained in:
Thomas--S 2021-08-15 09:26:42 +02:00
parent 428a3d552f
commit b0c6911638
3 changed files with 27 additions and 7 deletions

View File

@ -109,6 +109,7 @@ TA3 Booster=TA3 Gebläse
### button.lua ### ### button.lua ###
Access:=Zugriff:
TA3 Button/Switch=TA3 Taster/Schalter TA3 Button/Switch=TA3 Taster/Schalter
TA4 Button/Switch=TA4 Schalter/Taster TA4 Button/Switch=TA4 Schalter/Taster

View File

@ -109,6 +109,7 @@ TA3 Booster=
### button.lua ### ### button.lua ###
Access:=
TA3 Button/Switch= TA3 Button/Switch=
TA4 Button/Switch= TA4 Button/Switch=

View File

@ -56,10 +56,12 @@ local function formspec(meta)
local numbers = meta:get_string("numbers") or "" local numbers = meta:get_string("numbers") or ""
local idx = meta:get_int("cycle_idx") or 0 local idx = meta:get_int("cycle_idx") or 0
if idx == 0 then idx = 1 end if idx == 0 then idx = 1 end
local access_idx = meta:get_string("public") == "true" and 3 or meta:get_string("protected") == "true" and 2 or 1
return "size[7.5,6]".. return "size[7.5,6]"..
"dropdown[0.2,0;3;type;switch,button 1s,button 2s,button 4s,button 8s,button 16s,button 32s;"..idx.."]".. "dropdown[0.2,0;3;type;switch,button 1s,button 2s,button 4s,button 8s,button 16s,button 32s;"..idx.."]"..
"field[0.5,2;7,1;numbers;"..S("Insert destination node number(s)")..";"..numbers.."]" .. "field[0.5,2;7,1;numbers;"..S("Insert destination node number(s)")..";"..numbers.."]" ..
"checkbox[1,3;public;public;false]".. "label[0.2,3;"..S("Access:").."]"..
"dropdown[3,3;4;access;private,protected,public;"..access_idx.."]"..
"button_exit[2,4;3,1;exit;"..S("Save").."]" "button_exit[2,4;3,1;exit;"..S("Save").."]"
end end
@ -72,8 +74,17 @@ local function on_receive_fields(pos, formname, fields, player)
return return
end end
meta:set_string("numbers", fields.numbers) meta:set_string("numbers", fields.numbers)
if fields.public then if fields.access == "protected" then
meta:set_string("public", fields.public) meta:set_string("protected", "true")
meta:set_string("public", "")
end
if fields.access == "public" then
meta:set_string("public", "true")
meta:set_string("protected", "")
end
if fields.access == "private" then
meta:set_string("public", "")
meta:set_string("protected", "")
end end
local cycle_time = nil local cycle_time = nil
if fields.type == "switch" then if fields.type == "switch" then
@ -110,12 +121,20 @@ local function on_receive_fields(pos, formname, fields, player)
end end
end end
local function can_access(pos, player)
local meta = M(pos)
local public = meta:get_string("public") == "true"
local protected = meta:get_string("protected") == "true"
local owner = meta:get_string("owner")
local name = player:get_player_name()
return public or protected and not minetest.is_protected(pos, name) or owner == name
end
local function on_rightclick_on(pos, node, clicker) local function on_rightclick_on(pos, node, clicker)
local meta = M(pos) local meta = M(pos)
local fixed = meta:get_string("fixed") local fixed = meta:get_string("fixed")
if fixed == "true" then if fixed == "true" then
if meta:get_string("public") == "true" or if can_access(pos, clicker) then
clicker:get_player_name() == meta:get_string("owner") then
switch_on(pos) switch_on(pos)
end end
end end
@ -126,8 +145,7 @@ local function on_rightclick_off(pos, node, clicker)
local numbers = meta:get_string("numbers") local numbers = meta:get_string("numbers")
local cycle_time = meta:get_int("cycle_time") or 0 local cycle_time = meta:get_int("cycle_time") or 0
if numbers ~= "" and numbers ~= nil and cycle_time == 0 then if numbers ~= "" and numbers ~= nil and cycle_time == 0 then
if meta:get_string("public") == "true" or if can_access(pos, clicker) then
clicker:get_player_name() == meta:get_string("owner") then
switch_off(pos) switch_off(pos)
end end
end end