| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137 |
- using System.Linq;
- using Content.Server.Administration.Managers;
- using Content.Shared.Administration;
- using Content.Shared.CCVar;
- using Content.Shared.Database;
- using Robust.Server.Player;
- using Robust.Shared.Configuration;
- using Robust.Shared.Console;
- namespace Content.Server.Administration.Commands;
- [AdminCommand(AdminFlags.Ban)]
- public sealed class BanCommand : LocalizedCommands
- {
- [Dependency] private readonly IPlayerLocator _locator = default!;
- [Dependency] private readonly IBanManager _bans = default!;
- [Dependency] private readonly IConfigurationManager _cfg = default!;
- [Dependency] private readonly IPlayerManager _playerManager = default!;
- [Dependency] private readonly ILogManager _logManager = default!;
- public override string Command => "ban";
- public override async void Execute(IConsoleShell shell, string argStr, string[] args)
- {
- string target;
- string reason;
- uint minutes;
- if (!Enum.TryParse(_cfg.GetCVar(CCVars.ServerBanDefaultSeverity), out NoteSeverity severity))
- {
- _logManager.GetSawmill("admin.server_ban")
- .Warning("Server ban severity could not be parsed from config! Defaulting to high.");
- severity = NoteSeverity.High;
- }
- switch (args.Length)
- {
- case 2:
- target = args[0];
- reason = args[1];
- minutes = 0;
- break;
- case 3:
- target = args[0];
- reason = args[1];
- if (!uint.TryParse(args[2], out minutes))
- {
- shell.WriteLine(Loc.GetString("cmd-ban-invalid-minutes", ("minutes", args[2])));
- shell.WriteLine(Help);
- return;
- }
- break;
- case 4:
- target = args[0];
- reason = args[1];
- if (!uint.TryParse(args[2], out minutes))
- {
- shell.WriteLine(Loc.GetString("cmd-ban-invalid-minutes", ("minutes", args[2])));
- shell.WriteLine(Help);
- return;
- }
- if (!Enum.TryParse(args[3], ignoreCase: true, out severity))
- {
- shell.WriteLine(Loc.GetString("cmd-ban-invalid-severity", ("severity", args[3])));
- shell.WriteLine(Help);
- return;
- }
- break;
- default:
- shell.WriteLine(Loc.GetString("cmd-ban-invalid-arguments"));
- shell.WriteLine(Help);
- return;
- }
- var located = await _locator.LookupIdByNameOrIdAsync(target);
- var player = shell.Player;
- if (located == null)
- {
- shell.WriteError(Loc.GetString("cmd-ban-player"));
- return;
- }
- var targetUid = located.UserId;
- var targetHWid = located.LastHWId;
- _bans.CreateServerBan(targetUid, target, player?.UserId, null, targetHWid, minutes, severity, reason);
- }
- public override CompletionResult GetCompletion(IConsoleShell shell, string[] args)
- {
- if (args.Length == 1)
- {
- var options = _playerManager.Sessions.Select(c => c.Name).OrderBy(c => c).ToArray();
- return CompletionResult.FromHintOptions(options, LocalizationManager.GetString("cmd-ban-hint"));
- }
- if (args.Length == 2)
- return CompletionResult.FromHint(LocalizationManager.GetString("cmd-ban-hint-reason"));
- if (args.Length == 3)
- {
- var durations = new CompletionOption[]
- {
- new("0", LocalizationManager.GetString("cmd-ban-hint-duration-1")),
- new("1440", LocalizationManager.GetString("cmd-ban-hint-duration-2")),
- new("4320", LocalizationManager.GetString("cmd-ban-hint-duration-3")),
- new("10080", LocalizationManager.GetString("cmd-ban-hint-duration-4")),
- new("20160", LocalizationManager.GetString("cmd-ban-hint-duration-5")),
- new("43800", LocalizationManager.GetString("cmd-ban-hint-duration-6")),
- };
- return CompletionResult.FromHintOptions(durations, LocalizationManager.GetString("cmd-ban-hint-duration"));
- }
- if (args.Length == 4)
- {
- var severities = new CompletionOption[]
- {
- new("none", Loc.GetString("admin-note-editor-severity-none")),
- new("minor", Loc.GetString("admin-note-editor-severity-low")),
- new("medium", Loc.GetString("admin-note-editor-severity-medium")),
- new("high", Loc.GetString("admin-note-editor-severity-high")),
- };
- return CompletionResult.FromHintOptions(severities, Loc.GetString("cmd-ban-hint-severity"));
- }
- return CompletionResult.Empty;
- }
- }
|