diff --git a/Content.Server/_DV/Administration/Commands/FreezeCommands.cs b/Content.Server/_DV/Administration/Commands/FreezeCommands.cs new file mode 100644 index 0000000000..55ae6bfa0d --- /dev/null +++ b/Content.Server/_DV/Administration/Commands/FreezeCommands.cs @@ -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(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(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"); + } +} diff --git a/Resources/Locale/en-US/_DV/administration/admin-qol.ftl b/Resources/Locale/en-US/_DV/administration/admin-qol.ftl index 9bfabcca1f..ac406f8c81 100644 --- a/Resources/Locale/en-US/_DV/administration/admin-qol.ftl +++ b/Resources/Locale/en-US/_DV/administration/admin-qol.ftl @@ -10,6 +10,18 @@ cmd-getping-desc = Prints the specified player's current ping cmd-getping-help = getping cmd-getping-err = Unable to find specified player +cmd-freeze-desc = Freezes and mutes the specified player +cmd-freeze-help = freeze [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 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")