Merge branch 'feature/building-block-workflow-contract-baseline' into development

This commit is contained in:
José René White Enciso 2026-02-25 18:18:09 -06:00
commit bdac1edce0
9 changed files with 75 additions and 0 deletions

2
.gitignore vendored
View File

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

View File

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

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/building-block-workflow</RepositoryUrl>
<PackageProjectUrl>http://192.168.68.156:3000/AgileWebs/building-block-workflow</PackageProjectUrl>
<PackageRequireLicenseAcceptance>false</PackageRequireLicenseAcceptance>
</PropertyGroup>
</Project>

View File

@ -0,0 +1,11 @@
using BuildingBlock.Workflow.Contracts.Requests;
using BuildingBlock.Workflow.Contracts.Responses;
namespace BuildingBlock.Workflow.Contracts.Abstractions;
public interface IWorkflowCapabilityContract
{
Task<TransitionWorkflowStateResponse> TransitionWorkflowStateAsync(
TransitionWorkflowStateRequest request,
CancellationToken cancellationToken);
}

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,11 @@
namespace BuildingBlock.Workflow.Contracts.Contracts;
public enum WorkflowState
{
Queued = 0,
InProgress = 1,
Blocked = 2,
Completed = 3,
Failed = 4,
Canceled = 5
}

View File

@ -0,0 +1,8 @@
namespace BuildingBlock.Workflow.Contracts.Contracts;
public sealed record WorkflowWorkItemContract(
string WorkItemId,
string WorkType,
int Priority,
DateTime RequestedAtUtc,
WorkflowState CurrentState);

View File

@ -0,0 +1,9 @@
using BuildingBlock.Workflow.Contracts.Contracts;
namespace BuildingBlock.Workflow.Contracts.Requests;
public sealed record TransitionWorkflowStateRequest(
string WorkItemId,
WorkflowState TargetState,
string RequestedBy,
DateTime RequestedAtUtc);

View File

@ -0,0 +1,10 @@
using BuildingBlock.Workflow.Contracts.Contracts;
namespace BuildingBlock.Workflow.Contracts.Responses;
public sealed record TransitionWorkflowStateResponse(
string WorkItemId,
WorkflowState PreviousState,
WorkflowState CurrentState,
bool TransitionApplied,
string? RejectionReason);