85 lines
3.7 KiB
C#
85 lines
3.7 KiB
C#
using Microsoft.AspNet.Builder;
|
|
using Microsoft.AspNet.Diagnostics;
|
|
using Microsoft.AspNet.Http;
|
|
using Microsoft.AspNet.Identity;
|
|
using Microsoft.AspNet.Routing;
|
|
using Microsoft.AspNet.Security.Cookies;
|
|
using Microsoft.Data.Entity;
|
|
using Microsoft.Framework.ConfigurationModel;
|
|
using Microsoft.Framework.DependencyInjection;
|
|
using IdentitySample.Models;
|
|
|
|
namespace IdentitySamples
|
|
{
|
|
public class Startup
|
|
{
|
|
public void Configure(IBuilder app)
|
|
{
|
|
/* Adding IConfiguration as a service in the IoC to avoid instantiating Configuration again.
|
|
* Below code demonstrates usage of multiple configuration sources. For instance a setting say 'setting1' is found in both the registered sources,
|
|
* then the later source will win. By this way a Local config can be overridden by a different setting while deployed remotely.
|
|
*/
|
|
var configuration = new Configuration();
|
|
configuration.AddJsonFile("LocalConfig.json");
|
|
configuration.AddEnvironmentVariables(); //All environment variables in the process's context flow in as configuration values.
|
|
|
|
app.UseServices(services =>
|
|
{
|
|
// Add EF services to the services container
|
|
services.AddEntityFramework()
|
|
.AddSqlServer();
|
|
|
|
// Configure DbContext
|
|
services.SetupOptions<IdentityDbContextOptions>(options =>
|
|
{
|
|
options.DefaultAdminUserName = configuration.Get("DefaultAdminUsername");
|
|
options.DefaultAdminPassword = configuration.Get("DefaultAdminPassword");
|
|
options.UseSqlServer(configuration.Get("Data:IdentityConnection:ConnectionString"));
|
|
});
|
|
|
|
// Add Identity services to the services container
|
|
services.AddIdentitySqlServer<ApplicationDbContext, ApplicationUser>()
|
|
.AddHttpSignIn()
|
|
.SetupOptions(options =>
|
|
{
|
|
options.Password.RequireDigit = false;
|
|
options.Password.RequireLowercase = false;
|
|
options.Password.RequireUppercase = false;
|
|
options.Password.RequireNonLetterOrDigit = false;
|
|
});
|
|
|
|
// Add MVC services to the services container
|
|
services.AddMvc();
|
|
});
|
|
|
|
/* Error page middleware displays a nice formatted HTML page for any unhandled exceptions in the request pipeline.
|
|
* Note: ErrorPageOptions.ShowAll to be used only at development time. Not recommended for production.
|
|
*/
|
|
app.UseErrorPage(ErrorPageOptions.ShowAll);
|
|
|
|
// Add static files to the request pipeline
|
|
app.UseStaticFiles();
|
|
|
|
// Add cookie-based authentication to the request pipeline
|
|
app.UseCookieAuthentication(new CookieAuthenticationOptions
|
|
{
|
|
AuthenticationType = DefaultAuthenticationTypes.ApplicationCookie,
|
|
LoginPath = new PathString("/Account/Login"),
|
|
});
|
|
|
|
app.UseTwoFactorSignInCookies();
|
|
|
|
// Add MVC to the request pipeline
|
|
app.UseMvc(routes =>
|
|
{
|
|
routes.MapRoute(
|
|
name: "default",
|
|
template: "{controller}/{action}/{id?}",
|
|
defaults: new { controller = "Home", action = "Index" });
|
|
});
|
|
|
|
//Populates the MusicStore sample data
|
|
SampleData.InitializeIdentityDatabaseAsync(app.ApplicationServices).Wait();
|
|
}
|
|
}
|
|
} |