Files
crystall-punk-14/Content.Server/Access/Systems/IdCardSystem.cs

92 lines
3.5 KiB
C#
Raw Permalink Normal View History

using System.Linq;
using Content.Server.Administration.Logs;
2022-02-12 17:53:54 -07:00
using Content.Server.Kitchen.Components;
using Content.Server.Popups;
using Content.Shared.Access;
2021-12-16 23:42:02 +13:00
using Content.Shared.Access.Components;
using Content.Shared.Access.Systems;
using Content.Shared.Database;
using Content.Shared.Popups;
2022-02-12 17:53:54 -07:00
using Robust.Shared.Prototypes;
using Robust.Shared.Random;
using Content.Server.Kitchen.EntitySystems;
2023-12-09 23:38:50 -06:00
namespace Content.Server.Access.Systems;
public sealed class IdCardSystem : SharedIdCardSystem
{
2023-12-09 23:38:50 -06:00
[Dependency] private readonly PopupSystem _popupSystem = default!;
[Dependency] private readonly IRobustRandom _random = default!;
[Dependency] private readonly IPrototypeManager _prototypeManager = default!;
[Dependency] private readonly IAdminLogManager _adminLogger = default!;
[Dependency] private readonly MicrowaveSystem _microwave = default!;
get that crap outta here (completely rewrites inventorysystem) (#5807) * some work * equip: done unequip: todo * unequipping done & refactored events * workin * movin * reee namespaces * stun * mobstate * fixes * some work on events * removes serverside itemcomp & misc fixes * work * smol merge fix * ports template to prototype & finishes ui * moves relay & adds containerenumerator * actions & cuffs * my god what is actioncode * more fixes * im loosing my grasp on reality * more fixes * more work * explosions * yes * more work * more fixes * merge master & misc fixed because i forgot to commit before merging master * more fixes * fixes * moar * more work * moar fixes * suffixmap * more work on client * motivation low * no. no containers * mirroring client to server * fixes * move serverinvcomp * serverinventorycomponent is dead * gaming * only strippable & ai left... * only ai and richtext left * fixes ai * fixes * fixes sprite layers * more fixes * resolves optional * yes * stable:tm: * fixes * moar fixes * moar * fix some tests * lmao * no comment * good to merge:tm: * fixes build but for real * adresses some reviews * adresses some more reviews * nullables, yo * fixes lobbyscreen * timid refactor to differentiate actor & target * adresses more reviews * more * my god what a mess * removed the rest of duplicates * removed duplicate slotflags and renamed shoes to feet * removes another unused one * yes * fixes lobby & makes tryunequip return unequipped item * fixes * some funny renames * fixes * misc improvements to attemptevents * fixes * merge fixes Co-authored-by: Paul Ritter <ritter.paul1@gmail.com>
2021-12-30 22:56:10 +01:00
2023-12-09 23:38:50 -06:00
public override void Initialize()
{
base.Initialize();
2023-12-09 23:38:50 -06:00
SubscribeLocalEvent<IdCardComponent, BeingMicrowavedEvent>(OnMicrowaved);
}
2023-12-09 23:38:50 -06:00
private void OnMicrowaved(EntityUid uid, IdCardComponent component, BeingMicrowavedEvent args)
{
if (!component.CanMicrowave || !TryComp<MicrowaveComponent>(args.Microwave, out var micro) || micro.Broken)
return;
2023-12-09 23:38:50 -06:00
if (TryComp<AccessComponent>(uid, out var access))
2022-02-12 17:53:54 -07:00
{
2023-12-09 23:38:50 -06:00
float randomPick = _random.NextFloat();
2023-12-09 23:38:50 -06:00
// if really unlucky, burn card
if (randomPick <= 0.15f)
2022-02-12 17:53:54 -07:00
{
2023-12-09 23:38:50 -06:00
TryComp(uid, out TransformComponent? transformComponent);
if (transformComponent != null)
{
2023-12-09 23:38:50 -06:00
_popupSystem.PopupCoordinates(Loc.GetString("id-card-component-microwave-burnt", ("id", uid)),
transformComponent.Coordinates, PopupType.Medium);
EntityManager.SpawnEntity("FoodBadRecipe",
transformComponent.Coordinates);
}
_adminLogger.Add(LogType.Action, LogImpact.Medium,
2023-12-09 23:38:50 -06:00
$"{ToPrettyString(args.Microwave)} burnt {ToPrettyString(uid):entity}");
EntityManager.QueueDeleteEntity(uid);
return;
2022-02-12 17:53:54 -07:00
}
//Explode if the microwave can't handle it
if (!micro.CanMicrowaveIdsSafely)
{
_microwave.Explode((args.Microwave, micro));
return;
}
2023-12-09 23:38:50 -06:00
// If they're unlucky, brick their ID
if (randomPick <= 0.25f)
2022-08-29 22:38:00 -04:00
{
2023-12-09 23:38:50 -06:00
_popupSystem.PopupEntity(Loc.GetString("id-card-component-microwave-bricked", ("id", uid)), uid);
2022-08-29 22:38:00 -04:00
2023-12-09 23:38:50 -06:00
access.Tags.Clear();
Dirty(uid, access);
2023-12-09 23:38:50 -06:00
_adminLogger.Add(LogType.Action, LogImpact.Medium,
$"{ToPrettyString(args.Microwave)} cleared access on {ToPrettyString(uid):entity}");
2022-08-29 22:38:00 -04:00
}
else
{
2023-12-09 23:38:50 -06:00
_popupSystem.PopupEntity(Loc.GetString("id-card-component-microwave-safe", ("id", uid)), uid, PopupType.Medium);
2022-08-29 22:38:00 -04:00
}
2023-12-09 23:38:50 -06:00
// Give them a wonderful new access to compensate for everything
var random = _random.Pick(_prototypeManager.EnumeratePrototypes<AccessLevelPrototype>().ToArray());
2023-12-09 23:38:50 -06:00
access.Tags.Add(random.ID);
Dirty(uid, access);
2023-12-09 23:38:50 -06:00
_adminLogger.Add(LogType.Action, LogImpact.Medium,
$"{ToPrettyString(args.Microwave)} added {random.ID} access to {ToPrettyString(uid):entity}");
}
2023-12-09 23:38:50 -06:00
}
}