public async Task <ActionResult> PartialUpdate(string username, [FromBody] JsonPatchDocument <UserViewModel> model) { if (!ModelState.IsValid) { NotifyModelStateErrors(); return(ModelStateErrorResponseError()); } var actualUser = await _userManageAppService.FindByUsernameAsync(username); model.ApplyTo(actualUser); await _userManageAppService.UpdateUser(actualUser); return(ResponsePutPatch()); }
private async Task <IActionResult> LoginByAspNetIdentity(LoginInputModel model, AuthorizationRequest context) { UserViewModel userIdentity; if (model.IsUsernameEmail()) { userIdentity = await _userManageAppService.FindByEmailAsync(model.Username); } else { userIdentity = await _userManageAppService.FindByUsernameAsync(model.Username); } if (userIdentity == null) { await _events.RaiseAsync(new UserLoginFailureEvent(model.Username, "invalid credentials")); ModelState.AddModelError("", AccountOptions.InvalidCredentialsErrorMessage); } if (userIdentity != null) { var result = await _signInManager.PasswordSignInAsync(userIdentity.UserName, model.Password, model.RememberLogin, lockoutOnFailure : true); if (result.Succeeded) { return(await SuccessfullLogin(model, userIdentity, context)); } else { await FailedLogin(model, result, userIdentity); } } // something went wrong, show form with error var vm = await BuildLoginViewModelAsync(model); return(View(vm)); }
public async Task Should_Not_Find_User() { var result = await _userManagerAppService.FindByUsernameAsync(_faker.Person.FirstName); result.Should().BeNull(); }
public async Task <IActionResult> Login(LoginInputModel model, string button) { // the user clicked the "cancel" button var context = await _interaction.GetAuthorizationContextAsync(model.ReturnUrl); if (button != "login") { if (context != null) { // if the user cancels, send a result back into IdentityServer as if they // denied the consent (even if this client does not require consent). // this will send back an access denied OIDC error response to the client. await _interaction.GrantConsentAsync(context, ConsentResponse.Denied); // we can trust model.ReturnUrl since GetAuthorizationContextAsync returned non-null return(Redirect(model.ReturnUrl)); } else { // since we don't have a valid context, then we just go back to the home page return(Redirect("~/")); } } if (ModelState.IsValid) { UserViewModel userIdentity; if (model.IsUsernameEmail()) { userIdentity = await _userManageAppService.FindByEmailAsync(model.Username); } else { userIdentity = await _userManageAppService.FindByUsernameAsync(model.Username); } if (userIdentity == null) { await _events.RaiseAsync(new UserLoginFailureEvent(model.Username, "invalid credentials")); ModelState.AddModelError("", AccountOptions.InvalidCredentialsErrorMessage); } if (userIdentity != null) { var result = await _signInManager.PasswordSignInAsync(userIdentity.UserName, model.Password, model.RememberLogin, lockoutOnFailure : true); if (result.Succeeded) { return(await SuccessfullLogin(model, userIdentity, context)); } else { await FailedLogin(model, result, userIdentity); } } } // something went wrong, show form with error var vm = await BuildLoginViewModelAsync(model); return(View(vm)); }
public async Task <ActionResult <UserViewModel> > UserData() { var user = await _userAppService.FindByUsernameAsync(_systemUser.Username); return(ResponseGet(user)); }