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": "*" +}