ModularPipelines 2.42.226

Prefix Reserved
There is a newer version of this package available.
See the version list below for details.
dotnet add package ModularPipelines --version 2.42.226                
NuGet\Install-Package ModularPipelines -Version 2.42.226                
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="ModularPipelines" Version="2.42.226" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add ModularPipelines --version 2.42.226                
#r "nuget: ModularPipelines, 2.42.226"                
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
// Install ModularPipelines as a Cake Addin
#addin nuget:?package=ModularPipelines&version=2.42.226

// Install ModularPipelines as a Cake Tool
#tool nuget:?package=ModularPipelines&version=2.42.226                

ModularPipelines

Define your pipeline in .NET! Strong types, intellisense, parallelisation, and the entire .NET ecosystem at your fingertips.

nuget

Nuget GitHub Workflow Status (with event) GitHub last commit (branch) Codacy Badge CodeFactor License Codacy Badge codecov

Documentation

https://thomhurst.github.io/ModularPipelines

Features

  • Parallel execution
  • Dependency management
  • Familiar C# code
  • Ability to debug pipelines
  • Ability to run pipelines locally, even creating versions for setting up local development
  • Strong typing, where different modules/steps can pass data to one another
  • Dependency collision detection - Don't worry about accidentally making two modules dependent on each other
  • Numerous helpers to do things like: Search files, check checksums, (un)zip folders, download files, install files, execute CLI commands, hash data, and more
  • Easy to Skip or Ignore Failures for each individual module by passing in custom logic
  • Hooks that can run before and/or after modules
  • Pipeline requirements - Validate your requirements are met before executing your pipeline, such as a Linux operating system
  • Easy to use File and Folder classes, that can search, read, update, delete and more
  • Source controlled pipelines
  • Build agent agnostic - Can easily move to a different build system without completely recreating your pipeline
  • No need to learn new syntaxes such as YAML defined pipelines
  • Strongly typed wrappers around command line tools
  • Utilise existing .NET libraries
  • Secret obfuscation
  • Grouped logging, and the ability to extend sources by adding to the familiar ILogger
  • Run based on categories
  • Easy to read exceptions
  • Dynamic console progress reporting (if the console supports interactive mode)
  • Pretty results table

Available Modules

Package Description Version
ModularPipelines Write your pipelines in C#! nuget
ModularPipelines.AmazonWebServices Helpers for interacting with Amazon Web Services. nuget
ModularPipelines.Azure Helpers for interacting with Azure. nuget
ModularPipelines.Azure.Pipelines Helpers for interacting with Azure Pipeline agents. nuget
ModularPipelines.Chocolatey Helpers for interacting with the Chocolatey CLI. nuget
ModularPipelines.Cmd Helpers for interacting with the Windows cmd process. nuget
ModularPipelines.Docker Helpers for interacting with the Docker CLI. nuget
ModularPipelines.DotNet Helpers for interacting with dotnet CLI. nuget
ModularPipelines.Email Helpers for sending emails. nuget
ModularPipelines.Ftp Helpers for downloading and uploading via FTP. nuget
ModularPipelines.Git Helpers for interacting with git. nuget
ModularPipelines.GitHub Helpers for interacting with GitHub Actions build agents. nuget
ModularPipelines.Google Helpers for interacting with the Google gcloud CLI. nuget
ModularPipelines.Helm Helpers for interacting with Helm CLI. nuget
ModularPipelines.Kubernetes Helpers for interacting with kubectl CLI. nuget
ModularPipelines.MicrosoftTeams Helpers for sending Microsoft Teams cards. nuget
ModularPipelines.Node Helpers for interacting with node / npm CLI. nuget
ModularPipelines.Slack Helpers for sending Slack cards. nuget
ModularPipelines.TeamCity Helpers for interacting with TeamCity build agents. nuget
ModularPipelines.Terraform Helpers for interacting with Terraform CLI. nuget
ModularPipelines.WinGet Helpers for interacting with the Windows Package Manager. nuget
ModularPipelines.Yarn Helpers for interacting with Yarn CLI. nuget

Getting Started

If you want to see how to get started, or want to know more about ModularPipelines, read the Documentation here

Console Progress

image

Results

<img width="444" alt="image" src="https://github.com/thomhurst/ModularPipelines/assets/30480171/8963e891-2c29-4382-9a3e-6ced4daf4d4b">

How does this compare to Cake / Nuke

  • Strong types! You have complete control over what data, and what shape of data to pass around from and to different modules
  • No external tooling is required. Pipelines are run with a simple dotnet run
  • Full dependency injection support for your services
  • Similar and familiar setup to frameworks like ASP.NET Core
  • Real C# - Whereas frameworks like cake are a scripted form of C#
  • Parallelism - Work will run concurrently unless it is dependent on something else
  • The style of writing pipelines is very different - Work is organised into separate module classes, keeping code organised and more closely following SRP than having all your work in one main class. This also helps multiple contributors avoid things like merge conflicts

Code Examples

Program.cs - Main method

await PipelineHostBuilder.Create()
    .ConfigureAppConfiguration((context, builder) =>
    {
        builder.AddJsonFile("appsettings.json")
            .AddUserSecrets<Program>()
            .AddEnvironmentVariables();
    })
    .ConfigureServices((context, collection) =>
    {
        collection.Configure<NuGetSettings>(context.Configuration.GetSection("NuGet"));
        collection.Configure<PublishSettings>(context.Configuration.GetSection("Publish"));
        collection.AddSingleton<ISomeService1, SomeService1>();
        collection.AddTransient<ISomeService2, SomeService2>();
    })
    .AddModule<FindNugetPackagesModule>()
    .AddModule<UploadNugetPackagesModule>()
    .ExecutePipelineAsync();

Custom Modules

public class FindNugetPackagesModule : Module<FileInfo>
{
    protected override Task<List<File>?> ExecuteAsync(IPipelineContext context, CancellationToken cancellationToken)
    {
        return context.Git()
            .RootDirectory
            .GetFiles(path => path.Extension is ".nupkg")
            .ToList()
            .AsTask();
    }
}
[DependsOn<FindNugetPackagesModule>]
public class UploadNugetPackagesModule : Module<FileInfo>
{
    private readonly IOptions<NuGetSettings> _nugetSettings;

    public UploadNugetPackagesModule(IOptions<NuGetSettings> nugetSettings)
    {
        _nugetSettings = nugetSettings;
    }

    protected override async Task<CommandResult?> ExecuteAsync(IPipelineContext context, CancellationToken cancellationToken)
    {
        var nugetFiles = await GetModule<FindNugetPackagesModule>();

        return await nugetFiles.Value!
            .SelectAsync(async nugetFile => await context.DotNet().Nuget.Push(new DotNetNugetPushOptions
            {
                Path = nugetFile,
                Source = "https://api.nuget.org/v3/index.json",
                ApiKey = _nugetSettings.Value.ApiKey!,
            }, cancellationToken), cancellationToken: cancellationToken)
            .ProcessOneAtATime();
    }
}

Breaking changes

While I will try to limit breaking changes, there may be some changes within minor versions. These will be noted on release notes.

Product Compatible and additional computed target framework versions.
.NET net6.0 is compatible.  net6.0-android was computed.  net6.0-ios was computed.  net6.0-maccatalyst was computed.  net6.0-macos was computed.  net6.0-tvos was computed.  net6.0-windows was computed.  net7.0 was computed.  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 is compatible.  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.  net9.0 is compatible.  net9.0-android was computed.  net9.0-browser was computed.  net9.0-ios was computed.  net9.0-maccatalyst was computed.  net9.0-macos was computed.  net9.0-tvos was computed.  net9.0-windows was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages (25)

Showing the top 5 NuGet packages that depend on ModularPipelines:

Package Downloads
ModularPipelines.AmazonWebServices

Helpers for interacting with Amazon Web Services.

ModularPipelines.Azure.Pipelines

Helpers for interacting with Azure Pipeline agents.

ModularPipelines.DotNet

Helpers for interacting with dotnet CLI.

ModularPipelines.Git

Helpers for interacting with git.

ModularPipelines.Cmd

Helpers for interacting with the Windows cmd process.

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last updated
2.42.228 1,221 1/10/2025
2.42.226 283 1/9/2025
2.42.140 3,048 12/1/2024
2.42.134 625 11/30/2024
2.42.132 420 11/30/2024
2.42.115 6,081 11/17/2024
2.42.87 5,155 10/28/2024
2.42.67 4,312 9/29/2024
2.42.59 1,713 9/19/2024
2.42.54 553 9/19/2024
2.42.53 445 9/19/2024
2.42.47 1,434 9/13/2024
2.42.45 7,314 9/12/2024
2.42.9 2,417 9/5/2024
2.42.8 982 9/4/2024
2.42.0 620 9/4/2024
2.41.4 645 9/3/2024
2.41.0 777 9/3/2024
2.40.18 634 9/2/2024
2.40.15 536 9/2/2024
2.40.10 629 9/2/2024
2.40.8 545 9/2/2024
2.40.4 2,023 8/29/2024
2.40.1 652 8/28/2024
2.38.36 717 8/26/2024
2.38.25 1,372 8/12/2024
2.38.2 1,102 7/27/2024
2.38.1 442 7/27/2024
2.37.9 3,510 7/14/2024
2.37.1 88 7/14/2024
2.36.29 1,070 7/5/2024
2.36.23 950 6/30/2024
2.36.4 1,633 6/7/2024
2.35.0 841 6/2/2024
2.34.0 874 5/23/2024
2.33.0 1,060 5/20/2024
2.32.0 760 5/17/2024
2.31.3 1,641 4/15/2024
2.31.0 771 4/15/2024
2.30.9 950 3/27/2024
2.30.5 561 3/26/2024
2.30.3 625 3/26/2024
2.29.32 737 3/26/2024
2.29.22 1,134 3/8/2024
2.29.15 912 3/1/2024
2.29.11 881 2/27/2024
2.29.9 947 2/26/2024
2.29.0 822 2/25/2024
2.28.0 863 2/23/2024
2.27.12 1,005 2/15/2024
2.27.9 716 2/14/2024
2.27.3 1,030 2/8/2024
2.27.0 879 2/8/2024
2.26.8 1,142 2/4/2024
2.26.0 904 1/29/2024
2.25.0 897 1/28/2024
2.24.9 997 1/25/2024
2.24.4 881 1/25/2024
2.24.1 1,169 1/22/2024
2.22.0 1,076 1/18/2024
2.21.12 1,013 1/18/2024
2.21.9 964 1/18/2024
2.21.4 1,112 1/13/2024
2.21.0 957 1/12/2024
2.20.2 1,024 1/11/2024
2.19.2 1,152 12/27/2023
2.19.0 754 12/26/2023
2.18.8 578 12/26/2023
2.18.0 1,186 12/24/2023
2.17.25 670 12/22/2023
2.17.20 743 12/5/2023
2.17.0 782 11/24/2023
2.16.2 614 11/23/2023
2.16.0 575 11/23/2023
2.15.24 577 11/22/2023
2.15.21 568 11/22/2023
2.15.17 607 11/20/2023
2.15.3 627 11/9/2023
2.15.0 532 11/8/2023
2.14.9 570 11/6/2023
2.14.7 585 11/6/2023
2.14.1 547 11/6/2023
2.13.63 571 10/29/2023
2.13.47 649 10/20/2023
2.13.8 515 10/13/2023
2.13.5 528 10/13/2023
2.12.15 520 10/10/2023
2.12.11 596 10/10/2023
2.12.5 585 10/6/2023
2.12.1 557 10/4/2023
2.11.12 560 10/1/2023
2.11.11 519 9/30/2023
2.11.9 551 9/30/2023
2.11.4 566 9/30/2023
2.11.0 582 9/29/2023
2.10.6 636 9/29/2023
2.10.0 526 9/28/2023
2.9.0 543 9/28/2023
2.8.23 478 9/26/2023
2.8.12 515 9/24/2023
2.8.4 480 9/24/2023
2.8.0 494 9/24/2023
2.7.10 521 9/23/2023
2.7.6 487 9/22/2023
2.6.0 479 9/19/2023
2.5.11 502 9/16/2023
2.5.5 469 9/14/2023
2.5.2 483 9/14/2023
2.5.0 450 9/14/2023
2.4.0 489 9/12/2023
2.3.2 538 9/11/2023
2.3.0 514 9/11/2023
2.2.0 505 9/11/2023
2.0.8 566 9/7/2023
2.0.5 527 9/6/2023
2.0.0 567 9/6/2023
1.9.38 551 9/5/2023
1.9.36 529 9/5/2023
1.9.35 504 9/4/2023
1.9.31 497 9/4/2023
1.9.28 497 9/4/2023
1.9.22 510 9/3/2023
1.9.17 551 9/3/2023
1.9.15 480 9/3/2023
1.9.8 519 9/1/2023
1.9.6 513 9/1/2023
1.9.4 536 9/1/2023
1.9.1 514 8/31/2023
1.8.22 557 8/29/2023
1.8.18 548 8/29/2023
1.8.8 565 8/24/2023
1.8.6 520 8/24/2023
1.7.0 541 8/22/2023
1.6.3 607 8/17/2023
1.6.2 619 8/17/2023
1.6.1 635 8/17/2023
1.6.0 625 8/17/2023
1.5.5 611 8/15/2023
1.5.0 623 8/14/2023
1.4.34 630 8/11/2023
1.4.33 596 8/11/2023
1.4.31 618 8/11/2023
1.4.29 604 8/10/2023
1.4.22 620 8/10/2023
1.4.21 631 8/10/2023
1.4.20 615 8/10/2023
1.4.18 583 8/7/2023
1.4.17 599 8/7/2023
1.4.15 616 8/7/2023
1.4.14 678 8/2/2023
1.4.12 590 8/2/2023
1.4.11 613 7/19/2023
1.4.10 646 7/19/2023
1.4.9 619 7/18/2023
1.4.8 589 7/18/2023
1.4.6 600 7/13/2023
1.4.5 581 7/11/2023
1.4.4 569 7/10/2023
1.4.3 613 7/10/2023
1.4.2 620 7/7/2023
1.4.1 612 7/6/2023
1.4.0 610 7/6/2023
1.3.17 650 7/5/2023
1.3.15 664 7/5/2023
1.3.14 561 7/5/2023
1.3.13 621 7/5/2023
1.3.12 642 6/30/2023
1.3.11 541 6/30/2023
1.3.8 576 6/30/2023
1.3.7 569 6/30/2023
1.3.6 598 6/30/2023
1.3.5 546 6/30/2023
1.3.4 579 6/30/2023
1.3.3 547 6/29/2023
1.3.2 586 6/29/2023
1.3.1 565 6/29/2023
1.3.0 559 6/29/2023
1.2.0 599 6/29/2023
1.1.0 588 6/29/2023
1.0.1 584 6/29/2023
0.3.26 567 6/29/2023
0.2.0 566 6/29/2023
0.1.1-initial-2-0027 480 6/8/2023
0.1.1-initial-2-0025 500 6/8/2023
0.1.1-initial-2-0024 468 6/8/2023
0.1.0 608 6/28/2023
0.1.0-initial-2-19 511 6/8/2023
0.1.0-initial-2-17 363 6/8/2023
0.1.0-initial-2-16 458 6/8/2023
0.1.0-initial-2-0023 447 6/8/2023
0.0.1-alpha03 250 5/29/2023
0.0.1-alpha02 255 5/28/2023
0.0.1-alpha01 246 5/28/2023