public async Task <IActionResult> Create(CovenantUserRegister register) { try { if (register.Password != register.ConfirmPassword) { return(BadRequest($"BadRequest - Password does not match ConfirmPassword.")); } if (!_userManager.Users.Any()) { CovenantUser user = new CovenantUser { UserName = register.UserName }; IdentityResult userResult = await _userManager.CreateAsync(user, register.Password); await _userManager.AddToRoleAsync(user, "User"); await _userManager.AddToRoleAsync(user, "Administrator"); await _signInManager.PasswordSignInAsync(register.UserName, register.Password, true, lockoutOnFailure : false); } else if (_signInManager.IsSignedIn(HttpContext.User) && HttpContext.User.IsInRole("Administrator")) { CovenantUser user = new CovenantUser { UserName = register.UserName }; IdentityResult userResult = await _userManager.CreateAsync(user, register.Password); await _userManager.AddToRoleAsync(user, "User"); } else { return(new UnauthorizedResult()); } return(RedirectToAction("Index", "Home")); } catch (Exception e) when(e is ControllerNotFoundException || e is ControllerBadRequestException || e is ControllerUnauthorizedException) { ModelState.AddModelError(string.Empty, e.Message); return(RedirectToAction("Index", "Home")); } }
public async Task <ActionResult <CovenantUser> > CreateUser([FromBody] CovenantUserRegister register) { try { CovenantUser user = await _service.CreateUserVerify(HttpContext.User, register); return(CreatedAtRoute(nameof(GetUser), new { id = user.Id }, user)); } catch (ControllerNotFoundException e) { return(NotFound(e.Message)); } catch (ControllerBadRequestException e) { return(BadRequest(e.Message)); } catch (ControllerUnauthorizedException) { return(new UnauthorizedResult()); } }
public Task <CovenantUser> CreateUserVerify(ClaimsPrincipal principal, CovenantUserRegister register) { return(_connection.InvokeAsync <CovenantUser>("CreateUserVerify", principal, register)); }