private static IServiceCollection AddApplicationAuthentication( this IServiceCollection services, AuthenticationServiceConfiguration config) { JwtSecurityTokenHandler.DefaultInboundClaimTypeMap.Clear(); IdentityModelEventSource.ShowPII = true; services .AddAuthentication(options => { options.DefaultScheme = CookieAuthenticationDefaults.AuthenticationScheme; options.DefaultChallengeScheme = OpenIdConnectDefaults.AuthenticationScheme; }) .AddCookie("Cookies") .AddOpenIdConnect(OpenIdConnectDefaults.AuthenticationScheme, options => { options.SignInScheme = "Cookies"; options.Authority = config.MetadataAddress; options.RequireHttpsMetadata = false; options.ClientId = "apprentice"; options.Scope.Clear(); options.Scope.Add("openid"); options.Scope.Add("profile"); options.SaveTokens = true; options.DisableTelemetry = false; }); return(services); }
public static IServiceCollection AddAuthentication( this IServiceCollection services, AuthenticationServiceConfiguration config, IWebHostEnvironment environment) { services .AddApplicationAuthentication(config) .AddApplicationAuthorisation(environment); services.AddTransient((_) => config); return(services); }