Rystem.RepositoryFramework.Cache
9.0.4
dotnet add package Rystem.RepositoryFramework.Cache --version 9.0.4
NuGet\Install-Package Rystem.RepositoryFramework.Cache -Version 9.0.4
<PackageReference Include="Rystem.RepositoryFramework.Cache" Version="9.0.4" />
paket add Rystem.RepositoryFramework.Cache --version 9.0.4
#r "nuget: Rystem.RepositoryFramework.Cache, 9.0.4"
// Install Rystem.RepositoryFramework.Cache as a Cake Addin #addin nuget:?package=Rystem.RepositoryFramework.Cache&version=9.0.4 // Install Rystem.RepositoryFramework.Cache as a Cake Tool #tool nuget:?package=Rystem.RepositoryFramework.Cache&version=9.0.4
What is Rystem?
Cache
Examples
You can add a repository (with default blob integration for instance) and after attack an in memory cache for all methods. The RefreshTime is a property that adds an Expiration date to the cached value, in the example below you can see that after 20 seconds the in memory cache requests again to the repository pattern a new value for each key. The Methods is a flag that allows to setup what operations have to be cached.
Query → query will be cached with this key
var keyAsString = $"{nameof(RepositoryMethods.Query)}_{typeof(T).Name}_{FactoryName}_{filter.ToKey()}";
Operation → operation will be cached with this key
var keyAsString = $"{nameof(RepositoryMethods.Operation)}_{operation.Name}_{typeof(T).Name}_{FactoryName}_{filter.ToKey()}";
Get → query will be cached with this key
var keyAsString = $"{nameof(RepositoryMethods.Get)}_{typeof(T).Name}_{FactoryName}_{key.AsString()}";
Exist → query will be cached with this key
var keyAsString = $"{nameof(RepositoryMethod.Exist)}_{typeof(T).Name}_{FactoryName}_{key.AsString()}";
Now you can understand the special behavior for commands. If you set Insert and/or Update and/or Delete, during any command if you allowed it for each command automatically the framework will update the cache value, with updated or inserted value or removing the deleted value. The code below allows everything
x.Methods = RepositoryMethod.All
In the example below you're setting up the following behavior: setting up a cache only for Get operation, and update the Get cache when exists a new Insert or an Update, or a removal when Delete operation were perfomed.
x.Methods = RepositoryMethod.Get | RepositoryMethod.Insert | RepositoryMethod.Update | RepositoryMethod.Delete
Setup in DI
services
.AddRepository<Plant, int>(settings =>
{
settings
.WithInMemory();
settings
.WithInMemoryCache(x =>
{
x.ExpiringTime = TimeSpan.FromSeconds(1);
x.Methods = RepositoryMethods.All;
});
});
Usage
You always will find the same interface. For instance
IRepository<Plant, int> repository
or if you added a query pattern or command pattern
IQuery<Plant, int> query
ICommand<Plant, int> command
Distributed Cache
Based on this link you may use the standard interface IDistributedCache instead of create a custom IDistributedCache<T, TKey, TState>. For instance you may choose between three libraries: Distributed SQL Server cache, Distributed Redis cache, Distributed NCache cache. You need to add the cache
builder.Services.AddStackExchangeRedisCache(options =>
{
options.Configuration = builder.Configuration.GetConnectionString("MyRedisConStr");
options.InstanceName = "SampleInstance";
});
then you add the IDistributedCache implementation to your repository patterns or CQRS.
.AddRepository<Country, CountryKey>(builder =>
{
builder
.WithInMemory(inMemoryBuilder =>
{
inMemoryBuilder
.PopulateWithRandomData(NumberOfEntries, NumberOfEntries);
});
builder
.WithDistributedCache(distributedCacheBuilder =>
{
distributedCacheBuilder.ExpiringTime = TimeSpan.FromSeconds(10);
});
});
or a mix of them
.AddRepository<Country, CountryKey>(builder =>
{
builder
.WithInMemory(inMemoryBuilder =>
{
inMemoryBuilder
.PopulateWithRandomData(NumberOfEntries, NumberOfEntries);
});
builder
.WithInMemoryCache(inMemoryCacheBuilder =>
{
inMemoryCacheBuilder.ExpiringTime = TimeSpan.FromSeconds(10);
})
.WithDistributedCache(distributedCacheBuilder =>
{
distributedCacheBuilder.ExpiringTime = TimeSpan.FromSeconds(10);
});
});
and as always you will use the standard interface that is automatically integrated in the repository flow.
IRepository<User, string> repository;
The same is valid for ICommand and IQuery.
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net9.0 is compatible. |
-
net9.0
- Microsoft.Extensions.Caching.Abstractions (>= 9.0.0)
- Microsoft.Extensions.Caching.Memory (>= 9.0.0)
- Rystem.RepositoryFramework.Abstractions (>= 9.0.4)
NuGet packages (1)
Showing the top 1 NuGet packages that depend on Rystem.RepositoryFramework.Cache:
Package | Downloads |
---|---|
Rystem.RepositoryFramework.Cache.Azure.Storage.Blob
Rystem.RepositoryFramework allows you to use correctly concepts like repository pattern, CQRS and DDD. You have interfaces for your domains, auto-generated api, auto-generated HttpClient to simplify connection "api to front-end", a functionality for auto-population in memory of your models, a functionality to simulate exceptions and waiting time from external sources to improve your implementation/business test and load test. |
GitHub repositories
This package is not used by any popular GitHub repositories.
Version | Downloads | Last updated |
---|---|---|
9.0.4 | 79,495 | 12/23/2024 |
9.0.3 | 94 | 12/22/2024 |
9.0.2 | 10,641 | 12/21/2024 |
9.0.1 | 1,126 | 12/21/2024 |
9.0.0 | 172,906 | 11/16/2024 |
9.0.0-rc.1 | 84 | 10/18/2024 |
6.2.0 | 219,047 | 10/9/2024 |
6.1.1 | 110 | 10/9/2024 |
6.1.0 | 47,862 | 9/29/2024 |
6.0.24 | 127 | 9/11/2024 |
6.0.23 | 117 | 7/18/2024 |
6.0.21 | 134 | 6/18/2024 |
6.0.20 | 130 | 6/16/2024 |
6.0.19 | 126 | 6/14/2024 |
6.0.18 | 120 | 6/14/2024 |
6.0.17 | 119 | 6/14/2024 |
6.0.16 | 112 | 6/10/2024 |
6.0.15 | 132 | 6/9/2024 |
6.0.14 | 131 | 5/24/2024 |
6.0.13 | 132 | 5/23/2024 |
6.0.12 | 120 | 5/23/2024 |
6.0.11 | 142 | 5/20/2024 |
6.0.9 | 146 | 5/20/2024 |
6.0.7 | 129 | 5/18/2024 |
6.0.6 | 120 | 5/10/2024 |
6.0.5 | 132 | 5/10/2024 |
6.0.4 | 165 | 4/3/2024 |
6.0.3 | 1,469 | 3/25/2024 |
6.0.2 | 194 | 3/11/2024 |
6.0.0 | 1,014 | 11/21/2023 |
6.0.0-rc.6 | 114 | 10/25/2023 |
6.0.0-rc.5 | 85 | 10/25/2023 |
6.0.0-rc.4 | 78 | 10/23/2023 |
6.0.0-rc.3 | 74 | 10/19/2023 |
6.0.0-rc.2 | 84 | 10/18/2023 |
6.0.0-rc.1 | 86 | 10/16/2023 |
5.0.20 | 525 | 9/25/2023 |
5.0.19 | 519 | 9/10/2023 |
5.0.18 | 502 | 9/6/2023 |
5.0.17 | 482 | 9/6/2023 |
5.0.16 | 559 | 9/5/2023 |
5.0.15 | 505 | 9/5/2023 |
5.0.14 | 501 | 9/5/2023 |
5.0.13 | 496 | 9/1/2023 |
5.0.12 | 469 | 8/31/2023 |
5.0.11 | 498 | 8/30/2023 |
5.0.10 | 525 | 8/29/2023 |
5.0.9 | 505 | 8/24/2023 |
5.0.8 | 514 | 8/24/2023 |
5.0.7 | 536 | 8/23/2023 |
5.0.6 | 549 | 8/21/2023 |
5.0.5 | 530 | 8/21/2023 |
5.0.4 | 558 | 8/16/2023 |
5.0.3 | 621 | 8/2/2023 |
5.0.2 | 577 | 8/2/2023 |
5.0.1 | 603 | 8/1/2023 |
5.0.0 | 606 | 7/31/2023 |
4.1.26 | 632 | 7/20/2023 |
4.1.25 | 598 | 7/16/2023 |
4.1.24 | 711 | 6/13/2023 |
4.1.23 | 619 | 6/13/2023 |
4.1.22 | 1,019 | 5/30/2023 |
4.1.21 | 613 | 5/20/2023 |
4.1.20 | 315,642 | 4/19/2023 |
4.1.19 | 95,561 | 3/20/2023 |
4.1.18 | 721 | 3/20/2023 |
4.1.17 | 696 | 3/16/2023 |
4.1.16 | 701 | 3/16/2023 |
4.1.15 | 695 | 3/15/2023 |
4.1.14 | 1,783 | 3/9/2023 |
4.1.13 | 722 | 3/7/2023 |
4.1.12 | 875 | 2/10/2023 |
4.1.11 | 751 | 1/26/2023 |
4.1.10 | 769 | 1/22/2023 |
4.1.9 | 741 | 1/20/2023 |
4.1.8 | 753 | 1/18/2023 |
4.1.7 | 745 | 1/18/2023 |
4.1.6 | 754 | 1/17/2023 |
4.1.1 | 787 | 1/4/2023 |
4.1.0 | 788 | 1/1/2023 |
3.1.5 | 768 | 12/21/2022 |
3.1.3 | 775 | 12/12/2022 |
3.1.2 | 756 | 12/7/2022 |
3.1.1 | 773 | 12/7/2022 |
3.1.0 | 830 | 12/2/2022 |
3.0.29 | 765 | 12/1/2022 |
3.0.28 | 787 | 12/1/2022 |
3.0.27 | 830 | 11/23/2022 |
3.0.25 | 894 | 11/23/2022 |
3.0.24 | 893 | 11/18/2022 |
3.0.23 | 886 | 11/18/2022 |
3.0.22 | 889 | 11/15/2022 |
3.0.21 | 882 | 11/14/2022 |
3.0.20 | 918 | 11/13/2022 |
3.0.19 | 1,024 | 11/2/2022 |
3.0.18 | 893 | 11/2/2022 |
3.0.17 | 945 | 10/29/2022 |
3.0.16 | 946 | 10/29/2022 |
3.0.15 | 933 | 10/29/2022 |
3.0.14 | 1,075 | 10/24/2022 |
3.0.13 | 955 | 10/24/2022 |
3.0.12 | 947 | 10/17/2022 |
3.0.11 | 992 | 10/10/2022 |
3.0.10 | 990 | 10/6/2022 |
3.0.9 | 980 | 10/6/2022 |
3.0.8 | 977 | 10/6/2022 |
3.0.7 | 915 | 10/6/2022 |
3.0.6 | 985 | 10/5/2022 |
3.0.5 | 859 | 10/5/2022 |
3.0.4 | 994 | 10/5/2022 |
3.0.3 | 974 | 10/3/2022 |
3.0.2 | 964 | 9/30/2022 |
3.0.1 | 982 | 9/30/2022 |
2.0.17 | 864 | 9/29/2022 |
2.0.16 | 1,006 | 9/27/2022 |
2.0.15 | 1,054 | 9/27/2022 |
2.0.14 | 1,042 | 9/26/2022 |
2.0.13 | 1,002 | 9/26/2022 |
2.0.12 | 999 | 9/26/2022 |
2.0.11 | 1,026 | 9/25/2022 |
2.0.10 | 1,073 | 9/25/2022 |
2.0.9 | 1,038 | 9/22/2022 |
2.0.8 | 993 | 9/22/2022 |
2.0.6 | 1,025 | 9/20/2022 |
2.0.5 | 1,157 | 9/20/2022 |
2.0.4 | 999 | 9/20/2022 |
2.0.2 | 1,024 | 9/20/2022 |
2.0.1 | 1,076 | 9/13/2022 |
2.0.0 | 991 | 8/19/2022 |
1.1.24 | 1,085 | 7/30/2022 |
1.1.23 | 1,057 | 7/29/2022 |
1.1.22 | 906 | 7/29/2022 |
1.1.21 | 1,020 | 7/29/2022 |
1.1.20 | 1,036 | 7/29/2022 |
1.1.19 | 1,040 | 7/27/2022 |
1.1.17 | 1,091 | 7/27/2022 |
1.1.16 | 1,012 | 7/26/2022 |
1.1.15 | 1,034 | 7/25/2022 |
1.1.14 | 1,031 | 7/25/2022 |
1.1.13 | 1,015 | 7/22/2022 |
1.1.12 | 1,051 | 7/19/2022 |
1.1.11 | 1,042 | 7/19/2022 |
1.1.10 | 1,004 | 7/19/2022 |
1.1.9 | 1,043 | 7/19/2022 |
1.1.8 | 1,072 | 7/18/2022 |
1.1.7 | 1,029 | 7/18/2022 |
1.1.6 | 1,031 | 7/18/2022 |
1.1.5 | 1,062 | 7/17/2022 |
1.1.4 | 913 | 7/17/2022 |
1.1.3 | 1,181 | 7/17/2022 |
1.1.2 | 1,032 | 7/17/2022 |
1.1.0 | 1,054 | 7/17/2022 |
1.0.2 | 1,014 | 7/15/2022 |
1.0.1 | 909 | 7/15/2022 |
1.0.0 | 1,055 | 7/8/2022 |
0.10.7 | 1,011 | 7/7/2022 |
0.10.2 | 1,044 | 7/2/2022 |
0.10.1 | 1,061 | 7/1/2022 |
0.10.0 | 940 | 7/1/2022 |
0.9.10 | 1,012 | 6/20/2022 |
0.9.9 | 1,017 | 6/11/2022 |
0.9.7 | 901 | 6/9/2022 |
0.9.6 | 926 | 6/9/2022 |