GHM.Pipeline
3.0.2
See the version list below for details.
dotnet add package GHM.Pipeline --version 3.0.2
NuGet\Install-Package GHM.Pipeline -Version 3.0.2
<PackageReference Include="GHM.Pipeline" Version="3.0.2" />
paket add GHM.Pipeline --version 3.0.2
#r "nuget: GHM.Pipeline, 3.0.2"
// Install GHM.Pipeline as a Cake Addin #addin nuget:?package=GHM.Pipeline&version=3.0.2 // Install GHM.Pipeline as a Cake Tool #tool nuget:?package=GHM.Pipeline&version=3.0.2
<p align="center"> <img src="logo.png" alt="logo" width="200px"/> </p>
<h1 align="center"> GHM.Pipeline </h1>
GHM.Pipeline is a nuget package aims to manage pipelines in parts, where a pipeline has many stages and a stage has many steps.
Install Package
.NET CLI
dotnet add package GHM.Pipeline
Package Manager
NuGet\Install-Package GHM.Pipeline
Example
As an example, we will use an e-commerce pipeline in which the order is requested, validated, processed, shipped, and finalized. Within each stage, there are one or more steps.
Stages:
- Requested (
STAGE
)- requested by customer (
STEP
) - to insert in DataBase (
STEP
)
- requested by customer (
- Validation (
STAGE
)- customer has all data has been successfully validated (
STEP
) - seller has all data has been successfully validated (
STEP
)
- customer has all data has been successfully validated (
- Processing (
STAGE
)- to Process credit card (
STEP
)
- to Process credit card (
- Sending (
STAGE
)- to send the product (
STEP
)
- to send the product (
- Finish (
STAGE
)- confirmation of product to customer's localization (
STEP
)
- confirmation of product to customer's localization (
using GHM.Pipeline;
public static class EcommercePipeline{
public RequestedStage CreateRequestStage(EcommerceData data) => new(data);
public ValidationStage CreateValidationStage(EcommerceData data) => new(data)
}
public class RequestedStage : Stage<EcommerceData>
{
public RequestedStage(EcommerceData data)
: base(data) { }
}
public class ValidationStage : Stage<EcommerceData>
{
public RequestedStage(EcommerceData data)
: base(data) { }
}
public class EcommerceData { }
In services code
using GHM.Pipeline;
public class EcommerceService
{
public void Request(EcommerceData data)
{
RequestedStage stage = EcommercePipeline.CreateRequestedStage(data);
try
{
stage.AddInformation("processing request stage") // this step is only a information
if(data is null)
{
stage.AddCanceled("has no data to request") // this step canceled the stage
}
stage.AddSuccess("add data") // // this step validated the stage
}
catch (Exception ex)
{
stage.AddError("internal error: " + ex.Message) // // this step create a error to the stage
}
}
}
Classes
Step
Step has many Status. The following list is ordered by more critical desc:
- Canceled
- Error
- InProgress
- InAdjustment
- Success
- Information
- Default
Step step = Step.Success("success test","Step Name")
step.Status // Success
step.IsSuccess // true
step.IsError // false
step.IsCanceled // false
Stage
Stage has:
- Many steps
- Data to execute the stage process
- Status more critical in step list
Star
if you enjoy, don't forget the ⭐ and install the package 😊.
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net7.0 is compatible. net7.0-android was computed. net7.0-ios was computed. net7.0-maccatalyst was computed. net7.0-macos was computed. net7.0-tvos was computed. net7.0-windows was computed. net8.0 was computed. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. |
-
net7.0
- No dependencies.
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.