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.
$ dotnet add package Rystem.RepositoryFramework.Infrastructure.Dynamics.Dataverse builder.Services.AddRepositoryDataverse<CalamityUniverseUser, string>(x =>
{
x.Prefix = "repo_";
x.SolutionName = "TestAlessandro";
x.Environment = configuration["ConnectionString:Dataverse:Environment"];
x.ApplicationIdentity = new(configuration["ConnectionString:Dataverse:ClientId"],
configuration["ConnectionString:Dataverse:ClientSecret"]);
})
.AddBusinessBeforeInsert<CalamityUniverseUserBeforeInsertBusiness>()
.AddBusinessBeforeInsert<CalamityUniverseUserBeforeInsertBusiness2>();
You found the IRepository<CalamityUniverseUser, string> in DI to play with it.
With automated api, you may have the api implemented with your dataverse integration. You need only to add the AddApiFromRepositoryFramework and UseApiForRepositoryFramework
builder.Services.AddApiFromRepositoryFramework(x =>
{
x.Name = "Repository Api";
x.HasSwagger = true;
x.HasDocumentation = true;
});
var app = builder.Build();
app.UseHttpsRedirection();
app.UseApiForRepositoryFramework();