Hyperbee.Pipeline.Caching
                              
                            
                                1.1.6-develop.240506164152
                            
                        
                    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
<PackageReference Include="Hyperbee.Pipeline.Caching" Version="1.1.6-develop.240506164152" />
<PackageVersion Include="Hyperbee.Pipeline.Caching" Version="1.1.6-develop.240506164152" />
<PackageReference Include="Hyperbee.Pipeline.Caching" />
paket add Hyperbee.Pipeline.Caching --version 1.1.6-develop.240506164152
#r "nuget: Hyperbee.Pipeline.Caching, 1.1.6-develop.240506164152"
#:package Hyperbee.Pipeline.Caching@1.1.6-develop.240506164152
#addin nuget:?package=Hyperbee.Pipeline.Caching&version=1.1.6-develop.240506164152&prerelease
#tool nuget:?package=Hyperbee.Pipeline.Caching&version=1.1.6-develop.240506164152&prerelease
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 | Versions 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. | 
- 
                                                    net8.0- Hyperbee.Pipeline (>= 1.0.0-develop.240506164152)
- Microsoft.Extensions.Caching.Abstractions (>= 8.0.0)
 
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 |