public async Task <ActionResult> Block(string[] checkUser) { foreach (var id in checkUser) { var user = await _userManager.FindByIdAsync(id); user.IsBlocked = true; var result = await _userManager.UpdateAsync(user); if (result.Succeeded) { await _userManager.SetLockoutEndDateAsync(user, new DateTime(9999, 12, 30)); lab5User iuser = await _userManager.FindByNameAsync(User.Identity.Name); if (iuser == user) { await _signInManager.SignOutAsync(); return(RedirectToAction("index")); } } } return(RedirectToAction("index")); }
private async Task LoadAsync(lab5User user) { var userName = await _userManager.GetUserNameAsync(user); var phoneNumber = await _userManager.GetPhoneNumberAsync(user); Username = userName; Input = new InputModel { PhoneNumber = phoneNumber }; }
public async Task <IActionResult> OnPostAsync(string returnUrl = null) { returnUrl = returnUrl ?? Url.Content("~/"); ExternalLogins = (await _signInManager.GetExternalAuthenticationSchemesAsync()).ToList(); if (ModelState.IsValid) { var user = new lab5User { UserName = Input.Email, Email = Input.Email, Registration_date = DateTime.Now.ToString(), IsBlocked = false }; 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 <ActionResult> Delete(string[] checkUser) { foreach (var id in checkUser) { var user = await _userManager.FindByIdAsync(id); lab5User iuser = await _userManager.FindByNameAsync(User.Identity.Name); var result = await _userManager.DeleteAsync(user); if (result.Succeeded) { if (iuser == user) { await _signInManager.SignOutAsync(); return(RedirectToAction("index")); } } } return(RedirectToAction("index")); }