feat: freeze and unfreeze commands

This commit is contained in:
DisposableCrewmember42 2026-04-20 20:28:05 +02:00
parent 84af3d71eb
commit 13f570e8e5
2 changed files with 99 additions and 0 deletions

View File

@ -0,0 +1,87 @@
using Content.Server.Administration;
using Content.Shared.Administration;
using Robust.Server.Player;
using Robust.Shared.Console;
namespace Content.Server._DV.Administration.Commands;
// Keeping these as separate commands instead of toggling in one command so it's harder to unfreeze someone by mistake
[AdminCommand(AdminFlags.Admin)]
public sealed class FreezeCommand : LocalizedEntityCommands
{
[Dependency] private readonly IPlayerManager _player = default!;
[Dependency] private readonly AdminFrozenSystem _frozen = default!;
[Dependency] private readonly IEntityManager _entity = default!;
public override string Command => "freeze";
public override void Execute(IConsoleShell shell, string argStr, string[] args)
{
foreach (var username in args)
{
if (!_player.TryGetSessionByUsername(username, out var session))
{
shell.WriteError(Loc.GetString("freeze-cmds-err-not-found", ("username", username)));
continue;
}
if (session.AttachedEntity is { } uid)
{
if (!_entity.HasComponent<AdminFrozenComponent>(uid))
{
_frozen.FreezeAndMute(uid);
shell.WriteLine(Loc.GetString("cmd-freeze-success", ("username", username)));
}
else
{
shell.WriteError(Loc.GetString("cmd-freeze-err-already-frozen", ("username", username)));
}
}
}
}
public override CompletionResult GetCompletion(IConsoleShell shell, string[] args)
{
return CompletionResult.FromHintOptions(CompletionHelper.SessionNames(), "username");
}
}
[AdminCommand(AdminFlags.Admin)]
public sealed class UnfreezeCommand : LocalizedEntityCommands
{
[Dependency] private readonly IPlayerManager _player = default!;
[Dependency] private readonly IEntityManager _entity = default!;
public override string Command => "unfreeze";
public override void Execute(IConsoleShell shell, string argStr, string[] args)
{
foreach (var username in args)
{
if (!_player.TryGetSessionByUsername(username, out var session))
{
shell.WriteError(Loc.GetString("freeze-cmds-err-not-found", ("username", username)));
continue;
}
if (session.AttachedEntity is { } uid)
{
if (_entity.RemoveComponent<AdminFrozenComponent>(uid))
{
shell.WriteLine(Loc.GetString("cmd-unfreeze-success", ("username", username)));
}
else
{
shell.WriteError(Loc.GetString("cmd-unfreeze-err-not-frozen", ("username", username)));
}
}
}
}
public override CompletionResult GetCompletion(IConsoleShell shell, string[] args)
{
return CompletionResult.FromHintOptions(CompletionHelper.SessionNames(), "username");
}
}

View File

@ -10,6 +10,18 @@ cmd-getping-desc = Prints the specified player's current ping
cmd-getping-help = getping <username>
cmd-getping-err = Unable to find specified player
cmd-freeze-desc = Freezes and mutes the specified player
cmd-freeze-help = freeze <username> [username 2] [username 3] ...
cmd-freeze-success = Froze and muted {$username}.
cmd-freeze-err-already-frozen = {$username} is already frozen.
cmd-unfreeze-desc = Unfreezes and unmutes the specified player
cmd-unfreeze-help = unfreeze <username> [username 2] [username 3] ...
cmd-unfreeze-success = Unfroze and unmuted {$username}.
cmd-unfreeze-err-not-frozen = {$username} isn't frozen.
freeze-cmds-err-not-found = Unable to find player {$username}.
# UI
ui-options-admin-player-tab-mark-ghosted = Mark ghosted players
ui-options-admin-player-tab-mark-ghosted-tooltip = Ghosts will have a "(G)" added to their character names (e.g. "(G) Glip-Glub")