mirror of
https://github.com/minetest-mods/teleport-request.git
synced 2025-01-23 13:21:25 +01:00
Small changes
Completed 2 tasks from the TODO list. See the "README.md" changes commit.
This commit is contained in:
parent
e102f4f18a
commit
c921f786d7
103
init.lua
103
init.lua
@ -1,7 +1,9 @@
|
|||||||
-- Originally Teleport Request by Traxie21 and released with the WTFPL license
|
--[[
|
||||||
-- https://forum.minetest.net/viewtopic.php?id=4457
|
Originally made by Traxie21 and released with the WTFPL license.
|
||||||
-- Updates by Zeno and ChaosWormz
|
https://forum.minetest.net/viewtopic.php?id=4457
|
||||||
-- New release by RobbieF under new mod: tps_teleport - http://blog.minetest.tv/teleport-request/
|
Updates by Zeno and ChaosWormz
|
||||||
|
New release by RobbieF under new mod: tps_teleport - http://blog.minetest.tv/teleport-request/
|
||||||
|
--]]
|
||||||
|
|
||||||
local timeout_delay = 60
|
local timeout_delay = 60
|
||||||
|
|
||||||
@ -15,13 +17,21 @@ local function can_teleport(to)
|
|||||||
return to.x < map_size and to.x > -map_size and to.y < map_size and to.y > -map_size and to.z < map_size and to.z > -map_size
|
return to.x < map_size and to.x > -map_size and to.y < map_size and to.y > -map_size and to.z < map_size and to.z > -map_size
|
||||||
end
|
end
|
||||||
|
|
||||||
|
minetest.register_privilege("tp", {
|
||||||
|
description = "Let players teleport to other players (request will be sent)",
|
||||||
|
give_to_singleplayer = false,
|
||||||
|
give_to_admin = true,
|
||||||
|
})
|
||||||
|
|
||||||
minetest.register_privilege("tp_admin", {
|
minetest.register_privilege("tp_admin", {
|
||||||
description = "Admin overrides for tps_teleport.",
|
description = "Admin overrides for tps_teleport.",
|
||||||
give_to_singleplayer=false
|
give_to_singleplayer = false,
|
||||||
|
give_to_admin = true,
|
||||||
})
|
})
|
||||||
minetest.register_privilege("tp_tpc", {
|
minetest.register_privilege("tp_tpc", {
|
||||||
description = "Allow player to teleport to coordinates (if permitted by area protection).",
|
description = "Allow player to teleport to coordinates (if permitted by area protection).",
|
||||||
give_to_singleplayer=true
|
give_to_singleplayer = true,
|
||||||
|
give_to_admin = true,
|
||||||
})
|
})
|
||||||
|
|
||||||
local function find_free_position_near(pos)
|
local function find_free_position_near(pos)
|
||||||
@ -62,8 +72,22 @@ local function parti2(pos)
|
|||||||
"tps_portal_parti.png")
|
"tps_portal_parti.png")
|
||||||
end
|
end
|
||||||
|
|
||||||
--Teleport Request System
|
-- Teleport Request System
|
||||||
local function tpr_send(sender, receiver)
|
function tpr_send(sender, receiver)
|
||||||
|
if minetest.check_player_privs(sender, {tp_admin = true}) then
|
||||||
|
-- Write name values to list and clear old values.
|
||||||
|
tpr_list[receiver] = sender
|
||||||
|
-- Teleport timeout delay
|
||||||
|
minetest.after(timeout_delay, function(name)
|
||||||
|
if tpr_list[name] then
|
||||||
|
tpr_list[name] = nil
|
||||||
|
end
|
||||||
|
end, sender)
|
||||||
|
tpr_accept(receiver)
|
||||||
|
minetest.chat_send_player(sender, "You are teleporting to " .. receiver .. ".")
|
||||||
|
return
|
||||||
|
end
|
||||||
|
|
||||||
if receiver == "" then
|
if receiver == "" then
|
||||||
minetest.chat_send_player(sender, "Usage: /tpr <Player name>")
|
minetest.chat_send_player(sender, "Usage: /tpr <Player name>")
|
||||||
return
|
return
|
||||||
@ -77,17 +101,32 @@ local function tpr_send(sender, receiver)
|
|||||||
minetest.chat_send_player(receiver, sender ..' is requesting to teleport to you. /tpy to accept.')
|
minetest.chat_send_player(receiver, sender ..' is requesting to teleport to you. /tpy to accept.')
|
||||||
minetest.chat_send_player(sender, 'Teleport request sent! It will time out in '.. timeout_delay ..' seconds.')
|
minetest.chat_send_player(sender, 'Teleport request sent! It will time out in '.. timeout_delay ..' seconds.')
|
||||||
|
|
||||||
--Write name values to list and clear old values.
|
-- Write name values to list and clear old values.
|
||||||
|
if not minetest.check_player_privs(sender, {tp_admin = true}) then
|
||||||
tpr_list[receiver] = sender
|
tpr_list[receiver] = sender
|
||||||
--Teleport timeout delay
|
-- Teleport timeout delay
|
||||||
minetest.after(timeout_delay, function(name)
|
minetest.after(timeout_delay, function(name)
|
||||||
if tpr_list[name] then
|
if tpr_list[name] then
|
||||||
tpr_list[name] = nil
|
tpr_list[name] = nil
|
||||||
end
|
end
|
||||||
end, sender)
|
end, sender)
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
local function tphr_send(sender, receiver)
|
function tphr_send(sender, receiver)
|
||||||
|
if minetest.check_player_privs(sender, {tp_admin = true}) then
|
||||||
|
-- Write name values to list and clear old values.
|
||||||
|
tphr_list[receiver] = sender
|
||||||
|
-- Teleport timeout delay
|
||||||
|
minetest.after(timeout_delay, function(name)
|
||||||
|
if tphr_list[name] then
|
||||||
|
tphr_list[name] = nil
|
||||||
|
end
|
||||||
|
end, sender)
|
||||||
|
tpr_accept(receiver)
|
||||||
|
minetest.chat_send_player(sender, receiver .. " is teleporting to you.")
|
||||||
|
return
|
||||||
|
end
|
||||||
if receiver == "" then
|
if receiver == "" then
|
||||||
minetest.chat_send_player(sender, "Usage: /tphr <Player name>")
|
minetest.chat_send_player(sender, "Usage: /tphr <Player name>")
|
||||||
return
|
return
|
||||||
@ -101,19 +140,21 @@ local function tphr_send(sender, receiver)
|
|||||||
minetest.chat_send_player(receiver, sender ..' is requesting that you teleport to them. /tpy to accept; /tpn to deny')
|
minetest.chat_send_player(receiver, sender ..' is requesting that you teleport to them. /tpy to accept; /tpn to deny')
|
||||||
minetest.chat_send_player(sender, 'Teleport request sent! It will time out in '.. timeout_delay ..' seconds.')
|
minetest.chat_send_player(sender, 'Teleport request sent! It will time out in '.. timeout_delay ..' seconds.')
|
||||||
|
|
||||||
--Write name values to list and clear old values.
|
-- Write name values to list and clear old values.
|
||||||
|
if not minetest.check_player_privs(sender, {tp_admin = true}) then
|
||||||
tphr_list[receiver] = sender
|
tphr_list[receiver] = sender
|
||||||
--Teleport timeout delay
|
-- Teleport timeout delay
|
||||||
minetest.after(timeout_delay, function(name)
|
minetest.after(timeout_delay, function(name)
|
||||||
if tphr_list[name] then
|
if tphr_list[name] then
|
||||||
tphr_list[name] = nil
|
tphr_list[name] = nil
|
||||||
end
|
end
|
||||||
end, sender)
|
end, sender)
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
local function tpc_send(player,coordinates)
|
function tpc_send(player,coordinates)
|
||||||
|
|
||||||
local posx,posy,posz = string.match(coordinates, "^(-?%d+),(-?%d+),(-?%d+)$")
|
local posx,posy,posz = string.match(coordinates, "^(-?%d+), (-?%d+), (-?%d+)$")
|
||||||
local pname = minetest.get_player_by_name(player)
|
local pname = minetest.get_player_by_name(player)
|
||||||
|
|
||||||
if posx ~= nil or posy ~= nil or posz ~= nil then
|
if posx ~= nil or posy ~= nil or posz ~= nil then
|
||||||
@ -123,7 +164,7 @@ local function tpc_send(player,coordinates)
|
|||||||
end
|
end
|
||||||
|
|
||||||
if posx==nil or posy==nil or posz==nil or string.len(posx) > 6 or string.len(posy) > 6 or string.len(posz) > 6 then
|
if posx==nil or posy==nil or posz==nil or string.len(posx) > 6 or string.len(posy) > 6 or string.len(posz) > 6 then
|
||||||
minetest.chat_send_player(player, "Usage: /tpc <x,y,z>")
|
minetest.chat_send_player(player, "Usage: /tpc <x, y, z>")
|
||||||
return nil
|
return nil
|
||||||
end
|
end
|
||||||
|
|
||||||
@ -139,21 +180,21 @@ local function tpc_send(player,coordinates)
|
|||||||
-- Admin user (priv "tp_admin") overrides all protection
|
-- Admin user (priv "tp_admin") overrides all protection
|
||||||
if minetest.check_player_privs(pname, {tp_admin=true}) then
|
if minetest.check_player_privs(pname, {tp_admin=true}) then
|
||||||
minetest.chat_send_player(player, 'Teleporting to '..posx..','..posy..','..posz)
|
minetest.chat_send_player(player, 'Teleporting to '..posx..','..posy..','..posz)
|
||||||
pname:setpos(find_free_position_near(target_coords))
|
pname:set_pos(find_free_position_near(target_coords))
|
||||||
minetest.sound_play("whoosh", {pos = target_coords, gain = 0.5, max_hear_distance = 10})
|
minetest.sound_play("whoosh", {pos = target_coords, gain = 0.5, max_hear_distance = 10})
|
||||||
--parti2(target_coords)
|
--parti2(target_coords)
|
||||||
else
|
else
|
||||||
if minetest.check_player_privs(pname, {tp_tpc=true}) then
|
if minetest.check_player_privs(pname, {tp_tpc=true}) then
|
||||||
local protected = minetest.is_protected(target_coords,pname)
|
local protected = minetest.is_protected(target_coords,pname)
|
||||||
if protected then
|
if protected then
|
||||||
if not areas:canInteract(target_coords, player) then
|
if not areas:canInteract(target_coords, player) or not minetest.check_player_privs(pname, {areas = true}) then
|
||||||
local owners = areas:getNodeOwners(target_coords)
|
local owners = areas:getNodeOwners(target_coords)
|
||||||
minetest.chat_send_player(player,("Error: %s is protected by %s."):format(minetest.pos_to_string(target_coords),table.concat(owners, ", ")))
|
minetest.chat_send_player(player,("Error: %s is protected by %s."):format(minetest.pos_to_string(target_coords),table.concat(owners, ", ")))
|
||||||
return
|
return
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
minetest.chat_send_player(player, 'Teleporting to '..posx..','..posy..','..posz)
|
minetest.chat_send_player(player, 'Teleporting to '..posx..','..posy..','..posz)
|
||||||
pname:setpos(find_free_position_near(target_coords))
|
pname:set_pos(find_free_position_near(target_coords))
|
||||||
minetest.sound_play("whoosh", {pos = target_coords, gain = 0.5, max_hear_distance = 10})
|
minetest.sound_play("whoosh", {pos = target_coords, gain = 0.5, max_hear_distance = 10})
|
||||||
--parti2(target_coords)
|
--parti2(target_coords)
|
||||||
else
|
else
|
||||||
@ -164,6 +205,7 @@ local function tpc_send(player,coordinates)
|
|||||||
end
|
end
|
||||||
|
|
||||||
local function tpr_deny(name)
|
local function tpr_deny(name)
|
||||||
|
if minetest.check_player_privs(name, {tp_admin = true}) then return end
|
||||||
if tpr_list[name] then
|
if tpr_list[name] then
|
||||||
minetest.chat_send_player(tpr_list[name], 'Teleport request denied.')
|
minetest.chat_send_player(tpr_list[name], 'Teleport request denied.')
|
||||||
tpr_list[name] = nil
|
tpr_list[name] = nil
|
||||||
@ -177,7 +219,7 @@ end
|
|||||||
--Teleport Accept Systems
|
--Teleport Accept Systems
|
||||||
local function tpr_accept(name, param)
|
local function tpr_accept(name, param)
|
||||||
|
|
||||||
--Check to prevent constant teleporting.
|
-- Check to prevent constant teleporting.
|
||||||
if not tpr_list[name]
|
if not tpr_list[name]
|
||||||
and not tphr_list[name] then
|
and not tphr_list[name] then
|
||||||
minetest.chat_send_player(name, "Usage: /tpy allows you to accept teleport requests sent to you by other players.")
|
minetest.chat_send_player(name, "Usage: /tpy allows you to accept teleport requests sent to you by other players.")
|
||||||
@ -211,8 +253,8 @@ local function tpr_accept(name, param)
|
|||||||
minetest.chat_send_player(name2, "Request Accepted!")
|
minetest.chat_send_player(name2, "Request Accepted!")
|
||||||
minetest.chat_send_player(name, chatmsg)
|
minetest.chat_send_player(name, chatmsg)
|
||||||
|
|
||||||
local target_coords=source:getpos()
|
local target_coords=source:get_pos()
|
||||||
target:setpos(find_free_position_near(target_coords))
|
target:set_pos(find_free_position_near(target_coords))
|
||||||
minetest.sound_play("whoosh", {pos = target_coords, gain = 0.5, max_hear_distance = 10})
|
minetest.sound_play("whoosh", {pos = target_coords, gain = 0.5, max_hear_distance = 10})
|
||||||
--parti2(target_coords)
|
--parti2(target_coords)
|
||||||
end
|
end
|
||||||
@ -252,7 +294,7 @@ local function tpj(player,param)
|
|||||||
minetest.chat_send_player(player, "You cannot teleport to a location outside the map!")
|
minetest.chat_send_player(player, "You cannot teleport to a location outside the map!")
|
||||||
return
|
return
|
||||||
end
|
end
|
||||||
pname:setpos(find_free_position_near(target_coords))
|
pname:set_pos(find_free_position_near(target_coords))
|
||||||
minetest.sound_play("whoosh", {pos = target_coords, gain = 0.5, max_hear_distance = 10})
|
minetest.sound_play("whoosh", {pos = target_coords, gain = 0.5, max_hear_distance = 10})
|
||||||
--parti2(target_coords)
|
--parti2(target_coords)
|
||||||
end
|
end
|
||||||
@ -287,47 +329,48 @@ end
|
|||||||
minetest.register_chatcommand("tpr", {
|
minetest.register_chatcommand("tpr", {
|
||||||
description = "Request teleport to another player",
|
description = "Request teleport to another player",
|
||||||
params = "<playername> | leave playername empty to see help message",
|
params = "<playername> | leave playername empty to see help message",
|
||||||
privs = {interact=true},
|
privs = {interact = true, tp = true},
|
||||||
func = tpr_send
|
func = tpr_send
|
||||||
})
|
})
|
||||||
|
|
||||||
minetest.register_chatcommand("tphr", {
|
minetest.register_chatcommand("tphr", {
|
||||||
description = "Request player to teleport to you",
|
description = "Request player to teleport to you",
|
||||||
params = "<playername> | leave playername empty to see help message",
|
params = "<playername> | leave playername empty to see help message",
|
||||||
privs = {interact=true},
|
privs = {interact = true, tp = true},
|
||||||
func = tphr_send
|
func = tphr_send
|
||||||
})
|
})
|
||||||
|
|
||||||
minetest.register_chatcommand("tpc", {
|
minetest.register_chatcommand("tpc", {
|
||||||
description = "Teleport to coordinates",
|
description = "Teleport to coordinates",
|
||||||
params = "<coordinates> | leave coordinates empty to see help message",
|
params = "<coordinates> | leave coordinates empty to see help message",
|
||||||
privs = {interact=true,tp_tpc=true},
|
privs = {interact = true, tp_tpc = true},
|
||||||
func = tpc_send
|
func = tpc_send
|
||||||
})
|
})
|
||||||
|
|
||||||
minetest.register_chatcommand("tpj", {
|
minetest.register_chatcommand("tpj", {
|
||||||
description = "Teleport to relative position",
|
description = "Teleport to relative position",
|
||||||
params = "<axis> <distance> | leave empty to see help message",
|
params = "<axis> <distance> | leave empty to see help message",
|
||||||
privs = {interact=true,tp_tpc=true},
|
privs = {interact = true, tp_tpc = true},
|
||||||
func = tpj
|
func = tpj
|
||||||
})
|
})
|
||||||
|
|
||||||
minetest.register_chatcommand("tpe", {
|
minetest.register_chatcommand("tpe", {
|
||||||
description = "Evade Enemy",
|
description = "Evade Enemy",
|
||||||
privs = {interact=true,tp_tpc=true},
|
privs = {interact = true, tp_tpc = true},
|
||||||
func = tpe
|
func = tpe
|
||||||
})
|
})
|
||||||
|
|
||||||
minetest.register_chatcommand("tpy", {
|
minetest.register_chatcommand("tpy", {
|
||||||
description = "Accept teleport requests from another player",
|
description = "Accept teleport requests from another player",
|
||||||
privs = {interact=true},
|
privs = {interact = true, tp = true},
|
||||||
func = tpr_accept
|
func = tpr_accept
|
||||||
})
|
})
|
||||||
|
|
||||||
minetest.register_chatcommand("tpn", {
|
minetest.register_chatcommand("tpn", {
|
||||||
description = "Deny teleport requests from another player",
|
description = "Deny teleport requests from another player",
|
||||||
privs = {interact=true},
|
privs = {interact = true, tp = true},
|
||||||
func = tpr_deny
|
func = tpr_deny
|
||||||
})
|
})
|
||||||
|
|
||||||
|
-- Log
|
||||||
minetest.log("info", "[Teleport Request] TPS Teleport v" .. version .. " Loaded.")
|
minetest.log("info", "[Teleport Request] TPS Teleport v" .. version .. " Loaded.")
|
||||||
|
Loading…
Reference in New Issue
Block a user