Rystem.RepositoryFramework.Api.Client 10.0.1

dotnet add package Rystem.RepositoryFramework.Api.Client --version 10.0.1
                    
NuGet\Install-Package Rystem.RepositoryFramework.Api.Client -Version 10.0.1
                    
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="Rystem.RepositoryFramework.Api.Client" Version="10.0.1" />
                    
For projects that support PackageReference, copy this XML node into the project file to reference the package.
<PackageVersion Include="Rystem.RepositoryFramework.Api.Client" Version="10.0.1" />
                    
Directory.Packages.props
<PackageReference Include="Rystem.RepositoryFramework.Api.Client" />
                    
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 Rystem.RepositoryFramework.Api.Client --version 10.0.1
                    
#r "nuget: Rystem.RepositoryFramework.Api.Client, 10.0.1"
                    
#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 Rystem.RepositoryFramework.Api.Client@10.0.1
                    
#: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=Rystem.RepositoryFramework.Api.Client&version=10.0.1
                    
Install as a Cake Addin
#tool nuget:?package=Rystem.RepositoryFramework.Api.Client&version=10.0.1
                    
Install as a Cake Tool

What is Rystem?

Services extensions

HttpClient to use your API (example)

You can add a client for a specific url

builder.Services.AddRepository<User, string>(builder =>
{
    builder
        .WithApiClient()
        .WithHttpClient("localhost:7058");
});

You may add a Polly policy to your api client for example:

var retryPolicy = HttpPolicyExtensions
  .HandleTransientHttpError()
  .Or<TimeoutRejectedException>()
  .RetryAsync(3);

builder.Services.AddRepository<User, string>(builder =>
{
    builder
        .WithApiClient()
        .WithHttpClient("localhost:7058")
            .ClientBuilder
        .AddPolicyHandler(retryPolicy);
});

and use it in DI with

IRepository<User, string> repository

Query and Command

In DI you install the services

services.AddCommand<User, string>(builder => {
    builder
        .WithApiClient()
        .WithHttpClient("localhost:7058");
});
services.AddQuery<User, string>(builder => {
    builder
        .WithApiClient()
        .WithHttpClient("localhost:7058");
});

And you may inject the objects

Please, use ICommand, IQuery and not ICommandPattern, IQueryPattern

ICommand<User, string> command
IQuery<User, string> command

With a non default key

In DI you install the services with a bool key for example.

services.AddRepository<User, bool>(builder => {
    builder
        .WithApiClient()
        .WithHttpClient("localhost:7058");
});
services.AddCommand<User, bool>(builder => {
    builder
        .WithApiClient()
        .WithHttpClient("localhost:7058");
});
services.AddQuery<User, bool>(builder => {
    builder
        .WithApiClient()
        .WithHttpClient("localhost:7058");
});

And you may inject the objects

Please, use ICommand, IQuery, IRepository and not ICommandPattern, IQueryPattern, IRepositoryPattern

IRepository<User, string> repository
ICommand<User, string> command
IQuery<User, string> command

Interceptors

You may add a custom interceptor for every request for every model

public static IServiceCollection AddApiClientInterceptor<TInterceptor>(this IServiceCollection services,
    ServiceLifetime serviceLifetime = ServiceLifetime.Scoped)
    where TInterceptor : class, IRepositoryClientInterceptor

or a specific interceptor for each model

public static IServiceCollection AddApiClientInterceptor<TInterceptor>(this IServiceCollection services,
    ServiceLifetime serviceLifetime = ServiceLifetime.Scoped)
    where TInterceptor : class, IRepositoryClientInterceptor

or for a string as default TKey

 public static RepositorySettings<T, TKey> AddApiClientSpecificInterceptor<T, TKey, TInterceptor>(
    this RepositorySettings<T, TKey> settings,
    ServiceLifetime serviceLifetime = ServiceLifetime.Scoped)
    where TInterceptor : class, IRepositoryClientInterceptor<T>
    where TKey : notnull   

Maybe you can use it to add a token as JWT o another pre-request things.

Default interceptor for Authentication with JWT

You may use the default interceptor to deal with the identity manager in .Net DI.

builder.Services.AddDefaultAuthorizationInterceptorForApiHttpClient();

with package

RepositoryFramework.Api.Client.Authentication.BlazorServer

or if you need to use in Wasm blazor use with

Rystem.RepositoryFramework.Api.Client.Authentication.BlazorWasm
Product Compatible and additional computed target framework versions.
.NET net10.0 is compatible.  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 (2)

Showing the top 2 NuGet packages that depend on Rystem.RepositoryFramework.Api.Client:

Package Downloads
Rystem.RepositoryFramework.Api.Client.Authentication.BlazorServer

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.

Rystem.RepositoryFramework.Api.Client.Authentication.BlazorWasm

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
10.0.1 254 11/12/2025
9.1.3 319 9/2/2025
9.1.2 764,561 5/29/2025
9.1.1 97,844 5/2/2025
9.0.32 186,640 4/15/2025
9.0.31 5,864 4/2/2025
9.0.30 88,843 3/26/2025
9.0.29 9,052 3/18/2025
9.0.28 236 3/17/2025
9.0.27 226 3/16/2025
9.0.26 267 3/13/2025
9.0.25 52,127 3/9/2025
9.0.21 383 3/6/2025
9.0.20 19,607 3/6/2025
9.0.19 310 3/6/2025
9.0.18 330 3/4/2025
9.0.17 199 3/1/2025
9.0.16 210 3/1/2025
9.0.15 75,575 2/22/2025
9.0.14 22,590 2/18/2025
9.0.13 229 2/9/2025
9.0.12 217,699 1/13/2025
9.0.11 24,069 1/9/2025
9.0.10 195 1/9/2025
9.0.9 4,059 1/7/2025
9.0.8 12,564 1/6/2025
9.0.7 190 1/6/2025
9.0.4 92,350 12/23/2024
9.0.3 215 12/22/2024
9.0.2 10,737 12/21/2024
9.0.1 1,251 12/21/2024
9.0.0 173,105 11/16/2024
9.0.0-rc.1 134 10/18/2024
6.2.0 219,124 10/9/2024
6.1.1 242 10/9/2024
6.1.0 48,025 9/29/2024
6.0.24 253 9/11/2024
6.0.23 340,224 7/18/2024
6.0.21 257 6/18/2024
6.0.20 727,871 6/16/2024
6.0.19 30,513 6/14/2024
6.0.18 252 6/14/2024
6.0.17 231 6/14/2024
6.0.16 50,097 6/10/2024
6.0.15 227 6/9/2024
6.0.14 94,380 5/24/2024
6.0.13 242 5/23/2024
6.0.12 243 5/23/2024
6.0.11 262 5/20/2024
6.0.9 265 5/20/2024
6.0.7 253 5/18/2024
6.0.6 209 5/10/2024
6.0.5 232 5/10/2024
6.0.4 549,900 4/3/2024
6.0.3 287 3/25/2024
6.0.2 393,583 3/11/2024
6.0.0 1,170,150 11/21/2023
6.0.0-rc.6 185 10/25/2023
6.0.0-rc.5 120 10/25/2023
6.0.0-rc.4 134 10/23/2023
6.0.0-rc.3 140 10/19/2023
6.0.0-rc.2 119 10/18/2023
6.0.0-rc.1 113 10/16/2023
5.0.20 638,809 9/25/2023
5.0.19 438 9/10/2023
5.0.18 398 9/6/2023
5.0.17 370 9/6/2023
5.0.16 363 9/5/2023
5.0.15 364 9/5/2023
5.0.14 367 9/5/2023
5.0.13 377 9/1/2023
5.0.12 361 8/31/2023
5.0.11 339 8/30/2023
5.0.10 350 8/29/2023
5.0.9 401 8/24/2023
5.0.8 397 8/24/2023
5.0.7 449,843 8/23/2023
5.0.6 17,653 8/21/2023
5.0.5 4,444 8/21/2023
5.0.4 305 8/16/2023
5.0.3 212,597 8/2/2023
5.0.2 1,862 8/2/2023
5.0.1 11,670 8/1/2023
5.0.0 11,981 7/31/2023
4.1.26 140,809 7/20/2023
4.1.25 24,766 7/16/2023
4.1.24 397,967 6/13/2023
4.1.23 45,838 6/13/2023
4.1.22 129,242 5/30/2023
4.1.21 55,560 5/20/2023
4.1.20 404,712 4/19/2023
4.1.19 95,439 3/20/2023
4.1.18 422 3/20/2023
4.1.17 423 3/16/2023
4.1.16 383 3/16/2023
4.1.15 426 3/15/2023
4.1.14 1,007 3/9/2023
4.1.13 410 3/7/2023
4.1.12 548 2/10/2023
4.1.11 496 1/26/2023
4.1.10 537 1/22/2023
4.1.9 452 1/20/2023
4.1.8 489 1/18/2023
4.1.7 601 1/18/2023
4.1.6 472 1/17/2023
4.1.1 505 1/4/2023
4.1.0 483 1/1/2023
3.1.5 483 12/21/2022
3.1.3 540 12/12/2022
3.1.2 450 12/7/2022
3.1.1 467 12/7/2022
3.1.0 554 12/2/2022
3.0.29 511 12/1/2022
3.0.28 498 12/1/2022
3.0.27 695 11/23/2022
3.0.25 493 11/23/2022
3.0.24 554 11/18/2022
3.0.23 531 11/18/2022
3.0.22 532 11/15/2022
3.0.21 549 11/14/2022
3.0.20 562 11/13/2022
3.0.19 741 11/2/2022
3.0.18 562 11/2/2022
3.0.17 572 10/29/2022
3.0.16 581 10/29/2022
3.0.15 595 10/29/2022
3.0.14 617 10/24/2022
3.0.13 627 10/24/2022
3.0.12 679 10/17/2022
3.0.11 612 10/10/2022
3.0.10 646 10/6/2022
3.0.9 592 10/6/2022
3.0.8 577 10/6/2022
3.0.7 595 10/6/2022
3.0.6 602 10/5/2022
3.0.5 572 10/5/2022
3.0.4 597 10/5/2022
3.0.3 670 10/3/2022
3.0.2 617 9/30/2022
3.0.1 621 9/29/2022
2.0.17 646 9/29/2022
2.0.16 606 9/27/2022
2.0.15 676 9/27/2022
2.0.14 703 9/26/2022
2.0.13 672 9/26/2022
2.0.12 663 9/26/2022
2.0.11 632 9/25/2022
2.0.10 690 9/25/2022
2.0.9 673 9/22/2022
2.0.8 627 9/22/2022
2.0.6 653 9/20/2022
2.0.5 670 9/20/2022
2.0.4 628 9/20/2022
2.0.2 627 9/20/2022
2.0.1 662 9/13/2022
2.0.0 649 8/19/2022
1.1.24 687 7/30/2022
1.1.23 637 7/29/2022
1.1.22 662 7/29/2022
1.1.21 907 7/29/2022
1.1.20 685 7/29/2022
1.1.19 698 7/27/2022
1.1.17 668 7/27/2022
1.1.16 694 7/26/2022
1.1.15 658 7/25/2022
1.1.14 679 7/25/2022
1.1.13 693 7/22/2022
1.1.12 653 7/19/2022
1.1.11 660 7/19/2022
1.1.10 651 7/19/2022
1.1.9 678 7/19/2022
1.1.8 709 7/18/2022
1.1.7 710 7/18/2022
1.1.6 674 7/18/2022
1.1.5 637 7/17/2022
1.1.4 669 7/17/2022
1.1.3 705 7/17/2022
1.1.2 699 7/17/2022
1.1.0 688 7/17/2022
1.0.2 647 7/15/2022
1.0.1 655 7/15/2022
1.0.0 706 7/8/2022
0.10.7 660 7/7/2022
0.10.2 688 7/2/2022
0.10.1 671 7/1/2022
0.10.0 672 7/1/2022
0.9.12 720 6/29/2022
0.9.11 710 6/21/2022
0.9.10 678 6/20/2022
0.9.9 660 6/11/2022
0.9.7 686 6/9/2022
0.9.6 642 6/5/2022
0.9.5 639 6/3/2022
0.9.3 626 6/3/2022
0.9.2 678 5/31/2022
0.9.1 651 5/31/2022
0.9.0 654 5/31/2022