Merge branch 'feature/kitchen-dal-adapters' into development

This commit is contained in:
José René White Enciso 2026-02-25 18:18:15 -06:00
commit d1ce3bb123
7 changed files with 64 additions and 0 deletions

2
.gitignore vendored
View File

@ -1,2 +1,4 @@
.tasks/ .tasks/
.agile/ .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/kitchen-dal</RepositoryUrl>
<PackageProjectUrl>http://192.168.68.156:3000/AgileWebs/kitchen-dal</PackageProjectUrl>
<PackageRequireLicenseAcceptance>false</PackageRequireLicenseAcceptance>
</PropertyGroup>
</Project>

5
Kitchen.DAL.slnx Normal file
View File

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

View File

@ -0,0 +1,8 @@
namespace Kitchen.DAL.Contracts;
public sealed record KitchenWorkItemRecord(
string WorkItemId,
string WorkType,
int Priority,
DateTime RequestedAtUtc,
string State);

View File

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

View File

@ -0,0 +1,9 @@
using Kitchen.DAL.Contracts;
namespace Kitchen.DAL.Repositories;
public interface IKitchenWorkItemRepository
{
Task<IReadOnlyCollection<KitchenWorkItemRecord>> ListQueuedAsync(CancellationToken cancellationToken);
Task UpsertAsync(KitchenWorkItemRecord record, CancellationToken cancellationToken);
}

View File

@ -0,0 +1,21 @@
using System.Collections.Concurrent;
using Kitchen.DAL.Contracts;
namespace Kitchen.DAL.Repositories;
public sealed class InMemoryKitchenWorkItemRepository : IKitchenWorkItemRepository
{
private readonly ConcurrentDictionary<string, KitchenWorkItemRecord> store = new();
public Task<IReadOnlyCollection<KitchenWorkItemRecord>> ListQueuedAsync(CancellationToken cancellationToken)
{
var result = store.Values.Where(x => x.State == "Queued").OrderByDescending(x => x.Priority).ToArray();
return Task.FromResult<IReadOnlyCollection<KitchenWorkItemRecord>>(result);
}
public Task UpsertAsync(KitchenWorkItemRecord record, CancellationToken cancellationToken)
{
store[record.WorkItemId] = record;
return Task.CompletedTask;
}
}