diff --git a/.gitignore b/.gitignore
index 31c7257..b299ff1 100644
--- a/.gitignore
+++ b/.gitignore
@@ -1,2 +1,4 @@
.tasks/
.agile/
+**/bin/
+**/obj/
diff --git a/Directory.Build.props b/Directory.Build.props
new file mode 100644
index 0000000..c3ef511
--- /dev/null
+++ b/Directory.Build.props
@@ -0,0 +1,10 @@
+
+
+ AgileWebs
+ AgileWebs
+ git
+ http://192.168.68.156:3000/AgileWebs/kitchen-service
+ http://192.168.68.156:3000/AgileWebs/kitchen-service
+ false
+
+
diff --git a/Kitchen.Service.slnx b/Kitchen.Service.slnx
new file mode 100644
index 0000000..aa32480
--- /dev/null
+++ b/Kitchen.Service.slnx
@@ -0,0 +1,7 @@
+
+
+
+
+
+
+
diff --git a/src/Kitchen.Service.Application/Kitchen.Service.Application.csproj b/src/Kitchen.Service.Application/Kitchen.Service.Application.csproj
new file mode 100644
index 0000000..1e968fb
--- /dev/null
+++ b/src/Kitchen.Service.Application/Kitchen.Service.Application.csproj
@@ -0,0 +1,12 @@
+
+
+
+ net10.0
+ enable
+ enable
+
+
+
+
+
+
diff --git a/src/Kitchen.Service.Application/Ports/DefaultKitchenQueueReadPort.cs b/src/Kitchen.Service.Application/Ports/DefaultKitchenQueueReadPort.cs
new file mode 100644
index 0000000..510427d
--- /dev/null
+++ b/src/Kitchen.Service.Application/Ports/DefaultKitchenQueueReadPort.cs
@@ -0,0 +1,18 @@
+using Kitchen.Service.Contracts.Contracts;
+using Kitchen.Service.Contracts.Responses;
+
+namespace Kitchen.Service.Application.Ports;
+
+public sealed class DefaultKitchenQueueReadPort : IKitchenQueueReadPort
+{
+ public Task ReadQueueAsync(string queueName, int limit, CancellationToken cancellationToken)
+ {
+ var items = new[]
+ {
+ new KitchenQueueItemContract("WK-1001", "PrepareOrder", 3, "Queued"),
+ new KitchenQueueItemContract("WK-1002", "AssembleTray", 2, "Queued")
+ }.Take(Math.Max(limit, 0)).ToArray();
+
+ return Task.FromResult(new GetKitchenQueueResponse(items));
+ }
+}
diff --git a/src/Kitchen.Service.Application/Ports/IKitchenQueueReadPort.cs b/src/Kitchen.Service.Application/Ports/IKitchenQueueReadPort.cs
new file mode 100644
index 0000000..0ee81f7
--- /dev/null
+++ b/src/Kitchen.Service.Application/Ports/IKitchenQueueReadPort.cs
@@ -0,0 +1,8 @@
+using Kitchen.Service.Contracts.Responses;
+
+namespace Kitchen.Service.Application.Ports;
+
+public interface IKitchenQueueReadPort
+{
+ Task ReadQueueAsync(string queueName, int limit, CancellationToken cancellationToken);
+}
diff --git a/src/Kitchen.Service.Application/UseCases/GetKitchenQueueUseCase.cs b/src/Kitchen.Service.Application/UseCases/GetKitchenQueueUseCase.cs
new file mode 100644
index 0000000..c859206
--- /dev/null
+++ b/src/Kitchen.Service.Application/UseCases/GetKitchenQueueUseCase.cs
@@ -0,0 +1,13 @@
+using Kitchen.Service.Application.Ports;
+using Kitchen.Service.Contracts.Requests;
+using Kitchen.Service.Contracts.Responses;
+
+namespace Kitchen.Service.Application.UseCases;
+
+public sealed class GetKitchenQueueUseCase(IKitchenQueueReadPort readPort) : IGetKitchenQueueUseCase
+{
+ public Task HandleAsync(GetKitchenQueueRequest request, CancellationToken cancellationToken)
+ {
+ return readPort.ReadQueueAsync(request.QueueName, request.Limit, cancellationToken);
+ }
+}
diff --git a/src/Kitchen.Service.Application/UseCases/IGetKitchenQueueUseCase.cs b/src/Kitchen.Service.Application/UseCases/IGetKitchenQueueUseCase.cs
new file mode 100644
index 0000000..dd071b8
--- /dev/null
+++ b/src/Kitchen.Service.Application/UseCases/IGetKitchenQueueUseCase.cs
@@ -0,0 +1,9 @@
+using Kitchen.Service.Contracts.Requests;
+using Kitchen.Service.Contracts.Responses;
+
+namespace Kitchen.Service.Application.UseCases;
+
+public interface IGetKitchenQueueUseCase
+{
+ Task HandleAsync(GetKitchenQueueRequest request, CancellationToken cancellationToken);
+}
diff --git a/src/Kitchen.Service.Contracts/Contracts/KitchenQueueItemContract.cs b/src/Kitchen.Service.Contracts/Contracts/KitchenQueueItemContract.cs
new file mode 100644
index 0000000..3e90ded
--- /dev/null
+++ b/src/Kitchen.Service.Contracts/Contracts/KitchenQueueItemContract.cs
@@ -0,0 +1,3 @@
+namespace Kitchen.Service.Contracts.Contracts;
+
+public sealed record KitchenQueueItemContract(string WorkItemId, string WorkType, int Priority, string State);
diff --git a/src/Kitchen.Service.Contracts/Kitchen.Service.Contracts.csproj b/src/Kitchen.Service.Contracts/Kitchen.Service.Contracts.csproj
new file mode 100644
index 0000000..b760144
--- /dev/null
+++ b/src/Kitchen.Service.Contracts/Kitchen.Service.Contracts.csproj
@@ -0,0 +1,9 @@
+
+
+
+ net10.0
+ enable
+ enable
+
+
+
diff --git a/src/Kitchen.Service.Contracts/Requests/GetKitchenQueueRequest.cs b/src/Kitchen.Service.Contracts/Requests/GetKitchenQueueRequest.cs
new file mode 100644
index 0000000..4700e3c
--- /dev/null
+++ b/src/Kitchen.Service.Contracts/Requests/GetKitchenQueueRequest.cs
@@ -0,0 +1,3 @@
+namespace Kitchen.Service.Contracts.Requests;
+
+public sealed record GetKitchenQueueRequest(string QueueName, int Limit);
diff --git a/src/Kitchen.Service.Contracts/Responses/GetKitchenQueueResponse.cs b/src/Kitchen.Service.Contracts/Responses/GetKitchenQueueResponse.cs
new file mode 100644
index 0000000..7cb3a43
--- /dev/null
+++ b/src/Kitchen.Service.Contracts/Responses/GetKitchenQueueResponse.cs
@@ -0,0 +1,5 @@
+using Kitchen.Service.Contracts.Contracts;
+
+namespace Kitchen.Service.Contracts.Responses;
+
+public sealed record GetKitchenQueueResponse(IReadOnlyCollection Items);
diff --git a/src/Kitchen.Service.Grpc/Kitchen.Service.Grpc.csproj b/src/Kitchen.Service.Grpc/Kitchen.Service.Grpc.csproj
new file mode 100644
index 0000000..85ccb41
--- /dev/null
+++ b/src/Kitchen.Service.Grpc/Kitchen.Service.Grpc.csproj
@@ -0,0 +1,13 @@
+
+
+
+ net10.0
+ enable
+ enable
+
+
+
+
+
+
+
diff --git a/src/Kitchen.Service.Grpc/Program.cs b/src/Kitchen.Service.Grpc/Program.cs
new file mode 100644
index 0000000..c3c33c6
--- /dev/null
+++ b/src/Kitchen.Service.Grpc/Program.cs
@@ -0,0 +1,17 @@
+using Kitchen.Service.Application.Ports;
+using Kitchen.Service.Application.UseCases;
+using Kitchen.Service.Contracts.Requests;
+
+var builder = WebApplication.CreateBuilder(args);
+builder.Services.AddSingleton();
+builder.Services.AddSingleton();
+
+var app = builder.Build();
+
+app.MapGet("/internal/kitchen/queue", async (string queueName, int? limit, IGetKitchenQueueUseCase useCase, CancellationToken ct) =>
+{
+ var request = new GetKitchenQueueRequest(queueName, limit ?? 20);
+ return Results.Ok(await useCase.HandleAsync(request, ct));
+});
+
+app.Run();
diff --git a/src/Kitchen.Service.Grpc/Properties/launchSettings.json b/src/Kitchen.Service.Grpc/Properties/launchSettings.json
new file mode 100644
index 0000000..c55f6a2
--- /dev/null
+++ b/src/Kitchen.Service.Grpc/Properties/launchSettings.json
@@ -0,0 +1,23 @@
+{
+ "$schema": "https://json.schemastore.org/launchsettings.json",
+ "profiles": {
+ "http": {
+ "commandName": "Project",
+ "dotnetRunMessages": true,
+ "launchBrowser": true,
+ "applicationUrl": "http://localhost:0",
+ "environmentVariables": {
+ "ASPNETCORE_ENVIRONMENT": "Development"
+ }
+ },
+ "https": {
+ "commandName": "Project",
+ "dotnetRunMessages": true,
+ "launchBrowser": true,
+ "applicationUrl": "https://localhost:0;http://localhost:0",
+ "environmentVariables": {
+ "ASPNETCORE_ENVIRONMENT": "Development"
+ }
+ }
+ }
+}
diff --git a/src/Kitchen.Service.Grpc/appsettings.Development.json b/src/Kitchen.Service.Grpc/appsettings.Development.json
new file mode 100644
index 0000000..0c208ae
--- /dev/null
+++ b/src/Kitchen.Service.Grpc/appsettings.Development.json
@@ -0,0 +1,8 @@
+{
+ "Logging": {
+ "LogLevel": {
+ "Default": "Information",
+ "Microsoft.AspNetCore": "Warning"
+ }
+ }
+}
diff --git a/src/Kitchen.Service.Grpc/appsettings.json b/src/Kitchen.Service.Grpc/appsettings.json
new file mode 100644
index 0000000..10f68b8
--- /dev/null
+++ b/src/Kitchen.Service.Grpc/appsettings.json
@@ -0,0 +1,9 @@
+{
+ "Logging": {
+ "LogLevel": {
+ "Default": "Information",
+ "Microsoft.AspNetCore": "Warning"
+ }
+ },
+ "AllowedHosts": "*"
+}