Ejemplo n.º 1
0
        /// <summary>
        /// Редактирование пользователя администратором
        /// </summary>
        /// <param name="model"></param>
        /// <returns></returns>
        public async Task <BaseApiResponse> EditUserAsync(EditApplicationUser model)
        {
            var validation = ValidateModel(model);

            if (!validation.IsSucceeded)
            {
                return(validation);
            }


            var clientRepo = GetRepository <Client>();

            var searcher = new UserSearcher(AmbientContext);

            var userDto = await searcher.GetUserByIdAsync(model.Id);

            if (userDto == null)
            {
                return(new BaseApiResponse(false, ValidationMessages.UserIsNotFoundByIdentifier));
            }

            if (await clientRepo.Query().AnyAsync(x => x.Email == model.Email && x.Id != model.Id))
            {
                return(new BaseApiResponse(false, ValidationMessages.ThisEmailIsAlreadyTaken));
            }

            if (await clientRepo.Query().AnyAsync(x => x.PhoneNumber == model.PhoneNumber && x.Id != model.Id))
            {
                return(new BaseApiResponse(false, ValidationMessages.ThisPhoneNumberIsAlreadyTaken));
            }

            var userToEditEntity = await clientRepo.Query().FirstOrDefaultAsync(x => x.Id == model.Id);

            if (userToEditEntity == null)
            {
                var ex = new Exception("Ужасная ошибка");

                Logger.LogException(ex);

                return(new BaseApiResponse(ex));
            }


            userToEditEntity.Email       = model.Email;
            userToEditEntity.Name        = model.Name;
            userToEditEntity.Surname     = model.Surname;
            userToEditEntity.Patronymic  = model.Patronymic;
            userToEditEntity.Sex         = model.Sex;
            userToEditEntity.ObjectJson  = model.ObjectJson;
            userToEditEntity.PhoneNumber = new string(model.PhoneNumber.Where(char.IsDigit).ToArray());
            userToEditEntity.BirthDate   = model.BirthDate;

            clientRepo.UpdateHandled(userToEditEntity);

            return(await TrySaveChangesAndReturnResultAsync("Данные пользователя обновлены"));
        }
Ejemplo n.º 2
0
        public ActionResult Edit(string id)
        {
            var user = _userService.Get(id);

            var result = new EditApplicationUser
            {
                Id            = user.Id,
                FullName      = user.FullName,
                Email         = user.Email,
                IsUserBlocked = user.IsUserBlocked,
                ReturnUrl     = Url.Action("Index")
            };

            return(View(result));
        }
Ejemplo n.º 3
0
        public ActionResult EditMyAccount()
        {
            var user = _userService.Get(User.Identity.GetUserId());

            var result = new EditApplicationUser
            {
                Id            = user.Id,
                FullName      = user.FullName,
                Email         = user.Email,
                IsUserBlocked = user.IsUserBlocked,
                ReturnUrl     = Url.Action("MyAccount", "User")
            };

            return(View("Edit", result));
        }
Ejemplo n.º 4
0
        public ActionResult Edit(EditApplicationUser _user)
        {
            if (ModelState.IsValid)
            {
                var user = _userService.Get(_user.Id);

                user.FullName      = _user.FullName;
                user.Email         = _user.Email;
                user.IsUserBlocked = _user.IsUserBlocked;

                _userService.Update(user);

                return(Redirect(_user.ReturnUrl));
            }

            return(View(_user));
        }
Ejemplo n.º 5
0
        /// <summary>
        /// Редактирование пользователя администратором
        /// </summary>
        /// <param name="model"></param>
        /// <returns></returns>
        public async Task <BaseApiResponse> EditUserAsync(EditApplicationUser model)
        {
            var validation = ValidateModelAndUserIsAdmin(model);

            if (!validation.IsSucceeded)
            {
                return(validation);
            }

            var clientRepo = GetRepository <Client>();

            var userDto = await UserSearcher.GetUserByIdAsync(model.Id);

            if (userDto == null)
            {
                return(new BaseApiResponse(false, ValidationMessages.UserIsNotFoundByIdentifier));
            }

            if (userDto.Email == RootSettings.RootEmail)
            {
                return(new BaseApiResponse(false, ValidationMessages.YouCantEditRootUser));
            }

            if (await clientRepo.Query().AnyAsync(x => x.Email == model.Email && x.Id != model.Id))
            {
                return(new BaseApiResponse(false, ValidationMessages.ThisEmailIsAlreadyTaken));
            }

            if (await clientRepo.Query().AnyAsync(x => x.PhoneNumber == model.PhoneNumber && x.Id != model.Id))
            {
                return(new BaseApiResponse(false, ValidationMessages.ThisPhoneNumberIsAlreadyTaken));
            }

            if (!User.IsInRole(RolesSetting.AdminRoleName) && (userDto.IsInRole(RolesSetting.AdminRoleName)))
            {
                return(new BaseApiResponse(false, ValidationMessages.YouCantEditUserBecauseHeIsAdministrator));
            }

            var userToEditEntity = await clientRepo.Query().FirstOrDefaultAsync(x => x.Id == model.Id);

            if (userToEditEntity == null)
            {
                var ex = new Exception("Ужасная ошибка");

                Logger.LogError(ex, "EditUserAsync.OnException");

                return(new BaseApiResponse(ex));
            }

            userToEditEntity.Email       = model.Email;
            userToEditEntity.Name        = model.Name;
            userToEditEntity.Surname     = model.Surname;
            userToEditEntity.Patronymic  = model.Patronymic;
            userToEditEntity.Sex         = model.Sex;
            userToEditEntity.ObjectJson  = model.ObjectJson;
            userToEditEntity.PhoneNumber = new string(model.PhoneNumber.Where(char.IsDigit).ToArray());
            userToEditEntity.BirthDate   = model.BirthDate;

            clientRepo.UpdateHandled(userToEditEntity);

            var response = await TrySaveChangesAndReturnResultAsync("Данные пользователя обновлены");

            if (response.IsSucceeded)
            {
                await PublishMessageAsync(new ClientDataUpdatedEvent
                {
                    Id = userToEditEntity.Id
                });
            }

            return(response);
        }