Exemple #1
0
        public async Task <IHttpActionResult> RegisterExternal(RegisterExternalBindingModel model)
        {
            if (!ModelState.IsValid)
            {
                return(BadRequest(ModelState));
            }

            var info = await Authentication.GetExternalLoginInfoAsync();

            if (info == null)
            {
                return(InternalServerError());
            }

            var user = new JwadUser()
            {
                UserName = model.Email, Email = model.Email
            };

            IdentityResult result = await UserManager.CreateAsync(user);

            if (!result.Succeeded)
            {
                return(GetErrorResult(result));
            }

            result = await UserManager.AddLoginAsync(user.Id, info.Login);

            if (!result.Succeeded)
            {
                return(GetErrorResult(result));
            }
            return(Ok());
        }
Exemple #2
0
        public static void Seed(JwadDbContext context)
        {
            UserStore <JwadUser>   store   = new UserStore <JwadUser>(context);
            UserManager <JwadUser> manager = new UserManager <JwadUser>(store);

            JwadUser tdavis = manager.FindByEmail("*****@*****.**");

            if (tdavis == null)
            {
                tdavis = new JwadUser
                {
                    Email    = "*****@*****.**",
                    UserName = "******"
                };
                manager.Create(tdavis, "123456");
            }

            context.JobRequirements.AddOrUpdate(m => m.JobTitle,
                                                new Job
            {
                JobTitle       = "Junior Software Developer",
                JobState       = "CA",
                JobCity        = "San Franciso",
                JobZipCode     = 94110,
                JobDescription = "Have skills with these languages JavaScript, HTML5, C#, .NET Framework",
                Salary         = 100000m
            });
            context.JobRequirements.AddOrUpdate(m => m.JobTitle,
                                                new Job
            {
                JobTitle       = "Software Developer",
                JobState       = "TX",
                JobCity        = "Lewisville",
                JobZipCode     = 75057,
                JobDescription = "Have skills",
                Salary         = 120000m
            });

            context.Employers.AddOrUpdate(m => m.EmployerName,
                                          new Employer
            {
                EmployerName = "Coder Camps",
                EmployerUrl  = "https://www.codercamps.com/",
            });

            context.Employers.AddOrUpdate(m => m.EmployerName,
                                          new Employer
            {
                EmployerName = "Coder For Rent",
                EmployerUrl  = "https://www.codercamps.com/",
            })
            ;
        }
Exemple #3
0
        public async Task <IHttpActionResult> GetExternalLogin(string provider, string error = null)
        {
            if (error != null)
            {
                return(Redirect(Url.Content("~/") + "#error=" + Uri.EscapeDataString(error)));
            }

            if (!User.Identity.IsAuthenticated)
            {
                return(new ChallengeResult(provider, this));
            }

            ExternalLoginData externalLogin = ExternalLoginData.FromIdentity(User.Identity as ClaimsIdentity);

            if (externalLogin == null)
            {
                return(InternalServerError());
            }

            if (externalLogin.LoginProvider != provider)
            {
                Authentication.SignOut(DefaultAuthenticationTypes.ExternalCookie);
                return(new ChallengeResult(provider, this));
            }

            JwadUser user = await UserManager.FindAsync(new UserLoginInfo(externalLogin.LoginProvider,
                                                                          externalLogin.ProviderKey));

            bool hasRegistered = user != null;

            if (hasRegistered)
            {
                Authentication.SignOut(DefaultAuthenticationTypes.ExternalCookie);

                ClaimsIdentity oAuthIdentity = await user.GenerateUserIdentityAsync(UserManager,
                                                                                    OAuthDefaults.AuthenticationType);

                ClaimsIdentity cookieIdentity = await user.GenerateUserIdentityAsync(UserManager,
                                                                                     CookieAuthenticationDefaults.AuthenticationType);

                AuthenticationProperties properties = ApplicationOAuthProvider.CreateProperties(user.UserName);
                Authentication.SignIn(properties, oAuthIdentity, cookieIdentity);
            }
            else
            {
                IEnumerable <Claim> claims   = externalLogin.GetClaims();
                ClaimsIdentity      identity = new ClaimsIdentity(claims, OAuthDefaults.AuthenticationType);
                Authentication.SignIn(identity);
            }

            return(Ok());
        }
Exemple #4
0
        public async Task <IHttpActionResult> Register(RegisterBindingModel model)
        {
            if (!ModelState.IsValid)
            {
                return(BadRequest(ModelState));
            }

            var user = new JwadUser()
            {
                UserName = model.Email, Email = model.Email, UserRole = model.Role, FirstName = model.FirstName, LastName = model.LastName
            };

            IdentityResult result = await UserManager.CreateAsync(user, model.Password);

            if (!result.Succeeded)
            {
                return(GetErrorResult(result));
            }

            return(Ok());
        }
        public override async Task GrantResourceOwnerCredentials(OAuthGrantResourceOwnerCredentialsContext context)
        {
            var userManager = context.OwinContext.GetUserManager <ApplicationUserManager>();

            JwadUser user = await userManager.FindAsync(context.UserName, context.Password);

            if (user == null)
            {
                context.SetError("invalid_grant", "The user name or password is incorrect.");
                return;
            }

            ClaimsIdentity oAuthIdentity = await user.GenerateUserIdentityAsync(userManager,
                                                                                OAuthDefaults.AuthenticationType);

            ClaimsIdentity cookiesIdentity = await user.GenerateUserIdentityAsync(userManager,
                                                                                  CookieAuthenticationDefaults.AuthenticationType);

            AuthenticationProperties properties = CreateProperties(user.UserName);
            AuthenticationTicket     ticket     = new AuthenticationTicket(oAuthIdentity, properties);

            context.Validated(ticket);
            context.Request.Context.Authentication.SignIn(cookiesIdentity);
        }