Exemplo n.º 1
0
        public void ResetPassword(UserDto userDto)
        {
            userDto.Password = Guid.NewGuid().ToString().Substring(0, 8);

            this.membershipService.UpdateUser(userDto.Username,
                                              userDto.Email,
                                              userDto.Password);

            Mailing.SendGenericMail("Solicitud de reseteo de contraseña", userDto.Email, userDto,
                                    "~/views/EmailTemplate/Password.cshtml");
        }
Exemplo n.º 2
0
        public void ChangePassword(ChangePasswordDto changePasswordDto)
        {
            var user            = this.entityRepository.GetSingle(changePasswordDto.UserId);
            var currentPassword = this.encryptionService.EncryptPassword(changePasswordDto.CurrentPassword, user.Salt);

            if (user.HashedPassword == currentPassword)
            {
                this.membershipService.UpdateUser(user.Username, user.Email, changePasswordDto.NewPassword);

                UserDto userDto = new UserDto();
                userDto.Username = user.Username;
                userDto.Password = changePasswordDto.CurrentPassword;

                Mailing.SendGenericMail("Solicitud de usuario", user.Email, userDto,
                                        "~/views/EmailTemplate/Password.cshtml");
            }
            else
            {
                throw new System.InvalidOperationException("La contraseña actual ingresada es incorrecta.");
            }
        }
Exemplo n.º 3
0
        public override UserDto Save(UserDto userDto)
        {
            var sendMail = false;

            if (userDto.Id == 0)
            {
                if (userDto.Password == null)
                {
                    userDto.Password = this.membershipService.CreateRandomPassword();
                }


                var user = Mapper.Map <UserDto, User>(userDto);

                var passwordSalt = this.encryptionService.CreateSalt();

                user.Salt           = passwordSalt;
                user.HashedPassword = this.encryptionService.EncryptPassword(userDto.Password, passwordSalt);
                user.Status         = 1;
                this.entityRepository.Add(user);

                this.unitOfWork.Commit();

                userDto.Id = user.Id;
                sendMail   = true;
            }
            else
            {
                var user = this.entityRepository.GetSingle(userDto.Id);
                user.FirstName = userDto.FirstName;
                user.LastName  = userDto.LastName;
                user.RoleId    = userDto.Role.Id;
                if (user.Email != userDto.Email)
                {
                    sendMail = true;
                }
                if (!string.IsNullOrEmpty(userDto.Password))
                {
                    var passwordSalt = this.encryptionService.CreateSalt();
                    user.HashedPassword = this.encryptionService.EncryptPassword(userDto.Password, passwordSalt);
                }
                user.Email    = userDto.Email;
                user.Id_Erp   = userDto.Id_Erp;
                user.Username = userDto.Username;
                user.IsLocked = userDto.IsLocked;

                this.entityRepository.Edit(user);
                this.unitOfWork.Commit();
            }

            var userGroupCompanies = this.userCompanyGroupRepository.GetAll().Where(x => x.UserId == userDto.Id).ToList();

            if (userGroupCompanies.Count > 0)
            {
                foreach (var userGroupCompany in userGroupCompanies)
                {
                    var entity = this.userCompanyGroupRepository.GetSingle(userGroupCompany.Id);
                    this.userCompanyGroupRepository.Delete(entity);
                }

                this.unitOfWork.Commit();
            }


            foreach (var userGroupCompanyDto in userDto.UserCompanyGroups)
            {
                userGroupCompanyDto.UserId = userDto.Id;
                var ugcentity = Mapper.Map <UserCompanyGroupDto, UserCompanyGroup>(userGroupCompanyDto);
                this.userCompanyGroupRepository.Add(ugcentity);
            }

            this.unitOfWork.Commit();


            if (sendMail)
            {
                Mailing.SendGenericMail("Solicitud de usuario", userDto.Email, userDto,
                                        "~/views/EmailTemplate/Index.cshtml");
            }
            return(userDto);
        }