Merge branch 'feature/operations-domain-invariants' into development

This commit is contained in:
José René White Enciso 2026-02-25 18:18:14 -06:00
commit 21030d4cbc
8 changed files with 62 additions and 0 deletions

2
.gitignore vendored
View File

@ -1,2 +1,4 @@
.tasks/
.agile/
**/bin/
**/obj/

10
Directory.Build.props Normal file
View File

@ -0,0 +1,10 @@
<Project>
<PropertyGroup>
<Authors>AgileWebs</Authors>
<Company>AgileWebs</Company>
<RepositoryType>git</RepositoryType>
<RepositoryUrl>http://192.168.68.156:3000/AgileWebs/operations-domain</RepositoryUrl>
<PackageProjectUrl>http://192.168.68.156:3000/AgileWebs/operations-domain</PackageProjectUrl>
<PackageRequireLicenseAcceptance>false</PackageRequireLicenseAcceptance>
</PropertyGroup>
</Project>

5
Operations.Domain.slnx Normal file
View File

@ -0,0 +1,5 @@
<Solution>
<Folder Name="/src/">
<Project Path="src/Operations.Domain/Operations.Domain.csproj" />
</Folder>
</Solution>

View File

@ -0,0 +1,3 @@
namespace Operations.Domain.Conventions;
public interface IOperationsDomainPackageContract;

View File

@ -0,0 +1,11 @@
using Operations.Domain.Models;
namespace Operations.Domain.Decisions;
public interface IOperationsPolicyResolutionService
{
ResolvedPolicyDecision ResolvePolicy(
string policyName,
IReadOnlyDictionary<string, string> facts,
IReadOnlyDictionary<string, bool> featureFlags);
}

View File

@ -0,0 +1,19 @@
using Operations.Domain.Models;
namespace Operations.Domain.Decisions;
public sealed class OperationsPolicyResolutionService : IOperationsPolicyResolutionService
{
public ResolvedPolicyDecision ResolvePolicy(
string policyName,
IReadOnlyDictionary<string, string> facts,
IReadOnlyDictionary<string, bool> featureFlags)
{
if (featureFlags.TryGetValue($"policy:{policyName}:disabled", out var disabled) && disabled)
{
return new ResolvedPolicyDecision(false, "Policy disabled by feature flag.");
}
return new ResolvedPolicyDecision(true, "Policy allowed by default resolution.");
}
}

View File

@ -0,0 +1,3 @@
namespace Operations.Domain.Models;
public sealed record ResolvedPolicyDecision(bool Allowed, string Explanation);

View File

@ -0,0 +1,9 @@
<Project Sdk="Microsoft.NET.Sdk">
<PropertyGroup>
<TargetFramework>net10.0</TargetFramework>
<ImplicitUsings>enable</ImplicitUsings>
<Nullable>enable</Nullable>
</PropertyGroup>
</Project>