public static ShareThingsUser Get(IHeaderDictionary Headers) { string headerAuth = Headers["Authorization"]; ShareThingsUser user = headerAuth == IdentitySingleton.KeyLender ? IdentitySingleton.Instance.GetLender() : IdentitySingleton.Instance.GetBorrower(); return(user); }
public async Task <IActionResult> OnPostAsync(string returnUrl = null) { returnUrl ??= Url.Content("~/"); ExternalLogins = (await _signInManager.GetExternalAuthenticationSchemesAsync()).ToList(); if (ModelState.IsValid) { var user = new ShareThingsUser { UserName = Input.Email, Email = Input.Email, Name = Input.Name, Surname = Input.Surname, Address = Input.Address, PostalCode = Input.PostalCode, Country = Input.Country, PhoneNumber = Input.PhoneNumber, BirthDate = Input.BirthDate }; 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()); }
private IdentitySingleton() { this._userBorrower = new ShareThingsUser { Id = Guid.NewGuid().ToString(), UserName = KeyBorrower, Email = KeyBorrower + "@sharethings.es" }; this._userLender = new ShareThingsUser { Id = Guid.NewGuid().ToString(), UserName = KeyLender, Email = KeyLender + "@sharethings.es" }; }
protected override Task <AuthenticateResult> HandleAuthenticateAsync() { ShareThingsUser user = AuthorizationFactory.Get(this.Context.Request.Headers); var claims = new[] { new Claim(ClaimTypes.Name, user.UserName), new Claim(ClaimTypes.NameIdentifier, user.Id), new Claim(ClaimTypes.Email, user.Email), }; var identity = new ClaimsIdentity(claims, user.UserName); var principal = new ClaimsPrincipal(identity); var ticket = new AuthenticationTicket(principal, user.UserName); var result = AuthenticateResult.Success(ticket); return(Task.FromResult(result)); }
private async Task LoadAsync(ShareThingsUser user) { var userName = await _userManager.GetUserNameAsync(user); var phoneNumber = await _userManager.GetPhoneNumberAsync(user); Username = userName; Input = new InputModel { UserName = Username, //Email = user.Email, Name = user.Name, Surname = user.Surname, Address = user.Address, PostalCode = user.PostalCode, Country = user.Country, PhoneNumber = phoneNumber, BirthDate = user.BirthDate }; }