public static Account CreateAccount(string email, string password, string battleTag, Account.UserLevels userLevel = Account.UserLevels.User) { if (password.Length > 16) { password = password.Substring(0, 16); // make sure the password does not exceed 16 chars. } var hashCode = GetRandomHashCodeForBattleTag(); var salt = SRP6a.GetRandomBytes(32); var passwordVerifier = SRP6a.CalculatePasswordVerifierForAccount(email, password, salt); var newDBAccount = new DBAccount { Email = email, Salt = salt, PasswordVerifier = passwordVerifier, BattleTagName = battleTag, UserLevel = userLevel, HashCode = hashCode }; DBSessions.AccountSession.SaveOrUpdate(newDBAccount); DBSessions.AccountSession.Flush(); return(GetAccountByDBAccount(newDBAccount)); }
public Account(string email, string password, UserLevels userLevel) // Account with **newly generated** persistent ID : base() { if (password.Length > 16) { password = password.Substring(0, 16); // make sure the password does not exceed 16 chars. } var salt = SRP6a.GetRandomBytes(32); var passwordVerifier = SRP6a.CalculatePasswordVerifierForAccount(email, password, salt); this.SetFields(email, salt, passwordVerifier, userLevel); }
public Account(string email, string password, string battleTagName, int hashCode, UserLevels userLevel) // Account with **newly generated** persistent ID : base(StringHashHelper.HashIdentity(battleTagName + "#" + hashCode.ToString("D4"))) { if (password.Length > 16) { password = password.Substring(0, 16); // make sure the password does not exceed 16 chars. } var salt = SRP6a.GetRandomBytes(32); var passwordVerifier = SRP6a.CalculatePasswordVerifierForAccount(email, password, salt); this.SetFields(email, salt, passwordVerifier, battleTagName, hashCode, userLevel); }