Ejemplo n.º 1
0
        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());
            }
        }
Ejemplo n.º 3
0
 public Task <CovenantUser> CreateUserVerify(ClaimsPrincipal principal, CovenantUserRegister register)
 {
     return(_connection.InvokeAsync <CovenantUser>("CreateUserVerify", principal, register));
 }