Files
tbd-station-14/Content.Server/Shuttles/DockCommand.cs
2023-03-23 16:10:49 +11:00

53 lines
1.6 KiB
C#

using Content.Server.Administration;
using Content.Server.Shuttles.Components;
using Content.Server.Shuttles.Systems;
using Content.Shared.Administration;
using Robust.Shared.Console;
namespace Content.Server.Shuttles;
[AdminCommand(AdminFlags.Mapping)]
public sealed class DockCommand : IConsoleCommand
{
[Dependency] private readonly IEntityManager _entManager = default!;
public string Command => "dock";
public string Description => $"Attempts to dock 2 airlocks together. Doesn't check whether it is valid.";
public string Help => $"{Command} <airlock entityuid1> <airlock entityuid2>";
public void Execute(IConsoleShell shell, string argStr, string[] args)
{
if (args.Length != 2)
{
shell.WriteError($"Invalid number of args supplied");
return;
}
if (!EntityUid.TryParse(args[0], out var airlock1))
{
shell.WriteError($"Invalid EntityUid {args[0]}");
return;
}
if (!EntityUid.TryParse(args[1], out var airlock2))
{
shell.WriteError($"Invalid EntityUid {args[1]}");
return;
}
if (!_entManager.TryGetComponent(airlock1, out DockingComponent? dock1))
{
shell.WriteError($"No docking component found on {airlock1}");
return;
}
if (!_entManager.TryGetComponent(airlock2, out DockingComponent? dock2))
{
shell.WriteError($"No docking component found on {airlock2}");
return;
}
var dockSystem = _entManager.System<DockingSystem>();
dockSystem.Dock(airlock1, dock1, airlock2, dock2);
}
}