예제 #1
0
        public async Task<ActionResult> ChangeProfile(ApplicationUser applicationUser)
        {
            ManageMessageId manageMessageId;
            ApplicationUser retrieveApplicationUser = await UserManager.FindByIdAsync(User.Identity.GetUserId());
            retrieveApplicationUser.FirstName = applicationUser.FirstName;
            retrieveApplicationUser.LastName = applicationUser.LastName;
            retrieveApplicationUser.Address = applicationUser.Address;
            retrieveApplicationUser.City = applicationUser.City;
            retrieveApplicationUser.State = applicationUser.State;
            retrieveApplicationUser.ZipCode = applicationUser.ZipCode;

            var result = await UserManager.UpdateAsync(retrieveApplicationUser);
            if (result.Succeeded)
            {
                manageMessageId = ManageMessageId.ChangeProfileSuccess;
                if (retrieveApplicationUser.Email != applicationUser.Email)
                {
                    string previoususerName = retrieveApplicationUser.UserName;
                    retrieveApplicationUser.UserName = applicationUser.Email;
                    result = await UserManager.SetEmailAsync(retrieveApplicationUser.Id, applicationUser.Email);
                    if (result.Succeeded)
                    {
                        manageMessageId = ManageMessageId.ChangeEmailSuccess;

                        string code = await UserManager.GenerateEmailConfirmationTokenAsync(retrieveApplicationUser.Id);
                        var callbackUrl = Url.Action(
                            "ConfirmEmail",
                            "Account",
                            new { userId = retrieveApplicationUser.Id, code = code }, protocol: Request.Url.Scheme);

                        await UserManager.SendEmailAsync(
                            retrieveApplicationUser.Id,
                            "Confirm your account",
                            "Please confirm your account by clicking <a href=\"" + callbackUrl + "\">here</a>");
                    }
                    else
                    {
                        retrieveApplicationUser.UserName = previoususerName;
                        result = await UserManager.UpdateAsync(retrieveApplicationUser);
                        manageMessageId = ManageMessageId.Error;
                    }
                }
            }
            else
            {
                manageMessageId = ManageMessageId.Error;
            }
            return RedirectToAction("Index", new { Message = manageMessageId });
        }
        public async Task<ActionResult> ExternalLoginConfirmation(ExternalLoginConfirmationViewModel model, string returnUrl)
        {
            if (User.Identity.IsAuthenticated)
            {
                return RedirectToAction("Index", "Manage");
            }

            if (ModelState.IsValid)
            {
                // Get the information about the user from the external login provider
                var info = await AuthenticationManager.GetExternalLoginInfoAsync();
                if (info == null)
                {
                    return View("ExternalLoginFailure");
                }
                var user = new ApplicationUser { UserName = model.Email, Email = model.Email };
                var result = await UserManager.CreateAsync(user);
                if (result.Succeeded)
                {
                    result = await UserManager.AddLoginAsync(user.Id, info.Login);
                    if (result.Succeeded)
                    {
                        await SignInManager.SignInAsync(user, isPersistent: false, rememberBrowser: false);
                        return RedirectToLocal(returnUrl);
                    }
                }
                AddErrors(result);
            }

            ViewBag.ReturnUrl = returnUrl;
            return View(model);
        }
        public async Task<ActionResult> Register(RegisterViewModel model)
        {
            if (ModelState.IsValid)
            {
                var user = new ApplicationUser { UserName = model.Email, Email = model.Email,FirstName = model.FirstName};
                var result = await UserManager.CreateAsync(user, model.Password);
                if (result.Succeeded)
                {
                    string code = await UserManager.GenerateEmailConfirmationTokenAsync(user.Id);

                    var callbackUrl = Url.Action(
                        "ConfirmEmail",
                        "Account",
                        new {userId= user.Id,code=code },protocol:Request.Url.Scheme);


                    await UserManager.SendEmailAsync(user.Id,
                        "Confirm Your Email",
                        "Please confirm your account by clicking <a ref=\"" + callbackUrl + "\">here</a>");

                    return View("CheckYourEmail");
                }
                AddErrors(result);
            }

            // If we got this far, something failed, redisplay form
            return View(model);
        }
예제 #4
0
        public async Task<ActionResult> Register(RegisterViewModel model)
        {
            if (ModelState.IsValid)
            {
                var user = new ApplicationUser { UserName = model.Email, Email = model.Email };
                var result = await UserManager.CreateAsync(user, model.Password);
                if (result.Succeeded)
                {
                    await SignInManager.SignInAsync(user, isPersistent:false, rememberBrowser:false);
                    
                    // For more information on how to enable account confirmation and password reset please visit http://go.microsoft.com/fwlink/?LinkID=320771
                    // Send an email with this link
                    // string code = await UserManager.GenerateEmailConfirmationTokenAsync(user.Id);
                    // var callbackUrl = Url.Action("ConfirmEmail", "Account", new { userId = user.Id, code = code }, protocol: Request.Url.Scheme);
                    // await UserManager.SendEmailAsync(user.Id, "Confirm your account", "Please confirm your account by clicking <a href=\"" + callbackUrl + "\">here</a>");

                    return RedirectToAction("Index", "Home");
                }
                AddErrors(result);
            }

            // If we got this far, something failed, redisplay form
            return View(model);
        }
예제 #5
0
        public async Task<ActionResult> ExternalLoginConfirmation(ExternalLoginConfirmationViewModel model, string returnUrl)
        {
            if (User.Identity.IsAuthenticated)
            {
                return RedirectToAction("Index", "Manage");
            }

            if (ModelState.IsValid)
            {
                // Get the information about the user from the external login provider
                var info = await AuthenticationManager.GetExternalLoginInfoAsync();
                if (info == null)
                {
                    return View("ExternalLoginFailure");
                }
                string firstName = info.ExternalIdentity.Claims.First(c => c.Type.Contains("givenname")).Value ??
                                   string.Empty;

                var user = new ApplicationUser
                {
                    UserName = model.Email,
                    Email = model.Email,
                    FirstName = firstName.Substring(0, Math.Min(firstName.Length, 15))
                };
                var result = await UserManager.CreateAsync(user);
                if (result.Succeeded)
                {
                    await UserManager.SetTwoFactorEnabledAsync(user.Id, true);
                    result = await UserManager.AddLoginAsync(user.Id, info.Login);
                    if (result.Succeeded)
                    {
                        await SignInManager.SignInAsync(user, isPersistent: false, rememberBrowser: false);
                        return RedirectToLocal(returnUrl);
                    }
                }
                AddErrors(result);
            }

            ViewBag.ReturnUrl = returnUrl;
            return View(model);
        }
예제 #6
0
 public async Task<ActionResult> GenerateConfirmationEmail(ApplicationUser user)
 {
     string code = await UserManager.GenerateEmailConfirmationTokenAsync(user.Id);
     var callbackUrl = Url.Action("ConfirmEmail",
         "Account",
         new { userId = user.Id, code = code }, protocol: Request.Url.Scheme);
     await UserManager.SendEmailAsync(user.Id, "Check your account",
         "please confirm your account by clicking <a href=\"" + callbackUrl + "\">here</a>");
     return View("CheckYourEmail");
 }
예제 #7
0
        public async Task<ActionResult> Register(RegisterViewModel model)
        {
            if (ModelState.IsValid)
            {
                var user = new ApplicationUser
                {
                    UserName = model.Email,
                    Email = model.Email,
                    FirstName = model.FirstName
                };
                var result = await UserManager.CreateAsync(user, model.Password);
                //await UserManager.SetTwoFactorEnabledAsync(user.Id, true);
                if (result.Succeeded)
                {
                    return await GenerateConfirmationEmail(user);
                }
                AddErrors(result);
            }

            // If we got this far, something failed, redisplay form
            return View(model);
        }
예제 #8
0
 private async Task SignInAsync(ApplicationUser user, bool isPersistent)
 {
     AuthenticationManager.SignOut(DefaultAuthenticationTypes.ExternalCookie, DefaultAuthenticationTypes.TwoFactorCookie);
     AuthenticationManager.SignIn(new AuthenticationProperties { IsPersistent = isPersistent }, await user.GenerateUserIdentityAsync(UserManager));
 }