123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202 |
- if not minetest.global_exists("command_tokens") then command_tokens = {} end
- command_tokens.jail = command_tokens.jail or {}
- local formspec = "size[4.1,2.0]" ..
- default.gui_bg ..
- default.gui_bg_img ..
- default.gui_slots ..
- "label[0,0;Type name of trespasser:]" ..
- "field[0.30,0.75;4,1;PLAYERNAME;;]" ..
- "button_exit[0,1.30;2,1;OK;Confirm]" ..
- "button_exit[2,1.30;2,1;CANCEL;Cancel]" ..
- "field_close_on_enter[PLAYERNAME;true]"
- -- Called when the player uses a jail token.
- command_tokens.jail.jail_player = function(itemstack, user, pointed)
- if user and user:is_player() then
- local pname = user:get_player_name()
- if pointed.type == "object" then
- local object = pointed.ref
- if object and object:is_player() then
- local success = command_tokens.jail.execute(
- pname, object:get_player_name())
- if success then
- itemstack:take_item()
- return itemstack
- end
- else
- minetest.chat_send_player(pname, "# Server: Target is not a player!")
- end
- else
- minetest.show_formspec(pname, "command_tokens:jail", formspec)
- end
- end
- end
- local function is_valid_target(name, target)
- if minetest.get_player_by_name(target) then
- if not minetest.check_player_privs(target, {ignore_jail_token=true}) then
- return true
- end
- end
- return false
- end
- command_tokens.jail.execute = function(player, target)
- player = rename.grn(player)
- target = rename.grn(target)
- if not minetest.get_player_by_name(target) then
- minetest.chat_send_player(player, "# Server: Law enforcement couldn't find player <" .. rename.gpn(target) .. ">.")
- return
- end
- local pref = minetest.get_player_by_name(player)
- local p1 = pref:get_pos()
- local p2 = minetest.get_player_by_name(target):get_pos()
- if not rc.same_realm(p1, p2) then
- minetest.chat_send_player(player, "# Server: Target is in another dimension!")
- return
- end
- local self_arrest = false
- if player == target then
- --minetest.chat_send_player(player, "# Server: Law-enforcement does not arrest self-trespassers.")
- --return
- self_arrest = true
- end
-
- -- Allow self-arrest.
- if player ~= target then
- if not is_valid_target(player, target) then
- minetest.chat_send_player(player, "# Server: Player <" .. rename.gpn(target) .. "> is immune to accusations of trespassing.")
- return
- end
- end
-
- local ent = minetest.get_player_by_name(target)
- -- 'ent' should always be valid.
- local pos = ent:get_pos()
- local landowner = false
- -- If position is protected, and player has access, then player owns the land.
- if minetest.test_protection(pos, "") and
- not minetest.test_protection(pos, player) then
- landowner = true
- end
-
- if not city_block:in_city(pos) then
- minetest.chat_send_player(player, "# Server: Trespasser is not within city boundaries.")
- return
- end
- if not landowner then
- minetest.chat_send_player(player, "# Server: Player <" .. rename.gpn(target) .. "> is not in territory owned by you.")
- return
- end
- -- Ensure player has a jail token in their inventory.
- do
- local pinv = pref:get_inventory()
- local stack = ItemStack("command_tokens:jail_player")
- if not pinv:contains_item("main", stack) then
- return
- end
- end
-
- -- Get player out of cart.
- local kicktype = default.detach_player_if_attached(ent)
- if kicktype == "cart" then
- minetest.chat_send_all("# Server: Someone threw <" .. rename.gpn(target) .. "> out of a minecart.")
- elseif kicktype == "boat" then
- minetest.chat_send_all("# Server: Boater <" .. rename.gpn(target) .. "> was tossed overboard.")
- elseif kicktype == "sled" then
- minetest.chat_send_all("# Server: Someone kicked <" .. rename.gpn(target) .. "> off a sled.")
- elseif kicktype == "bed" then
- local formspec = "size[8,15;true]" ..
- "bgcolor[#080808BB; true]" ..
- "button_exit[2,12;4,0.75;leave;Ok]" ..
- "label[2.7,11;You were kicked out of bed!]"
- minetest.show_formspec(target, "command_tokens:bedkicked", formspec)
- minetest.chat_send_all("# Server: <" .. rename.gpn(target) .. "> was rudely kicked out of bed.")
- end
- local jaildelay = 0
- if kicktype ~= "" then
- jaildelay = 1
- end
- -- Not sure why the delay is necessary, but it may have to do with lag.
- minetest.after(jaildelay, function()
- if not default.player_attached[target] then
- local bcb = function()
- if self_arrest then
- minetest.chat_send_all("# Server: Player <" .. rename.gpn(target) .. "> committed self-arrest.")
- else
- minetest.chat_send_all("# Server: Player <" .. rename.gpn(target) .. "> sent to jail for trespassing on <" .. rename.gpn(player) .. ">'s land.")
- end
- end
- if not jail.go_to_jail(minetest.get_player_by_name(target), bcb) then
- minetest.chat_send_player(player, "# Server: There's no law enforcement to speak of!")
- end
- else
- minetest.chat_send_player(player, "# Server: Player <" .. rename.gpn(target) .. "> could not be detached!")
- end
- end)
-
- -- Caller must consume token.
- return true
- end
- command_tokens.jail_on_receive_fields = function(player, formname, fields)
- if formname == "command_tokens:jail" then
- if fields.key_enter_field == "PLAYERNAME" or fields.OK then
- local pname = player:get_player_name()
- local success = command_tokens.jail.execute(
- pname, fields.PLAYERNAME or "")
- if success then
- local inv = player:get_inventory()
- if inv then
- inv:remove_item("main", "command_tokens:jail_player")
- end
- end
- end
- end
- end
- -- Register once only.
- if not command_tokens.jail.registered then
- minetest.register_privilege("ignore_jail_token", {
- description = "Player cannot be sent to jail.",
- give_to_singleplayer = false,
- })
- minetest.register_on_player_receive_fields(function(...)
- return command_tokens.jail_on_receive_fields(...)
- end)
- command_tokens.jail.registered = true
- end
|