1
0
mirror of https://github.com/Refactorio/RedMew.git synced 2024-12-14 10:13:13 +02:00
RedMew/map_gen/maps/crash_site/commands.lua

240 lines
7.3 KiB
Lua
Raw Normal View History

2019-01-17 01:55:19 +02:00
local Command = require 'utils.command'
local Rank = require 'features.rank_system'
2019-01-17 01:55:19 +02:00
local Task = require 'utils.task'
local Token = require 'utils.token'
local Server = require 'features.server'
local Popup = require 'features.gui.popup'
local Global = require 'utils.global'
local Ranks = require 'resources.ranks'
local Core = require 'utils.core'
2020-11-05 20:28:34 +02:00
local Color = require 'resources.color_presets'
2019-01-17 01:55:19 +02:00
local Public = {}
function Public.control(config)
2019-01-17 01:55:19 +02:00
local server_player = {name = '<server>', print = print}
local global_data = {restarting = nil}
Global.register(
global_data,
function(tbl)
global_data = tbl
end
)
local function double_print(str)
game.print(str)
print(str)
end
local callback
callback =
Token.register(
function(data)
if not global_data.restarting then
return
end
local state = data.state
if state == 0 then
Server.start_scenario(data.scenario_name)
double_print('restarting')
global_data.restarting = nil
2019-01-17 01:55:19 +02:00
return
elseif state == 1 then
local time_string = Core.format_time(game.ticks_played)
local discord_crashsite_role = '<@&762441731194748958>' -- @crash_site
--local discord_crashsite_role = '<@&593534612051984431>' -- @test
Server.to_discord_raw(discord_crashsite_role .. ' **Crash Site has just restarted! Previous map lasted: ' .. time_string .. '!**')
2020-10-29 18:38:14 +02:00
local unix_time = Server.get_current_time()
local game_time = game.ticks_played
Server.set_data('crash_site_data', tostring(unix_time), game_time) -- Store the server unix time as key and total game ticks in the Scenario Data
2020-10-29 18:38:14 +02:00
2019-01-17 01:55:19 +02:00
Popup.all('\nServer restarting!\nInitiated by ' .. data.name .. '\n')
end
double_print(state)
data.state = state - 1
Task.set_timeout_in_ticks(60, callback, data)
end
)
local static_entities_to_check = {
'spitter-spawner','biter-spawner',
'small-worm-turret', 'medium-worm-turret','big-worm-turret', 'behemoth-worm-turret',
'gun-turret', 'laser-turret', 'artillery-turret', 'flamethrower-turret'
}
local biter_entities_to_check = {
'small-spitter', 'medium-spitter', 'big-spitter', 'behemoth-spitter',
'small-biter', 'medium-biter', 'big-biter', 'behemoth-biter'
}
local function map_cleared(player)
player = player or server_player
local get_entity_count = game.forces["enemy"].get_entity_count
-- Check how many of each turrets, worms and spawners are left and return false if there are any of each left.
for i = 1, #static_entities_to_check do
local name = static_entities_to_check[i]
if get_entity_count(name) > 0 then
player.print('All enemy spawners, worms, buildings, biters and spitters must be cleared before crashsite can be restarted.')
return false
end
end
-- Count all the remaining biters and spitters
local biter_total = 0;
for i = 1, #biter_entities_to_check do
local name = biter_entities_to_check[i]
biter_total = biter_total + get_entity_count(name)
end
-- Return false if more than 20 left. Players have had problems finding the last few biters so set to a reasonable value.
if biter_total > 20 then
player.print('All enemy spawners, worms, buildings are dead. Crashsite can be restarted when all biters and spitters are killed.')
return false
end
return true
end
2019-03-06 23:35:38 +02:00
local function restart(args, player)
player = player or server_player
local sanitised_scenario = args.scenario_name
2019-03-06 23:35:38 +02:00
if global_data.restarting then
player.print('Restart already in progress')
return
end
if player ~= server_player and Rank.less_than(player.name, Ranks.admin) then
-- Check enemy count
if not map_cleared(player) then
return
end
-- Limit the ability of non-admins to call the restart function with arguments to change the scenario
-- If not an admin, restart the same scenario always
sanitised_scenario = config.scenario_name
end
2019-03-06 23:35:38 +02:00
global_data.restarting = true
double_print('#################-Attention-#################')
double_print('Server restart initiated by ' .. player.name)
double_print('###########################################')
for _, p in pairs(game.players) do
if p.admin then
p.print('Abort restart with /abort')
2019-03-06 23:35:38 +02:00
end
end
print('Abort restart with /abort')
Task.set_timeout_in_ticks(60, callback, {name = player.name, scenario_name = sanitised_scenario, state = 10})
2019-03-06 23:35:38 +02:00
end
local function abort(_, player)
player = player or server_player
if global_data.restarting then
global_data.restarting = nil
double_print('Restart aborted by ' .. player.name)
else
player.print('Cannot abort a restart that is not in progress.')
end
end
local function spy(args, player)
local player_name = player.name
local inv = player.get_inventory(defines.inventory.character_main)
2020-11-05 20:28:34 +02:00
local coin_count = inv.get_item_count("coin")
2020-11-04 18:24:14 +02:00
-- Parse the values from the location string
-- {location = "[gps=-110,-17,redmew]"}
local location_string = args.location
local coords = {}
2020-11-06 20:56:42 +02:00
2020-11-04 18:24:14 +02:00
for m in string.gmatch( location_string, "%-?%d+" ) do
table.insert(coords, tonumber(m))
end
-- Do some checks then reveal the pinged map and remove 1000 coins
if #coords < 2 then
player.print({'command_description.crash_site_spy_invalid'}, Color.fail)
return
elseif coin_count < 1000 then
player.print({'command_description.crash_site_spy_funds'}, Color.fail)
return
else
local xpos=coords[1]
local ypos=coords[2]
-- reveal 3x3 chunks centred on chunk containing pinged location
player.force.chart(player.surface, {{xpos-32, ypos-32}, {xpos+32, ypos+32}})
game.print({'command_description.crash_site_spy_success', player_name, xpos,ypos}, Color.success)
2020-11-05 20:28:34 +02:00
inv.remove({name = "coin", count = 1000})
end
end
2019-03-06 23:35:38 +02:00
Command.add(
'crash-site-restart-abort',
{
description = {'command_description.crash_site_restart_abort'},
required_rank = Ranks.admin,
allowed_by_server = true
},
abort
)
2019-01-17 01:55:19 +02:00
Command.add(
2019-03-06 23:35:38 +02:00
'abort',
2019-01-17 01:55:19 +02:00
{
description = {'command_description.crash_site_restart_abort'},
required_rank = Ranks.admin,
2019-01-17 01:55:19 +02:00
allowed_by_server = true
},
2019-03-06 23:35:38 +02:00
abort
2019-01-17 01:55:19 +02:00
)
local default_name = config.scenario_name or 'crashsite'
Command.add(
'crash-site-restart',
{
description = {'command_description.crash_site_restart'},
arguments = {'scenario_name'},
default_values = {scenario_name = default_name},
required_rank = Ranks.admin,
allowed_by_server = true
},
restart
)
Command.add(
'restart',
{
description = {'command_description.crash_site_restart'},
arguments = {'scenario_name'},
default_values = {scenario_name = default_name},
required_rank = Ranks.auto_trusted,
allowed_by_server = true
},
restart
)
Command.add(
'spy',
{
description = {'command_description.crash_site_spy'},
arguments = {'location'},
2020-11-05 20:28:34 +02:00
capture_excess_arguments = true,
required_rank = Ranks.guest,
allowed_by_server = false
},
spy
)
end
return Public