Fix gulag & tweak ratio (#36)

* - tweak: Tweak gulag ratio

* - fix: Fix gulag.
This commit is contained in:
Aviu00
2024-02-08 18:43:17 +09:00
committed by GitHub
parent 84c371a2a3
commit 337034d734
6 changed files with 60 additions and 3 deletions

View File

@@ -1,4 +1,5 @@
using System.Text;
using Content.Server.Administration.Managers;
using Content.Server.Database;
using Content.Shared.Administration;
using Robust.Shared.Console;
@@ -16,6 +17,7 @@ namespace Content.Server.Administration.Commands
{
var player = shell.Player;
var dbMan = IoCManager.Resolve<IServerDbManager>();
var banManager = IoCManager.Resolve<IBanManager>();
if (args.Length != 1)
{
@@ -37,6 +39,9 @@ namespace Content.Server.Administration.Commands
return;
}
if (ban.UserId.HasValue)
banManager.RemoveCachedServerBan(ban.UserId.Value, banId);
if (ban.Unban != null)
{
var response = new StringBuilder("This ban has already been pardoned");

View File

@@ -207,7 +207,26 @@ public sealed class BanManager : IBanManager, IPostInjectInit
if (banDef.UserId.HasValue)
{
_cachedServerBans.GetOrNew(banDef.UserId.Value).Add(banDef);
var banlist = await _db.GetServerBansAsync(addressRange?.Item1, target, hwid, false);
if (banlist.Count > 0 && banlist[^1].Id.HasValue)
{
var banDefWithId = new ServerBanDef(
banlist[^1].Id,
banDef.UserId,
banDef.Address,
banDef.HWId,
banDef.BanTime,
banDef.ExpirationTime,
banDef.RoundId,
banDef.PlaytimeAtNote,
banDef.Reason,
banDef.Severity,
banDef.BanningAdmin,
banDef.Unban,
banDef.ServerName);
_cachedServerBans.GetOrNew(banDef.UserId.Value).Add(banDefWithId);
}
}
// If we're not banning a player we don't care about disconnecting people
@@ -241,6 +260,22 @@ public sealed class BanManager : IBanManager, IPostInjectInit
return new HashSet<ServerBanDef>();
}
public void RemoveCachedServerBan(NetUserId userId, int? id)
{
if (_cachedServerBans.TryGetValue(userId, out var bans))
{
bans.RemoveWhere(ban => ban.Id == id);
}
}
public void AddCachedServerBan(ServerBanDef banDef)
{
if (banDef.UserId == null)
return;
_cachedServerBans.GetOrNew(banDef.UserId.Value).Add(banDef);
}
//Miracle edit end
#region Job Bans

View File

@@ -30,6 +30,9 @@ public interface IBanManager
public HashSet<string>? GetJobBans(NetUserId playerUserId);
public HashSet<ServerBanDef> GetServerBans(NetUserId userId); // Miracle edit
public void RemoveCachedServerBan(NetUserId userId, int? id); // Miracle edit
public void AddCachedServerBan(ServerBanDef banDef); // Miracle edit
/// <summary>
/// Creates a job ban for the specified target, username or GUID

View File

@@ -43,7 +43,7 @@ namespace Content.Server._Miracle.GulagSystem;
public sealed partial class GulagSystem : SharedGulagSystem
{
//1 second = 10 points
//1 second = 0.01 points
[Dependency] private readonly AdminSystem _adminSystem = default!;
[Dependency] private readonly IBanManager _banManager = default!;
[Dependency] private readonly BiomeSystem _biome = default!;
@@ -382,7 +382,16 @@ public sealed partial class GulagSystem : SharedGulagSystem
var newExpirationTime = banDef.ExpirationTime!.Value.DateTime - ConvertPointsToTime(points);
_db.EditServerBan(banDef.Id!.Value, banDef.Reason, banDef.Severity, newExpirationTime, banDef.UserId!.Value, DateTime.Now);
// Update time
_banManager.RemoveCachedServerBan(banDef.UserId.Value, banDef.Id.Value);
_banManager.AddCachedServerBan(new ServerBanDef(
banDef.Id, banDef.UserId, banDef.Address, banDef.HWId, banDef.BanTime, newExpirationTime,
banDef.RoundId, banDef.PlaytimeAtNote, banDef.Reason, banDef.Severity, banDef.BanningAdmin,
banDef.Unban, banDef.ServerName));
}
_pointsPerPlayer.Clear();
_activeMap = null!;
_mapEntity = null!;

View File

@@ -2,6 +2,7 @@
using Content.Server.Database;
using Content.Server._White.PandaSocket.Interfaces;
using Content.Server._White.PandaSocket.Main;
using Content.Server.Administration.Managers;
namespace Content.Server._White.PandaSocket.Commands;
@@ -15,6 +16,7 @@ public sealed class PandaUnbanCommand : IPandaCommand
var dbMan = IoCManager.Resolve<IServerDbManager>();
var locator = IoCManager.Resolve<IPlayerLocator>();
var banManager = IoCManager.Resolve<IBanManager>();
IoCManager.InjectDependencies(this);
var located = await locator.LookupIdByNameOrIdAsync(message.ACkey!);
@@ -41,6 +43,9 @@ public sealed class PandaUnbanCommand : IPandaCommand
return;
}
if (ban.UserId.HasValue)
banManager.RemoveCachedServerBan(ban.UserId.Value, banId);
await dbMan.AddServerUnbanAsync(new ServerUnbanDef(banId, player, DateTimeOffset.Now));
UtkaSendResponse(true, context);

View File

@@ -8,5 +8,5 @@ public sealed class MiracleCvars
// <points> / <ratio> = <time_in_seconds>
// 100 / 10 = 10
public static readonly CVarDef<double> GulagPointsToTimeRatio = CVarDef.Create("miracle.gulag.points_to_time",
10.0d, CVar.SERVERONLY, "<points> / <ratio> = <time_in_seconds>");
0.01d, CVar.SERVERONLY, "<points> / <ratio> = <time_in_seconds>");
}