// Copyright (c) Microsoft Open Technologies, Inc. // All Rights Reserved // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. // You may obtain a copy of the License at // // http://www.apache.org/licenses/LICENSE-2.0 // // THIS CODE IS PROVIDED *AS IS* BASIS, WITHOUT WARRANTIES OR // CONDITIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED, INCLUDING // WITHOUT LIMITATION ANY IMPLIED WARRANTIES OR CONDITIONS OF // TITLE, FITNESS FOR A PARTICULAR PURPOSE, MERCHANTABLITY OR // NON-INFRINGEMENT. // See the Apache 2 License for the specific language governing // permissions and limitations under the License. using Microsoft.AspNet.DependencyInjection; using System; namespace Microsoft.AspNet.Identity { public class IdentityBuilder where TUser : class where TRole : class { private ServiceCollection Services { get; set; } public IdentityBuilder(ServiceCollection services) { Services = services; } public IdentityBuilder Use(Func func) { Services.AddInstance(func()); return this; } public IdentityBuilder UseIdentity() { Services.Add(IdentityServices.GetDefaultUserServices()); Services.Add(IdentityServices.GetDefaultRoleServices()); return this; } public IdentityBuilder UseUserStore(Func> func) { return Use(func); } public IdentityBuilder UseRoleStore(Func> func) { return Use(func); } public IdentityBuilder UsePasswordValidator(Func func) { return Use(func); } public IdentityBuilder UseUserValidator(Func> func) { return Use(func); } public IdentityBuilder UseUserManager() where TManager : UserManager { Services.AddScoped(); return this; } public IdentityBuilder UseRoleManager() where TManager : RoleManager { Services.AddScoped(); return this; } //public IdentityBuilder UseTwoFactorProviders(Func>> func) //{ // return Use(func); //} public IdentityBuilder UseLockoutPolicy(Func func) { return Use(func); } } }