ModularPipelines.Git 2.11.11

Prefix Reserved
There is a newer version of this package available.
See the version list below for details.
dotnet add package ModularPipelines.Git --version 2.11.11                
NuGet\Install-Package ModularPipelines.Git -Version 2.11.11                
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.Git" Version="2.11.11" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add ModularPipelines.Git --version 2.11.11                
#r "nuget: ModularPipelines.Git, 2.11.11"                
#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.Git as a Cake Addin
#addin nuget:?package=ModularPipelines.Git&version=2.11.11

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

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

Features

  • Parallel execution with easy waiting on dependencies if necessary
  • 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
  • Dynamic console progress reporting (if the console supports interactive mode)

Available Modules

Package Version
ModularPipelines nuget
ModularPipelines.AmazonWebServices nuget
ModularPipelines.Azure nuget
ModularPipelines.Azure.Pipelines nuget
ModularPipelines.Cmd nuget
ModularPipelines.Docker nuget
ModularPipelines.DotNet nuget
ModularPipelines.Email nuget
ModularPipelines.Ftp nuget
ModularPipelines.Git nuget
ModularPipelines.GitHub nuget
ModularPipelines.Helm nuget
ModularPipelines.Kubernetes nuget
ModularPipelines.MicrosoftTeams nuget
ModularPipelines.Node nuget
ModularPipelines.NuGet nuget
ModularPipelines.Slack nuget
ModularPipelines.TeamCity nuget
ModularPipelines.Terraform nuget

Getting Started

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

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>
{
    private readonly ISomeService1 _someService1;

    public FindNugetPackagesModule(ISomeService1 someService1) 
    {
        _someService1 = someService1;
    }

    protected override async Task<List<File>?> ExecuteAsync(IPipelineContext context, CancellationToken cancellationToken)
    {
        await _someService1.DoSomething();

        return context.Git()
            .RootDirectory
            .GetFiles(path => path.Extension is ".nupkg")
            .ToList();
    }
}
[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 context.NuGet()
            .UploadPackages(new NuGetUploadOptions(packagePaths.Value!.AsPaths(), new Uri("https://api.nuget.org/v3/index.json"))
            {
                ApiKey = _nugetSettings.Value.ApiKey,
                NoSymbols = true
            });
    }
}

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 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.  net9.0 was computed.  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 (1)

Showing the top 1 NuGet packages that depend on ModularPipelines.Git:

Package Downloads
ModularPipelines.GitHub

Helpers for interacting with GitHub Actions build agents.

GitHub repositories (2)

Showing the top 2 popular GitHub repositories that depend on ModularPipelines.Git:

Repository Stars
thomhurst/TUnit
A modern, fast and flexible .NET testing framework
thomhurst/EnumerableAsyncProcessor
Process Multiple Asynchronous Tasks in Various Ways - One at a time / Batched / Rate limited / Concurrently
Version Downloads Last updated
2.42.228 748 1/10/2025
2.42.226 134 1/9/2025
2.42.140 2,669 12/1/2024
2.42.134 329 11/30/2024
2.42.132 138 11/30/2024
2.42.115 5,519 11/17/2024
2.42.87 1,969 10/28/2024
2.42.67 3,871 9/29/2024
2.42.59 1,350 9/19/2024
2.42.54 193 9/19/2024
2.42.53 130 9/19/2024
2.42.47 999 9/13/2024
2.42.45 6,890 9/12/2024
2.42.9 1,898 9/5/2024
2.42.8 494 9/4/2024
2.42.0 174 9/4/2024
2.41.4 191 9/3/2024
2.41.0 291 9/3/2024
2.40.18 203 9/2/2024
2.40.15 124 9/2/2024
2.40.10 199 9/2/2024
2.40.8 130 9/2/2024
2.40.4 1,587 8/29/2024
2.40.1 211 8/28/2024
2.38.36 256 8/26/2024
2.38.25 789 8/12/2024
2.38.2 760 7/27/2024
2.38.1 114 7/27/2024
2.37.9 344 7/14/2024
2.37.1 112 7/14/2024
2.36.29 609 7/5/2024
2.36.23 449 6/30/2024
2.36.4 1,050 6/7/2024
2.35.0 274 6/2/2024
2.34.0 295 5/23/2024
2.33.0 502 5/20/2024
2.32.0 203 5/17/2024
2.31.3 970 4/15/2024
2.31.0 133 4/15/2024
2.30.9 372 3/27/2024
2.30.5 130 3/26/2024
2.30.3 132 3/26/2024
2.29.32 155 3/26/2024
2.29.22 442 3/8/2024
2.29.15 229 3/1/2024
2.29.11 185 2/27/2024
2.29.9 304 2/26/2024
2.29.0 143 2/25/2024
2.28.0 146 2/23/2024
2.27.12 328 2/15/2024
2.27.9 164 2/14/2024
2.27.3 313 2/8/2024
2.27.0 122 2/8/2024
2.26.8 279 2/4/2024
2.26.0 372 1/29/2024
2.25.0 150 1/28/2024
2.24.9 246 1/25/2024
2.24.4 116 1/25/2024
2.24.1 186 1/22/2024
2.22.0 133 1/18/2024
2.21.12 150 1/18/2024
2.21.9 131 1/18/2024
2.21.4 175 1/13/2024
2.21.0 107 1/12/2024
2.20.2 173 1/11/2024
2.19.2 283 12/27/2023
2.19.0 155 12/26/2023
2.18.8 117 12/26/2023
2.18.0 233 12/24/2023
2.17.25 188 12/22/2023
2.17.20 353 12/5/2023
2.17.0 308 11/24/2023
2.16.2 141 11/23/2023
2.16.0 158 11/23/2023
2.15.24 166 11/22/2023
2.15.21 141 11/22/2023
2.15.17 150 11/20/2023
2.15.3 196 11/9/2023
2.15.0 107 11/8/2023
2.14.9 201 11/6/2023
2.14.7 146 11/6/2023
2.14.1 143 11/6/2023
2.13.63 178 10/29/2023
2.13.47 226 10/20/2023
2.13.8 163 10/13/2023
2.13.5 137 10/13/2023
2.12.15 144 10/10/2023
2.12.11 190 10/10/2023
2.12.5 148 10/6/2023
2.12.1 161 10/4/2023
2.11.12 162 10/1/2023
2.11.11 138 9/30/2023
2.11.9 157 9/30/2023
2.11.4 153 9/30/2023
2.11.0 192 9/29/2023
2.10.6 246 9/29/2023
2.10.0 144 9/28/2023
2.9.0 134 9/28/2023
2.8.23 146 9/26/2023
2.8.12 151 9/24/2023
2.8.4 140 9/24/2023
2.8.0 140 9/24/2023
2.7.10 143 9/23/2023
2.7.6 151 9/22/2023
2.6.0 158 9/19/2023
2.5.11 154 9/16/2023
2.5.5 166 9/14/2023
2.5.2 162 9/14/2023
2.5.0 134 9/14/2023
2.4.0 143 9/12/2023
2.3.2 168 9/11/2023
2.3.0 155 9/11/2023
2.2.0 170 9/11/2023
2.0.8 161 9/7/2023
2.0.5 137 9/6/2023
2.0.0 148 9/6/2023
1.9.38 152 9/5/2023
1.9.36 133 9/5/2023
1.9.35 148 9/4/2023
1.9.31 153 9/4/2023
1.9.28 152 9/4/2023
1.9.22 153 9/3/2023
1.9.17 147 9/3/2023
1.9.15 139 9/3/2023
1.9.8 149 9/1/2023
1.9.6 168 9/1/2023
1.9.4 163 9/1/2023
1.9.1 170 8/31/2023
1.8.22 188 8/29/2023
1.8.18 150 8/29/2023
1.8.8 149 8/24/2023
1.8.6 149 8/24/2023
1.7.0 160 8/22/2023
1.6.3 168 8/17/2023
1.6.2 156 8/17/2023
1.6.1 195 8/17/2023
1.6.0 177 8/17/2023
1.5.5 187 8/15/2023
1.5.0 178 8/14/2023
1.4.34 183 8/11/2023
1.4.33 162 8/11/2023
1.4.31 189 8/11/2023
1.4.29 167 8/10/2023
1.4.22 173 8/10/2023
1.4.21 234 8/10/2023
1.4.20 183 8/10/2023
1.4.18 184 8/7/2023
1.4.17 181 8/7/2023
1.4.15 185 8/7/2023
1.4.14 194 8/2/2023
1.4.12 190 8/2/2023
1.4.11 187 7/19/2023
1.4.10 191 7/19/2023
1.4.9 177 7/18/2023
1.4.8 179 7/18/2023
1.4.6 189 7/13/2023
1.4.5 170 7/11/2023
1.4.4 187 7/10/2023
1.4.3 172 7/10/2023
1.4.2 188 7/7/2023
1.4.1 213 7/6/2023
1.4.0 175 7/6/2023
1.3.17 188 7/5/2023
1.3.15 190 7/5/2023
1.3.14 181 7/5/2023
1.3.13 172 7/5/2023
1.3.12 184 6/30/2023
1.3.11 199 6/30/2023
1.3.8 193 6/30/2023
1.3.7 187 6/30/2023
1.3.6 185 6/30/2023
1.3.5 162 6/30/2023
1.3.4 184 6/30/2023
1.3.3 186 6/29/2023
1.3.2 183 6/29/2023
1.3.1 176 6/29/2023
1.3.0 182 6/29/2023
1.2.0 173 6/29/2023
1.1.0 176 6/29/2023
1.0.1 188 6/29/2023
0.3.26 190 6/29/2023
0.2.0 169 6/29/2023
0.1.1-initial-2-0027 149 6/8/2023
0.1.1-initial-2-0025 149 6/8/2023
0.1.1-initial-2-0024 146 6/8/2023
0.1.0 193 6/28/2023
0.1.0-initial-2-19 147 6/8/2023
0.1.0-initial-2-0023 146 6/8/2023
0.1.0-initial-2.1 63 6/8/2023
0.0.1-alpha03 147 5/29/2023
0.0.1-alpha02 136 5/28/2023
0.0.1-alpha01 140 5/28/2023