Add admin logs to Rehydration comp. (#30597)

This commit is contained in:
Repo
2024-08-09 18:24:19 +12:00
committed by GitHub
parent 736325a31f
commit 31cd2a0927

View File

@@ -1,4 +1,6 @@
using Content.Shared.Administration.Logs;
using Content.Shared.Chemistry.Components; using Content.Shared.Chemistry.Components;
using Content.Shared.Database;
using Content.Shared.FixedPoint; using Content.Shared.FixedPoint;
using Content.Shared.Popups; using Content.Shared.Popups;
using Robust.Shared.Network; using Robust.Shared.Network;
@@ -13,6 +15,7 @@ public sealed class RehydratableSystem : EntitySystem
[Dependency] private readonly SharedPopupSystem _popup = default!; [Dependency] private readonly SharedPopupSystem _popup = default!;
[Dependency] private readonly SharedSolutionContainerSystem _solutions = default!; [Dependency] private readonly SharedSolutionContainerSystem _solutions = default!;
[Dependency] private readonly SharedTransformSystem _xform = default!; [Dependency] private readonly SharedTransformSystem _xform = default!;
[Dependency] private readonly ISharedAdminLogManager _adminLogger = default!;
public override void Initialize() public override void Initialize()
{ {
@@ -24,6 +27,7 @@ public sealed class RehydratableSystem : EntitySystem
private void OnSolutionChange(Entity<RehydratableComponent> ent, ref SolutionContainerChangedEvent args) private void OnSolutionChange(Entity<RehydratableComponent> ent, ref SolutionContainerChangedEvent args)
{ {
var quantity = _solutions.GetTotalPrototypeQuantity(ent, ent.Comp.CatalystPrototype); var quantity = _solutions.GetTotalPrototypeQuantity(ent, ent.Comp.CatalystPrototype);
_adminLogger.Add(LogType.Action, LogImpact.Medium, $"{ToPrettyString(ent.Owner)} was hydrated, now contains a solution of: {SharedSolutionContainerSystem.ToPrettyString(args.Solution)}.");
if (quantity != FixedPoint2.Zero && quantity >= ent.Comp.CatalystMinimum) if (quantity != FixedPoint2.Zero && quantity >= ent.Comp.CatalystMinimum)
{ {
Expand(ent); Expand(ent);
@@ -41,6 +45,8 @@ public sealed class RehydratableSystem : EntitySystem
var randomMob = _random.Pick(comp.PossibleSpawns); var randomMob = _random.Pick(comp.PossibleSpawns);
var target = Spawn(randomMob, Transform(uid).Coordinates); var target = Spawn(randomMob, Transform(uid).Coordinates);
_adminLogger.Add(LogType.Action, LogImpact.Medium, $"{ToPrettyString(ent.Owner)} has been hydrated correctly and spawned: {ToPrettyString(target)}.");
_popup.PopupEntity(Loc.GetString("rehydratable-component-expands-message", ("owner", uid)), target); _popup.PopupEntity(Loc.GetString("rehydratable-component-expands-message", ("owner", uid)), target);
_xform.AttachToGridOrMap(target); _xform.AttachToGridOrMap(target);