2018-04-06 20:58:50 +01:00
local Event = require " utils.event "
2018-06-02 17:17:54 +02:00
local UserGroups = require " user_groups "
2018-06-02 18:16:04 +02:00
local Utils = require " utils.utils "
2017-07-08 22:24:24 +02:00
2017-12-19 18:10:55 +01:00
function allowed_to_nuke ( player )
2017-12-25 23:00:24 +01:00
if type ( player ) == " table " then
2018-06-02 17:17:54 +02:00
return player.admin or UserGroups.is_regular ( player.name ) or ( ( player.online_time / 216000 ) > global.scenario . config.nuke_min_time_hours )
2017-12-28 23:03:50 +01:00
elseif type ( player ) == " number " then
2017-12-25 23:00:24 +01:00
return allowed_to_nuke ( game.players [ player ] )
end
2017-07-08 22:24:24 +02:00
end
local function ammo_changed ( event )
local player = game.players [ event.player_index ]
if allowed_to_nuke ( player ) then return end
2017-07-23 04:39:02 +02:00
local nukes = player.remove_item ( { name = " atomic-bomb " , count = 1000 } )
2017-07-08 22:24:24 +02:00
if nukes > 0 then
game.print ( player.name .. " tried to use a nuke, but instead dropped it on his foot. " )
2018-06-07 23:50:31 +01:00
local character = player.character
if character and character.valid then
for _ , p in ipairs ( game.connected_players ) do
if p ~= player then
p.add_custom_alert ( character , { type = ' item ' , name = ' atomic-bomb ' } , player.name , true )
end
end
end
2017-07-08 22:24:24 +02:00
player.character . health = 0
end
end
2017-07-23 04:39:02 +02:00
local function on_player_deconstructed_area ( event )
local player = game.players [ event.player_index ]
if allowed_to_nuke ( player ) then return end
2018-06-07 23:50:31 +01:00
player.remove_item ( { name = " deconstruction-planner " , count = 1000 } )
2017-11-09 20:28:56 +01:00
--Make them think they arent noticed
2018-06-03 14:24:33 +02:00
Utils.print_except ( player.name .. " tried to deconstruct something, but instead deconstructed themself. " , player )
2017-12-25 23:00:24 +01:00
player.print ( " Only regulars can mark things for deconstruction, if you want to deconstruct something you may ask an admin to promote you. " )
2017-11-09 20:28:56 +01:00
2018-06-07 23:50:31 +01:00
local character = player.character
if character and character.valid then
for _ , p in ipairs ( game.connected_players ) do
if p ~= player then
p.add_custom_alert ( character , { type = ' item ' , name = ' deconstruction-planner ' } , player.name , true )
end
end
end
character.health = 0
2018-06-24 23:31:08 +01:00
local area = event.area
local left_top , right_bottom = area.left_top , area.right_bottom
if left_top.x == right_bottom.x and left_top.y == right_bottom.y then
return
end
local entities = player.surface . find_entities_filtered { area = area , force = player.force }
2017-11-09 20:05:37 +01:00
if # entities > 1000 then
2018-06-02 18:16:04 +02:00
Utils.print_admins ( " Warning! " .. player.name .. " just tried to deconstruct " .. tostring ( # entities ) .. " entities! " )
2017-11-09 20:05:37 +01:00
end
for _ , entity in pairs ( entities ) do
2017-11-09 19:52:55 +01:00
if entity.valid and entity.to_be_deconstructed ( game.players [ event.player_index ] . force ) then
2017-09-28 01:07:38 +02:00
entity.cancel_deconstruction ( game.players [ event.player_index ] . force )
end
2017-07-23 04:39:02 +02:00
end
end
2017-12-27 01:33:29 +01:00
local function item_not_sanctioned ( item )
local name = item.name
return (
2018-06-02 17:17:54 +02:00
name : find ( " capsule " ) or
name == " cliff-explosives " or
name == " raw-fish " or
2018-02-08 08:55:26 +01:00
name == " discharge-defense-remote "
2017-12-27 01:33:29 +01:00
)
end
2018-05-16 10:58:55 +01:00
local function entity_allowed_to_bomb ( entity )
2018-02-08 08:55:26 +01:00
local name = entity.name
return (
name : find ( " turret " ) or
name : find ( " rail " ) or
2018-06-07 21:06:48 +01:00
name : find ( " ghost " ) or
2018-02-08 08:55:26 +01:00
name == " player " or
name == " stone-wall " or
entity.type == " electric-pole "
)
end
2017-12-25 23:00:24 +01:00
global.players_warned = { }
local function on_capsule_used ( event )
2018-06-08 00:24:08 +01:00
local item = event.item
2017-12-25 23:00:24 +01:00
local player = game.players [ event.player_index ]
2018-06-08 00:24:08 +01:00
if not player or not player.valid then
return
end
if item.name == ' artillery-targeting-remote ' then
player.surface . create_entity { name = ' flying-text ' , text = player.name , color = player.color , position = event.position }
end
if item_not_sanctioned ( item ) then return end
2017-12-25 23:00:24 +01:00
if ( not allowed_to_nuke ( player ) ) then
local area = { { event.position . x - 5 , event.position . y - 5 } , { event.position . x + 5 , event.position . y + 5 } }
2018-01-07 11:14:36 +01:00
local count = 0
local entities = player.surface . find_entities_filtered { force = player.force , area = area }
2018-06-02 17:17:54 +02:00
for _ , e in pairs ( entities ) do
if not entity_allowed_to_bomb ( e ) then count = count + 1 end
2018-01-07 11:14:36 +01:00
end
2018-02-08 08:55:26 +01:00
if count > 8 then
2017-12-25 23:00:24 +01:00
if global.players_warned [ event.player_index ] then
2017-12-26 00:09:32 +01:00
game.ban_player ( player , string.format ( " Damaged %i entities with %s. This action was performed automatically. If you want to contest this ban please visit redmew.com/discord. " , count , event.item . name ) )
2017-12-25 23:00:24 +01:00
else
global.players_warned [ event.player_index ] = true
game.kick_player ( player , string.format ( " Damaged %i entities with %s -Antigrief " , count , event.item . name ) )
end
end
2017-12-19 18:10:55 +01:00
end
end
2018-04-06 20:58:50 +01:00
Event.add ( defines.events . on_player_ammo_inventory_changed , ammo_changed )
Event.add ( defines.events . on_player_deconstructed_area , on_player_deconstructed_area )
--Event.add(defines.events.on_player_mined_entity, on_player_mined_item)
Event.add ( defines.events . on_player_used_capsule , on_capsule_used )