Hyperbee.Pipeline.Caching 1.1.6-develop.240506164152

This is a prerelease version of Hyperbee.Pipeline.Caching.
There is a newer version of this package available.
See the version list below for details.
dotnet add package Hyperbee.Pipeline.Caching --version 1.1.6-develop.240506164152
                    
NuGet\Install-Package Hyperbee.Pipeline.Caching -Version 1.1.6-develop.240506164152
                    
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="Hyperbee.Pipeline.Caching" Version="1.1.6-develop.240506164152" />
                    
For projects that support PackageReference, copy this XML node into the project file to reference the package.
<PackageVersion Include="Hyperbee.Pipeline.Caching" Version="1.1.6-develop.240506164152" />
                    
Directory.Packages.props
<PackageReference Include="Hyperbee.Pipeline.Caching" />
                    
Project file
For projects that support Central Package Management (CPM), copy this XML node into the solution Directory.Packages.props file to version the package.
paket add Hyperbee.Pipeline.Caching --version 1.1.6-develop.240506164152
                    
#r "nuget: Hyperbee.Pipeline.Caching, 1.1.6-develop.240506164152"
                    
#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.
#:package Hyperbee.Pipeline.Caching@1.1.6-develop.240506164152
                    
#:package directive can be used in C# file-based apps starting in .NET 10 preview 4. Copy this into a .cs file before any lines of code to reference the package.
#addin nuget:?package=Hyperbee.Pipeline.Caching&version=1.1.6-develop.240506164152&prerelease
                    
Install as a Cake Addin
#tool nuget:?package=Hyperbee.Pipeline.Caching&version=1.1.6-develop.240506164152&prerelease
                    
Install as a Cake Tool

Hyperbee.Pipeline.Caching

The Hyperbee.Pipeline.Caching library is a set of extentsions to Hyperbee.Pipeline that adds support for caching within a pipeline using Microsoft.Extensions.Caching libraries.

Memory Cache Examples

For simple pipelines the previous step's return value can be used as the key:

// Takes a string and returns a number
var command = PipelineFactory
    .Start<string>()
    .PipeCacheAsync( CharacterCountAsync )
    .Build();

var result = await command( factory.Create( logger ), "test" );

Assert.AreEqual( 4, result );

Or for more complex the options callback can be used to customize how the results will be cached.

// Takes a string and returns a number
var command = PipelineFactory
    .Start<string>()
    .PipeCacheAsync( CharacterCountAsync,
        ( input, options ) =>
        {
            options.Key = $"custom/{input}";
            options.AbsoluteExpirationRelativeToNow = TimeSpan.FromHours( 1 );
            return options;
        } )
    .Build();

var result = await command( factory.Create( logger ), "test" );

Assert.AreEqual( 4, result );

When a set of steps should cache the overload that takes a builder can be used. In this case the inital input will be used at the key and the final step of the nested pipeline will be cached

// Takes a string and returns a number
var command = PipelineFactory
    .Start<string>()
    .PipeCacheAsync( b => b
        .PipeAsync( CharacterCountAsync )
        .Pipe( (ctx, arg) => arg + 100 ))
    .Build();

var result = await command( factory.Create( logger ), "test" );

Assert.AreEqual( 104, result );

Distributed Cache

Distributed Caches work in the same way, but requires the registration of a IDistributedCache, an optional ICacheSerializer serializer (defaults to Json) and only supports Async methods

var command = PipelineFactory
    .Start<string>()
    .PipeDistributedCacheAsync( CharacterCountAsync )
    .Build();

Dependacy Injection

Because this uses the existing DI built into pipelines, caching can be configured with an existing cache.

Memory Cache

// Add Memory Cache
services.AddMemoryCache();

// Share with the pipelines
services.AddPipeline( includeAllServices: true );

Or defined seperately as part of the container use for the pipelines:

services.AddPipeline( (factoryServices, rootProvider) =>
{
    factoryServices.AddMemoryCache();
    factoryServices.AddPipelineDefaultCacheSettings( absoluteExpirationRelativeToNow: TimeSpan.FromHours( 1 ) )
} );

Distributed Cache

An Establish caching services such as SQL needs to be configured:

services.AddDistributedSqlServerCache(options =>
{
    options.ConnectionString = builder.Configuration.GetConnectionString(
        "DistCache_ConnectionString");
    options.SchemaName = "dbo";
    options.TableName = "TestCache";
});

An Optional ICacheSerializer can be registered. If one is missing the JsonCacheSerializer which uses System.Text.Json.JsonSerializer is used.

services.AddTransient<ICacheSerializer, JsonCacheSerializer>()
Product Compatible and additional computed target framework versions.
.NET 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 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.  net10.0 was computed.  net10.0-android was computed.  net10.0-browser was computed.  net10.0-ios was computed.  net10.0-maccatalyst was computed.  net10.0-macos was computed.  net10.0-tvos was computed.  net10.0-windows was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages

This package is not used by any NuGet packages.

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last Updated
2.1.0 169 7/16/2025
2.0.3 165 7/14/2025
2.0.3-develop.250714181624 125 7/14/2025
2.0.2 248 4/14/2025
2.0.2-develop.250414164139 174 4/14/2025
2.0.1 149 2/14/2025
2.0.0-null 125 2/14/2025
1.2.1-develop.250214175105 89 2/14/2025
1.2.0 180 8/9/2024
1.2.0-develop.250214174419 73 2/14/2025
1.2.0-develop.250214173751 92 2/14/2025
1.1.6 145 5/3/2024
1.1.6-develop.240702125702 92 7/2/2024
1.1.6-develop.240506164152 96 5/6/2024