Clean up LockSystem very slightly.
This commit is contained in:
@@ -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);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -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;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user