Better notes and bans (#14228)
Co-authored-by: Chief-Engineer <119664036+Chief-Engineer@users.noreply.github.com>
This commit is contained in:
@@ -1,19 +1,20 @@
|
||||
using System.Linq;
|
||||
using System.Linq;
|
||||
using System.Text;
|
||||
using Content.Server.Administration.Managers;
|
||||
using Content.Shared.Administration;
|
||||
using Content.Shared.CCVar;
|
||||
using Content.Shared.Database;
|
||||
using Content.Shared.Roles;
|
||||
using Robust.Server.Player;
|
||||
using Robust.Shared.Configuration;
|
||||
using Robust.Shared.Console;
|
||||
using Robust.Shared.Prototypes;
|
||||
using Serilog;
|
||||
|
||||
namespace Content.Server.Administration.Commands;
|
||||
|
||||
[AdminCommand(AdminFlags.Ban)]
|
||||
public sealed class RoleBanCommand : IConsoleCommand
|
||||
{
|
||||
[Dependency] private readonly IPlayerLocator _locator = default!;
|
||||
[Dependency] private readonly RoleBanManager _bans = default!;
|
||||
[Dependency] private readonly IBanManager _bans = default!;
|
||||
[Dependency] private readonly IConfigurationManager _cfg = default!;
|
||||
|
||||
public string Command => "roleban";
|
||||
public string Description => Loc.GetString("cmd-roleban-desc");
|
||||
@@ -25,6 +26,11 @@ public sealed class RoleBanCommand : IConsoleCommand
|
||||
string job;
|
||||
string reason;
|
||||
uint minutes;
|
||||
if (!Enum.TryParse(_cfg.GetCVar(CCVars.RoleBanDefaultSeverity), out NoteSeverity severity))
|
||||
{
|
||||
Logger.WarningS("admin.role_ban", "Role ban severity could not be parsed from config! Defaulting to medium.");
|
||||
severity = NoteSeverity.Medium;
|
||||
}
|
||||
|
||||
switch (args.Length)
|
||||
{
|
||||
@@ -45,6 +51,24 @@ public sealed class RoleBanCommand : IConsoleCommand
|
||||
return;
|
||||
}
|
||||
|
||||
break;
|
||||
case 5:
|
||||
target = args[0];
|
||||
job = args[1];
|
||||
reason = args[2];
|
||||
|
||||
if (!uint.TryParse(args[3], out minutes))
|
||||
{
|
||||
shell.WriteError(Loc.GetString("cmd-roleban-minutes-parse", ("time", args[3]), ("help", Help)));
|
||||
return;
|
||||
}
|
||||
|
||||
if (!Enum.TryParse(args[4], ignoreCase: true, out severity))
|
||||
{
|
||||
shell.WriteLine(Loc.GetString("cmd-roleban-severity-parse", ("severity", args[4]), ("help", Help)));
|
||||
return;
|
||||
}
|
||||
|
||||
break;
|
||||
default:
|
||||
shell.WriteError(Loc.GetString("cmd-roleban-arg-count"));
|
||||
@@ -53,15 +77,17 @@ public sealed class RoleBanCommand : IConsoleCommand
|
||||
}
|
||||
|
||||
var located = await _locator.LookupIdByNameOrIdAsync(target);
|
||||
|
||||
if (located == null)
|
||||
{
|
||||
shell.WriteError(Loc.GetString("cmd-roleban-name-parse"));
|
||||
return;
|
||||
}
|
||||
|
||||
_bans.CreateJobBan(shell, located, job, reason, minutes);
|
||||
_bans.SendRoleBans(located);
|
||||
var targetUid = located.UserId;
|
||||
var targetHWid = located.LastHWId;
|
||||
|
||||
_bans.CreateRoleBan(targetUid, located.Username, shell.Player?.UserId, null, targetHWid, job, minutes, severity, reason, DateTimeOffset.UtcNow);
|
||||
_bans.SendRoleBans(located.UserId);
|
||||
}
|
||||
|
||||
public CompletionResult GetCompletion(IConsoleShell shell, string[] args)
|
||||
@@ -76,6 +102,14 @@ public sealed class RoleBanCommand : IConsoleCommand
|
||||
new("43800", Loc.GetString("cmd-roleban-hint-duration-6")),
|
||||
};
|
||||
|
||||
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 args.Length switch
|
||||
{
|
||||
1 => CompletionResult.FromHintOptions(CompletionHelper.SessionNames(),
|
||||
@@ -84,6 +118,7 @@ public sealed class RoleBanCommand : IConsoleCommand
|
||||
Loc.GetString("cmd-roleban-hint-2")),
|
||||
3 => CompletionResult.FromHint(Loc.GetString("cmd-roleban-hint-3")),
|
||||
4 => CompletionResult.FromHintOptions(durOpts, Loc.GetString("cmd-roleban-hint-4")),
|
||||
5 => CompletionResult.FromHintOptions(severities, Loc.GetString("cmd-roleban-hint-5")),
|
||||
_ => CompletionResult.Empty
|
||||
};
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user