Rolebanlist command UI (#30827)
* rolebanlist command opens ui * removed commented out section
This commit is contained in:
@@ -1,5 +1,7 @@
|
|||||||
using System.Linq;
|
using System.Linq;
|
||||||
using System.Text;
|
using System.Text;
|
||||||
|
using Content.Server.Administration.BanList;
|
||||||
|
using Content.Server.EUI;
|
||||||
using Content.Server.Database;
|
using Content.Server.Database;
|
||||||
using Content.Shared.Administration;
|
using Content.Shared.Administration;
|
||||||
using Robust.Server.Player;
|
using Robust.Server.Player;
|
||||||
@@ -10,6 +12,12 @@ namespace Content.Server.Administration.Commands;
|
|||||||
[AdminCommand(AdminFlags.Ban)]
|
[AdminCommand(AdminFlags.Ban)]
|
||||||
public sealed class RoleBanListCommand : IConsoleCommand
|
public sealed class RoleBanListCommand : IConsoleCommand
|
||||||
{
|
{
|
||||||
|
[Dependency] private readonly IServerDbManager _dbManager = default!;
|
||||||
|
|
||||||
|
[Dependency] private readonly EuiManager _eui = default!;
|
||||||
|
|
||||||
|
[Dependency] private readonly IPlayerLocator _locator = default!;
|
||||||
|
|
||||||
public string Command => "rolebanlist";
|
public string Command => "rolebanlist";
|
||||||
public string Description => Loc.GetString("cmd-rolebanlist-desc");
|
public string Description => Loc.GetString("cmd-rolebanlist-desc");
|
||||||
public string Help => Loc.GetString("cmd-rolebanlist-help");
|
public string Help => Loc.GetString("cmd-rolebanlist-help");
|
||||||
@@ -29,23 +37,18 @@ public sealed class RoleBanListCommand : IConsoleCommand
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
var dbMan = IoCManager.Resolve<IServerDbManager>();
|
var data = await _locator.LookupIdByNameOrIdAsync(args[0]);
|
||||||
|
|
||||||
var target = args[0];
|
if (data == null)
|
||||||
|
|
||||||
var locator = IoCManager.Resolve<IPlayerLocator>();
|
|
||||||
var located = await locator.LookupIdByNameOrIdAsync(target);
|
|
||||||
if (located == null)
|
|
||||||
{
|
{
|
||||||
shell.WriteError("Unable to find a player with that name or id.");
|
shell.WriteError("Unable to find a player with that name or id.");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
var targetUid = located.UserId;
|
if (shell.Player is not { } player)
|
||||||
var targetHWid = located.LastHWId;
|
{
|
||||||
var targetAddress = located.LastAddress;
|
|
||||||
|
|
||||||
var bans = await dbMan.GetServerRoleBansAsync(targetAddress, targetUid, targetHWid, includeUnbanned);
|
var bans = await _dbManager.GetServerRoleBansAsync(data.LastAddress, data.UserId, data.LastHWId, includeUnbanned);
|
||||||
|
|
||||||
if (bans.Count == 0)
|
if (bans.Count == 0)
|
||||||
{
|
{
|
||||||
@@ -53,42 +56,18 @@ public sealed class RoleBanListCommand : IConsoleCommand
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
var bansString = new StringBuilder("Bans in record:\n");
|
|
||||||
|
|
||||||
var first = true;
|
|
||||||
foreach (var ban in bans)
|
foreach (var ban in bans)
|
||||||
{
|
{
|
||||||
if (!first)
|
var msg = $"ID: {ban.Id}: Role: {ban.Role} Reason: {ban.Reason}";
|
||||||
bansString.Append("\n\n");
|
shell.WriteLine(msg);
|
||||||
else
|
}
|
||||||
first = false;
|
return;
|
||||||
|
|
||||||
bansString
|
|
||||||
.Append("Ban ID: ")
|
|
||||||
.Append(ban.Id)
|
|
||||||
.Append('\n')
|
|
||||||
.Append("Role: ")
|
|
||||||
.Append(ban.Role)
|
|
||||||
.Append('\n')
|
|
||||||
.Append("Banned on ")
|
|
||||||
.Append(ban.BanTime);
|
|
||||||
|
|
||||||
if (ban.ExpirationTime != null)
|
|
||||||
{
|
|
||||||
bansString
|
|
||||||
.Append(" until ")
|
|
||||||
.Append(ban.ExpirationTime.Value);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
bansString
|
var ui = new BanListEui();
|
||||||
.Append('\n');
|
_eui.OpenEui(ui, player);
|
||||||
|
await ui.ChangeBanListPlayer(data.UserId);
|
||||||
|
|
||||||
bansString
|
|
||||||
.Append("Reason: ")
|
|
||||||
.Append(ban.Reason);
|
|
||||||
}
|
|
||||||
|
|
||||||
shell.WriteLine(bansString.ToString());
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public CompletionResult GetCompletion(IConsoleShell shell, string[] args)
|
public CompletionResult GetCompletion(IConsoleShell shell, string[] args)
|
||||||
|
|||||||
Reference in New Issue
Block a user