diff --git a/Content.Server/Remotes/DoorRemoteSystem.cs b/Content.Server/Remotes/DoorRemoteSystem.cs index 2cb033ff77..1885bc98db 100644 --- a/Content.Server/Remotes/DoorRemoteSystem.cs +++ b/Content.Server/Remotes/DoorRemoteSystem.cs @@ -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(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(