public async Task <IActionResult> OnPostAsync(string returnUrl = null) { returnUrl ??= Url.Content("~/"); ExternalLogins = (await _signInManager.GetExternalAuthenticationSchemesAsync()).ToList(); if (ModelState.IsValid) { //Encript User Details var firstName = new UserDtoMap(_protector).Encript(Input.FirstName); var lastName = new UserDtoMap(_protector).Encript(Input.LastName); var user = new AppUser { UserName = Input.Email, Email = Input.Email, FirstName = firstName, LastName = lastName, IsEnabled = true }; var result = await _userManager.CreateAsync(user, Input.Password); if (result.Succeeded) { _logger.LogInformation("User created a new account with password."); var code = await _userManager.GenerateEmailConfirmationTokenAsync(user); code = WebEncoders.Base64UrlEncode(Encoding.UTF8.GetBytes(code)); var callbackUrl = Url.Page( "/Account/ConfirmEmail", pageHandler: null, values: new { area = "Identity", userId = user.Id, code = code, returnUrl = returnUrl }, protocol: Request.Scheme); await _emailSender.SendEmailAsync(Input.Email, "Confirm your email", $"Please confirm your account by <a href='{HtmlEncoder.Default.Encode(callbackUrl)}'>clicking here</a>."); if (_userManager.Options.SignIn.RequireConfirmedAccount) { return(RedirectToPage("RegisterConfirmation", new { email = Input.Email, returnUrl = returnUrl })); } else { await _signInManager.SignInAsync(user, isPersistent : false); return(LocalRedirect(returnUrl)); } } foreach (var error in result.Errors) { ModelState.AddModelError(string.Empty, error.Description); } } // If we got this far, something failed, redisplay form return(Page()); }
public async Task <IActionResult> OnGetAsync() { var user = await _userManager.GetUserAsync(User); if (user == null) { return(NotFound($"Unable to load user with ID '{_userManager.GetUserId(User)}'.")); } var userName = await _userManager.GetUserNameAsync(user); Username = userName; var allUsers = _context.Users.Where(e => e.UserName != Username).OrderByDescending(e => e.IsEnabled).ToList(); var userList = new UserDtoMap(_provider).Map(allUsers); UserDetails = userList; return(Page()); }
private async Task LoadAsync(AppUser user) { var userName = await _userManager.GetUserNameAsync(user); var phoneNumber = await _userManager.GetPhoneNumberAsync(user); Username = userName; var firstName = new UserDtoMap(_provider).Decript(user.FirstName); var lastName = new UserDtoMap(_provider).Decript(user.LastName); Input = new InputModel { PhoneNumber = phoneNumber, FirstName = firstName, LastName = lastName, IsEnabled = user.IsEnabled }; }
public static async Task <bool> CreateUser(UserManager <AppUser> userManager, string email, string password, string firstName, string lastName, string role) { firstName = new UserDtoMap(_provider).Encript(firstName); lastName = new UserDtoMap(_provider).Encript(lastName); if (await userManager.FindByNameAsync(email) == null) { var user = new AppUser { UserName = email, Email = email, FirstName = firstName, LastName = lastName, IsEnabled = true }; var result = await userManager.CreateAsync(user, password); if (result.Succeeded) { await userManager.AddToRoleAsync(user, role); } } return(true); }
public async Task <IActionResult> OnPostAsync() { var user = await _userManager.GetUserAsync(User); if (user == null) { return(NotFound($"Unable to load user with ID '{_userManager.GetUserId(User)}'.")); } if (!ModelState.IsValid) { await LoadAsync(user); return(Page()); } var firstName = new UserDtoMap(_provider).Decript(user.FirstName); var lastName = new UserDtoMap(_provider).Decript(user.LastName); if (Input.FirstName != firstName || Input.LastName != lastName) { user.FirstName = new UserDtoMap(_provider).Encript(Input.FirstName); user.LastName = new UserDtoMap(_provider).Encript(Input.LastName); var setNameChange = await _userManager.UpdateAsync(user); if (!setNameChange.Succeeded) { StatusMessage = "Unexpected error when trying to update the name."; return(RedirectToPage()); } } await _signInManager.RefreshSignInAsync(user); StatusMessage = "Your profile has been updated"; return(RedirectToPage()); }
public async Task <IActionResult> OnPostAsync(string returnUrl = null) { returnUrl ??= Url.Content("~/"); if (ModelState.IsValid) { //Encript User Details var firstName = new UserDtoMap(_provider).Encript(Input.FirstName); var lastName = new UserDtoMap(_provider).Encript(Input.LastName); if (await _userManager.FindByEmailAsync(Input.Email) != null) { StatusMessage = "Error: User Name " + Input.Email + " already exist"; return(RedirectToPage()); } var user = new AppUser { UserName = Input.Email, Email = Input.Email, FirstName = firstName, LastName = lastName, IsEnabled = true }; var result = await _userManager.CreateAsync(user, Input.Password); if (result.Succeeded) { _logger.LogInformation("User created a new account with password."); if (result.Succeeded) { await _userManager.AddToRoleAsync(user, Input.UserTypeName); } var code = await _userManager.GenerateEmailConfirmationTokenAsync(user); code = WebEncoders.Base64UrlEncode(Encoding.UTF8.GetBytes(code)); var callbackUrl = Url.Page( "/Account/ConfirmEmail", pageHandler: null, values: new { area = "Identity", userId = user.Id, code = code, returnUrl = returnUrl }, protocol: Request.Scheme); await _emailSender.SendEmailAsync(Input.Email, "Confirm your email", $"Please confirm your account by <a href='{HtmlEncoder.Default.Encode(callbackUrl)}'>clicking here</a>."); if (_userManager.Options.SignIn.RequireConfirmedAccount) { return(RedirectToPage("RegisterConfirmation", new { email = Input.Email, returnUrl = returnUrl })); } else { StatusMessage = "New user created successfully"; return(RedirectToPage("./Index")); } } var errorList = ""; foreach (var error in result.Errors) { errorList += error.Description + "/"; ModelState.AddModelError(string.Empty, error.Description); } StatusMessage = "Error: [" + errorList + "]"; } return(RedirectToPage()); //return Page(); }