mirror of
https://github.com/Refactorio/RedMew.git
synced 2024-12-12 10:04:40 +02:00
5beaee7144
Add logging to many commands, admin chat notices for a few commands Overhaul print_admins
160 lines
6.1 KiB
Lua
160 lines
6.1 KiB
Lua
local Event = require "utils.event"
|
|
local UserGroups = require "features.user_groups"
|
|
local Utils = require "utils.utils"
|
|
local Game = require "utils.game"
|
|
|
|
local function allowed_to_nuke(player)
|
|
if type(player) == "table" then
|
|
return player.admin or UserGroups.is_regular(player.name) or ((player.online_time / 216000) > global.scenario.config.nuke_control.nuke_min_time_hours)
|
|
elseif type(player) == "number" then
|
|
return allowed_to_nuke(Game.get_player_by_index(player))
|
|
end
|
|
end
|
|
|
|
local function ammo_changed(event)
|
|
local player = Game.get_player_by_index(event.player_index)
|
|
if allowed_to_nuke(player) then
|
|
return
|
|
end
|
|
local nukes = player.remove_item({name = "atomic-bomb", count = 1000})
|
|
if nukes > 0 then
|
|
game.print(player.name .. " tried to use a nuke, but instead dropped it on his foot.")
|
|
|
|
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
|
|
player.character.health = 0
|
|
end
|
|
end
|
|
|
|
local function on_player_deconstructed_area(event)
|
|
local player = Game.get_player_by_index(event.player_index)
|
|
if allowed_to_nuke(player) then
|
|
return
|
|
end
|
|
player.remove_item({name = "deconstruction-planner", count = 1000})
|
|
|
|
--Make them think they arent noticed
|
|
Utils.print_except(player.name .. " tried to deconstruct something, but instead deconstructed themself.", player)
|
|
player.print("Only regulars can mark things for deconstruction, if you want to deconstruct something you may ask an admin to promote you.")
|
|
|
|
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
|
|
|
|
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}
|
|
if #entities > 1000 then
|
|
Utils.print_admins("Warning! " .. player.name .. " just tried to deconstruct " .. tostring(#entities) .. " entities!", false)
|
|
end
|
|
for _, entity in pairs(entities) do
|
|
if entity.valid and entity.to_be_deconstructed(Game.get_player_by_index(event.player_index).force) then
|
|
entity.cancel_deconstruction(Game.get_player_by_index(event.player_index).force)
|
|
end
|
|
end
|
|
end
|
|
|
|
local function item_not_sanctioned(item)
|
|
local name = item.name
|
|
return (name:find("capsule") or name == "cliff-explosives" or name == "raw-fish" or name == "discharge-defense-remote")
|
|
end
|
|
|
|
global.entities_allowed_to_bomb = {
|
|
["stone-wall"] = true,
|
|
["transport-belt"] = true,
|
|
["fast-transport-belt"] = true,
|
|
["express-transport-belt"] = true,
|
|
["construction-robot"] = true,
|
|
["player"] = true,
|
|
["gun-turret"] = true,
|
|
["laser-turret"] = true,
|
|
["flamethrower-turret"] = true,
|
|
["rail"] = true,
|
|
["rail-chain-signal"] = true,
|
|
["rail-signal"] = true,
|
|
["tile-ghost"] = true,
|
|
["entity-ghost"] = true,
|
|
["gate"] = true,
|
|
["electric-pole"] = true,
|
|
["small-electric-pole"] = true,
|
|
["medium-electric-pole"] = true,
|
|
["big-electric-pole"] = true,
|
|
["logistic-robot"] = true,
|
|
["defender"] = true,
|
|
["destroyer"] = true,
|
|
["distractor"] = true
|
|
}
|
|
|
|
local function entity_allowed_to_bomb(entity)
|
|
return global.entities_allowed_to_bomb[entity.name]
|
|
end
|
|
global.players_warned = {}
|
|
local function on_capsule_used(event)
|
|
local item = event.item
|
|
local player = Game.get_player_by_index(event.player_index)
|
|
|
|
if not player or not player.valid or (global.scenario.config.nuke_control.enable_autokick and global.scenario.config.nuke_control.enable_autoban) 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
|
|
|
|
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}}
|
|
local count = 0
|
|
local entities = player.surface.find_entities_filtered {force = player.force, area = area}
|
|
for _, e in pairs(entities) do
|
|
if not entity_allowed_to_bomb(e) then
|
|
count = count + 1
|
|
end
|
|
end
|
|
if count > 8 then
|
|
if global.players_warned[event.player_index] then
|
|
if global.scenario.config.nuke_control.enable_autokick then
|
|
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))
|
|
end
|
|
else
|
|
global.players_warned[event.player_index] = true
|
|
if global.scenario.config.nuke_control.enable_autoban then
|
|
game.print(player, string.format("Damaged %i entities with %s -Antigrief", count, event.item.name))
|
|
end
|
|
end
|
|
end
|
|
end
|
|
end
|
|
|
|
local function on_player_joined(event)
|
|
local player = game.players[event.player_index]
|
|
if string.match(player.name, "^[Ili1|]+$") then
|
|
game.ban_player(player) --No reason given, to not give them any hints to change their name
|
|
end
|
|
end
|
|
|
|
Event.add(defines.events.on_player_ammo_inventory_changed, ammo_changed)
|
|
Event.add(defines.events.on_player_joined_game, on_player_joined)
|
|
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)
|