public async Task <IActionResult> OnPostConfirmationAsync(string returnUrl = null) { returnUrl = returnUrl ?? Url.Content("~/"); // Get the information about the user from the external login provider var info = await _signInManager.GetExternalLoginInfoAsync(); if (info == null) { ErrorMessage = "Error loading external login information during confirmation."; return(RedirectToPage("./Login", new { ReturnUrl = returnUrl })); } if (ModelState.IsValid) { var user = new MojIdentityUser { UserName = Input.Email, Email = Input.Email }; var result = await _userManager.CreateAsync(user); if (result.Succeeded) { result = await _userManager.AddLoginAsync(user, info); if (result.Succeeded) { await _signInManager.SignInAsync(user, isPersistent : false); _logger.LogInformation("User created an account using {Name} provider.", info.LoginProvider); var userId = await _userManager.GetUserIdAsync(user); 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 = userId, code = code }, 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>."); return(LocalRedirect(returnUrl)); } } foreach (var error in result.Errors) { ModelState.AddModelError(string.Empty, error.Description); } } LoginProvider = info.LoginProvider; ReturnUrl = returnUrl; return(Page()); }
public IActionResult Obrisi(int id) { MojIdentityUser x = _db.Users.Where(x => x.Id == id).FirstOrDefault(); if (x == null || x.Id == 1) { return(View(nameof(Index))); } _db.Users.Remove(x); _db.SaveChanges(); return(RedirectToActionPermanent(nameof(Index))); }
private async Task LoadAsync(MojIdentityUser user) { var email = await _userManager.GetEmailAsync(user); Email = email; Input = new InputModel { NewEmail = email, }; IsEmailConfirmed = await _userManager.IsEmailConfirmedAsync(user); }
private async Task LoadAsync(MojIdentityUser user) { var userName = await _userManager.GetUserNameAsync(user); var phoneNumber = await _userManager.GetPhoneNumberAsync(user); Username = userName; Input = new InputModel { PhoneNumber = phoneNumber }; }
private async Task LoadSharedKeyAndQrCodeUriAsync(MojIdentityUser user) { // Load the authenticator key & QR code URI to display on the form var unformattedKey = await _userManager.GetAuthenticatorKeyAsync(user); if (string.IsNullOrEmpty(unformattedKey)) { await _userManager.ResetAuthenticatorKeyAsync(user); unformattedKey = await _userManager.GetAuthenticatorKeyAsync(user); } SharedKey = FormatKey(unformattedKey); var email = await _userManager.GetEmailAsync(user); AuthenticatorUri = GenerateQrCodeUri(email, unformattedKey); }
public async Task <IActionResult> OnPostConfirmationAsync(string returnUrl = null) { returnUrl = returnUrl ?? Url.Content("~/"); // Get the information about the user from the external login provider var info = await _signInManager.GetExternalLoginInfoAsync(); if (info == null) { ErrorMessage = "Error loading external login information during confirmation."; return(RedirectToPage("./Login", new { ReturnUrl = returnUrl })); } if (ModelState.IsValid) { var user = new MojIdentityUser { UserName = Input.Email, Email = Input.Email }; var result = await _userManager.CreateAsync(user); if (result.Succeeded) { result = await _userManager.AddLoginAsync(user, info); if (result.Succeeded) { await _signInManager.SignInAsync(user, isPersistent : false); _logger.LogInformation("User created an account using {Name} provider.", info.LoginProvider); return(LocalRedirect(returnUrl)); } } foreach (var error in result.Errors) { ModelState.AddModelError(string.Empty, error.Description); } } LoginProvider = info.LoginProvider; ReturnUrl = returnUrl; return(Page()); }
public async Task <IActionResult> OnPostAsync(string returnUrl = null) { returnUrl = returnUrl ?? Url.Content("~/"); if (ModelState.IsValid) { var user = new MojIdentityUser { UserName = Input.Email, Email = Input.Email }; 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); var callbackUrl = Url.Page( "/Account/ConfirmEmail", pageHandler: null, values: new { userId = user.Id, code = code }, 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>."); 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 <bool> updateUser(string id, string token) { try { MojIdentityUser appUser = await _userManager.FindByIdAsync(id); appUser.SignalRToken = token; var x = await _userManager.UpdateAsync(appUser); if (x.Succeeded) { return(true); } } catch (Exception e) { Console.WriteLine(e.Message); return(false); } return(false); }
public async Task <MojIdentityUser> getUserById(string id) { MojIdentityUser appUser = await _userManager.FindByIdAsync(id); return(appUser); }
public async Task <MojIdentityUser> getUser(ClaimsPrincipal claims) { MojIdentityUser user = await _userManager.GetUserAsync(claims); return(user); }
public async Task <IActionResult> OnPostAsync(string returnUrl = null) { returnUrl = returnUrl ?? Url.Content("~/"); ExternalLogins = (await _signInManager.GetExternalAuthenticationSchemesAsync()).ToList(); IdentityResult result = null; if (ModelState.IsValid) { MojIdentityUser user = null; if (Input.Klijent != null) { int?_AdresaID = _db.Adresa.Where(x => x.Naziv.Equals(Input.Klijent.Adresa)).Select(x => x.AdresaID).FirstOrDefault(); if (_AdresaID == 0 || _AdresaID == null) { Adresa adresa = new Adresa() { Naziv = Input.Klijent.Adresa, GradID = Input.Klijent.GradID }; _db.Adresa.Add(adresa); _db.SaveChanges(); _AdresaID = adresa.AdresaID; } user = new MojIdentityUser { Ime = Input.FirstName, Prezime = Input.LastName, UserName = Input.Email, PhoneNumber = Input.Klijent.Telefon, AdresaID = (int)_AdresaID, Email = Input.Email, EmailConfirmed = true, Spol = Input.Klijent.Spol, JMBG = Input.Klijent.JMBG, DatumRodjenja = Input.Klijent.DatumRodjenja }; result = await _userManager.CreateAsync(user, Input.Password); if (result.Succeeded) { var curentUser = await _userManager.FindByNameAsync(user.UserName); await _userManager.AddToRoleAsync(curentUser, "Klijent"); } } if (Input.Prijevoznik != null) { int?_AdresaID = _db.Adresa.Where(x => x.Naziv.Equals(Input.Prijevoznik.Adresa)).Select(x => x.AdresaID).FirstOrDefault(); if (_AdresaID == 0 || _AdresaID == null) { Adresa adresa = new Adresa() { Naziv = Input.Prijevoznik.Adresa, GradID = Input.Prijevoznik.GradID }; _db.Adresa.Add(adresa); _db.SaveChanges(); _AdresaID = adresa.AdresaID; } user = new MojIdentityUser { Ime = Input.FirstName, Prezime = Input.LastName, UserName = Input.Email, PhoneNumber = Input.Prijevoznik.Telefon, AdresaID = (int)_AdresaID, Email = Input.Email, EmailConfirmed = true, Spol = Input.Prijevoznik.Spol, JMBG = Input.Prijevoznik.JMBG, DatumRodjenja = Input.Prijevoznik.DatumRodjenja }; result = await _userManager.CreateAsync(user, Input.Password); var curentUser = await _userManager.FindByNameAsync(user.UserName); await _userManager.AddToRoleAsync(curentUser, "Prijevoznik"); Models.Prijevoznik prijevoznik = new Models.Prijevoznik() { EmailPrijevoznika = Input.Prijevoznik.KontaktEmail, NazivPrijevoznika = Input.Prijevoznik.NazivPrijevoznika, UserID = user.Id }; _db.Prijevoznik.Add(prijevoznik); _db.SaveChanges(); } 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 }, 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 })); } 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()); }