Clean up LockSystem very slightly.

This commit is contained in:
Vera Aguilera Puerto
2021-10-02 12:00:02 +02:00
parent 0f5298e020
commit b5a8e21f78
2 changed files with 33 additions and 31 deletions

View File

@@ -52,14 +52,13 @@ namespace Content.Server.Storage.Components
// Call relevant entity system // Call relevant entity system
var lockSystem = user.EntityManager.EntitySysManager.GetEntitySystem<LockSystem>(); var lockSystem = user.EntityManager.EntitySysManager.GetEntitySystem<LockSystem>();
var eventData = new ActivateInWorldEvent(user, component.Owner);
if (component.Locked) if (component.Locked)
{ {
lockSystem.DoUnlock(component, eventData); lockSystem.DoUnlock(component.Owner.Uid, user, component);
} }
else else
{ {
lockSystem.DoLock(component, eventData); lockSystem.DoLock(component.Owner.Uid, user, component);
} }
} }
} }

View File

@@ -28,7 +28,7 @@ namespace Content.Server.Lock
SubscribeLocalEvent<LockComponent, ExaminedEvent>(OnExamined); SubscribeLocalEvent<LockComponent, ExaminedEvent>(OnExamined);
} }
private void OnStartup(EntityUid eUI, LockComponent lockComp, ComponentStartup args) private void OnStartup(EntityUid uid, LockComponent lockComp, ComponentStartup args)
{ {
if (lockComp.Owner.TryGetComponent(out AppearanceComponent? appearance)) if (lockComp.Owner.TryGetComponent(out AppearanceComponent? appearance))
{ {
@@ -36,21 +36,20 @@ namespace Content.Server.Lock
} }
} }
private void OnActivated(EntityUid eUI, LockComponent lockComp, ActivateInWorldEvent args) private void OnActivated(EntityUid uid, LockComponent lockComp, ActivateInWorldEvent args)
{ {
// Only attempt an unlock by default on Activate // Only attempt an unlock by default on Activate
if (lockComp.Locked) if (lockComp.Locked)
{ {
DoUnlock(lockComp, args); DoUnlock(uid, args.User, lockComp);
} }
else else if (lockComp.LockOnClick)
{ {
if (lockComp.LockOnClick) DoLock(uid, args.User, lockComp);
DoLock(lockComp, args);
} }
} }
private void OnExamined(EntityUid eUI, LockComponent lockComp, ExaminedEvent args) private void OnExamined(EntityUid uid, LockComponent lockComp, ExaminedEvent args)
{ {
args.PushText(Loc.GetString(lockComp.Locked args.PushText(Loc.GetString(lockComp.Locked
? "lock-comp-on-examined-is-locked" ? "lock-comp-on-examined-is-locked"
@@ -58,14 +57,15 @@ namespace Content.Server.Lock
("entityName", lockComp.Owner.Name))); ("entityName", lockComp.Owner.Name)));
} }
public void DoLock(LockComponent lockComp, ActivateInWorldEvent args) public bool DoLock(EntityUid uid, IEntity user, LockComponent? lockComp = null)
{ {
if (!HasUserAccess(lockComp, args.User)) if (!Resolve(uid, ref lockComp))
{ return false;
return;
}
lockComp.Owner.PopupMessage(args.User, Loc.GetString("lock-comp-do-lock-success", ("entityName",lockComp.Owner.Name))); if (!HasUserAccess(uid, user))
return false;
lockComp.Owner.PopupMessage(user, Loc.GetString("lock-comp-do-lock-success", ("entityName",lockComp.Owner.Name)));
lockComp.Locked = true; lockComp.Locked = true;
if(lockComp.LockSound != null) if(lockComp.LockSound != null)
{ {
@@ -79,17 +79,18 @@ namespace Content.Server.Lock
RaiseLocalEvent(lockComp.Owner.Uid, new LockToggledEvent(true)); RaiseLocalEvent(lockComp.Owner.Uid, new LockToggledEvent(true));
args.Handled = true; return true;
} }
public void DoUnlock(LockComponent lockComp, ActivateInWorldEvent args ) public bool DoUnlock(EntityUid uid, IEntity user, LockComponent? lockComp = null)
{ {
if (!HasUserAccess(lockComp, args.User)) if (!Resolve(uid, ref lockComp))
{ return false;
return;
}
lockComp.Owner.PopupMessage(args.User, Loc.GetString("lock-comp-do-unlock-success", ("entityName", lockComp.Owner.Name))); if (!HasUserAccess(uid, user))
return false;
lockComp.Owner.PopupMessage(user, Loc.GetString("lock-comp-do-unlock-success", ("entityName", lockComp.Owner.Name)));
lockComp.Locked = false; lockComp.Locked = false;
if(lockComp.UnlockSound != null) if(lockComp.UnlockSound != null)
{ {
@@ -104,20 +105,22 @@ namespace Content.Server.Lock
RaiseLocalEvent(lockComp.Owner.Uid, new LockToggledEvent(false)); RaiseLocalEvent(lockComp.Owner.Uid, new LockToggledEvent(false));
// To stop EntityStorageComponent from opening right after the container gets unlocked // To stop EntityStorageComponent from opening right after the container gets unlocked
args.Handled = true; return true;
} }
private static bool HasUserAccess(LockComponent lockComp, IEntity user) private bool HasUserAccess(EntityUid uid, IEntity user, AccessReader? reader = null)
{ {
if (lockComp.Owner.TryGetComponent(out AccessReader? reader)) // Not having an AccessComponent means you get free access. woo!
if (!Resolve(uid, ref reader))
return true;
if (!reader.IsAllowed(user))
{ {
if (!reader.IsAllowed(user)) reader.Owner.PopupMessage(user, Loc.GetString("lock-comp-has-user-access-fail"));
{ return false;
lockComp.Owner.PopupMessage(user, Loc.GetString("lock-comp-has-user-access-fail"));
return false;
}
} }
return true; return true;
} }
} }