mirror of
https://notabug.org/TenPlus1/protector.git
synced 2025-01-25 04:41:29 +01:00
Added player checking for player effects
This commit is contained in:
parent
5d1f2e2c01
commit
950fb7e7cf
38
init.lua
38
init.lua
@ -1,10 +1,8 @@
|
|||||||
|
|
||||||
-- older privelage for admins to rbypass protected nodes, do not use anymore
|
|
||||||
-- instead grant admin 'protection_bypass' privelage.
|
|
||||||
|
|
||||||
-- 'delprotect' priv removed, use 'protection_bypass' instead
|
-- 'delprotect' priv removed, use 'protection_bypass' instead
|
||||||
--minetest.register_privilege("delprotect","Ignore player protection")
|
--minetest.register_privilege("delprotect","Ignore player protection")
|
||||||
|
|
||||||
|
|
||||||
-- get minetest.conf settings
|
-- get minetest.conf settings
|
||||||
protector = {}
|
protector = {}
|
||||||
protector.mod = "redo"
|
protector.mod = "redo"
|
||||||
@ -15,9 +13,11 @@ protector.hurt = tonumber(minetest.setting_get("protector_hurt")) or 0
|
|||||||
protector.spawn = tonumber(minetest.setting_get("protector_spawn")
|
protector.spawn = tonumber(minetest.setting_get("protector_spawn")
|
||||||
or minetest.setting_get("protector_pvp_spawn")) or 0
|
or minetest.setting_get("protector_pvp_spawn")) or 0
|
||||||
|
|
||||||
|
|
||||||
-- get static spawn position
|
-- get static spawn position
|
||||||
local statspawn = minetest.setting_get_pos("static_spawnpoint") or {x = 0, y = 2, z = 0}
|
local statspawn = minetest.setting_get_pos("static_spawnpoint") or {x = 0, y = 2, z = 0}
|
||||||
|
|
||||||
|
|
||||||
-- Intllib
|
-- Intllib
|
||||||
local S
|
local S
|
||||||
if minetest.get_modpath("intllib") then
|
if minetest.get_modpath("intllib") then
|
||||||
@ -40,18 +40,21 @@ else
|
|||||||
end
|
end
|
||||||
protector.intllib = S
|
protector.intllib = S
|
||||||
|
|
||||||
|
|
||||||
-- return list of members as a table
|
-- return list of members as a table
|
||||||
protector.get_member_list = function(meta)
|
protector.get_member_list = function(meta)
|
||||||
|
|
||||||
return meta:get_string("members"):split(" ")
|
return meta:get_string("members"):split(" ")
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
||||||
-- write member list table in protector meta as string
|
-- write member list table in protector meta as string
|
||||||
protector.set_member_list = function(meta, list)
|
protector.set_member_list = function(meta, list)
|
||||||
|
|
||||||
meta:set_string("members", table.concat(list, " "))
|
meta:set_string("members", table.concat(list, " "))
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
||||||
-- check if player name is a member
|
-- check if player name is a member
|
||||||
protector.is_member = function (meta, name)
|
protector.is_member = function (meta, name)
|
||||||
|
|
||||||
@ -65,6 +68,7 @@ protector.is_member = function (meta, name)
|
|||||||
return false
|
return false
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
||||||
-- add player name to table as member
|
-- add player name to table as member
|
||||||
protector.add_member = function(meta, name)
|
protector.add_member = function(meta, name)
|
||||||
|
|
||||||
@ -79,6 +83,7 @@ protector.add_member = function(meta, name)
|
|||||||
protector.set_member_list(meta, list)
|
protector.set_member_list(meta, list)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
||||||
-- remove player name from table
|
-- remove player name from table
|
||||||
protector.del_member = function(meta, name)
|
protector.del_member = function(meta, name)
|
||||||
|
|
||||||
@ -95,6 +100,7 @@ protector.del_member = function(meta, name)
|
|||||||
protector.set_member_list(meta, list)
|
protector.set_member_list(meta, list)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
||||||
-- protector interface
|
-- protector interface
|
||||||
protector.generate_formspec = function(meta)
|
protector.generate_formspec = function(meta)
|
||||||
|
|
||||||
@ -145,6 +151,7 @@ protector.generate_formspec = function(meta)
|
|||||||
return formspec
|
return formspec
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
||||||
-- check if pos is inside a protected spawn area
|
-- check if pos is inside a protected spawn area
|
||||||
local function inside_spawn(pos, radius)
|
local function inside_spawn(pos, radius)
|
||||||
|
|
||||||
@ -165,6 +172,7 @@ local function inside_spawn(pos, radius)
|
|||||||
return false
|
return false
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
||||||
-- Infolevel:
|
-- Infolevel:
|
||||||
-- 0 for no info
|
-- 0 for no info
|
||||||
-- 1 for "This area is owned by <owner> !" if you can't dig
|
-- 1 for "This area is owned by <owner> !" if you can't dig
|
||||||
@ -273,16 +281,15 @@ function minetest.is_protected(pos, digger)
|
|||||||
|
|
||||||
local player = minetest.get_player_by_name(digger)
|
local player = minetest.get_player_by_name(digger)
|
||||||
|
|
||||||
|
if player and player:is_player() then
|
||||||
|
|
||||||
-- hurt player if protection violated
|
-- hurt player if protection violated
|
||||||
if protector.hurt > 0
|
if protector.hurt > 0 and player:get_hp() > 0 then
|
||||||
and player then
|
|
||||||
player:set_hp(player:get_hp() - protector.hurt)
|
player:set_hp(player:get_hp() - protector.hurt)
|
||||||
end
|
end
|
||||||
|
|
||||||
-- flip player when protection violated
|
-- flip player when protection violated
|
||||||
if protector.flip
|
if protector.flip then
|
||||||
and player then
|
|
||||||
|
|
||||||
-- yaw + 180°
|
-- yaw + 180°
|
||||||
--local yaw = player:get_look_horizontal() + math.pi
|
--local yaw = player:get_look_horizontal() + math.pi
|
||||||
local yaw = player:get_look_yaw() + math.pi
|
local yaw = player:get_look_yaw() + math.pi
|
||||||
@ -312,8 +319,7 @@ function minetest.is_protected(pos, digger)
|
|||||||
end
|
end
|
||||||
|
|
||||||
-- drop tool/item if protection violated
|
-- drop tool/item if protection violated
|
||||||
if protector.drop == true
|
if protector.drop == true then
|
||||||
and player then
|
|
||||||
|
|
||||||
local holding = player:get_wielded_item()
|
local holding = player:get_wielded_item()
|
||||||
|
|
||||||
@ -333,7 +339,7 @@ function minetest.is_protected(pos, digger)
|
|||||||
obj:setvelocity({x = 0, y = 5, z = 0})
|
obj:setvelocity({x = 0, y = 5, z = 0})
|
||||||
end
|
end
|
||||||
end)
|
end)
|
||||||
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
@ -342,9 +348,9 @@ function minetest.is_protected(pos, digger)
|
|||||||
|
|
||||||
-- otherwise can dig or place
|
-- otherwise can dig or place
|
||||||
return protector.old_is_protected(pos, digger)
|
return protector.old_is_protected(pos, digger)
|
||||||
|
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
||||||
-- make sure protection block doesn't overlap another protector's area
|
-- make sure protection block doesn't overlap another protector's area
|
||||||
function protector.check_overlap(itemstack, placer, pointed_thing)
|
function protector.check_overlap(itemstack, placer, pointed_thing)
|
||||||
|
|
||||||
@ -378,6 +384,7 @@ function protector.check_overlap(itemstack, placer, pointed_thing)
|
|||||||
|
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
||||||
-- protection node
|
-- protection node
|
||||||
minetest.register_node("protector:protect", {
|
minetest.register_node("protector:protect", {
|
||||||
description = S("Protection Block"),
|
description = S("Protection Block"),
|
||||||
@ -457,6 +464,7 @@ minetest.register_craft({
|
|||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
|
||||||
|
|
||||||
-- protection logo
|
-- protection logo
|
||||||
minetest.register_node("protector:protect2", {
|
minetest.register_node("protector:protect2", {
|
||||||
description = S("Protection Logo"),
|
description = S("Protection Logo"),
|
||||||
@ -537,6 +545,7 @@ minetest.register_craft({
|
|||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
|
||||||
|
|
||||||
-- check formspec buttons or when name entered
|
-- check formspec buttons or when name entered
|
||||||
minetest.register_on_player_receive_fields(function(player, formname, fields)
|
minetest.register_on_player_receive_fields(function(player, formname, fields)
|
||||||
|
|
||||||
@ -578,6 +587,7 @@ minetest.register_on_player_receive_fields(function(player, formname, fields)
|
|||||||
end
|
end
|
||||||
end)
|
end)
|
||||||
|
|
||||||
|
|
||||||
-- display entity shown when protector node is punched
|
-- display entity shown when protector node is punched
|
||||||
minetest.register_entity("protector:display", {
|
minetest.register_entity("protector:display", {
|
||||||
physical = false,
|
physical = false,
|
||||||
@ -599,6 +609,7 @@ minetest.register_entity("protector:display", {
|
|||||||
end,
|
end,
|
||||||
})
|
})
|
||||||
|
|
||||||
|
|
||||||
-- Display-zone node, Do NOT place the display as a node,
|
-- Display-zone node, Do NOT place the display as a node,
|
||||||
-- it is made to be used as an entity (see above)
|
-- it is made to be used as an entity (see above)
|
||||||
|
|
||||||
@ -632,6 +643,7 @@ minetest.register_node("protector:display_node", {
|
|||||||
drop = "",
|
drop = "",
|
||||||
})
|
})
|
||||||
|
|
||||||
|
|
||||||
local path = minetest.get_modpath("protector")
|
local path = minetest.get_modpath("protector")
|
||||||
|
|
||||||
dofile(path .. "/doors_chest.lua")
|
dofile(path .. "/doors_chest.lua")
|
||||||
@ -640,6 +652,7 @@ dofile(path .. "/admin.lua")
|
|||||||
dofile(path .. "/tool.lua")
|
dofile(path .. "/tool.lua")
|
||||||
dofile(path .. "/lucky_block.lua")
|
dofile(path .. "/lucky_block.lua")
|
||||||
|
|
||||||
|
|
||||||
-- stop mesecon pistons from pushing protectors
|
-- stop mesecon pistons from pushing protectors
|
||||||
if minetest.get_modpath("mesecons_mvps") then
|
if minetest.get_modpath("mesecons_mvps") then
|
||||||
mesecon.register_mvps_stopper("protector:protect")
|
mesecon.register_mvps_stopper("protector:protect")
|
||||||
@ -647,4 +660,5 @@ if minetest.get_modpath("mesecons_mvps") then
|
|||||||
mesecon.register_mvps_stopper("protector:chest")
|
mesecon.register_mvps_stopper("protector:chest")
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
||||||
print (S("[MOD] Protector Redo loaded"))
|
print (S("[MOD] Protector Redo loaded"))
|
||||||
|
Loading…
Reference in New Issue
Block a user