-
Notifications
You must be signed in to change notification settings - Fork 3
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Showing
72 changed files
with
29,544 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,63 @@ | ||
############################################################################### | ||
# Set default behavior to automatically normalize line endings. | ||
############################################################################### | ||
* text=auto | ||
|
||
############################################################################### | ||
# Set default behavior for command prompt diff. | ||
# | ||
# This is need for earlier builds of msysgit that does not have it on by | ||
# default for csharp files. | ||
# Note: This is only used by command line | ||
############################################################################### | ||
#*.cs diff=csharp | ||
|
||
############################################################################### | ||
# Set the merge driver for project and solution files | ||
# | ||
# Merging from the command prompt will add diff markers to the files if there | ||
# are conflicts (Merging from VS is not affected by the settings below, in VS | ||
# the diff markers are never inserted). Diff markers may cause the following | ||
# file extensions to fail to load in VS. An alternative would be to treat | ||
# these files as binary and thus will always conflict and require user | ||
# intervention with every merge. To do so, just uncomment the entries below | ||
############################################################################### | ||
#*.sln merge=binary | ||
#*.csproj merge=binary | ||
#*.vbproj merge=binary | ||
#*.vcxproj merge=binary | ||
#*.vcproj merge=binary | ||
#*.dbproj merge=binary | ||
#*.fsproj merge=binary | ||
#*.lsproj merge=binary | ||
#*.wixproj merge=binary | ||
#*.modelproj merge=binary | ||
#*.sqlproj merge=binary | ||
#*.wwaproj merge=binary | ||
|
||
############################################################################### | ||
# behavior for image files | ||
# | ||
# image files are treated as binary by default. | ||
############################################################################### | ||
#*.jpg binary | ||
#*.png binary | ||
#*.gif binary | ||
|
||
############################################################################### | ||
# diff behavior for common document formats | ||
# | ||
# Convert binary document formats to text before diffing them. This feature | ||
# is only available from the command line. Turn it on by uncommenting the | ||
# entries below. | ||
############################################################################### | ||
#*.doc diff=astextplain | ||
#*.DOC diff=astextplain | ||
#*.docx diff=astextplain | ||
#*.DOCX diff=astextplain | ||
#*.dot diff=astextplain | ||
#*.DOT diff=astextplain | ||
#*.pdf diff=astextplain | ||
#*.PDF diff=astextplain | ||
#*.rtf diff=astextplain | ||
#*.RTF diff=astextplain |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,22 @@ | ||
|
||
Microsoft Visual Studio Solution File, Format Version 12.00 | ||
# Visual Studio 15 | ||
VisualStudioVersion = 15.0.26206.0 | ||
MinimumVisualStudioVersion = 10.0.40219.1 | ||
Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "EasyAuthKaushal", "EasyAuthKaushal\EasyAuthKaushal.csproj", "{714BBA3C-A063-49D6-8E6C-310F4E2895D8}" | ||
EndProject | ||
Global | ||
GlobalSection(SolutionConfigurationPlatforms) = preSolution | ||
Debug|Any CPU = Debug|Any CPU | ||
Release|Any CPU = Release|Any CPU | ||
EndGlobalSection | ||
GlobalSection(ProjectConfigurationPlatforms) = postSolution | ||
{714BBA3C-A063-49D6-8E6C-310F4E2895D8}.Debug|Any CPU.ActiveCfg = Debug|Any CPU | ||
{714BBA3C-A063-49D6-8E6C-310F4E2895D8}.Debug|Any CPU.Build.0 = Debug|Any CPU | ||
{714BBA3C-A063-49D6-8E6C-310F4E2895D8}.Release|Any CPU.ActiveCfg = Release|Any CPU | ||
{714BBA3C-A063-49D6-8E6C-310F4E2895D8}.Release|Any CPU.Build.0 = Release|Any CPU | ||
EndGlobalSection | ||
GlobalSection(SolutionProperties) = preSolution | ||
HideSolutionNode = FALSE | ||
EndGlobalSection | ||
EndGlobal |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,31 @@ | ||
using System.Web; | ||
using System.Web.Optimization; | ||
|
||
namespace EasyAuthKaushal | ||
{ | ||
public class BundleConfig | ||
{ | ||
// For more information on bundling, visit https://go.microsoft.com/fwlink/?LinkId=301862 | ||
public static void RegisterBundles(BundleCollection bundles) | ||
{ | ||
bundles.Add(new ScriptBundle("~/bundles/jquery").Include( | ||
"~/Scripts/jquery-{version}.js")); | ||
|
||
bundles.Add(new ScriptBundle("~/bundles/jqueryval").Include( | ||
"~/Scripts/jquery.validate*")); | ||
|
||
// Use the development version of Modernizr to develop with and learn from. Then, when you're | ||
// ready for production, use the build tool at https://modernizr.com to pick only the tests you need. | ||
bundles.Add(new ScriptBundle("~/bundles/modernizr").Include( | ||
"~/Scripts/modernizr-*")); | ||
|
||
bundles.Add(new ScriptBundle("~/bundles/bootstrap").Include( | ||
"~/Scripts/bootstrap.js", | ||
"~/Scripts/respond.js")); | ||
|
||
bundles.Add(new StyleBundle("~/Content/css").Include( | ||
"~/Content/bootstrap.css", | ||
"~/Content/site.css")); | ||
} | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,13 @@ | ||
using System.Web; | ||
using System.Web.Mvc; | ||
|
||
namespace EasyAuthKaushal | ||
{ | ||
public class FilterConfig | ||
{ | ||
public static void RegisterGlobalFilters(GlobalFilterCollection filters) | ||
{ | ||
filters.Add(new HandleErrorAttribute()); | ||
} | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,109 @@ | ||
using System; | ||
using System.Collections.Generic; | ||
using System.Data.Entity; | ||
using System.Linq; | ||
using System.Security.Claims; | ||
using System.Threading.Tasks; | ||
using System.Web; | ||
using Microsoft.AspNet.Identity; | ||
using Microsoft.AspNet.Identity.EntityFramework; | ||
using Microsoft.AspNet.Identity.Owin; | ||
using Microsoft.Owin; | ||
using Microsoft.Owin.Security; | ||
using EasyAuthKaushal.Models; | ||
|
||
namespace EasyAuthKaushal | ||
{ | ||
public class EmailService : IIdentityMessageService | ||
{ | ||
public Task SendAsync(IdentityMessage message) | ||
{ | ||
// Plug in your email service here to send an email. | ||
return Task.FromResult(0); | ||
} | ||
} | ||
|
||
public class SmsService : IIdentityMessageService | ||
{ | ||
public Task SendAsync(IdentityMessage message) | ||
{ | ||
// Plug in your SMS service here to send a text message. | ||
return Task.FromResult(0); | ||
} | ||
} | ||
|
||
// Configure the application user manager used in this application. UserManager is defined in ASP.NET Identity and is used by the application. | ||
public class ApplicationUserManager : UserManager<ApplicationUser> | ||
{ | ||
public ApplicationUserManager(IUserStore<ApplicationUser> store) | ||
: base(store) | ||
{ | ||
} | ||
|
||
public static ApplicationUserManager Create(IdentityFactoryOptions<ApplicationUserManager> options, IOwinContext context) | ||
{ | ||
var manager = new ApplicationUserManager(new UserStore<ApplicationUser>(context.Get<ApplicationDbContext>())); | ||
// Configure validation logic for usernames | ||
manager.UserValidator = new UserValidator<ApplicationUser>(manager) | ||
{ | ||
AllowOnlyAlphanumericUserNames = false, | ||
RequireUniqueEmail = true | ||
}; | ||
|
||
// Configure validation logic for passwords | ||
manager.PasswordValidator = new PasswordValidator | ||
{ | ||
RequiredLength = 6, | ||
RequireNonLetterOrDigit = true, | ||
RequireDigit = true, | ||
RequireLowercase = true, | ||
RequireUppercase = true, | ||
}; | ||
|
||
// Configure user lockout defaults | ||
manager.UserLockoutEnabledByDefault = true; | ||
manager.DefaultAccountLockoutTimeSpan = TimeSpan.FromMinutes(5); | ||
manager.MaxFailedAccessAttemptsBeforeLockout = 5; | ||
|
||
// Register two factor authentication providers. This application uses Phone and Emails as a step of receiving a code for verifying the user | ||
// You can write your own provider and plug it in here. | ||
manager.RegisterTwoFactorProvider("Phone Code", new PhoneNumberTokenProvider<ApplicationUser> | ||
{ | ||
MessageFormat = "Your security code is {0}" | ||
}); | ||
manager.RegisterTwoFactorProvider("Email Code", new EmailTokenProvider<ApplicationUser> | ||
{ | ||
Subject = "Security Code", | ||
BodyFormat = "Your security code is {0}" | ||
}); | ||
manager.EmailService = new EmailService(); | ||
manager.SmsService = new SmsService(); | ||
var dataProtectionProvider = options.DataProtectionProvider; | ||
if (dataProtectionProvider != null) | ||
{ | ||
manager.UserTokenProvider = | ||
new DataProtectorTokenProvider<ApplicationUser>(dataProtectionProvider.Create("ASP.NET Identity")); | ||
} | ||
return manager; | ||
} | ||
} | ||
|
||
// Configure the application sign-in manager which is used in this application. | ||
public class ApplicationSignInManager : SignInManager<ApplicationUser, string> | ||
{ | ||
public ApplicationSignInManager(ApplicationUserManager userManager, IAuthenticationManager authenticationManager) | ||
: base(userManager, authenticationManager) | ||
{ | ||
} | ||
|
||
public override Task<ClaimsIdentity> CreateUserIdentityAsync(ApplicationUser user) | ||
{ | ||
return user.GenerateUserIdentityAsync((ApplicationUserManager)UserManager); | ||
} | ||
|
||
public static ApplicationSignInManager Create(IdentityFactoryOptions<ApplicationSignInManager> options, IOwinContext context) | ||
{ | ||
return new ApplicationSignInManager(context.GetUserManager<ApplicationUserManager>(), context.Authentication); | ||
} | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,23 @@ | ||
using System; | ||
using System.Collections.Generic; | ||
using System.Linq; | ||
using System.Web; | ||
using System.Web.Mvc; | ||
using System.Web.Routing; | ||
|
||
namespace EasyAuthKaushal | ||
{ | ||
public class RouteConfig | ||
{ | ||
public static void RegisterRoutes(RouteCollection routes) | ||
{ | ||
routes.IgnoreRoute("{resource}.axd/{*pathInfo}"); | ||
|
||
routes.MapRoute( | ||
name: "Default", | ||
url: "{controller}/{action}/{id}", | ||
defaults: new { controller = "Home", action = "Index", id = UrlParameter.Optional } | ||
); | ||
} | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,68 @@ | ||
using System; | ||
using Microsoft.AspNet.Identity; | ||
using Microsoft.AspNet.Identity.Owin; | ||
using Microsoft.Owin; | ||
using Microsoft.Owin.Security.Cookies; | ||
using Microsoft.Owin.Security.Google; | ||
using Owin; | ||
using EasyAuthKaushal.Models; | ||
|
||
namespace EasyAuthKaushal | ||
{ | ||
public partial class Startup | ||
{ | ||
// For more information on configuring authentication, please visit https://go.microsoft.com/fwlink/?LinkId=301864 | ||
public void ConfigureAuth(IAppBuilder app) | ||
{ | ||
// Configure the db context, user manager and signin manager to use a single instance per request | ||
app.CreatePerOwinContext(ApplicationDbContext.Create); | ||
app.CreatePerOwinContext<ApplicationUserManager>(ApplicationUserManager.Create); | ||
app.CreatePerOwinContext<ApplicationSignInManager>(ApplicationSignInManager.Create); | ||
|
||
// Enable the application to use a cookie to store information for the signed in user | ||
// and to use a cookie to temporarily store information about a user logging in with a third party login provider | ||
// Configure the sign in cookie | ||
app.UseCookieAuthentication(new CookieAuthenticationOptions | ||
{ | ||
AuthenticationType = DefaultAuthenticationTypes.ApplicationCookie, | ||
LoginPath = new PathString("/Account/Login"), | ||
Provider = new CookieAuthenticationProvider | ||
{ | ||
// Enables the application to validate the security stamp when the user logs in. | ||
// This is a security feature which is used when you change a password or add an external login to your account. | ||
OnValidateIdentity = SecurityStampValidator.OnValidateIdentity<ApplicationUserManager, ApplicationUser>( | ||
validateInterval: TimeSpan.FromMinutes(30), | ||
regenerateIdentity: (manager, user) => user.GenerateUserIdentityAsync(manager)) | ||
} | ||
}); | ||
app.UseExternalSignInCookie(DefaultAuthenticationTypes.ExternalCookie); | ||
|
||
// Enables the application to temporarily store user information when they are verifying the second factor in the two-factor authentication process. | ||
app.UseTwoFactorSignInCookie(DefaultAuthenticationTypes.TwoFactorCookie, TimeSpan.FromMinutes(5)); | ||
|
||
// Enables the application to remember the second login verification factor such as phone or email. | ||
// Once you check this option, your second step of verification during the login process will be remembered on the device where you logged in from. | ||
// This is similar to the RememberMe option when you log in. | ||
app.UseTwoFactorRememberBrowserCookie(DefaultAuthenticationTypes.TwoFactorRememberBrowserCookie); | ||
|
||
// Uncomment the following lines to enable logging in with third party login providers | ||
//app.UseMicrosoftAccountAuthentication( | ||
// clientId: "", | ||
// clientSecret: ""); | ||
|
||
//app.UseTwitterAuthentication( | ||
// consumerKey: "", | ||
// consumerSecret: ""); | ||
|
||
//app.UseFacebookAuthentication( | ||
// appId: "", | ||
// appSecret: ""); | ||
|
||
//app.UseGoogleAuthentication(new GoogleOAuth2AuthenticationOptions() | ||
//{ | ||
// ClientId = "", | ||
// ClientSecret = "" | ||
//}); | ||
} | ||
} | ||
} |
Oops, something went wrong.