Пример #1
0
        /// <summary>
        /// Updates a user's password
        /// </summary>
        /// <param name="emailAddress">Email Address of the user who's password is to be updated.</param>
        /// <param name="password">New password of the user</param>
        public void UpdatePassword(string emailAddress, string password)
        {
            var user = GetUserByEmail(emailAddress);

            if (user == null)
            {
                throw new ArgumentException($"Change Password - no user found for email address specified: {emailAddress}");
            }

            var currentPassword = _passwordRepository.GetById(user.BusinessEntityId);
            var salt            = HashGenerator.CreateSalt();

            currentPassword.PasswordSalt = salt;
            currentPassword.PasswordHash = HashGenerator.GenerateHash(password, salt);

            _passwordRepository.Update(currentPassword);
        }
Пример #2
0
        private void InsertUser()
        {
            if (_context.People.Any())
            {
                return;
            }

            var businessEntity = new BusinessEntity();

            _context.BusinessEntities.Add(businessEntity);
            _context.SaveChanges();

            var person = new Person()
            {
                BusinessEntityId = businessEntity.BusinessEntityId,
                FirstName        = "Default",
                MiddleName       = string.Empty,
                LastName         = "Admin",
                DisplayName      = "Default Admin",
                Username         = "******",
                EmailAddress     = "*****@*****.**",
                About            = string.Empty,
                Website          = string.Empty,
                DateCreatedUtc   = DateTime.UtcNow,
                DateModifiedUtc  = DateTime.UtcNow,
                DateLastLoginUtc = DateTime.UtcNow,
                Avatar           = $""
            };

            _context.People.Add(person);
            _context.SaveChanges();

            const string plainTextPassword = "******";
            var          passwordSalt      = HashGenerator.CreateSalt();
            var          passwordHash      = HashGenerator.GenerateHash(plainTextPassword, passwordSalt);

            var password = new Password()
            {
                PasswordHash     = passwordHash,
                PasswordSalt     = passwordSalt,
                BusinessEntityId = person.BusinessEntityId
            };

            _context.Passwords.Add(password);
            _context.SaveChanges();
        }
Пример #3
0
        public async Task <bool> CreateUser(CreateUserEntity obj)
        {
            try
            {
                var salt    = HashGenerator.CreateSalt();
                var newUser = new User()
                {
                    UserName     = obj.UserName,
                    FirstName    = obj.FirstName,
                    LastName     = obj.LastName,
                    MiddleName   = obj.MiddleName,
                    Email        = obj.Email,
                    Mobile       = obj.Mobile,
                    CreatedBy    = "Admin",
                    CreatedDate  = DateTime.Now,
                    IsActive     = true,
                    PasswordHash = HashGenerator.CreateHashPassword(obj.Password, salt),
                    Salt         = salt
                };

                _context.Users.Add(newUser);
                var res = _context.SaveChanges();
                if (res > 0)
                {
                    return(true);
                }
                else
                {
                    return(false);
                }
            }
            catch (Exception ex)
            {
                return(false);
            }
        }
Пример #4
0
        /// <summary>
        /// Register a new user (person)
        /// </summary>
        /// <param name="person">Person object to register</param>
        /// <param name="password">Password for the new user in plain text</param>
        /// <returns></returns>
        public UserRegistrationResult Register(Person person, string password)
        {
            if (person == null)
            {
                throw new ArgumentException("Person object cannot be null.", nameof(person));
            }

            var result = new UserRegistrationResult();

            if (_userService.CheckIfUserExistsByEmail(person.EmailAddress))
            {
                result.AddError("A user already exists with the specified email address.");
            }

            if (person.Username.Length < 4)
            {
                result.AddError("Username must be at least 4 characters long.");
            }

            var usernameNumber = 0;

            if (int.TryParse(person.Username, out usernameNumber))
            {
                result.AddError("Username cannot be numeric.");
            }

            if (string.IsNullOrEmpty(person.EmailAddress))
            {
                result.AddError("Email Address is not provided.");
            }

            if (!CommonHelper.IsValidEmail(person.EmailAddress))
            {
                result.AddError("Invalid Email Address specfied.");
            }

            if (string.IsNullOrEmpty(password))
            {
                result.AddError("A password is required.");
            }

            if (string.IsNullOrEmpty(person.Username))
            {
                result.AddError("Please enter a username.");
            }

            if (_userService.CheckIfUserExistsByUsername(person.Username))
            {
                result.AddError("The username is not available.");
            }

            if (person.Username.Length > 50)
            {
                result.AddError("The username cannot exceed 50 characters.");
            }

            if (!result.Success)
            {
                return(result);
            }

            // If we made it this far, then the information provided is valid. We can proceed now.

            var businessEntity = new BusinessEntity();

            _businessEntityRepository.Create(businessEntity);

            var user = new Person()
            {
                BusinessEntityId = businessEntity.BusinessEntityId,
                FirstName        = person.FirstName,
                MiddleName       = person.MiddleName,
                LastName         = person.LastName,
                DisplayName      = $"{person.FirstName} {person.LastName}",
                About            = person.About,
                Username         = person.Username,
                EmailAddress     = person.EmailAddress,
                Website          = person.Website,
                IsDeleted        = false,
                IsBlocked        = false,
                IsEmailVerified  = false,
                DateCreatedUtc   = DateTime.UtcNow,
                DateModifiedUtc  = DateTime.UtcNow,
                DateLastLoginUtc = DateTime.UtcNow
            };

            _peopleRepository.Create(user);

            var salt        = HashGenerator.CreateSalt();
            var passwordSet = new Password()
            {
                BusinessEntityId = businessEntity.BusinessEntityId,
                PasswordSalt     = salt,
                PasswordHash     = HashGenerator.GenerateHash(password, salt)
            };

            _passwordRepository.Create(passwordSet);

            return(result);
        }