feat: freeze and unfreeze commands
This commit is contained in:
parent
84af3d71eb
commit
13f570e8e5
|
|
@ -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");
|
||||
}
|
||||
}
|
||||
|
|
@ -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")
|
||||
|
|
|
|||
Loading…
Reference in New Issue