Files
tbd-station-14/Content.Shared/Roles/JobRequirements.cs
Errant b692b6e33e Antag Rolebans (#35966)
Co-authored-by: beck-thompson <beck314159@hotmail.com>
Co-authored-by: Hannah Giovanna Dawson <karakkaraz@gmail.com>
2025-09-17 23:59:07 +02:00

77 lines
2.8 KiB
C#

using System.Diagnostics.CodeAnalysis;
using Content.Shared.Preferences;
using Robust.Shared.Prototypes;
using Robust.Shared.Serialization;
using Robust.Shared.Utility;
namespace Content.Shared.Roles;
public static class JobRequirements
{
/// <summary>
/// Checks if the requirements of the job are met by the provided play-times.
/// </summary>
/// <param name="job"> The job to test. </param>
/// <param name="playTimes"> The playtimes used for the check. </param>
/// <param name="reason"> If the requirements were not met, details are provided here. </param>
/// <returns>Returns true if all requirements were met or there were no requirements.</returns>
public static bool TryRequirementsMet(
JobPrototype job,
IReadOnlyDictionary<string, TimeSpan> playTimes,
[NotNullWhen(false)] out FormattedMessage? reason,
IEntityManager entManager,
IPrototypeManager protoManager,
HumanoidCharacterProfile? profile)
{
var sys = entManager.System<SharedRoleSystem>();
var requirements = sys.GetRoleRequirements(job);
return TryRequirementsMet(requirements, playTimes, out reason, entManager, protoManager, profile);
}
/// <summary>
/// Checks if the list of requirements are met by the provided play-times.
/// </summary>
/// <param name="requirements"> The requirements to test. </param>
/// <param name="playTimes"> The playtimes used for the check. </param>
/// <param name="reason"> If the requirements were not met, details are provided here. </param>
/// <returns>Returns true if all requirements were met or there were no requirements.</returns>
public static bool TryRequirementsMet(
HashSet<JobRequirement>? requirements,
IReadOnlyDictionary<string, TimeSpan> playTimes,
[NotNullWhen(false)] out FormattedMessage? reason,
IEntityManager entManager,
IPrototypeManager protoManager,
HumanoidCharacterProfile? profile)
{
reason = null;
if (requirements == null)
return true;
foreach (var requirement in requirements)
{
if (!requirement.Check(entManager, protoManager, profile, playTimes, out reason))
return false;
}
return true;
}
}
/// <summary>
/// Abstract class for playtime and other requirements for role gates.
/// </summary>
[ImplicitDataDefinitionForInheritors]
[Serializable, NetSerializable]
public abstract partial class JobRequirement
{
[DataField]
public bool Inverted;
public abstract bool Check(
IEntityManager entManager,
IPrototypeManager protoManager,
HumanoidCharacterProfile? profile,
IReadOnlyDictionary<string, TimeSpan> playTimes,
[NotNullWhen(false)] out FormattedMessage? reason);
}