diff options
| author | Shauren <shauren.trinity@gmail.com> | 2023-12-23 20:51:53 +0100 |
|---|---|---|
| committer | funjoker <funjoker109@gmail.com> | 2024-01-09 11:58:28 +0100 |
| commit | 23877d2dced0a2de9b2114ea77eb736e3371724a (patch) | |
| tree | d62b811dc26c0cfcebe63d5361374f120fc16437 /src/server/game/Accounts/AccountMgr.cpp | |
| parent | df6dcfd5c6fac5f375ea4a5d1687bd86671c5841 (diff) | |
Core/Accounts: Migrate RA credentials checking to use AccountMgr instead of copying its logic
(cherry picked from commit e05541665b67e55c4ff70073854886df1222643d)
Diffstat (limited to 'src/server/game/Accounts/AccountMgr.cpp')
| -rw-r--r-- | src/server/game/Accounts/AccountMgr.cpp | 19 |
1 files changed, 19 insertions, 0 deletions
diff --git a/src/server/game/Accounts/AccountMgr.cpp b/src/server/game/Accounts/AccountMgr.cpp index bae151cd1b6..0229dd686b4 100644 --- a/src/server/game/Accounts/AccountMgr.cpp +++ b/src/server/game/Accounts/AccountMgr.cpp @@ -344,6 +344,25 @@ bool AccountMgr::GetEmail(uint32 accountId, std::string& email) return false; } +bool AccountMgr::CheckPassword(std::string username, std::string password) +{ + Utf8ToUpperOnlyLatin(username); + Utf8ToUpperOnlyLatin(password); + + LoginDatabasePreparedStatement* stmt = LoginDatabase.GetPreparedStatement(LOGIN_SEL_CHECK_PASSWORD_BY_NAME); + stmt->setString(0, username); + + if (PreparedQueryResult result = LoginDatabase.Query(stmt)) + { + Trinity::Crypto::SRP6::Salt salt = (*result)[0].GetBinary<Trinity::Crypto::SRP6::SALT_LENGTH>(); + Trinity::Crypto::SRP6::Verifier verifier = (*result)[1].GetBinary<Trinity::Crypto::SRP6::VERIFIER_LENGTH>(); + if (Trinity::Crypto::SRP6::CheckLogin(username, password, salt, verifier)) + return true; + } + + return false; +} + bool AccountMgr::CheckPassword(uint32 accountId, std::string password) { std::string username; |
