Add door remote logs (#13310)

* add door remote logs

* replace .Owner
This commit is contained in:
Chief-Engineer
2023-01-10 03:37:26 -06:00
committed by GitHub
parent f343b428db
commit ca20897e31

View File

@@ -1,3 +1,4 @@
using Content.Server.Administration.Logs;
using Robust.Shared.Player;
using Content.Shared.Interaction;
using Content.Shared.Popups;
@@ -8,6 +9,7 @@ using Content.Shared.Access.Components;
using Content.Server.Doors.Systems;
using Content.Server.Doors.Components;
using Content.Server.Power.EntitySystems;
using Content.Shared.Database;
using Content.Shared.Interaction.Events;
using static Content.Server.Remotes.DoorRemoteComponent;
@@ -15,6 +17,7 @@ namespace Content.Server.Remotes
{
public sealed class DoorRemoteSystem : EntitySystem
{
[Dependency] private readonly IAdminLogManager _adminLogger = default!;
[Dependency] private readonly SharedPopupSystem _popupSystem = default!;
[Dependency] private readonly DoorSystem _doorSystem = default!;
[Dependency] private readonly SharedInteractionSystem _interactionSystem = default!;
@@ -71,9 +74,9 @@ namespace Content.Server.Remotes
}
if (TryComp<AccessReaderComponent>(args.Target, out var accessComponent) &&
!_doorSystem.HasAccess(doorComp.Owner, args.Used, accessComponent))
!_doorSystem.HasAccess(args.Target.Value, args.Used, accessComponent))
{
_doorSystem.Deny(airlockComp.Owner, doorComp, args.User);
_doorSystem.Deny(args.Target.Value, doorComp, args.User);
ShowPopupToUser("door-remote-denied", args.User);
return;
}
@@ -81,14 +84,19 @@ namespace Content.Server.Remotes
switch (component.Mode)
{
case OperatingMode.OpenClose:
_doorSystem.TryToggleDoor(doorComp.Owner, doorComp, args.Used);
if (_doorSystem.TryToggleDoor(args.Target.Value, doorComp, args.Used))
_adminLogger.Add(LogType.Action, LogImpact.Medium, $"{ToPrettyString(args.User):player} used {ToPrettyString(args.Used)} on {ToPrettyString(args.Target.Value)}: {doorComp.State}");
break;
case OperatingMode.ToggleBolts:
if (!airlockComp.BoltWireCut)
{
airlockComp.SetBoltsWithAudio(!airlockComp.IsBolted());
_adminLogger.Add(LogType.Action, LogImpact.Medium, $"{ToPrettyString(args.User):player} used {ToPrettyString(args.Used)} on {ToPrettyString(args.Target.Value)} to {(airlockComp.IsBolted() ? "" : "un")}bolt it");
}
break;
case OperatingMode.ToggleEmergencyAccess:
_sharedAirlockSystem.ToggleEmergencyAccess(airlockComp);
_adminLogger.Add(LogType.Action, LogImpact.Medium, $"{ToPrettyString(args.User):player} used {ToPrettyString(args.Used)} on {ToPrettyString(args.Target.Value)} to set emergency access {(airlockComp.EmergencyAccess ? "on" : "off")}");
break;
default:
throw new InvalidOperationException(