Пример #1
0
        /// <summary>
        /// Returns a Secret comprised entirely of random bytes retrieved from
        /// a cryptographically secure RNG.
        /// </summary>
        public static Secret Random(int numBytes)
        {
            if (numBytes < 0)
            {
                throw Error.Common_ValueMustBeNonNegative(nameof(numBytes));
            }

            if (numBytes == 0)
            {
                byte dummy;
                return(new Secret(&dummy, 0));
            }
            else
            {
                // Don't use CNG if we're not on Windows.
                if (!OSVersionUtil.IsWindows())
                {
                    return(new Secret(ManagedGenRandomImpl.Instance.GenRandom(numBytes)));
                }

                byte[] bytes = new byte[numBytes];
                fixed(byte *pbBytes = bytes)
                {
                    try
                    {
                        BCryptUtil.GenRandom(pbBytes, (uint)numBytes);
                        return(new Secret(pbBytes, numBytes));
                    }
                    finally
                    {
                        UnsafeBufferUtil.SecureZeroMemory(pbBytes, numBytes);
                    }
                }
            }
        }
        public dynamic Registry([FromBody] UserRegistryModel userRegistry)
        {
            if (ModelState.IsValid)
            {
                UserWriteDTO user = new UserWriteDTO();

                user.UserID   = Guid.NewGuid();
                user.UserName = userRegistry.UserName;
                user.Email    = userRegistry.Email;
                user.Password = BCryptUtil.HashPassword(userRegistry.Password);

                Task <Services.Entities.CustomResponse> task = _userService.RegistryAsync(user);

                if (task.Result.status)
                {
                    UserReadDTO user_return = new UserReadDTO(user.UserID.ToString(), user.UserName, user.Email);

                    return(new
                    {
                        status = true,
                        code = ReturnCodes.DataCreateFailed,
                        message = "Đăng Ký Thành Công",
                        data = user_return
                    });
                }
            }

            return(new
            {
                status = false,
                code = ReturnCodes.DataCreateFailed,
                message = "Đăng Ký Không Thành Công"
            });
        }
        public void UpdatePassword_Success_ActualFalse()
        {
            //Arrange
            db.Users.RemoveRange(db.Users);
            db.SaveChanges();

            User user = new User();

            user.UserID          = Guid.NewGuid();
            user.UserName        = "******";
            user.Email           = "*****@*****.**";
            user.HashPassword    = BCryptUtil.HashPassword("123456");
            user.isAuthenticated = false;

            db.Users.Add(user);
            db.SaveChanges();

            string UserID      = user.UserID.ToString();
            string OldPassword = "******";
            string NewPassword = "******";

            //Act
            var status = userService.UpdatePassword(UserID, OldPassword, NewPassword).Result.status;

            //Assert
            Assert.AreEqual(true, status);
        }
Пример #4
0
        public UnitTest_GetPost_PostService()
        {
            db          = new BlogApplicationDbContext();
            postService = new PostService(db);

            //Arrange
            db.Users.RemoveRange(db.Users);
            db.ImageGalleries.RemoveRange(db.ImageGalleries);

            UserTest = new User();

            UserTest.UserID          = Guid.NewGuid();
            UserTest.UserName        = "******";
            UserTest.Email           = "*****@*****.**";
            UserTest.HashPassword    = BCryptUtil.HashPassword("1234560");
            UserTest.isAuthenticated = false;

            ImageGalleryTest            = new ImageGallery();
            ImageGalleryTest.Base64Code = "";
            ImageGalleryTest.ImageID    = Guid.NewGuid();

            db.Users.Add(UserTest);
            db.ImageGalleries.Add(ImageGalleryTest);
            db.SaveChanges();
        }
Пример #5
0
        public void Registry_AccountIsExist_ActualFalse()
        {
            //Arrange
            User user = new User
            {
                UserID          = new System.Guid(),
                UserName        = "******",
                Email           = "*****@*****.**",
                HashPassword    = BCryptUtil.HashPassword("123456"),
                isAuthenticated = false
            };

            db.Users.Add(user);
            db.SaveChanges();

            UserWriteDTO userWriteDTO = new UserWriteDTO
            {
                UserID          = new System.Guid(),
                UserName        = "******",
                Email           = "*****@*****.**",
                Password        = BCryptUtil.HashPassword("123456"),
                isAuthenticated = false
            };

            //Act
            var status = userService.RegistryAsync(userWriteDTO).Result.status;

            //Assert
            Assert.AreEqual(status, false);
        }
Пример #6
0
        public void Login_EmailValueLengthEquals0_ActualFalse()
        {
            //Arrange
            User user = new User
            {
                UserID          = new System.Guid(),
                UserName        = "******",
                Email           = "*****@*****.**",
                HashPassword    = BCryptUtil.HashPassword("123456"),
                isAuthenticated = false
            };

            db.Users.RemoveRange(db.Users);

            db.Users.Add(user);
            db.SaveChanges();

            string Email    = "";
            string Password = "******";

            //Act
            var status = userService.Login(Email, Password).status;

            //Assert
            Assert.AreEqual(status, false);
        }
        /*Đăng Nhập*/
        public CustomResponse Login(string Email, string Password)
        {
            if (Email == null || Password == null)
            {
                return(new CustomResponse(false, "Dữ Liệu Không Hợp Lệ"));
            }

            if (Email.Length <= 0 || Password.Length <= 0)
            {
                return(new CustomResponse(false, "Dữ Liệu Không Hợp Lệ"));
            }

            try
            {
                User UserResult = GetUser_EmailAsync(Email).Result;

                if (UserResult != null)
                {
                    if (BCryptUtil.VerifyPassword(Password, UserResult.HashPassword))
                    {
                        return(new CustomResponse(_mapper.Map <UserReadDTO>(UserResult), true, "Đăng Nhập Thành Công"));
                    }
                }
            }
            catch (Exception e)
            {
                return(new CustomResponse(false, e.Message));
            }

            return(new CustomResponse(false, "Đăng Nhập Thất Bại"));
        }
        public static ProtectedMemoryBlob Random(int numBytes)
        {
            CryptoUtil.Assert(numBytes >= 0, "numBytes >= 0");

            if (numBytes == 0)
            {
                byte dummy;
                return(new ProtectedMemoryBlob(&dummy, 0));
            }
            else
            {
                // Don't use CNG if we're not on Windows.
                if (!OSVersionUtil.IsBCryptOnWin7OrLaterAvailable())
                {
                    return(new ProtectedMemoryBlob(ManagedGenRandomImpl.Instance.GenRandom(numBytes)));
                }

                byte[] bytes = new byte[numBytes];
                fixed(byte *pbBytes = bytes)
                {
                    try
                    {
                        BCryptUtil.GenRandom(pbBytes, (uint)numBytes);
                        return(new ProtectedMemoryBlob(pbBytes, numBytes));
                    }
                    finally
                    {
                        UnsafeBufferUtil.SecureZeroMemory(pbBytes, numBytes);
                    }
                }
            }
        }
Пример #9
0
        public void UpdateToken_TokenNotExist_ActualFalse()
        {
            //Arrange
            db.Users.RemoveRange(db.Users);
            db.Tokens.RemoveRange(db.Tokens);

            string      UserID      = Guid.NewGuid().ToString();
            UserReadDTO userReadDTO = new UserReadDTO
            {
                UserID   = UserID,
                Email    = "*****@*****.**",
                UserName = "******"
            };

            Utilities.JWT.TokenResponse tokens = TokenUtil.GenerateTokens(userReadDTO, tokenProviderOption);

            DTO.ReadDTO.TokenReadDTO tokenReadDTO = new DTO.ReadDTO.TokenReadDTO
            {
                AccessToken           = tokens.AccessToken,
                AccessTokenExpriesIn  = tokens.AccessTokenExpiresIn,
                RefreshToken          = tokens.RefreshToken,
                RefreshTokenExpriesIn = tokens.RefreshTokenExpiresIn,
            };

            User user = new User
            {
                UserID          = new Guid(UserID),
                Email           = "*****@*****.**",
                UserName        = "******",
                HashPassword    = BCryptUtil.HashPassword("123456"),
                isAuthenticated = false
            };

            db.Users.Add(user);
            db.SaveChanges();

            Token token = new Token
            {
                AccessToken           = tokenReadDTO.AccessToken,
                AccessTokenExpriesIn  = tokenReadDTO.AccessTokenExpriesIn,
                RefreshToken          = tokenReadDTO.RefreshToken,
                RefreshTokenExpriesIn = tokenReadDTO.RefreshTokenExpriesIn,
                UserID = user.UserID
            };

            db.Tokens.Add(token);
            db.SaveChanges();

            //Act
            var status = userService.UpdateToken(Guid.NewGuid().ToString(), tokenReadDTO).Result.status;

            //Assert
            Assert.AreEqual(false, status);
        }
        /*Update Password*/
        public async Task <CustomResponse> UpdatePassword(string UserID, string OldPassword, string NewPassword)
        {
            if (UserID == null || UserID.Trim().Length == 0)
            {
                return(new CustomResponse(false, "User ID invalid"));
            }

            if (OldPassword == null || OldPassword.Trim().Length == 0)
            {
                return(new CustomResponse(false, "Old Password invalid"));
            }

            if (NewPassword == null || NewPassword.Trim().Length == 0)
            {
                return(new CustomResponse(false, "New Password invalid"));
            }

            try
            {
                User userWillUpdate = db.Users.Where(u => u.UserID.Equals(new Guid(UserID))).FirstOrDefault();

                if (userWillUpdate != null)
                {
                    if (BCryptUtil.VerifyPassword(OldPassword, userWillUpdate.HashPassword))
                    {
                        userWillUpdate.HashPassword = BCryptUtil.HashPassword(NewPassword);

                        await db.SaveChangesAsync();
                    }
                    else
                    {
                        return(new CustomResponse(false, "Mật Khẩu Không Chính Xác"));
                    }
                }
                else
                {
                    return(new CustomResponse(false, "User Not Exist"));
                }
            }
            catch (Exception e)
            {
                return(new CustomResponse(false, e.Message));
            }

            return(new CustomResponse(true, "Update Mật Khẩu Thành Công"));
        }
Пример #11
0
    public void GenRandom_PopulatesBuffer()
    {
        // Arrange
        byte[] bytes = new byte[sizeof(Guid) + 6];
        bytes[0] = 0x04; // leading canary
        bytes[1] = 0x10;
        bytes[2] = 0xE4;
        bytes[sizeof(Guid) + 3] = 0xEA; // trailing canary
        bytes[sizeof(Guid) + 4] = 0xF2;
        bytes[sizeof(Guid) + 5] = 0x6A;

        fixed(byte *pBytes = &bytes[3])
        {
            for (int i = 0; i < 100; i++)
            {
                // Act
                BCryptUtil.GenRandom(pBytes, (uint)sizeof(Guid));

                // Check that the canaries haven't changed
                Assert.Equal(0x04, bytes[0]);
                Assert.Equal(0x10, bytes[1]);
                Assert.Equal(0xE4, bytes[2]);
                Assert.Equal(0xEA, bytes[sizeof(Guid) + 3]);
                Assert.Equal(0xF2, bytes[sizeof(Guid) + 4]);
                Assert.Equal(0x6A, bytes[sizeof(Guid) + 5]);

                // Check that the buffer was actually filled.
                // This check will fail once every 2**128 runs, which is insignificant.
                Guid newGuid = new Guid(bytes.Skip(3).Take(sizeof(Guid)).ToArray());
                Assert.NotEqual(Guid.Empty, newGuid);

                // Check that the first and last bytes of the buffer are not zero, which indicates that they
                // were in fact filled. This check will fail around 0.8% of the time, so we'll iterate up
                // to 100 times, which puts the total failure rate at once every 2**700 runs,
                // which is insignificant.
                if (bytes[3] != 0x00 && bytes[18] != 0x00)
                {
                    return; // success!
                }
            }
        }

        Assert.True(false, "Buffer was not filled as expected.");
    }
Пример #12
0
        public void Registry_Success_ActualTrue()
        {
            //Arrange
            db.Users.RemoveRange(db.Users);
            db.SaveChanges();

            UserWriteDTO userWriteDTO = new UserWriteDTO
            {
                UserID          = new System.Guid(),
                UserName        = "******",
                Email           = "*****@*****.**",
                Password        = BCryptUtil.HashPassword("123456"),
                isAuthenticated = false
            };

            //Act
            var status = userService.RegistryAsync(userWriteDTO).Result.status;

            //Assert
            Assert.AreEqual(status, true);
        }
Пример #13
0
        public async Task <HttpResponseMessage> Login([FromBody] AccountInfo info)
        {
            using (UserDbEntities entities = new UserDbEntities())
            {
                // Search user by ID, and then vaerify the password.
                var entity = await entities.Users.FirstOrDefaultAsync(e => e.UserID == info.UserID);

                if (entity != null)
                {
                    BCryptUtil bCrypt = new BCryptUtil();
                    bool       result = bCrypt.Verify(info.Password, entity.PasswordHash);


                    if (result)
                    {
                        JwtAuthUtil jwt = new JwtAuthUtil(entity.GUID.ToString());
                        // token for portal login
                        string accessToken = jwt.GenerateToken();

                        // return necessary information to the front end
                        return(Request.CreateResponse(HttpStatusCode.OK,
                                                      new
                        {
                            guid = entity.GUID.ToString().ToUpper(),
                            lifeQual = entity.SalesLifeQual.ToUpper(),
                            propQual = entity.SalesPropQual.ToUpper(),
                            access_token = accessToken
                        }));
                    }
                    else
                    {
                        return(Request.CreateErrorResponse(HttpStatusCode.BadRequest, "Wrong password!!"));
                    }
                }
                else
                {
                    return(Request.CreateErrorResponse(HttpStatusCode.BadRequest, "No such user!"));
                }
            }
        }
Пример #14
0
        public void UpdateUserInfor_Success_ActualFalse()
        {
            //Arrange
            db.Users.RemoveRange(db.Users);
            db.SaveChanges();

            User user = new User();

            user.UserID          = Guid.NewGuid();
            user.UserName        = "******";
            user.Email           = "*****@*****.**";
            user.HashPassword    = BCryptUtil.HashPassword("123456");
            user.isAuthenticated = false;

            db.Users.Add(user);
            db.SaveChanges();

            UserReadDTO userReadDTO = new UserReadDTO
            {
                UserID   = user.UserID.ToString(),
                Email    = "*****@*****.**",
                UserName = "******"
            };

            Utilities.JWT.TokenResponse tokens = TokenUtil.GenerateTokens(userReadDTO, tokenProviderOption);

            DTO.ReadDTO.TokenReadDTO tokenReadDTO = new DTO.ReadDTO.TokenReadDTO
            {
                AccessToken           = tokens.AccessToken,
                AccessTokenExpriesIn  = tokens.AccessTokenExpiresIn,
                RefreshToken          = tokens.RefreshToken,
                RefreshTokenExpriesIn = tokens.RefreshTokenExpiresIn,
            };

            //Act
            var status = userService.UpdateUserInfor(userReadDTO).Result.status;

            //Assert
            Assert.AreEqual(status, true);
        }
        public void GetToken_UserIDExistNotLoginFirstTime_Actual()
        {
            //Arrange
            db.Users.RemoveRange(db.Users);

            User user = new User {
                UserID          = new Guid(),
                UserName        = "******",
                Email           = "*****@*****.**",
                HashPassword    = BCryptUtil.HashPassword("123456"),
                isAuthenticated = false
            };

            db.Users.Add(user);
            db.SaveChanges();

            var UserId = user.UserID.ToString();

            //Assert
            var Token = userService.GetToken(UserId);

            //Assert
            Assert.AreEqual(null, Token);
        }
Пример #16
0
 public void GenRandom(byte *pbBuffer, uint cbBuffer)
 {
     BCryptUtil.GenRandom(pbBuffer, cbBuffer);
 }