using DotBased.AspNet.Authority.Crypto; using DotBased.AspNet.Authority.Models.Authority; using DotBased.AspNet.Authority.Models.Options; using DotBased.AspNet.Authority.Services; using DotBased.AspNet.Authority.Validators; using Microsoft.Extensions.DependencyInjection; using Microsoft.Extensions.DependencyInjection.Extensions; namespace DotBased.AspNet.Authority; public static class AuthorityProviderExtensions { public static AuthorityBuilder AddAuthority(this IServiceCollection services, Action? optionsAction = null) => services.AddAuthority(optionsAction); public static AuthorityBuilder AddAuthority(this IServiceCollection services, Action? optionsAction = null) where TUser : class where TGroup : class where TRole : class { if (optionsAction != null) { services.AddOptions(); services.Configure(optionsAction); } services.TryAddScoped(); services.TryAddScoped(); services.TryAddScoped, PasswordOptionsValidator>(); services.TryAddScoped, UserValidator>(); /*services.TryAddScoped(); services.TryAddScoped(); services.TryAddScoped();*/ services.TryAddScoped(); services.TryAddScoped>(); services.TryAddScoped>(); services.TryAddScoped>(); return new AuthorityBuilder(services); } public static AuthorityBuilder AddAuthorityRepository(this AuthorityBuilder authorityBuilder) where TRepository : class { return authorityBuilder; } public static AuthorityBuilder MapAuthorityEndpoints(this AuthorityBuilder builder) { return builder; } }